Compare commits

...

784 Commits

Author SHA1 Message Date
Florian Müllner 1b881e1eaa Bump version to 3.31.2
Update NEWS.
2018-11-14 02:21:07 +01:00
Florian Müllner 40a8ab60f4 Update sass submodule 2018-11-14 02:21:07 +01:00
Piotr Drąg b684e756e2 Update POTFILES.in 2018-11-13 01:26:18 +01:00
Florian Müllner 7eae32eb76 workspace-indicator: Don't override ClutterActor.destroy()
Now that PanelMenu.Button was made an StWidget subclass, the destroy()
method actually maps to the ClutterActor method, and overriding it
results in warnings when the extension is disabled. So instead, use
the existing ::destroy handler.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/113
2018-11-12 23:42:06 +00:00
Florian Müllner 34c20e6176 workspace-indicator: Stop using compatibility actor property
PanelMenu.Button sets up a `this.actor = this` property for compatibility,
but let's reflect the actual new object hierarchy.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/113
2018-11-12 23:42:06 +00:00
Florian Müllner 62818e71e9 workspace-indicator: Adjust to gnome-shell changes
PanelMenu.Button is now a GObject subclass, so initialization must
happen in _init() rather than constructor().

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/113
2018-11-12 23:42:06 +00:00
Florian Müllner ee85839d60 drive-menu: Don't override ClutterActor.destroy()
Now that PanelMenu.Button was made an StWidget subclass, the destroy()
method actually maps to the ClutterActor method, and overriding it
results in warnings when the extension is disabled. So instead, use
the existing ::destroy handler.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/113
2018-11-12 23:42:06 +00:00
Florian Müllner d9932b8f55 drive-menu: Stop using compatibility actor property
PanelMenu.Button sets up a `this.actor = this` property for compatibility,
but let's reflect the actual new object hierarchy.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/113
2018-11-12 23:42:06 +00:00
Florian Müllner efa882080f drive-menu: Adjust to gnome-shell changes
PanelMenu.Button is now a GObject subclass, so initialization must
happen in _init() rather than constructor().

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/113
2018-11-12 23:42:06 +00:00
Florian Müllner 132b3b0509 places-menu: Don't override ClutterActor.destroy()
Now that PanelMenu.Button was made an StWidget subclass, the destroy()
method actually maps to the ClutterActor method, and overriding it
results in warnings when the extension is disabled. So instead, use
the existing ::destroy handler.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/113
2018-11-12 23:42:06 +00:00
Florian Müllner e5a0616a0a places-menu: Stop using compatibility actor property
PanelMenu.Button sets up a `this.actor = this` property for compatibility,
but let's reflect the actual new object hierarchy.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/113
2018-11-12 23:42:06 +00:00
Florian Müllner fbeb3cf1e9 places-menu: Adjust to gnome-shell changes
PanelMenu.Button is now a GObject subclass, so initialization must
happen in _init() rather than constructor().

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/113
2018-11-12 23:42:06 +00:00
Florian Müllner 072fbee7cb apps-menu: Stop using compatibility actor property
PanelMenu.Button sets up a `this.actor = this` property for compatibility,
but let's reflect the actual new object hierarchy.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/113
2018-11-12 23:42:06 +00:00
Florian Müllner e9928b3c08 apps-menu: Adjust to gnome-shell changes
PanelMenu.Button is now a GObject subclass, so initialization must
happen in _init() rather than constructor().

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/113
2018-11-12 23:42:06 +00:00
Florian Müllner 2af737a8c2 apps-menu: Remove pointless destroy() implementation
https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/113
2018-11-12 23:42:06 +00:00
Florian Müllner 321702fd15 window-list: Stop using compatibility actor property
PanelMenu.Button sets up a `this.actor = this` property for compatibility,
but let's reflect the actual new object hierarchy.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/113
2018-11-12 23:42:06 +00:00
Florian Müllner 60493faf96 window-list: Don't override ClutterActor.destroy()
Now that PanelMenu.Button was made an StWidget subclass, the destroy()
method actually maps to the ClutterActor method, and overriding it
results in warnings when the extension is disabled. So instead, use
the existing ::destroy handler.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/113
2018-11-12 23:42:06 +00:00
Florian Müllner 821cbf9328 window-list: Adjust to gnome-shell changes
PanelMenu.Button is now a GObject subclass, so initialization must
happen in _init() rather than constructor().

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/113
2018-11-12 23:42:06 +00:00
Florian Müllner cc0f167c0e extensions: Remove example extension
There are plenty of extension examples out there, no need to include
a sample extension that doesn't show-case any useful functionality
but puts additional burden on distributors to exclude it from packaged
extensions.
2018-11-13 00:19:45 +01:00
Florian Müllner d731534d04 extensions: Remove alternate-tab
Ever since GNOME 3.8 when gnome-shell started to provide the window
switcher functionality itself, the extension has only existed to
change the default behavior of the alt-tab shortcut in the classic
session. Now that we achieve this behavior with a per-desktop override,
there's no longer a need for the extension, so remove it altogether.

Users who prefer the window switcher over the default app switcher
can use the regular keyboard settings to assign a shortcut to the
"Switch windows" action.

https://bugzilla.gnome.org/show_bug.cgi?id=786496
2018-11-13 00:14:44 +01:00
Florian Müllner 94eba47358 Bump version to 3.30.1
Update NEWS.
2018-10-08 22:55:05 +02:00
Florian Müllner d34933de0b Update sass submodule 2018-10-08 22:50:52 +02:00
Florian Müllner 9410bdfad6 window-list: Ignore hidden buttons when scrolling
Window lists are per-monitor, so workspaces are implemented by
simply hiding all buttons that correspond to windows/apps on
other workspaces. That means we need to take the visibility
into account when handling scroll-events to switch through the
list, or else we'll end up switching "randomly" between workspaces.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/78
2018-10-06 16:05:46 +00:00
Florian Müllner d424b0f645 window-list: Minor clean-up
Modern javascript has explicit methods for locating the first
element of an array that meets a certain condition, use those
instead of manually looping over the array.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/78
2018-10-06 16:05:46 +00:00
Florian Müllner c0454db0c6 appsMenu: Consider scale-factor in height computation
Actor heights are in physical pixels, while CSS measures are in logical
pixels, so we need to adjust accordingly to prevent the scale factor
from being applied twice.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/102
2018-09-23 17:31:03 +02:00
Florian Müllner 913b2ba691 Bump version to 3.30.0 2018-09-04 00:10:36 +02:00
Florian Müllner ba51869b93 Bump version to 3.29.91
Update NEWS.
2018-08-20 15:48:53 +02:00
Florian Müllner ffe6110ea9 Stop using conditional catch statements
They are a mozilla extension that is going away in SpiderMonkey 60.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/90
2018-08-13 12:00:22 +02:00
Florian Müllner 8b1bcc9fed Bump version to 3.29.90
Update NEWS.
2018-08-01 03:47:30 +02:00
Florian Müllner ebad80c64d Update sass submodule 2018-08-01 03:46:05 +02:00
Florian Müllner 39caf951e0 data: Use override for default alt-tab keybindings
Per-desktop overrides aren't limited to keys in org.gnome.mutter, so
we can use them instead of the alternate-tab extension to default to
the window switcher in the classic session.

https://bugzilla.gnome.org/show_bug.cgi?id=786496
2018-07-09 19:18:54 +02:00
Florian Müllner ecf28e13b4 window-list: Use correct settings schemas
Override schemas are gone (yay!), so we can now simply use the original
schema independent from the used session mode.

https://bugzilla.gnome.org/show_bug.cgi?id=786496
2018-07-09 19:18:54 +02:00
Florian Müllner a01b44f7de data: Replace override schema with per-desktop override
GSettings now recognizes per-desktop overrides that can be used
to change schemas' default values for classic mode, so use that
instead of the separate override schema we currently use with
mutter's custom override mechanism.

https://bugzilla.gnome.org/show_bug.cgi?id=786496
2018-07-09 19:18:54 +02:00
Florian Müllner 6b1926bab3 Bump version to 3.29.3
Update NEWS.
2018-07-09 19:09:13 +02:00
Florian Müllner 64986740e3 Update sass submodule 2018-07-09 19:08:15 +02:00
Jonas Ådahl 6583eae622 Remove usage of MetaScreen
As of the libmutter API version 3 MetaScreen does no longer exist.
Functionality that previously depended on MetaScreen has been moved
elsewhere (e.g. MetaDisplay or MetaWorkspaceManager etc).

https://bugzilla.gnome.org/show_bug.cgi?id=759538
2018-07-06 19:53:08 +02:00
Florian Müllner 9add688abf Actually bump version number
Gah ...
2018-05-24 19:06:33 +02:00
Florian Müllner a85764a0ab Bump version to 3.29.2
Update NEWS.
2018-05-24 19:04:07 +02:00
Florian Müllner eaa2c7857e Update submodule URL
gnome-shell-sass was migrated to gitlab, so update to the correct URL
instead of relying on the redirect.
2018-05-24 19:04:07 +02:00
Florian Müllner 6e1b5bc346 Update sass submodule 2018-05-24 19:01:36 +02:00
Florian Müllner f59ab1272d drive-menu: Disconnect volume monitor signals
The handler IDs were renamed at some point, resulting in the signals
not being disconnected on disable.
2018-05-10 18:56:23 +02:00
Florian Müllner f25ffe6f63 build: Include translations in uploaded zip files
The meson port accidentally dropped translations from the generated
zip files for uploading to extensions.gnome.org, add them back.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/69
2018-05-07 12:00:19 +02:00
Florian Müllner 6746061898 Bump version to 3.28.1
Update NEWS.
2018-04-13 20:30:56 +02:00
Florian Müllner 3dc9f2e4ff cleanup: Use Array.includes() to check for element existence
This is a relatively recent addition to the standard we can use where we
don't care about the actual position of an element inside the array.
(Array.includes() and Array.indexOf() do behave differently in edge cases,
for example in the handling of NaN, but those don't matter to us)
2018-04-12 11:05:41 +02:00
Florian Müllner 682d6a8fd1 window-list: Handle no overrides settings
We can only know about override settings that are provided by the
upstream GNOME or GNOME Classic sessions, but not any custom sessions
created by admins, users or distributions. Handle that case by falling
back to the original settings.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/62
2018-04-12 11:05:41 +02:00
Dz Chen d3ea985e14 Update zh_CN translation 2018-03-21 19:21:17 +08:00
Xiaoguang Wang 496ae16cf1 apps-menu: Duplicate destroy actor
https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/59
2018-03-13 09:06:00 +08:00
Florian Müllner 0554e0deb9 Bump version to 3.28.0
Update NEWS.
2018-03-12 21:57:46 +01:00
Bruce Cowan c0c938977c Update British English translation 2018-03-10 18:05:48 +00:00
Aman Alam 8ee207d74d Update Punjabi translation 2018-03-10 15:37:59 +00:00
Xiaoguang Wang 0e625bedba data: Remove nautilus classic
nautilus doesn't support nautilus classic from version 3.27
2018-03-07 12:49:37 +08:00
Florian Müllner 127b5e6c25 ci: Install mozjs-devel instead of gjs-devel
All we are really interested in is mozjs' js52 utility for running
syntax checks - gjs has significantly more dependencies, so cut
down on time and bandwidth spent on downloading and installing
unneeded packages.

This cuts down the number of packages we install from 202 to 13,
and the download size from 133M to 17M.
2018-03-06 01:07:43 +01:00
Florian Müllner 64c17acc0a ci: Use latest stable Fedora
Rawhide is being very rawhide right now, so unbreak CI by using
the latest stable release.
2018-03-05 23:58:42 +01:00
Florian Müllner 0102b2800a Bump version to 3.27.92
Update NEWS.
2018-03-05 23:42:34 +01:00
Daniel Șerbănescu 7c66434616 Update Romanian translation 2018-03-03 13:06:18 +00:00
GNOME Translation Robot f9ae518c9d Update Scottish Gaelic translation
(cherry picked from commit 0f2baf3e566a7b96f9c472db1fe2802a2354aeba)
2018-02-26 12:54:09 +00:00
Piotr Drąg 55ba3c086a Fix Spanish translation header 2018-02-24 00:20:16 +01:00
Florian Müllner d22e603686 build: Fix classic .session definition
Session files should be installed with the .session extension, not
.desktop ...
2018-02-22 15:26:36 +01:00
Florian Müllner 3e0d8bd56f build: Fix xsession installation dir 2018-02-22 15:26:36 +01:00
Florian Müllner 45ac2cd403 Bump version to 3.27.91
Update NEWS.
2018-02-22 13:40:15 +01:00
Florian Müllner a808380d04 Update sass submodule 2018-02-22 13:40:15 +01:00
Florian Müllner 5c0ef12d13 build: Require sassc for classic style
Meson has a strict separation of source- and build directory, and
expects anything generated in the latter. That means that in order
to maintain our current setup - shipping the generated CSS in the
repo while also optionally updating it automatically when sassc is
found - we have to fight the build system to some extent, which makes
it less reliable than we would like.

Since we switched to sassc which is a more acceptable build-time
dependency than the original ruby-based tool, just drop the CSS
from the repo and unconditionally generate it from SASS if classic
mode is enabled.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/merge_requests/28
2018-02-22 10:59:55 +00:00
Piotr Drąg b80aa8ee11 Remove po/Makevars
Meson doesn’t use it, and Damned Lies learned to read po/meson.build.
2018-02-21 00:05:55 +01:00
Jeremy Bicha 7de345fc8b data: Adjust to another g-s-d plugin removal 2018-02-17 15:54:41 -05:00
Jonas Kümmerlin ff3adb8429 classic: fix panel gradient in overview
https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/40
2018-01-28 20:22:41 +01:00
Jonas Kümmerlin 3398e74005 classic: never show drop shadow for panel icons
https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/39
2018-01-28 20:21:24 +01:00
Jonas Kümmerlin f9ad051367 classic: make notifications legible again
https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/41

As requested in discussion about !26, this is resolved by
switching to a light background.
2018-01-28 01:15:10 +01:00
Florian Müllner ae65a82fdd classic: Fix "Clear All" button readability
Most buttons appear in modal dialogs which keep their normal
appearance in the classic theme, except for the calendar's
"Clear All" which needs a dark text color to be readable on
the light background.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/26
2018-01-18 13:53:09 +01:00
Florian Müllner 2dbe692a31 Revert last two commits
Gah, nasty accident :-(
2018-01-18 13:44:54 +01:00
Florian Müllner 7de28858e1 WIP: Disable places-menu extension
For whatever reason it prevents the classic session to come up?!
2018-01-18 13:26:15 +01:00
Florian Müllner 8881fbcc9d classic: Fix "Clear All" button readability 2018-01-18 13:26:15 +01:00
Florian Müllner 3b5a1486de auto-move-windows: Track apps' windows instead of window creation
We currently track window creation to decide whether the new window
should be moved or not. In order for this to work, the window must
already have been matched to the correct application, which is only
the case when the properties used for app matching were supplied
during window creation.

This is usually the case on X11, but never on wayland. To avoid this
issue altogether, stop listening for raw window creations, and instead
track when a window is added to an application we are interested in.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/33
2018-01-18 13:26:15 +01:00
Florian Müllner 0721ed6504 auto-move-windows: Cache app configuration in map
While reading the configuration, processing it and iterating over the
configured apps to find a match isn't terribly expensive, but caching
the configuration in a map does save a bit of work, and makes for much
cleaner code in findAndMove().

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/33
2018-01-18 13:26:15 +01:00
Florian Müllner ec98cff9d9 auto-move-windows: Minor style cleanups
Use camelCase for variable names, call the first index variable 'i'
instead of 'j', and fix some whitespace errors.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/33
2018-01-18 13:26:15 +01:00
Florian Müllner 9ecd6bbb13 auto-move-windows: Remove unused imports
https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/33
2018-01-18 13:26:15 +01:00
Florian Müllner 3b6cd04a59 auto-move-windows: Do not copy checkWorkspaces() method
When overriding an upstream method, copying the original method code
should always be a last resort, as the two code bases tend to get
out of sync and it often becomes hard to spot the modifications done
by the override. Both those issues can be avoided when figuring out
a way to split out the modifications and call the unmodified upstream
method - we are in luck with our checkWorkspaces() override, as we
can trick the upstream method into not removing workspaces we want
to keep instead of copying the method altogether.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/33
2018-01-18 13:26:15 +01:00
Florian Müllner 3284fe81d7 places-menu: Don't force dispose() of uninitialized proxies
Trying to dispose a proxy object before it has been properly
initialized triggers an "uncatchable exception", which gjs
treats as a fatal error since commit c7bdcaab4. We only have
anything to clean up once the proxy is initialized anyway, so
don't force dispose() before that.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/44
2018-01-17 22:48:45 +01:00
Florian Müllner 39274f286c places-menu: Minor style tweak
Reindent function parameters to fit the old-fart 80-character limit
for better readability.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/44
2018-01-17 22:48:31 +01:00
Florian Müllner eba3cfccfe build: Include UUID suffix in classic mode description
The shortnames we use elsewhere don't match the actual UUID, so we
effectively don't enable any extensions in classic mode at the moment.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/45
2018-01-17 19:04:48 +01:00
Florian Müllner f5c69cbfdc build: Fix generated classic session definition
The list of enabled extensions should be an array of strings, so add
quotes instead of just dumping the extension names into the file.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/45
2018-01-17 19:04:37 +01:00
Florian Müllner c668392462 build: Install schema overrides for classic mode
This was lost accidentally when porting to meson.

https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/45
2018-01-17 19:04:22 +01:00
Florian Müllner 22e416c09b window-list: Fix icons not showing for some windows on wayland
On wayland, the properties that are used for application matching
are generally set after the window has been created, so it is
normal that buttons start with the fallback icon. While we already
track the properties that are relevant for app matching, our signal
handler may run before the window is matched to its app.

Make sure the WindowTracker gets to process those signals first by
using connect_after() for our own handlers.

Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/10.
2017-12-25 10:29:20 +01:00
Iñigo Martínez 9dc183af23 build: Fix description of the enable_extensions option
The description of the `enable_extensions` was wrong since it
changed to the `array` type, because the extension separator
is now a comma instead of space.
2017-12-20 17:41:24 +01:00
Iñigo Martínez 6a0a247668 build: Use the new array type
meson 0.44 features a new option type called `array` that allows
more than one string to be passed.

This feature fits perfectly the `enable_extensions` option needs,
so it has been changed to be an `array` type. the option has not
been limited to a set of choices to avoid duplication.
2017-12-20 10:41:30 +01:00
Florian Müllner 2aaf4370b6 meta: Update description note for reporting bugs
We no longer take bugs in bugzilla.
2017-12-01 21:04:02 +01:00
Florian Müllner ba27cc4a64 cleanup: Get rid of Lang.bind()
After replacing Lang.Class with ES6 classes and adopting arrow notation
for anonymous callbacks, we only use the Lang module to bind `this` to
named callbacks. However since ES5, this functionality is already provided
by Function.prototype.bind() - in fact, Lang.bind() itself uses it when
no extra arguments are specified.

So just use the built-in function directly instead of the wrapper.

Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/30
2017-12-01 20:50:52 +01:00
Florian Müllner acb44de469 cleanup: Port GObject classes to ES6 classes
GJS added API for defining GObject classes with ES6 class syntax
last cycle, use it to port the remaining Lang.Class classes to
the new syntax.

Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/30
2017-12-01 20:50:52 +01:00
Florian Müllner 48399d46c0 cleanup: Port non-GObject classes to ES6 classes
ES6 finally adds standard class syntax to the language, so we can
replace our custom Lang.Class framework with the new syntax. Any
classes that inherit from GObject will need special treatment,
so limit the port to regular javascript classes for now.

Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/30
2017-12-01 20:50:46 +01:00
Florian Müllner 30e7ff5a8f cleanup: Use method syntax
Modern javascript has a short-hand for function properties, embrace
it for better readability and to prepare for porting to ES6 classes.

Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/30
2017-12-01 20:50:28 +01:00
Florian Müllner 968ae427f1 cleanup: Use arrow-notation for anonymous functions
Arrow notation is great, but as we only started using it recently,
we currently have a wild mix of Lang.bind(), function() and () => {}.
To make the style consistent again, change all anonymous functions
to arrow notation.

Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/30
2017-12-01 20:40:32 +01:00
Florian Müllner 4ee30a5445 cleanup: Replace tabs with spaces
Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/30
2017-12-01 20:38:38 +01:00
Florian Müllner d3bbeb1b0c cleanup: Fix some coding style issues
Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/30
2017-12-01 20:38:38 +01:00
Florian Müllner 9d5b149428 ci: Add initial gitlab continuous integration
Continuous integration is good, in particular when used before
merging a change to master as allowed by gitlab. And now that
we enabled some basic syntax checking of source files, we even
have something useful to test for ...

Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/32
2017-12-01 20:30:48 +01:00
Florian Müllner b90c99b87c build: Optionally syntax-check sources
As a pure javascript project, building is really just a glorified
copy operation, so success doesn't even indicate that sources are
syntactically correct (a.k.a. "compile-tested"). We can at least
get some minimal testing by performing some basic syntax checking
when SpilderMonkey's JS shell is available.

Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/32
2017-12-01 18:58:17 +01:00
Florian Müllner ba38019049 build: Remove autotools support
Complete the switch to meson and drop autotools support ...

Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/31
2017-12-01 17:43:21 +01:00
Florian Müllner 406f4cd170 docs: Update instructions for extension additions for meson
The steps for adding a new extension are clearly different in meson,
so update the instructions accordingly. Don't bother with keeping
the existing autotools steps - supporting both build systems in
parallel is just temporary, autotools is on its way out.

Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/31
2017-12-01 17:43:21 +01:00
Florian Müllner a2c63a46d3 build: Add utility script to export zip files
We currently do have some Makefile magic to export zip files suitable
for uploading to extensions.gnome.org. As this is not easily replicated
in meson, add a small non-magic script for the same purpose.

Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/31
2017-12-01 17:41:07 +01:00
Florian Müllner 3ab01aebec build: Support the meson build system
Meson is on track to replace autotools as the build system of choice,
so support it in addition to autotools.

Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/31
2017-12-01 17:41:04 +01:00
Florian Müllner c6ecf2c0df build: Update repo URL in metadata 2017-11-29 20:19:37 +01:00
Piotr Drąg a26f9e34c7 places-menu: Use Unicode quotation marks in a new string
See https://developer.gnome.org/hig/stable/typography.html

https://bugzilla.gnome.org/show_bug.cgi?id=772211
2017-11-25 16:21:35 +01:00
Florian Müllner 21315d74c3 apps-menu: Support separators
We currently only load entries and directories, and ignore any
separators defined by the user/admin. Make some people happy
by supporting them ...

Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/27
2017-11-25 06:46:29 +01:00
Florian Müllner d86044f383 apps-menu: Minor code cleanup
The parameter to _clearApplicationBox() has never been used, so
remove it. In fact, modern javascript makes the function so compact
that we can just move the code inline.

Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/27
2017-11-25 06:46:29 +01:00
Florian Müllner 077a292952 apps-menu: Reload on tree changes
Now that we respect the sort order defined in the .menu file, make
sure to reload the menu on those changes as well, not just when
the installed apps themselves change.

Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/27
2017-11-25 06:46:29 +01:00
Florian Müllner 8bd35eeb09 apps-menu: Don't override sort order
Keep the order in which GMenu returns loaded apps, so users can
reorder entries in Alacarte.

Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/27
2017-11-25 06:46:29 +01:00
Rémy Lefevre eb425ac8a2 places-menu: Support unmounting ejectable places
Being able to unmount places that can be ejected directly from the
menu is convenient and consistent with Nautilus, so add an eject
button to items that are removable.

Fixes https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues/17
2017-11-25 06:22:16 +01:00
Florian Müllner 724249dd29 docs: Use markdown
Markdown produces nicer output where supported, so use that instead
of custom ASCII formatting.
2017-11-25 04:01:19 +01:00
Florian Müllner 76526a9c2d Update README
Over the years the list of extensions has become seriously outdated - a
number of extensions has long been removed, while others have been added.
With the switch to gitlab, the README is displayed prominently, so make
sure the list is accurate again.
2017-11-25 02:55:01 +01:00
Florian Müllner 29ea5ca1a9 build: Update bug tracker to gitlab 2017-11-25 02:52:40 +01:00
Kjartan Maraas 40c6b8b1d8 Updated Norwegian bokmål translation. 2017-11-06 13:41:21 +01:00
Florian Müllner 2460ac9df8 auto-move: Remove unused imports 2017-10-26 20:03:12 +02:00
Florian Müllner 8c551ba8ee windowsNavigator: Use regular for() loops
"for each ... in" has been deprecated for a long time and won't be
supported in upcoming SpiderMonkey versions, so replace it with
"for ... of" instead.
2017-10-26 20:03:12 +02:00
Matej Urbančič 99295c438d Updated Slovenian translation 2017-10-20 16:57:37 +02:00
Florian Müllner f840f70052 Bump version to 3.27.1
Update NEWS.
2017-10-17 17:51:35 +02:00
Florian Müllner ef99394ffb nativeWindowPlacement: Use custom strategy to hook into layout
Instead of copying a long function for a single changed line, wrap the
layout algorithm in a LayoutStrategy so the workspace code picks it
up without modifications.

https://bugzilla.gnome.org/show_bug.cgi?id=787934
2017-10-13 16:08:07 +02:00
Florian Müllner 778eebc421 nativeWindowPlacement: Handle captions-on-top settings changes
Currently the injection to move title captions to the top depends on
the value of the setting at the time the extension is enabled.
Instead, do the injections unconditionally and query the setting
inside the function to pick up settings changes.

https://bugzilla.gnome.org/show_bug.cgi?id=787934
2017-10-13 16:08:07 +02:00
Florian Müllner 97d1cbca19 naturalWindowPlacement: Don't copy relayout() function
To move title captions to the top, we can simply apply a translation
before calling the unmodified original function.

https://bugzilla.gnome.org/show_bug.cgi?id=787934
2017-10-13 16:08:07 +02:00
Florian Müllner a0cae3d130 naturalWindowPlacement: Remove unused stuff
https://bugzilla.gnome.org/show_bug.cgi?id=787934
2017-10-13 16:08:07 +02:00
Florian Müllner 01893ca048 apps-menu: Fix whitespace errors 2017-10-13 16:08:07 +02:00
Xavi Ivars c86a67823c [l10n] Updated Catalan (Valencian) translation 2017-10-05 14:01:50 +02:00
Florian Müllner 726be0692e Bump version to 3.26.1
Update NEWS.
2017-10-04 17:42:16 +02:00
Florian Müllner f339001e22 data: Update style 2017-10-04 01:08:54 +02:00
Florian Müllner 530b165ddf nativeWindowPlacement: Adjust to overview changes
title._spacing is no longer defined, so we end up with bogus positions
when window-captions-on-top is set to true. Adjust the positioning to
do without that for now, though the whole extension could use a rewrite
to not copy everything-and-the-kitching-sink, or be killed off as yet
another extension from the original random collection that turned out
too expensive to keep dragging along ...

https://bugzilla.gnome.org/show_bug.cgi?id=787604
2017-10-04 01:06:42 +02:00
Anders Jonsson e479068d84 Update Swedish translation 2017-10-02 18:50:24 +00:00
Piotr Drąg 824e79d83e gschema: Fix gettext-domain 2017-10-01 19:10:42 +02:00
Efstathios Iosifidis 0d18c3f70d Update Greek translation 2017-09-25 13:48:39 +00:00
Arash Mousavi a682b66bbf Update Persian translation 2017-09-22 18:40:54 +00:00
Stas Solovey f4510b9b04 Update Russian translation 2017-09-20 08:40:39 +00:00
Alexander Rüedlinger c1143fa716 apps-menu: Use "0o" prefix for octal literals
In short, gjs complains that octal escape sequences are deprecated
and advises to use the "0o" prefix for octal literals. Do that to
fix the warning.

https://bugzilla.gnome.org/show_bug.cgi?id=787294
2017-09-17 23:18:52 +02:00
Alexander Rüedlinger 37b95a8498 apps-menu: Remove excess argument
This was an oversight in commit 63653406a3 when porting from a
removed Popover API to ClutterActor.add_child().

https://bugzilla.gnome.org/show_bug.cgi?id=787294
2017-09-17 23:18:52 +02:00
Alexander Rüedlinger cccef0e857 places-menu: Fix JS warning
Define class PlacesManager with 'var' instead of 'const', to shut
up a gjs warning when accessing it from the extension.

https://bugzilla.gnome.org/show_bug.cgi?id=787291
2017-09-17 23:18:52 +02:00
Florian Müllner 592b4ebacf Bump version to 3.26.0
Update NEWS.
2017-09-12 19:26:30 +02:00
Ask Hjorth Larsen 3a799d519b Updated Danish translation 2017-09-10 18:10:56 +02:00
Lyubomir Vasilev 8b09c17684 Updated Bulgarian translation 2017-09-10 18:03:23 +03:00
Inaki Larranaga Murgoitio f00ffcaa3d Update Basque language 2017-09-09 17:19:41 +02:00
Sveinn í Felli 82cc175df1 Update Icelandic translation 2017-09-08 06:08:48 +00:00
Sveinn í Felli eda9eeef18 Update Icelandic translation
(cherry picked from commit c5467e8a804abce0c45b43502e4ac16649a99a53)
2017-09-08 06:05:02 +00:00
Lyubomir Vasilev fb1d4faece Updated Bulgarian translation 2017-09-08 08:48:25 +03:00
Trần Ngọc Quân 3b1d7428df Updated Vietnamese translation
Signed-off-by: Trần Ngọc Quân <vnwildman@gmail.com>
2017-09-04 14:36:52 +07:00
Rafael Fontenelle dca18f3614 Update Brazilian Portuguese translation 2017-09-03 13:29:46 +00:00
Changwoo Ryu 6a9b3a9369 Update Korean translation 2017-09-02 03:55:18 +00:00
Yuras Shumovich 373c3660a1 Update Belarusian translation 2017-09-01 14:56:50 +00:00
hanniedu 74fdac5dfd Updated Dutch translation Master 3.26 2017-09-01 10:37:25 +02:00
Jordi Mas 49c00f3282 Fixes to Catalan translations 2017-08-30 19:23:31 +02:00
Jiri Grönroos b9a32a8f64 Update Finnish translation 2017-08-29 09:36:28 +00:00
Rūdolfs Mazurs bf2074cd82 Update Latvian translation 2017-08-28 10:27:11 +03:00
Cheng-Chia Tseng a659c3e586 Update Chinese (Taiwan) translation 2017-08-27 05:38:40 +00:00
Cheng-Chia Tseng 959dfee54e Update Chinese (Taiwan) translation 2017-08-27 03:45:29 +00:00
Milo Casagrande 714162fdd3 Update Italian translation 2017-08-26 15:40:48 +00:00
ST Alfas 856bda4270 Update Malayalam translation 2017-08-26 13:54:45 +00:00
Florian Müllner 5530229dd2 data: Update style 2017-08-22 13:08:23 +02:00
Florian Müllner cdc3894400 Bump version to 3.25.91
Update NEWS.
2017-08-22 00:59:27 +02:00
Jordi Mas f8f66f628e Update Catalan translation 2017-08-21 15:18:39 +02:00
Alexandre Franke f8b9afda07 Update French translation 2017-08-19 16:41:37 +00:00
Мирослав Николић 617904e69f Updated Serbian translation 2017-08-14 21:27:38 +02:00
Furkan Tokaç 6e4be83dec Update Turkish translation 2017-08-13 11:38:56 +00:00
Rafael Fontenelle 66f0972a43 Update Brazilian Portuguese translation
(cherry picked from commit c15d9af98dde60e1ca3e215b6b36665ca9e4eef6)
2017-08-12 22:58:51 +00:00
Gianvito Cavasoli e6bdbb2c68 Update Italian translation
(cherry picked from commit 825f1f2090690a7c93244e44e66fdc3213adc8f1)
2017-08-12 15:16:12 +00:00
Piotr Drąg 7d3915c30d Update Polish translation 2017-08-11 03:36:02 +02:00
Florian Müllner a04ad6acd7 Bump version to 3.25.90
Update NEWS.
2017-08-10 20:41:34 +02:00
Florian Müllner 8778c16f2a data: Update style 2017-08-10 20:27:35 +02:00
Anders Jonsson 2917deead1 Update Swedish translation 2017-08-08 22:04:26 +00:00
Fran Dieguez 08fc96c7ee Update Galician translation 2017-08-07 13:04:57 +00:00
Balázs Meskó 35c01d7223 Update Hungarian translation 2017-08-04 13:29:12 +00:00
Piotr Drąg 71ba8b04d7 drive-menu: Add a translator comment explaining a variable
https://bugzilla.gnome.org/show_bug.cgi?id=687590
2017-08-03 14:06:26 +02:00
Anders Jonsson c74077239e Update Swedish translation
(cherry picked from commit fa9243dae9d038233f23a48d2e88b8c49375dcdd)
2017-07-31 22:32:03 +00:00
Baurzhan Muftakhidinov 2c2d6b69ca Update Kazakh translation 2017-07-27 12:11:15 +00:00
Daniel Mustieles dcf08375c1 Updated Spanish translation 2017-07-25 20:14:53 +02:00
gogo 15085df41f Update Croatian translation 2017-07-25 18:10:23 +00:00
Matej Urbančič 29780d495d Updated Slovenian translation 2017-07-21 16:07:26 +02:00
Alexander Rüedlinger 69700dc29b apps-menu: Remove more dead code
Commit 0a91893b02 removed dead code, namely a ::panel-box-changed signal
handler. Unfortunately, it forgot to remove the associated code that
disconnects the signal.

Signed-off-by: Alexander Rüedlinger <a.rueedlinger@gmail.com>

https://bugzilla.gnome.org/show_bug.cgi?id=785202
2017-07-21 10:09:13 +02:00
Alexander Rüedlinger 0a91893b02 apps-menu: Remove dead code
This fell through the cracks in commit 2d1d81247 when adjusting to
the gnome-shell changes that also removed the ::panel-box-changed
signal ...

Signed-off-by: Alexander Rüedlinger <a.rueedlinger@gmail.com>

https://bugzilla.gnome.org/show_bug.cgi?id=785200
2017-07-21 01:34:38 +02:00
Florian Müllner dceebeaa7f Bump version to 3.25.4
Update NEWS.
2017-07-20 00:43:32 +02:00
Florian Müllner a2508106f4 data: Adjust classic style to top bar transparency changes 2017-07-19 12:45:59 +02:00
Florian Müllner 2716430310 data: Update style 2017-07-19 12:45:49 +02:00
Rui Matos 4fa73145b4 data: Adjust to g-s-d's plugin removals
These plugins have been removed.

https://bugzilla.gnome.org/show_bug.cgi?id=782233
2017-07-18 21:51:42 +02:00
Dušan Kazik f7b2a1ac58 Update Slovak translation 2017-07-13 14:46:17 +00:00
Aurimas Černius 8ac0313c24 Updated Lithuanian translation 2017-07-10 23:18:40 +03:00
Marek Cernocky 9d6d8e00ac Updated Czech translation 2017-07-10 16:50:19 +02:00
Kukuh Syafaat a8544a30e1 Update Indonesian translation 2017-07-10 09:28:36 +00:00
Jordi Mas bde50c021c Update Catalan translation 2017-07-09 09:20:40 +02:00
Christian Kirbach 1d5ab3f328 Update German translation 2017-07-07 19:43:32 +00:00
Fabio Tomat 31b00faef8 Update Friulian translation 2017-07-06 22:56:30 +00:00
Piotr Drąg 6e81f240dc Update Polish translation 2017-07-06 16:31:37 +02:00
Florian Müllner 74643a62d1 screenshot-window-sizer: Add explicit keybinding for backward cycling
The REVERSES flag was removed from Meta.KeyBindingFlags a while ago, as
gnome-control-center doesn't recognize it and the corresponding "magic"
shift handling. That is, nowadays reversible keybindings need to
provide an explicit reversed binding.

https://bugzilla.gnome.org/show_bug.cgi?id=784079
2017-07-05 17:06:37 +02:00
Khaled Hosny 29a9c7582d Update Arabic translation 2017-07-02 06:12:51 +02:00
Yuras Shumovich cce2f10fba Update Belarusian translation 2017-06-28 17:29:02 +00:00
Florian Müllner de240fa679 Bump version to 3.25.3
Update NEWS.
2017-06-21 22:06:28 +02:00
Baurzhan Muftakhidinov e884f770b0 Update Kazakh translation 2017-06-17 08:51:25 +00:00
Florian Müllner eafdd1d78d window-list: Respect MWM hints
The window context menu contains minimize, maximize and close items
that are currently enabled unconditionally, regardless of whether
the window indicates support. Respect those hints by updating the
items' sensitivity every time the popup is shown.

https://bugzilla.gnome.org/show_bug.cgi?id=783601
2017-06-09 17:54:24 +02:00
Florian Müllner 61a2e5ab9e window-list: Do not pick up transparency from top bar
The top bar now uses a translucent style when no windows are in its
proximity. As translucency looks odd in some situations (in particular
with maximized windows), we don't want to pick it up unconditionally.
If someone fancies to integrate with the top bar's proximity tracking,
they are welcome to have a go, but for now we just restore the former
solid style unconditionally.
2017-06-09 17:54:24 +02:00
Christian Kellner 0824847ac1 places-menu: can now ask user for info on mounting
When we try to launch an application for an uri where the enclosing
mount is not yet mounted we might need information from the user
such as passwwords. Using a MountOperation makes this possible.

https://bugzilla.gnome.org/show_bug.cgi?id=781788
2017-06-09 16:35:48 +02:00
Daniel Mustieles 791f9abb39 Update Spanish translation 2017-06-05 14:23:25 +00:00
Florian Müllner 9b3ab2c9b2 build: Switch to sassc for generating style
GTK+ switched from ruby-based sass to c-based sassc for performance
reasons. It makes sense to follow suit, if not to not require two
tools for the same job ...

https://bugzilla.gnome.org/show_bug.cgi?id=783210
2017-05-30 12:42:05 +02:00
Fabio Tomat 5ec54112ab Update Friulian translation 2017-05-25 12:31:56 +00:00
Florian Müllner 5a84c6d608 Bump version to 3.25.2
Update NEWS.
2017-05-25 00:10:19 +02:00
Balázs Úr f8360601b9 Update Hungarian translation 2017-05-14 21:08:47 +00:00
Mario Blättermann 0359736890 Update German translation 2017-05-12 15:29:28 +00:00
Kukuh Syafaat 0a46c0d1df Update Indonesian translation 2017-05-10 09:25:24 +00:00
Florian Müllner c5da5cf9b5 drive-menu: Fix launch-nautilus label
The user-visible name of nautilus is "Files", not "File" ...

https://bugzilla.gnome.org/show_bug.cgi?id=781235
2017-05-09 19:30:52 +02:00
Matej Urbančič 843238b96b Updated Slovenian translation 2017-05-05 14:15:19 +02:00
Kukuh Syafaat bac1e8b695 Update Indonesian translation 2017-05-02 08:29:47 +00:00
Fabio Tomat ce2b710c25 Update Friulian translation 2017-04-30 11:34:31 +00:00
gogo 457db2980a Update Croatian translation 2017-04-29 22:59:40 +00:00
Christian Kellner c82f8a995b places-menu: report errors for mounting of volumes
When launching an application for an uri we detect the case that
the volume is not mounted and try to mount it. If this fails we
don't report any error, so there is no feedback for the user.
2017-04-28 15:14:59 +02:00
Christian Kellner cfbb2a459b places-menu: make launching asynchronous
Use the async version of Gio.AppInfo.launch_default_for_uri so
we don't hang or block if the uri we are trying to launch the
application for is on slow or dead network connections.

https://bugzilla.gnome.org/show_bug.cgi?id=781831
2017-04-28 15:14:14 +02:00
Florian Müllner 1d20edb6d8 Bump version to 3.25.1
Update NEWS.
2017-04-27 18:12:44 +02:00
Christian Kellner 8a4b245812 places-menu: make the icon query asynchronous
Don't use the sync version of g_file_query_info because that might
potentially block (especially when the connection is slow or drops).

https://bugzilla.gnome.org/show_bug.cgi?id=781765
2017-04-27 14:19:26 +02:00
Florian Müllner 8453cf05a7 apps-menu: 'Touch' copied .desktop file after updating attributes
At least for now, nautilus' file monitor is blind to certain metadata
updates:
https://git.gnome.org/browse/nautilus/tree/src/nautilus-mime-actions.c#n1537

So in order for the changes in the previous patch to take effect
immediately, we need to force nautilus to reload the file info.
Achieve this by updating the access time of the newly copied file
after marking it as trusted.

https://bugzilla.gnome.org/show_bug.cgi?id=781596
2017-04-24 17:22:26 +02:00
Florian Müllner 5cb2657df7 apps-menu: Mark copied .desktop files as trusted
The application can already be launched from the menu without further
confirmation from the user, so there is no security gain in asking the
user to trust it when launched from the desktop - just set the appropriate
attributes of the newly copied file to mark it as trusted to nautilus.

https://bugzilla.gnome.org/show_bug.cgi?id=781596
2017-04-24 17:22:26 +02:00
Florian Müllner 234cf96d39 apps-menu: Remove excess parameters
Someone mixed up add() and add_actor() - this has been present since the
the big rewrite based on the AxeMenu extension in commit 9211fa4409, so
there's little point in coming up with a replacement for something that
never had any effect to begin with ...
2017-04-22 00:59:00 +02:00
gogo fbf3cf35a6 Add Croatian translation 2017-04-11 13:24:54 +00:00
Florian Müllner 93040769d8 Bump version to 3.24.1
Update NEWS.
2017-04-11 02:21:46 +02:00
Tom Tryfonidis 00959dbf47 Update Greek translation 2017-04-08 19:12:29 +00:00
Trần Ngọc Quân a17aff71d1 Updated Vietnamese translation
Signed-off-by: Trần Ngọc Quân <vnwildman@gmail.com>
2017-03-27 15:17:25 +07:00
Florian Müllner 09a60a27ba apps-menu: Only enable DND when there's a desktop
It's not very useful to allow dragging when there's no drop target,
so tie the functionality added in the previous commit to the presence
of a DESKTOP window.

https://bugzilla.gnome.org/show_bug.cgi?id=780371
2017-03-22 19:15:28 +01:00
Florian Müllner 243f700fa2 apps-menu: Allow creating desktop launchers via DND
Back in the olden days, it used to be possible to drag items from
the application menu to the desktop to create a launcher shortcut.
Reimplement that "classic" functionality in the apps menu extension.

https://bugzilla.gnome.org/show_bug.cgi?id=780371
2017-03-22 19:15:28 +01:00
Florian Müllner 021037bfcd apps-menu: Use Map to keep track of app items
The use of Array to keep track of inserted items is extremely
confusing, as no elements are ever added to the array. What
the code actually does is monkey-patching properties into an
empty object (that happens to be of type "Array"). While the
direct idiomatic replacement would be {}, update the code to
use a proper map instead.

https://bugzilla.gnome.org/show_bug.cgi?id=780371
2017-03-21 21:01:04 +01:00
Florian Müllner 2b396b4cf3 Bump version to 3.24.0
Update NEWS.
2017-03-20 18:33:10 +01:00
Emin Tufan Çetin d05152c21e Update Turkish translation 2017-03-18 12:26:24 +00:00
Rūdolfs Mazurs 31f638775c Update Latvian translation 2017-03-18 10:34:15 +02:00
Florian Müllner d2529db9a9 Bump version to 3.23.92
Update NEWS.
2017-03-14 18:00:22 +01:00
Florian Müllner 441949b7c8 data: Update style 2017-03-14 17:57:52 +01:00
Jordi Mas 7db2a10975 Update Catalan translation 2017-03-13 20:22:02 +01:00
Aurimas Černius 93a26969d5 Updated Lithuanian translation 2017-03-10 21:52:04 +02:00
Stas Solovey d404d54d7a Update Russian translation 2017-03-10 09:34:37 +00:00
Marek Cernocky cf101ffbaf Updated Czech translation 2017-03-08 17:45:36 +01:00
Joe Hansen 06f200c7fd Updated Danish translation 2017-03-06 12:54:56 +01:00
Jordi Mas 154498ad52 Update Catalan translation 2017-03-04 10:07:33 +01:00
Changwoo Ryu d5513f8c96 Update Korean translation 2017-03-03 16:10:08 +00:00
Yuras Shumovich 50b3245e09 Update Belarusian translation 2017-03-02 16:50:54 +00:00
Florian Müllner 483b385c90 Bump version to 3.23.91
Update NEWS.
2017-03-01 19:25:31 +01:00
Paul Seyfert 9f963a4a8b Update German translation 2017-02-28 20:12:41 +00:00
Daniel Mustieles 1747d02622 Updated Spanish translation 2017-02-27 18:48:42 +01:00
Chao-Hsiung Liao 56d7ca1ee2 Update Chinese (Taiwan) translation 2017-02-27 00:34:57 +00:00
Balázs Meskó 1823fcea1f Update Hungarian translation 2017-02-26 12:00:18 +00:00
Мирослав Николић 8eef8c7507 Updated Serbian translation 2017-02-26 08:51:33 +01:00
Fran Dieguez 1d0e53aa60 Updated Galician translations 2017-02-26 01:15:25 +01:00
Rafael Fontenelle 0853abdbb7 Update Brazilian Portuguese translation 2017-02-25 20:46:37 +00:00
Fabio Tomat bda97a5267 Update Friulian translation 2017-02-23 23:52:03 +00:00
Claude Paroz 7e4a8bbd6d Updated French translation 2017-02-22 19:34:32 +01:00
Milo Casagrande 8b3685dd50 Update Italian translation 2017-02-21 18:12:01 +00:00
Kukuh Syafaat 6f9e2cfed7 Update Indonesian translation 2017-02-21 10:22:01 +00:00
Daniel Korostil dc00b23adc Updated Ukrainian translation 2017-02-20 13:56:22 +02:00
Piotr Drąg 142bea0a2d Update Polish translation 2017-02-19 21:50:29 +01:00
Kjartan Maraas 2f70271c1a Updated Norwegian bokmål translation. 2017-02-19 17:40:19 +01:00
Jiri Grönroos c93d6daf36 Update Finnish translation 2017-02-18 18:43:56 +00:00
Dušan Kazik ebf443ea23 Update Slovak translation 2017-02-18 10:13:35 +00:00
Anders Jonsson 23a46a7ac4 Update Swedish translation 2017-02-17 19:08:31 +00:00
Inaki Larranaga Murgoitio 60b198664d Update Basque language 2017-02-16 18:31:11 +01:00
Baurzhan Muftakhidinov aaed6da35e Update Kazakh translation 2017-02-16 04:09:02 +00:00
Piotr Drąg 5ad82d05f9 Use Unicode in translatable strings
See https://developer.gnome.org/hig/stable/typography.html

https://bugzilla.gnome.org/show_bug.cgi?id=772211
2017-02-16 02:20:03 +01:00
Florian Müllner 35b0ab6bf8 Bump version to 3.23.90
Update NEWS.
2017-02-16 01:34:27 +01:00
Yuras Shumovich c25b9ca0e6 Add Belarusian translation 2017-02-04 09:29:25 +00:00
Felipe Borges 0f9ac6088f window-list: Hide workspace indicator when there's 1 workspace
There's no need to show the workspace indicator at the right
corner of the window-list if there's just a single workspace
AND the workspace creation is static. This saves us a bit more
of space.

https://bugzilla.gnome.org/show_bug.cgi?id=777504
2017-01-20 16:31:16 +01:00
Jakub Steiner 5e545d2991 theme: window-list minimized button
- when a window is minimized, it's unfocused, thus the button
in the window list should remain raised

https://bugzilla.gnome.org/show_bug.cgi?id=775282
2017-01-20 14:45:30 +01:00
Florian Müllner 4d1105e361 Bump version to 3.23.2
To go along GNOME Shell 3.23.2.
2016-11-23 23:28:49 +01:00
Florian Müllner 0cdae2dae0 alternateTab: Don't take over 'switch-group' shortcuts
The original extension author really hated the app switcher with a
passion and took over all its uses, but there's really no reason
to replace the 'switch-group' shortcuts - not least because the
window switcher doesn't implement switching between windows of
a single application. So just keep the extension to making the
'switch-application' shortcuts behave as 'switch-windows' for the
"classic" session (and all users who rather install an extension
than change shortcut settings).

https://bugzilla.gnome.org/show_bug.cgi?id=771531
2016-11-14 12:30:12 +01:00
YunQiang Su b74c390e1b Fix zh_CN translation: cycle screenshot sizes 2016-10-18 17:56:10 +08:00
YunQiang Su a71ad438b3 Update zh_CN translation 2016-10-18 17:40:00 +08:00
Florian Müllner c400e30da8 data: Update classic session file for g-s-d changes
gnome-settings-daemon has been split up into separate daemons, which
means we'll need to invoke those separately.

See https://git.gnome.org/browse/gnome-session/commit?id=18b6e567e1a
for the corresponding change to the regular session file.

https://bugzilla.gnome.org/show_bug.cgi?id=772736
2016-10-11 11:49:52 +02:00
Florian Müllner af7903dba7 Bump version to 3.22.1
Update NEWS.
2016-10-11 00:38:37 +02:00
Florian Müllner f99b42e732 window-list: Update icon on app changes
We currently assume that the application associated with a particular
window is fixed. While this holds true for almost every application,
there are some cases of multi-app-packages like LibreOffice where
windows may change the properties used for application matching at
runtime. Catch those cases to make sure we display the correct icon
when the window shifts applications.

https://bugzilla.gnome.org/show_bug.cgi?id=771731
2016-09-20 18:06:08 +02:00
Florian Müllner 7074217b7c Bump version to 3.22.0
To go along GNOME Shell 3.22.0.
2016-09-19 22:22:12 +02:00
David King 8c07f6bee9 Update British English translation 2016-09-18 12:40:44 +02:00
Florian Müllner ad52860a5e Bump version to 3.21.92
To go along GNOME Shell 3.21.92.
2016-09-13 00:28:53 +02:00
Piotr Drąg 76a55e9b89 Add more options to XGETTEXT_OPTIONS in po/Makevars 2016-09-12 19:42:56 +02:00
Piotr Drąg 031a121bc5 Updated Polish translation 2016-09-09 02:55:10 +02:00
Florian Müllner 23b5594c24 data: Update style 2016-09-08 21:36:11 +02:00
Trần Ngọc Quân f28f08645a Updated Vietnamese translation
Signed-off-by: Trần Ngọc Quân <vnwildman@gmail.com>
2016-09-05 15:15:00 +07:00
Florian Müllner 229a624553 Bump version to 3.21.91
To go along GNOME Shell 3.21.91.
2016-08-30 00:28:43 +02:00
Piotr Drąg a7204736a8 Updated Polish translation 2016-08-19 23:34:09 +02:00
Florian Müllner b39931e759 Bump version to 3.21.90
To go along GNOME Shell 3.21.90.
2016-08-19 22:18:12 +02:00
Florian Müllner db3e910b76 build: Say good-bye to intltool
intltool is unmaintained nowadays while upstream gettext gained
support for everything we used it for, so make the switch.

https://bugzilla.gnome.org/show_bug.cgi?id=769077
2016-08-19 22:17:07 +02:00
વિશાલ ભલાણી 0ff77736da Updated Gujarati translation 2016-08-03 12:13:56 +00:00
Daniel Mustieles 2b36863442 Updated Spanish translation 2016-08-02 16:50:28 +02:00
Piotr Drąg cca1be6b70 Add Language headers to po files
Future versions of gettext will fail if this header is missing.
2016-07-21 02:52:15 +02:00
Florian Müllner aea1f5187a Bump version to 3.21.4
To go along GNOME Shell 3.21.4.
2016-07-20 20:50:04 +02:00
Florian Müllner deb7ee8ef6 Update style 2016-07-20 20:50:04 +02:00
Florian Müllner a35336d3c2 apps-menu: Handle .desktop files from non-standard directories
.desktop files in non-standard locations are not handled by GIO,
so looking up apps for entries for such locations (e.g. a
directory added via the AppsDir directive) will fail. We can
still handle this case in the menu by creating the app directly
from the entry's AppInfo.

https://bugzilla.gnome.org/show_bug.cgi?id=762206
2016-07-13 01:28:56 +02:00
Florian Müllner 7f44a3647c Bump version to 3.21.3
To go along GNOME Shell 3.21.3.
2016-06-21 21:05:57 +02:00
Florian Müllner e98e5d0d62 alternateTab: Adjust to gnome-shell changes
The code de-duplication in commit bf8d30603e57b broke the extension,
fix by duplicating the code here now :-(

(It's not really that bad though ...)

https://bugzilla.gnome.org/show_bug.cgi?id=767077
2016-06-10 17:43:27 +02:00
Cédric Valmary 71464c91c2 Updated Occitan translation 2016-05-30 18:46:05 +00:00
Florian Müllner 3c32cacb14 Bump version to 3.21.2
To go along GNOME Shell 3.21.2.
2016-05-27 16:03:35 +02:00
Florian Müllner f82915d153 Bump version to 3.20.1
Update NEWS.
2016-05-10 22:44:01 +02:00
Jakub Steiner 59aa0f66f3 panel style changes
- based on a patch by rudolf@palaticky.com
- having three css locations with hardcoded colors,
  what could possibly go wrong in the future. :(

https://bugzilla.gnome.org/show_bug.cgi?id=756807
2016-05-10 15:51:49 +02:00
Cédric Valmary ef149aab93 Updated Occitan translation 2016-05-09 19:09:03 +00:00
GNOME Translation Robot 59c351de63 Updated Scottish Gaelic translation 2016-04-29 10:09:55 +00:00
Florian Müllner 76e73b9154 Bump version to 3.20.0
To go along GNOME Shell 3.20.0.
2016-03-22 18:17:42 +01:00
Florian Müllner 69901c72a3 Bump version to 3.19.92
To go along GNOME Shell 3.19.92.
2016-03-16 19:07:41 +01:00
Florian Müllner 155d517fe8 Bump version to 3.19.91
To go along GNOME Shell 3.19.91.
2016-03-03 17:36:51 +01:00
Cédric Valmary ceee4d64dc Updated Occitan translation 2016-02-27 18:58:15 +00:00
Florian Müllner ab8090e0e2 Bump version to 3.19.90
To go along GNOME Shell 3.19.90.
2016-02-19 18:17:18 +01:00
Florian Müllner 68e3798dd8 Bump version to 3.19.4
To go along GNOME Shell 3.19.4.
2016-01-21 22:17:28 +01:00
Tim Lunn 2191d533b5 data: rename gnome-shell required component to org.gnome.Shell
gnome-shell is now dbus activated. The new name is org.gnome.Shell.

https://bugzilla.gnome.org/show_bug.cgi?id=760386
2016-01-11 11:40:14 +11:00
Aurimas Černius 18f0366307 Updated Lithuanian translation 2016-01-10 18:14:17 +02:00
Will Thompson 5b1f7704a6 screenshot-window-sizer: hidpi support
The new logical dimensions are reported in the overlay, rather than the
pixel dimensions. That is: if scaleFactor is 2, a window might be
resized to 2400×1350 device pixels, which will be reported as 1200×675
in the overlay.

This is consistent with (for example) the DevTools in Chrome, which
reports the logical size of the viewport when you resize the window,
rather than the physical pixel size.

Tested with a freely-resizable window and with a constrained-geometry
window (GNOME Terminal), on a hidpi display.

https://bugzilla.gnome.org/show_bug.cgi?id=754607
2016-01-08 14:09:48 +00:00
Florian Müllner 488eeffeaf Bump version to 3.19.3
To go along GNOME Shell 3.19.3.
2015-12-17 01:32:30 +01:00
Florian Müllner 79c76a87e2 apps-menu: Fix .desktop entries in subdirectories
GMenu's TreeEntries return an AppInfo that is created from the
.desktop filename, not from a desktop ID as expected by the
AppSystem. As a result, g_app_info_get_id() will simply return
the file's basename, which only matches the desktop ID if no
prefix-to-subdirectory mapping as described in the menu spec
is involved.
Fix this by basing the app lookup on the entry's desktop ID instead
of the AppInfo.

https://bugzilla.gnome.org/show_bug.cgi?id=759004
2015-12-16 22:50:41 +01:00
Florian Müllner 1958ce7794 apps-menu: Remove unused variable
https://bugzilla.gnome.org/show_bug.cgi?id=759004
2015-12-16 22:50:41 +01:00
Sveinn í Felli 42652088a3 Updated Icelandic translation
(cherry picked from commit dafd1581e8e77263b5a991b0196f16ea8c0ca75b)
2015-12-05 12:21:19 +00:00
Florian Müllner 2b9ea7519b native-window-placement: Make sure that the border does not overlap the title
https://bugzilla.gnome.org/show_bug.cgi?id=758976
2015-12-04 11:38:35 +01:00
Florian Müllner 1634af39dc native-window-placement: Cut down on copy-pasted code
https://bugzilla.gnome.org/show_bug.cgi?id=758976
2015-12-04 11:38:35 +01:00
Florian Müllner 31b415a378 Bump version to 3.19.2
To go along GNOME Shell 3.19.2.
2015-11-25 00:50:08 +01:00
Florian Müllner eb78d93601 Update style 2015-11-25 00:49:05 +01:00
GNOME Translation Robot 31f8d6761c Updated Scottish Gaelic translation 2015-11-17 17:13:03 +00:00
GNOME Translation Robot 010d0e538b Updated Scottish Gaelic translation 2015-11-17 16:36:46 +00:00
GNOME Translation Robot 6ec1bd5c5f Added Scottish Gaelic translation 2015-11-17 16:25:31 +00:00
Florian Müllner 5d4c14e0b7 Bump version to 3.19.1
To go along GNOME Shell 3.19.1.
2015-10-29 16:22:29 +01:00
Jakub Steiner 283f679fcc render up to date gnome-shell-sass
https://bugzilla.gnome.org/show_bug.cgi?id=757011
2015-10-26 15:53:31 +01:00
Jakub Steiner 2935848954 window-list button colors
- not sure I win the override game

https://bugzilla.gnome.org/show_bug.cgi?id=756807
2015-10-26 15:34:52 +01:00
Jakub Steiner 9676bc83af make spinner 60fps & 16x16px
https://bugzilla.gnome.org/show_bug.cgi?id=756888
2015-10-21 14:02:15 +02:00
Florian Müllner 7a0e393652 Bump version to 3.18.1
To go along GNOME Shell 3.18.1.
2015-10-15 22:33:00 +02:00
Florian Müllner ca1da1b349 apps-menu: Fix up hover state after dropping grab
Category items grab the pointer to implement "triangle navigation", which
interferes with automatic hover tracking in other widgets. While this is
the correct behavior while we hold the grab (i.e. when crossing other
category items without switching), it can interfere with user expectation
when the grab is dropped, as the motion event that causes us to do so
doesn't necessarily occur before the "target"'s enter event - address this
by syncing up the hover state manually after dropping the grab.

https://bugzilla.gnome.org/show_bug.cgi?id=754959
2015-10-15 22:33:00 +02:00
Jakub Steiner 7c5f0ed87f theme: darken the dot of days with events
https://bugzilla.gnome.org/show_bug.cgi?id=756497
2015-10-15 22:29:38 +02:00
Khaled Hosny f6c9ea3d61 Update Arabic translation 2015-09-23 23:56:33 +02:00
Florian Müllner c23580bd56 window-list: Set appropriate label-actors on buttons
Independent from the grouping mode, the window-list currently shows
up as a series of "push buttons" in screen readers, which is obviously
not useful, so point to the correct labels.

https://bugzilla.gnome.org/show_bug.cgi?id=755223
2015-09-21 22:39:38 +02:00
Florian Müllner 94f289280b Bump version to 3.18.0
To go along GNOME Shell 3.18.0.
2015-09-21 22:30:13 +02:00
Florian Müllner b664a1020a Bump version to 3.17.92
To go along GNOME Shell 3.17.92.
2015-09-16 17:16:51 +02:00
Florian Müllner fb1f010825 Update style from sass 2015-09-16 17:14:50 +02:00
Arash Mousavi 7cb5d8a94f Updated Persian translation 2015-09-12 00:09:24 +04:30
Florian Müllner 4cde6facc9 window-list: Use font-relative size in classic style
Commit 85b7049376 fixed this for the regular session, but forgot to also
update the classic style.
2015-09-04 19:56:23 +02:00
Florian Müllner 547163e895 places: Include DESKTOP when desktop icons are enabled
The user explicitly enabling desktop icons is a pretty good hint
that she intends to use the Desktop folder, so be consistent with
GTK+ and nautilus and include it when the corresponding setting
is true.

https://bugzilla.gnome.org/show_bug.cgi?id=754578
2015-09-04 17:50:06 +02:00
Florian Müllner f7fd160896 Bump version to 3.17.91
To go along GNOME Shell 3.17.91.
2015-09-03 16:01:53 +02:00
Hannie Dumoleyn 8a667ba142 Updated Dutch translation Master 3.18 2015-08-29 18:02:49 +02:00
Chao-Hsiung Liao 456d3cd07d Updated Chinese (Taiwan) translation 2015-08-26 12:45:28 +00:00
Piotr Drąg daeed1a864 Updated Polish translation 2015-08-24 16:20:22 +02:00
Florian Müllner 809c8cbd41 Bump version to 3.17.90
To go along GNOME Shell 3.17.90.
2015-08-20 14:06:54 +02:00
Florian Müllner 31506a342c workspace-indicator: Use consistent workspace numbering
The indicator numbers workspaces starting from 1, while newly added
workspace names in the preference dialog start counting at 0.
Change the latter to be consistent with the indicator.

https://bugzilla.gnome.org/show_bug.cgi?id=753105
2015-07-31 16:47:18 +02:00
Florian Müllner d1bf592539 apps-menu: Handle non-UTF8 filename encodings more gracefully
Instead of failing completely if any .desktop file uses a filename
encoding other than UTF-8, just filter out the offending apps.

https://bugzilla.gnome.org/show_bug.cgi?id=651503
2015-07-31 16:22:32 +02:00
Florian Müllner 6062284ac4 window-list: Don't consider skip-taskbar windows for app sorting
It is odd to consider windows that are not shown in the window list
for app sorting, in particular when switching between grouped and
ungrouped mode, and when a long-lived window like the DESKTOP is
present.

https://bugzilla.gnome.org/show_bug.cgi?id=753055
2015-07-30 18:24:19 +02:00
Florian Müllner 8f2ebafa75 Bump version to 3.17.4
To go along GNOME Shell 3.17.4.
2015-07-23 12:57:27 +02:00
Fabio Tomat 8390eadb0c Updated Friulian translation 2015-07-05 12:58:04 +00:00
Florian Müllner f45c672245 Bump version to 3.17.3
To go along GNOME Shell 3.17.3
2015-07-02 14:30:52 +02:00
Pedro Albuquerque 2d75090848 Updated Portuguese translation 2015-06-29 22:27:02 +00:00
Daniel Șerbănescu af090a99ea Updated Romanian Translation 2015-06-26 17:36:41 +02:00
Florian Müllner 85b7049376 window-list: Use font-relative sizes for width/height
Just like the top bar, the window list should scale according to
the font scaling factor, so convert the existing pixel sizes into
font-relative ones.

https://bugzilla.gnome.org/show_bug.cgi?id=703585
2015-06-19 23:49:01 +02:00
Florian Müllner 61ec98f504 window-list: Reposition on height changes
The window list position depends on both the monitor geometry and the
list height, however changes to the latter are currently ignored. For
the time being this doesn't matter due to the list's fixed height, but
we are about to scale the list with the text, so reposition the list
on height changes.

https://bugzilla.gnome.org/show_bug.cgi?id=703585
2015-06-19 23:49:01 +02:00
Florian Müllner b97c111bde window-list: Expand window buttons vertically
The window-list's fixed height currently allows us to get away without
expanding buttons, however this won't be the case anymore once we start
adapting the list with the text scaling. So fix up the code to do what
was always the intention anyway.

https://bugzilla.gnome.org/show_bug.cgi?id=703585
2015-06-19 23:49:01 +02:00
Florian Müllner 8b89840e2b apps-menu: Remove some obsolete code
The hot corner code has been modifying the existing hot corner rather
than replacing it with a custom one for quite a while now ...
2015-06-19 18:22:47 +02:00
Siteshwar Vashisht dd620df620 apps-menu: Fix call to open_new_window()
The function never had a timestamp parameter, the parameter that was
added at some point is a workspace index. Ouch, this has gone unspotted
since the original AxeMenu extension was adapted for the apps-menu ...
2015-06-12 15:29:32 +02:00
Jakub Steiner 0d0eff2ea2 scrollbars, expanders and spinner invisible in classic
- sync scrollbar colors with gtk
- don't hide expanders in popovers
- use a custom spinner for classic

https://bugzilla.gnome.org/show_bug.cgi?id=750072
2015-05-29 11:42:57 +02:00
Florian Müllner 271102be8d Bump version to 3.17.2
To go along GNOME Shell 3.17.2
2015-05-27 10:50:02 +02:00
Cédric Valmary 70f195da7a Updated Occitan translation 2015-05-18 14:36:58 +00:00
Bruno Ramalhete 9bca5c32da Updated Portuguese translation 2015-05-17 16:02:41 +00:00
sun b492b06228 update zh_CN translation 2015-05-03 10:39:55 +08:00
Florian Müllner a1583deed2 Update doap file 2015-04-30 19:18:49 +02:00
Florian Müllner e022c1671d Bump version to 3.17.1
Update NEWS.
2015-04-30 19:02:02 +02:00
Florian Müllner 1dd5343ff4 Update style 2015-04-30 19:00:57 +02:00
laurent Soleil 7750774c85 Added Occitan translation 2015-04-28 13:20:42 +00:00
Florian Müllner e80d667b44 Bump version to 3.16.1
To go along GNOME Shell 3.16.1
2015-04-14 23:38:15 +02:00
Mattias Põldaru 6297839106 [l10n] Updated Estonian translation 2015-04-08 20:25:23 +03:00
Rūdolfs Mazurs deae4392ab Updated Latvian translation 2015-04-03 20:41:18 +03:00
Florian Müllner bea06a7589 Update style 2015-03-30 17:41:47 +02:00
Hajime Taira c56805dea6 l10n: Update Japanese translation 2015-03-30 21:56:01 +09:00
Florian Müllner 0a5e5ee93c apps-menu: Take over shortcuts again on startup-complete
For a while now, gnome-shell has initialized extensions before
setting up its own keybinding handling. As a result, our taking
over of the panel-main-menu shortcut will be overwritten when
the extension is enabled at startup - work around this by setting
up the keybinding again on LayoutManager::startup-complete.

https://bugzilla.gnome.org/show_bug.cgi?id=746639
2015-03-24 14:20:49 +01:00
Florian Müllner 8f4cecc8e5 apps-menu: Move panel-main-menu handling into AppsMenuButton
This is really where it belongs, and will make an upcoming fix slightly
less ugly ...

https://bugzilla.gnome.org/show_bug.cgi?id=746639
2015-03-24 14:20:49 +01:00
Florian Müllner 487c089e86 apps-menu: Clean up signal code
Setting up signal handlers inside a class and rely on outside code
to disconnect them via global variables is utterly weird. Just
disconnect everything inside the class when the corresponding actor
is destroyed.

https://bugzilla.gnome.org/show_bug.cgi?id=746639
2015-03-24 14:20:49 +01:00
Rui Matos 903a3b25cb window-list: Fix WorkspaceIndicator's popup menu position
By default, PanelMenu.Button creates a popup menu with arrow side TOP
which is wrong in our case and can mess up BoxPointer's positioning.

We can work around that easily by creating the menu ourselves with the
correct arrow side.

https://bugzilla.gnome.org/show_bug.cgi?id=746365
2015-03-24 12:58:07 +01:00
Florian Müllner 697445c823 Bump version to 3.16.0
To go along GNOME Shell 3.16.0.
2015-03-23 20:45:02 +01:00
Jordi Mas 37e38ae692 Update Catalan translation 2015-03-18 04:53:18 -04:00
Florian Müllner 5ed7bf76f9 Bump version to 3.15.92
To go along GNOME Shell 3.15.92.
2015-03-17 19:49:30 +01:00
Florian Müllner 1e8c7a2d8f Update style 2015-03-17 19:46:05 +01:00
Florian Müllner 11b151e5e0 native-window-placement: Update for mutter API changes 2015-03-17 19:46:05 +01:00
Florian Müllner 0b18b15fee screenshot-window-size: Update for mutter API changes 2015-03-17 19:46:05 +01:00
Ask Hjorth Larsen 2c37ac8929 Updated Danish translation 2015-03-15 16:57:48 +01:00
A S Alam 83eb3ef620 Translation pa updated for Gnome 2015-03-13 21:36:20 -05:00
Samir Ribic a7186cb668 Added Bosnian translation 2015-03-13 15:50:06 +00:00
Jakub Steiner 6c58d700aa theme: fix invisible avatar for classic
https://bugzilla.gnome.org/show_bug.cgi?id=745693
2015-03-12 16:07:13 +01:00
Stas Solovey 7189f8586b Updated Russian translation 2015-03-11 21:23:41 +00:00
Florian Müllner f97c2c55a4 theme: Update from submodule 2015-03-11 18:03:33 +01:00
Jiri Grönroos 068eaad840 Finnish translation update 2015-03-11 17:01:43 +02:00
Jakub Steiner 36a51901d8 theme: no top bar border for login screen
https://bugzilla.gnome.org/show_bug.cgi?id=745686
2015-03-10 20:02:36 +01:00
Jakub Steiner 7cfd862e70 theme: panel improvements
- places menu still sports an arrow, must be a custom one

https://bugzilla.gnome.org/show_bug.cgi?id=745909
2015-03-10 19:56:42 +01:00
Florian Müllner 5e9f66f3d1 Use a proper arrows instead of UTF8
All proper shell menus were updated to do that a while ago, we
should do the same for consistency.

https://bugzilla.gnome.org/show_bug.cgi?id=745909
2015-03-10 19:56:41 +01:00
Jakub Steiner c1929e34d1 theme: re-render css 2015-03-10 19:46:31 +01:00
Jakub Steiner fdaecf6c44 theme: re-render to fix modal headings
https://bugzilla.gnome.org/show_bug.cgi?id=745687
2015-03-10 17:55:59 +01:00
Florian Müllner 8bad8a3b63 window-list: Don't use 'panel-menu' class in bottom panel
Menus in the top bar have some margin at the bottom, to prevent
menus to extend all the way to the bottom edge as the expand; we
obviously don't want the same behavior in the window-list at the
bottom, so stop pretending to be a top bar menu.

https://bugzilla.gnome.org/show_bug.cgi?id=745952
2015-03-10 14:27:16 +01:00
Jakub Steiner dae1feb250 theme: more on unlock/login top bar
https://bugzilla.gnome.org/show_bug.cgi?id=745686
2015-03-10 12:23:34 +01:00
Jakub Steiner 3ef2393d14 theme: top bar in login and lock screens
https://bugzilla.gnome.org/show_bug.cgi?id=745686
2015-03-10 11:52:15 +01:00
Victor Ibragimov 5e39f82b8e Updated Tajik translation 2015-03-10 06:26:55 +00:00
Alexander Shopov fb59540e41 Updated Bulgarian translation 2015-03-09 21:10:29 +02:00
Florian Müllner 715f445f61 apps-menu: Make it a bit narrower
General rule: if it can fit "GNU Image Manipulation Program", it is
wide enough ...

https://bugzilla.gnome.org/show_bug.cgi?id=745670
2015-03-06 17:28:01 +01:00
Jakub Steiner 4eceb9443f theme: use white labels for overview
- restructured selectors to avoid !important

https://bugzilla.gnome.org/show_bug.cgi?id=745732
2015-03-06 17:22:16 +01:00
Jakub Steiner 6909504c10 theme: provide custom switches and spinner
https://bugzilla.gnome.org/show_bug.cgi?id=745685
2015-03-06 17:08:36 +01:00
Мирослав Николић 3476b0d84e Updated Serbian translation 2015-03-05 22:46:25 +01:00
Florian Müllner 44cbe64e30 Bump version to 3.15.91
To go along GNOME Shell 3.15.91.
2015-03-05 17:45:59 +01:00
Florian Müllner 9413c806cb build: Remove deprecated autogen variable 2015-03-05 17:45:59 +01:00
Florian Müllner a519c97ca9 build: Update POTFILES 2015-03-05 17:45:58 +01:00
Florian Müllner c9a6421f36 extensions: Remove systemMonitor extension
The systemMonitor extension extends the message tray with its UI, which
obviously broke when the bottom tray was removed. It has also been the
source for various performance/memory issues in the past and is part of
the semi-random collection that pre-dates the extension.gnome.org site
rather than the set of classic-mode/endorsed extensions, so just remove
it from the module.
Hopefully this will motivate someone who actually cares about it to pick
it up ...

https://bugzilla.gnome.org/show_bug.cgi?id=745195
2015-03-05 17:14:48 +01:00
Florian Müllner ba13ae6955 Update classic style 2015-03-05 17:14:48 +01:00
Florian Müllner a39aba4099 app-menu: Remove unused function
This was an override for a parent function that hasn't existed
since summer 2013 ...

https://bugzilla.gnome.org/show_bug.cgi?id=745670
2015-03-05 16:33:36 +01:00
Changwoo Ryu 2c914571b5 Updated Korean translation 2015-03-05 11:13:06 +09:00
Piotr Drąg b114d9012d Updated Polish translation 2015-03-04 23:18:22 +01:00
Florian Müllner 612604cf16 Update classic style from sass 2015-03-04 17:40:29 +01:00
Fran Dieguez 15379351d7 Updated Galician translations 2015-03-03 01:29:27 +01:00
Florian Müllner c69ea808ae launch-new-instance: Fix warning
Commit 2667b9f3e5 updated the extension for a shell change that
renamed _onActivate() to _activate, but forgot to also rename the
declaration of the variable that stores the original function.
Fix this to stop a warning about assignment to an undefined variable.

https://bugzilla.gnome.org/show_bug.cgi?id=745470
2015-03-02 21:05:43 +01:00
Florian Müllner 7afdb541ce window-list: Adjust to trayBox removal
The point of that code is to keep the window-list underneath
modals' lightboxes if possible (i.e. unless the OSK is shown).
The trayBox was a natural pick back in the day, but the panel
will do just as well ...

https://bugzilla.gnome.org/show_bug.cgi?id=745304
2015-02-27 20:17:31 +01:00
Florian Müllner 57d012c846 theme: Apply notification list refinements 2015-02-26 19:09:14 +01:00
Daniel Korostil 6483189cd7 Updated Ukrainian translation 2015-02-24 22:58:06 +02:00
Rui Matos c0170ff945 window-list: Check if the window title is set
MetaWindow.title might be NULL, particularly for Wayland clients where
setting the title is a request separate from window creation. We
shouldn't try to set StLabel's text prop in that case.

https://bugzilla.gnome.org/show_bug.cgi?id=745064
2015-02-24 21:09:02 +01:00
Baurzhan Muftakhidinov 59060067fb Updated Kazakh translation 2015-02-24 15:54:42 +00:00
Milo Casagrande c334f0803b Updated Italian translation 2015-02-24 08:38:20 +00:00
Aurimas Černius eb623f5289 Updated Lithuanian translation 2015-02-23 23:10:16 +02:00
Florian Müllner 664cf6d527 Pull in theme changes from gnome-shell 2015-02-22 06:26:25 +01:00
Florian Müllner d96839190d build: Update CSS when sass is available 2015-02-22 06:26:25 +01:00
Fran Dieguez 2d5b0ed6d6 Updated Galician translations 2015-02-22 02:36:49 +01:00
Dušan Kazik bd2819e007 Updated Slovak translation 2015-02-21 16:20:39 +00:00
Chao-Hsiung Liao b8e2790850 Updated Chinese (Taiwan) translation 2015-02-21 10:18:36 +00:00
Florian Müllner 36ce1b0a79 Bump version to 3.15.90
To go along GNOME Shell 3.15.90.
2015-02-20 19:32:30 +01:00
Florian Müllner 93a1fd0b60 window-list: Fix for "app-less" windows
While rare, it is possible to have a window not associated with any app
(not even a fake window-based one). We currently throw an error when
trying to set the icon for such a window, so handle this case and
use a fallback icon instead of the app icon.

https://bugzilla.gnome.org/show_bug.cgi?id=743401
2015-02-20 18:28:32 +01:00
Florian Müllner 04ec4de375 window-list: Remove message tray handling
Notification banners are now displayed at the top, and the summary
moved into the date and time drop down - the bottom is ours now,
no more special sauce needed to interact with it gracefully.
2015-02-20 17:57:02 +01:00
Florian Müllner 8f7053a3ad style: Update for notification-redux changes 2015-02-20 17:57:01 +01:00
Carlos Soriano fb419712c9 theme: update from sass sources 2015-02-20 16:47:17 +01:00
Carlos Soriano 96bdc9f350 theme: Use gnome-shell-sass as a submodule
The sass sources now live in a project in GNOME, so they can
be used in multiple projects like gnome-shell-extensions.
Because of that, add gnome-shell-sass as a submodule and import the sass
sources from it.
2015-02-20 16:47:17 +01:00
Jakub Steiner 79f2792b7c theme: re-render gnome-shell theme 2015-02-20 09:51:54 +01:00
Jakub Steiner 4528568ff2 theme: re-rendered off gnome-shell changes 2015-02-20 09:51:54 +01:00
Jakub Steiner b4d1517099 theme: initial sassified classic theme 2015-02-20 09:51:54 +01:00
Alexandre Franke 303b19218c Updated French translation 2015-02-19 11:04:01 +00:00
Anders Jonsson 933bdf93b5 Updated Swedish translation 2015-02-18 15:54:33 +00:00
Muhammet Kara 804e95174a Updated Turkish translation 2015-02-14 15:46:34 +00:00
Inaki Larranaga Murgoitio 5cc48637d1 Updated Basque language 2015-02-07 16:50:58 +01:00
Kristjan SCHMIDT 044d6fab28 Updated Esperanto translation 2015-02-01 16:16:50 +01:00
Yosef Or Boczko ec7797dac8 Updated Hebrew translation 2015-01-26 21:10:42 +02:00
Sveinn í Felli 52cdc5945c Updated Icelandic translation 2015-01-26 13:43:00 +00:00
Dimitris Spingos 29320838f9 Updated Greek translation 2015-01-24 01:29:47 +02:00
Sveinn í Felli 44a36972bf Added Icelandic translation 2015-01-23 15:37:04 +00:00
Daniel Martinez 204042b66b Update Aragonese translation 2015-01-22 19:28:03 +01:00
Florian Müllner cecf8b9e40 Bump version to 3.15.4
To go along GNOME Shell 3.15.4.
2015-01-21 15:23:09 +01:00
Fabio Tomat 9d8ec2a262 Updated Friulian translation 2015-01-20 20:21:22 +00:00
Fabio Tomat 1c46ef68d1 Updated Friulian translation 2015-01-20 20:19:33 +00:00
Florian Müllner adc68889b7 window-list: Keep panel below modal dialogs when possible
Currently the window-list will be stacked above system modal dialogs,
which means it is not dimmed like the rest of the desktop and remains
accessible to interaction. We cannot do any better when showing the
on-screen keyboard, as we need to keep ourselves above to not end up
covered by the OSK, and the keyboard itself is stacked above modal
dialogs to allow its use for input. However we can at least fix the
case when not using the OSK.

https://bugzilla.gnome.org/show_bug.cgi?id=740722
2015-01-15 13:56:57 +01:00
Christian Kirbach 44af7991e2 Updated German translation 2015-01-10 20:37:29 +00:00
Stas Solovey c5c8610b4b Updated Russian translation 2015-01-10 10:21:31 +00:00
Daniel Mustieles c10f0000c0 Updated Spanish translation 2015-01-08 18:23:35 +01:00
Marek Černocký 48e0c37d4a Updated Czech translation 2015-01-07 09:04:50 +01:00
Kjartan Maraas de543bf31d Updated Norwegian bokmål translation. 2014-12-31 00:49:17 +01:00
Inaki Larranaga Murgoitio 38c19ac4b1 Updated Basque language 2014-12-30 15:17:00 +01:00
Trần Ngọc Quân f73361472c Updated Vietnamese translation
Signed-off-by: Trần Ngọc Quân <vnwildman@gmail.com>
2014-12-30 08:43:47 +07:00
Matej Urbančič 5b5492a643 Updated Slovenian translation 2014-12-26 18:25:50 +01:00
Andika Triwidada 76d2372884 Updated Indonesian translation 2014-12-24 04:54:00 +00:00
Rafael Ferreira b7b82b2408 Updated Brazilian Portuguese translation 2014-12-23 02:51:23 +00:00
Daniel Mustieles 03ee405f1d Updated Spanish translation 2014-12-22 13:07:41 +01:00
Balázs Úr e774baf9bb Updated Hungarian translation 2014-12-20 12:36:01 +00:00
Florian Müllner ccbcc2198c Bump version to 3.15.3.1
Gah, missed a gnome-shell change that broke several extensions ...
2014-12-19 16:15:54 +01:00
Florian Müllner 0e0f7c80c2 Update for KeyBindingMode => ActionMode change 2014-12-19 16:13:29 +01:00
Florian Müllner 8c496fd1a6 Bump version to 3.15.3
To go along GNOME Shell 3.15.3
2014-12-19 15:17:35 +01:00
Florian Müllner 8b59c031d5 window-list: Do not hardcode overrides schema
Classic mode uses a different overrides schema, so make sure we use the
correct setting instead of hardcoding the usual org.gnome.shell.overrides
schema.

https://bugzilla.gnome.org/show_bug.cgi?id=737486
2014-12-19 15:15:44 +01:00
Sylvain Pasche a3f352d0c3 window-list: Option to show the window list on all monitors
A new setting "show-on-all-monitors" (false by default) is available to
show window lists on all connected monitors.
The Extension object monitors conditions that require the list of
windows to be rebuilt. The WindowList and Button classes have a new
"perMonitor" property that indicates they should handle windows on
their own monitor only.

https://bugzilla.gnome.org/show_bug.cgi?id=737486
2014-12-19 15:15:44 +01:00
Sylvain Pasche e80b790b78 window-list: Refactor {Window,App}Button shared code into BaseButton
BaseButton is a new class that shares the common logic of WindowButton
and AppButton. AppButton is passed to AppContextMenu so that it can reuse
code from the now public getWindowList() method.

https://bugzilla.gnome.org/show_bug.cgi?id=737486
2014-12-19 15:15:44 +01:00
Piotr Drąg 0dfc4e9fbc Updated POTFILES.in 2014-12-17 18:36:03 +01:00
Matthias Clasen 43c4e7fa2e Clean up classic session definition
The gnome-shell-classic desktop file just launches gnome-shell
without options these days, so we don't need a separate desktop file.

https://bugzilla.gnome.org/show_bug.cgi?id=741660
2014-12-17 10:59:51 -05:00
Inaki Larranaga Murgoitio 5688cea552 Updated Basque language 2014-12-17 16:35:08 +01:00
Baurzhan Muftakhidinov 6d2b588740 Updated Kazakh translation 2014-12-14 14:10:25 +00:00
Muhammet Kara 72dc3234a7 Updated Turkish translation 2014-12-04 09:07:20 +00:00
Balázs Úr c8f9b23636 Updated Hungarian translation 2014-12-03 15:55:58 +00:00
Maxime Henrion 768bad6e1e Skip over XDG directories that cannot be found.
This fixes loading the places menu gnome-shell extension when the XDG
directories have not been configured.

https://bugzilla.gnome.org/show_bug.cgi?id=741033
2014-12-02 18:59:30 +01:00
Daniel Șerbănescu bfe60bd2d9 Added Romanian Translation 2014-11-30 12:19:47 +01:00
Florian Müllner 5ba4e68f17 classic: Install high-contrast theme variant
The classic style is decidedly lower contrast than the default
style, so the high-contrast variant could prove really useful
here. However for now, just override the default icon style as
in the default session.

https://bugzilla.gnome.org/show_bug.cgi?id=740447
2014-11-29 18:13:58 +01:00
Florian Müllner 8c6644f1be Revert "user-theme: Temporarily work around a gnome-shell regression"
The issue has been fixed in gnome-shell master, so we can revert the
workaround.
2014-11-27 14:49:43 +00:00
Florian Müllner 71fa03c4ea Bump version to 3.15.2
To go along GNOME Shell 3.15.2
2014-11-27 14:47:10 +00:00
Florian Müllner dd3c7ca199 user-theme: Temporarily work around a gnome-shell regression
setThemeStylesheet() stopped accepting %null to revert to the default
stylesheet. The issue is fixed in gnome-shell master, but work around
it for 3.15.2 to not ship broken (again).
2014-11-27 14:42:01 +00:00
Sylvain Pasche 5c2d13ec51 window-list: Move messageTray patching to the WindowList class
Move messageTray patching form the Extension object to the WindowList
class. Moreover, only do the patching if the window list is on the bottom
monitor. This refactoring will make it easier to have several instances
of WindowList (one on each monitor).

https://bugzilla.gnome.org/show_bug.cgi?id=737486
2014-11-26 20:00:50 +01:00
Sylvain Pasche 5fc66444b6 window-list: Refactoring to use an Extension object
Move the global state into a new Extension object. This is in
preparation for adding more logic to the Extension object.

https://bugzilla.gnome.org/show_bug.cgi?id=737486
2014-11-26 20:00:50 +01:00
Sylvain Pasche 57bfb9400e window-list: _pointerInTray was renamed to _pointerInNotification in bug 695800
https://bugzilla.gnome.org/show_bug.cgi?id=737486
2014-11-26 20:00:50 +01:00
Sylvain Pasche 4a1f49586d window-list: Disconnect drag and drop handlers
https://bugzilla.gnome.org/show_bug.cgi?id=737486
2014-11-26 20:00:49 +01:00
Florian Müllner 92012f6626 apps-menu: Center app labels
Currently labels are not vertically centered, unlike icons.
Fix this.

https://bugzilla.gnome.org/show_bug.cgi?id=740724
2014-11-26 19:06:41 +01:00
Florian Müllner 92b7c44e6d apps-menu: Update menu arrow to use an icon
gnome-shell no longer uses labels with UTF8 arrows, so the currently
used arrow is no longer consistent with other menus; fix that.

https://bugzilla.gnome.org/show_bug.cgi?id=740725
2014-11-26 18:54:18 +01:00
Marek Černocký 3a023a3cba Updated Czech translation 2014-11-26 09:11:41 +01:00
Florian Müllner 0a0d273d32 style: Inherit default stylesheet from resource
The default stylesheet has moved into a GResource, so we can no
longer address it with a relative path.

https://bugzilla.gnome.org/show_bug.cgi?id=740318
2014-11-18 16:08:07 +01:00
Trần Ngọc Quân 1f300838e8 Update Vietnamese translation
Signed-off-by: Trần Ngọc Quân <vnwildman@gmail.com>
2014-11-15 14:46:47 +07:00
Florian Müllner 4da36684ad drive-menu: Adjust for renamed .desktop file name
Nautilus now uses reverse domain notation for its .desktop file,
adjust for that.

https://bugzilla.gnome.org/show_bug.cgi?id=739931
2014-11-12 19:53:13 +01:00
Florian Müllner 109bdd1cd0 drive-menu: Update for gnome-shell changes
Since shell commit 3227d4f3edad, Shell.Global.create_app_launch_context()
expects additional parameters.
2014-11-12 19:51:33 +01:00
Jorge Perez Perez a351dd8c5c Update Aragonese translation 2014-11-06 21:10:19 +01:00
Yosef Or Boczko 1b7a3e8f36 Updated Hebrew translation 2014-11-04 18:46:05 +02:00
Florian Müllner b0c75392a3 Bump version to 3.15.1
To go along GNOME Shell 3.15.1
2014-10-30 11:49:17 +00:00
Kjartan Maraas 3825c5c715 Added Norwegian bokmål translation. 2014-10-22 20:31:53 +02:00
Daniel Mustieles d285d26604 Updated Spanish translation 2014-10-20 14:50:38 +02:00
Florian Müllner e669aa75b6 Revert "screenshot-window-sizer: Do not translate schema for now"
This reverts commit 53b1149d0a0316602bea310b624f3ad8b839541e.
2014-10-14 21:43:16 +02:00
Florian Müllner c9693d4f09 Bump version to 3.14.1
To go along GNOME Shell 3.14.1
2014-10-14 21:32:51 +02:00
Florian Müllner e372c5ace8 window-list: Avoid flashing when using auto-grouping
Currently when using auto-grouping, the list is ungrouped each
time a window is closed, and then possibly re-grouped on the next
allocation - as a result, there is a brief "ungroup flash" if the
list is supposed to remain grouped.
Avoid this by computing the width the ungrouped list would have
rather than by actually ungrouping it.

https://bugzilla.gnome.org/show_bug.cgi?id=738286
2014-10-11 00:06:59 +02:00
Piotr Drąg 9386610b01 Updated LINGUAS 2014-10-08 16:55:07 +02:00
Ivaylo Valkov c807b02c16 Added Bulgarian translation 2014-10-08 06:23:41 +03:00
Florian Müllner 614d1c9697 window-list: Fix spacing in app buttons 2014-10-07 20:01:56 +02:00
Florian Müllner 70056ba56e window-list: Don't unnecessarily add/remove window buttons
Since commit 191c7ccc24, we check whether we already have a window
in the list before re-adding it on MetaWorkspace::window-added.
We can do something similar on MetaWorkspace::window-removed to
avoid some extra work when a window is moved between workspaces
rather than destroyed.
2014-10-07 18:57:45 +02:00
Florian Müllner 4af36f41fa window-list: Don't use Meta.get_window_actors() directly
The list returned may contain windows that are being destroyed.
The ShellGlobal method filters those out, so use that instead; we
should eventually stop looking at window actors when we want windows,
but for now this is the easy and safe thing to do.
2014-10-07 17:19:00 +02:00
Florian Müllner 60ea0fb172 Stop using deprecated GSettings:schema property 2014-10-07 14:38:12 +02:00
Pedro Albuquerque ab37a8f92f Updated Portuguese translation 2014-10-05 21:11:17 +00:00
Milo Casagrande 91890367b8 Updated Italian translation 2014-10-05 13:20:05 +00:00
Florian Müllner 54e39c9779 launch-new-instance: Re-use original activate function
Rather than re-implementing the function (and risk missing improvements
like the launch animation), call the original one as if the user had
middle-clicked the launcher.
2014-09-29 15:32:02 +02:00
Florian Müllner d4ca2aeeb5 extension: Reuse original handler in keyPressHandler injection
We do need to inject our own handler to treat application-switch
actions the same way as the corresponding window-switch ones;
we can actually express exactly this without re-implementing the
entire function, by calling the original handler with a tweaked
action parameter - the resulting code is not only more concise,
but should also be a bit more robust against changes in core.

https://bugzilla.gnome.org/show_bug.cgi?id=737457
2014-09-29 15:32:02 +02:00
Rūdolfs Mazurs 1d53017a30 Updated Latvian translation 2014-09-28 16:38:56 +03:00
Florian Müllner 687ea92e82 alternateTab: Remove _initialSelection injection
Since shell commit 2b1077aaa169, the implementation in the
SwitcherPopup base class already works as expected.

https://bugzilla.gnome.org/show_bug.cgi?id=737457
2014-09-27 16:15:37 +02:00
Florian Müllner 0dd5b5251a alternateTab: Fix Escape not dismissing popup
Since shell commit dd85670f8b25, the handler got a return value to
determine whether Escape should be handled automatically; we do
want this for the window switcher, so add an appropriate return
value to restore the expected behavior.

https://bugzilla.gnome.org/show_bug.cgi?id=737457
2014-09-27 16:15:37 +02:00
Florian Müllner 6e82912fe5 launch-new-instance: Remove unused imports/variables 2014-09-27 16:15:36 +02:00
Florian Müllner 83a2083216 Bump version to 3.14.0
To go along GNOME Shell 3.14.0
2014-09-22 20:59:37 +02:00
Saibal Ray bdce0b68a8 Updated Bengali (India) translation 2014-09-22 11:08:16 +00:00
Мирослав Николић 846ac2c9d5 Updated Serbian translation 2014-09-22 12:28:13 +02:00
Rajesh Ranjan 33ca28d68c Added Hindi translation 2014-09-21 05:30:10 +00:00
Daniel Korostil 9deed91c0f Updated Ukrainian translation 2014-09-20 23:32:22 +03:00
Shankar Prasad 8e2cdf3a9e Updated Kannada translation 2014-09-17 12:52:52 +00:00
Shankar Prasad a8128eedac Updated Kannada translation 2014-09-17 11:04:56 +00:00
Saibal Ray 43cc0514ff Added Bengali (India) translation 2014-09-17 05:59:31 +00:00
Florian Müllner d421eff477 Bump version to 3.13.92
To go along GNOME Shell 3.13.92
2014-09-17 07:05:54 +02:00
Florian Müllner 8696067186 screenshot-window-sizer: Do not translate schema for now
It's not worth a string freeze break, we can revert after the freeze
has been lifted ...
2014-09-17 07:05:22 +02:00
Florian Müllner 1d5ab0f0de screenshot-window-sizer: New extension
Originally from hughsie's github[0], but way too useful to leave
in a 3rd party repo :-)

[0] https://github.com/hughsie/gnome-shell-extension-screenshot-window-sizer

https://bugzilla.gnome.org/show_bug.cgi?id=736470
2014-09-17 07:05:22 +02:00
Sandeep Sheshrao Shedmake 162ece1bba Added mr to LINGUAS file && Updated Marathi Translations 2014-09-17 09:13:00 +05:30
Sandeep Sheshrao Shedmake d8974faa65 Added mr in LINGUAS && Updated Marathi Translations 2014-09-17 09:02:33 +05:30
Muhammet Kara be38e343cd Updated Turkish translation 2014-09-16 11:43:50 +00:00
Umarzuki Bin Mochlis Moktar 88f2eef2b2 Added Malay translation 2014-09-16 06:45:37 +00:00
Shantha kumar 04e5c1da9e Updated Tamil translation 2014-09-15 06:56:42 +00:00
Wolfgang Stöggl f48055f331 Updated German translation 2014-09-14 17:58:55 +00:00
Pawan Chitrakar 3a484a9988 Added Nepali translation 2014-09-14 17:53:38 +00:00
Ask Hjorth Larsen 3fd977779f Updated Danish translation 2014-09-11 21:56:47 +00:00
Florian Müllner 191c7ccc24 window-list: Do not add sticky windows more than once
When a window's on-all-workspaces property changes to true, the
workspaces the window was not located on will emit the ::window-added
signal for the window; however we don't want multiple buttons for
the same window, so filter out the extra calls.

https://bugzilla.gnome.org/show_bug.cgi?id=736398
2014-09-11 12:13:10 +02:00
Dušan Kazik f77e38e771 Updated Slovak translation 2014-09-10 06:58:11 +00:00
Mattias Eriksson 4c53d9b143 Updated Swedish translation 2014-09-09 19:10:31 +00:00
Krishnababu Krothapalli 4164422156 Updated Telugu translations 2014-09-09 16:27:00 +05:30
Krishnababu Krothapalli 28d0d9e9bc Updated Telugu Translations 2014-09-09 15:09:19 +05:30
A S Alam e40ac33fb2 update Punjabi Translation - back for 3.14 2014-09-08 21:15:34 -05:00
Ville-Pekka Vainio 631ac48a4e Finnish translation update by Jiri Grönroos 2014-09-07 13:41:18 +03:00
Changwoo Ryu a8b2746089 Updated Korean translation 2014-09-05 07:14:36 +09:00
Piotr Drąg 6e53f579dd Updated Polish translation 2014-09-03 16:25:25 +02:00
Florian Müllner b6f434fba4 Bump version to 3.13.91
To go along GNOME Shell 3.13.91
2014-09-03 15:11:54 +02:00
Florian Müllner 2667b9f3e5 launch-new-instance: Update for gnome-shell changes 2014-09-03 15:11:54 +02:00
Florian Müllner 5616a6deae window-list: Expand workspace button for Fitts'ability
The workspace button used to extend to the bottom edge, which of
course is A Good Thing (tm) - commit ec8f269107 broke this when
it added an additional container to the hierarchy, expand the
button again to bring back the old mouse-friendly behavior.

https://bugzilla.gnome.org/show_bug.cgi?id=708247
2014-09-03 14:50:35 +02:00
Andika Triwidada 6195b5f4c0 Updated Indonesian translation 2014-09-02 12:22:55 +00:00
Sweta Kothari 2f63809699 Updated gujarati translations 2014-09-02 15:45:49 +05:30
Hajime Taira 4366702fcf l10n: Update Japanese translation 2014-08-31 12:02:04 +09:00
Arash Mousavi 6d4e97d087 Update Persian Translation 2014-08-28 20:06:26 +04:30
Manoj Kumar Giri 528ceec195 Updated Oriya translation 2014-08-26 06:47:44 +00:00
Alexandre Franke bfaac4f8e3 Updated French translation 2014-08-25 21:50:58 +00:00
Adel Gadllah b2a2653492 alternate-tab: Remove 'backwards' argument from SwitcherPopup:_keyPressHandler
Match the change from commit d450b74e10610c6164e

https://bugzilla.gnome.org/show_bug.cgi?id=735239
2014-08-24 13:33:08 +02:00
Baurzhan Muftakhidinov 26eea0bb46 Updated Kazakh translation 2014-08-24 04:23:57 +00:00
Marek Černocký 2fd1392666 Updated Czech translation 2014-08-22 11:55:59 +02:00
Giovanni Campagna 96c39cdda0 Bump version to 3.13.90
To go along GNOME Shell 3.13.90
2014-08-20 15:00:11 +02:00
Chao-Hsiung Liao eee0c56772 Updated Traditional Chinese translation(Hong Kong and Taiwan) 2014-08-19 20:22:20 +08:00
Carles Ferrando edda0cd626 [l10n] Updated Catalan (Valencian) translation 2014-08-17 14:40:13 +02:00
Gil Forcada 86c0ddc51b [l10n] Updated Catalan translation 2014-08-17 14:40:10 +02:00
Michael Catanzaro 583a997b86 Update README
See https://lists.debian.org/debian-devel/2014/08/msg00427.html
2014-08-14 20:30:28 -05:00
ngoswami 2b1e4a7456 Updated Assamese translation 2014-08-13 12:09:01 +00:00
Reinout van Schouwen d2194f652b Updated Dutch translation 2014-08-12 23:30:56 +02:00
Inaki Larranaga Murgoitio 955681505c Updated Basque language 2014-08-07 12:28:40 +02:00
Piotr Drąg a33047abbd doap: add <programming-language> 2014-07-31 19:16:55 +02:00
Olav Vitters 5bb4b44764 doap category core 2014-07-30 20:08:38 +02:00
Iris Gou 257694ab4a update zh_CN translation 2014-07-29 17:36:11 +08:00
Giovanni Campagna d24f4f86b3 Bump version to 3.13.4
To go along GNOME Shell 3.13.4
2014-07-24 16:17:51 +02:00
Carlos Soriano 4f1ffc9e62 theme: update to a change on 2d68bbf94e 2014-07-23 16:29:43 +02:00
Fran Diéguez b0f00299e6 Updated Galician translations 2014-07-01 21:25:18 +02:00
Yuri Myasoedov d9d80d3644 Updated Russian translation 2014-06-27 21:50:25 +04:00
MarMav 9f57e10288 Updated Greek translation 2014-06-27 15:36:59 +00:00
Giovanni Campagna a2d16b6f39 Bump version to 3.13.3
To go along GNOME Shell 3.13.3
2014-06-25 21:13:18 +02:00
Balázs Úr a434946ae7 Updated Hungarian translation 2014-06-16 23:37:25 +02:00
Matej Urbančič 3970bd0d28 Updated Slovenian translation 2014-06-16 22:10:45 +02:00
Daniel Mustieles d2b8875f7a Updated Spanish translation 2014-06-12 17:52:10 +02:00
Florian Müllner f38d76db06 native-window-placement: Fix 'button-layout' schema
The defaults have been shifted around so that the normal session
uses the regular schema and classic mode overrides it, so the
key is no longer present in 'org.gnome.shell.overrides'.
2014-06-10 12:26:14 +02:00
Florian Müllner bb84456c2c data: Don't set overridesSchema for classic mode
The shell now hardcodes this until we get session-specific defaults
in GSettings proper, so the property is no longer used.
2014-06-09 22:41:28 +02:00
Muhammet Kara 44d01e5e47 Updated Turkish translation 2014-06-07 21:27:38 +00:00
Kjartan Maraas 98bddd8a78 Updated Norwegian bokmål translation from Åka Sikrom. 2014-06-03 19:58:26 +02:00
Enrico Nicoletto 3cf95bb205 Updated Brazilian Portuguese translation 2014-06-03 13:07:37 +00:00
Aurimas Černius c1b6e58d5c Updated Lithuanian translation 2014-06-02 23:23:12 +03:00
Yosef Or Boczko c2cf5d2ffe Updated Hebrew translation 2014-05-30 09:06:52 +03:00
Florian Müllner 6a9c4e71fc example: Tweak prefs UI
Position the explanatory text below the actual option and tweak
whitespace a bit.

https://bugzilla.gnome.org/show_bug.cgi?id=730843
2014-05-28 01:27:37 +02:00
Florian Müllner de4782ebf5 Bump version to 3.13.2
To go along with GNOME Shell 3.13.2.
2014-05-28 01:19:25 +02:00
Florian Müllner d0110cf18a auto-move: Tweak prefs UI
- make tree view scrollable when list grows large
- add some borders
- use symbolic icons instead of (deprecated) stock items
- adjust spacing/alignment
- disable remove button when no item is selected

https://bugzilla.gnome.org/show_bug.cgi?id=730843
2014-05-28 01:14:42 +02:00
Florian Müllner de7fbe5b7d workspace-indicator: Tweak prefs UI
- make tree view scrollable when list grows large
 - add some borders
 - use symbolic icons instead of (deprecated) stock items
 - adjust spacing/alignment
 - disable remove button when no item is selected

https://bugzilla.gnome.org/show_bug.cgi?id=730843
2014-05-28 01:14:42 +02:00
Florian Müllner f4625f7968 alternate-tab: Tweak pref widget a bit
Adjust spacing to use more standard values and tweak alignments
to make the structure a bit more clear.

https://bugzilla.gnome.org/show_bug.cgi?id=730843
2014-05-28 01:14:42 +02:00
Philip Withnall 935bd9ce0b Update British English translation 2014-05-27 22:05:11 +01:00
Florian Müllner c290da01dc data: Add button-layout to override schema
The default in gsettings-desktop-schemas has changed to not include
minimize and maximize to match the default of client-side decorations
in GTK+, so start overriding the setting to bring them back in classic
mode.
2014-05-27 19:56:51 +02:00
Florian Müllner db04866ca2 window-list: Use Infinity instead of special-casing 0
This should fix the problem addressed in the last commit without
breaking 0 as stable sequence.
2014-05-27 19:27:43 +02:00
Florian Müllner f93234e442 window-list: Fix stupid thinko
Without special casing the start value of 0, we did not reduce
to the minimum stable sequence of app windows, but 0.
2014-05-27 19:06:22 +02:00
Matthias Clasen fca578d184 3.13.1 2014-05-01 11:18:56 -04:00
Florian Müllner d8eb2273c0 window-list: Sort buttons by stable sequence
Currently the initial set of buttons is in stack/MRU order. To
avoid shuffling around the list each time it is disabled/re-enabled
(lock screen) or the group-mode settings changes, sort it by the
stable sequence.

https://bugzilla.gnome.org/show_bug.cgi?id=719933
2014-04-29 19:08:26 +02:00
Bastien Nocera 110e747e04 data: Add DesktopNames to the session file
So that GDM can export the XDG_CURRENT_DESKTOP environment variable.

See also https://bugzilla.gnome.org/show_bug.cgi?id=727546

https://bugzilla.gnome.org/show_bug.cgi?id=727566
2014-04-29 10:40:15 +02:00
Debarshi Ray 512ff51d13 launch-new-instances: Drop obsolete signals and callbacks
The 'launching' signal and this._onActivateOverride callback were
removed from gnome-shell in 7ecb5af587af7ed892c6cfc5af0858a2acb04905
and 7ecb5af587af7ed892c6cfc5af0858a2acb04905 respectively.

https://bugzilla.gnome.org/show_bug.cgi?id=721864
2014-04-29 01:09:38 +02:00
Florian Müllner 80f49c2ed7 auto-move-windows: Never remove the active workspace
Follow core shell in never removing the active workspace.

https://bugzilla.gnome.org/show_bug.cgi?id=728865
2014-04-24 19:15:43 +02:00
Florian Müllner d9b543c6e0 auto-move-windows: Never show the overview after removing workspace
This follows the core shell behavior, where we stopped doing this
a while ago.

https://bugzilla.gnome.org/show_bug.cgi?id=728865
2014-04-24 19:15:43 +02:00
Florian Müllner c005393398 auto-move-windows: Take workspaces in startup sequences into account
See https://bugzilla.gnome.org/show_bug.cgi?id=664202 for the
corresponding patch in core shell.

https://bugzilla.gnome.org/show_bug.cgi?id=728865
2014-04-24 19:15:42 +02:00
Florian Müllner 7f008aa3ff auto-move-windows: Respect keep-alive flag in checkWorkspaces
https://bugzilla.gnome.org/show_bug.cgi?id=728865
2014-04-24 19:15:42 +02:00
Florian Müllner c8b67cb84d auto-move-windows: Move check for dynamic workspaces
Move the check into checkWorkspaces rather than replacing the function
conditionally, to handle changes to the setting.

https://bugzilla.gnome.org/show_bug.cgi?id=728865
2014-04-24 19:15:40 +02:00
Florian Müllner fee5495692 auto-move-windows: Fix fallout from API change
MetaWindowActor.get_workspace() was removed, however the now used
MetaWindow.get_workspace() returns a MetaWorkspace rather than an
index, so can't be used directly.

https://bugzilla.gnome.org/show_bug.cgi?id=728820
2014-04-24 13:09:11 +02:00
Florian Müllner ec49693c6f auto-move-windows: Remove unused parameters
meta_window_change_workspace_by_index() lost its timestamp parameter
a while ago.
2014-04-24 11:57:10 +02:00
Florian Müllner f007807ea1 window-list: Don't shift message tray when on different monitors
The message tray is moved to the bottom-most monitor when there are
monitors below the primary monitor; in that case, we need to leave
the tray alone.

https://bugzilla.gnome.org/show_bug.cgi?id=728288
2014-04-17 18:34:25 +02:00
Florian Müllner 4ec4bdb0ea style: Overwrite border-radius of tile previews in classic mode
In classic mode, the panel does not have rounded corners; thus
tile previews shouldn't either.

https://bugzilla.gnome.org/show_bug.cgi?id=728273
2014-04-15 18:07:06 +02:00
Khoem Sokhem 6c79710fcf Added Khmer translation 2014-04-10 01:08:00 +00:00
Piotr Drąg 4cc8cb5523 doap: update URLs 2014-04-04 19:38:22 +02:00
Ikuya Awashiro 9480e640a7 l10n: Update Japanese translation 2014-04-01 07:08:23 +09:00
Giovanni Campagna 4b03b660eb Bump version to 3.12.0
To go along GNOME Shell 3.12.0
2014-03-25 17:49:11 +01:00
Chao-Hsiung Liao cce9fe10dc Updated Traditional Chinese translation(Hong Kong and Taiwan) 2014-03-22 20:05:09 +08:00
Florian Müllner 6007a09782 Bump version to 3.11.92
To go along GNOME Shell 3.11.92
2014-03-19 23:08:37 +01:00
Giovanni Campagna e445278f52 Bump version to 3.11.91
To go along GNOME Shell 3.11.91
2014-03-06 01:39:46 +01:00
Changwoo Ryu d83b95ec8c Updated Korean translation 2014-03-05 20:11:31 +09:00
Fabio Tomat ad2ece839c Updated Friulian translation 2014-03-03 13:41:52 +01:00
Giovanni Campagna 7c9bd8acaf Bump version to 3.11.90
To go along GNOME Shell 3.11.90
2014-02-20 01:15:50 +01:00
Giovanni Campagna 4a5521a9ba auto-move-windows: update for gnome-shell changes
meta_window_actor_get_workspace() was removed.
2014-02-20 01:10:15 +01:00
Giovanni Campagna a42dcee6ec WindowList: allow switching windows with mouse scroll
This is something that gnome-panel supported, and apparently
some users would like to have it back, so restore this feature
on our window list too.

https://bugzilla.gnome.org/show_bug.cgi?id=723693
2014-02-19 17:21:45 +01:00
Manoj Kumar Giri a4846847de Updated Oriya translation 2014-02-19 15:22:57 +00:00
Florian Müllner 3cde65e85e window-list: Call destroy() on menus instead of their actors
PopupBaseMenu provides a destroy() method that will destroy the menu
actor and make sure that the menu will be removed from the corresponding
PopupMenuManager (if any). We miss the latter when we destroy the menu
actor directly, so use the menu method instead.

https://bugzilla.gnome.org/show_bug.cgi?id=724688
2014-02-18 21:12:16 +01:00
Florian Müllner b87ddf1195 window-list: Only have a single context menu at any time
Depending on the number of windows, AppButtons use different right-click
menus ("Minimize" vs. "Minimize all").
As the menu for the multiple-windows case remains the same, it is created
and added just once. However this means that in the single-window case,
the corresponding PopupMenuManager will track two menus for the same
source actor, resulting in various misbehaviors.
Fix these issues by adding and removing the app context menu appropriately,
so that the PopupMenuManager tracks a single menu at any time.

https://bugzilla.gnome.org/show_bug.cgi?id=724688
2014-02-18 21:12:16 +01:00
Florian Müllner c2fe2b5505 window-list: Sync hover after closing menus
StButton takes the hover state into account to decide whether a
series of events should be considered a click. So when dismissing
a menu by clicking on a different window/app button, its menu
cannot be triggered before leaving and re-entering the button
(and thus syncing the hover state).
Fix this by always syncing the hover state after a grab is dropped.

https://bugzilla.gnome.org/show_bug.cgi?id=724688
2014-02-18 21:12:16 +01:00
Florian Müllner 7e3db53dcd launch-new-instance: Update to changed API
https://bugzilla.gnome.org/show_bug.cgi?id=724428
2014-02-15 17:53:42 +01:00
Florian Müllner c9a4d15f05 window-list: Filter skip-taskbar windows
Applications now track all their windows, not just the ones that are
expected to show up in the window list. So to restore the previous
behavior, we now have to filter out windows with the skip-taskbar
hint ourselves.

https://bugzilla.gnome.org/show_bug.cgi?id=724134
2014-02-11 17:58:14 +01:00
Florian Müllner 9c6c00f8a3 window-list: Restrict right-click actions to windows in list
While the list of windows in the left-click menu is filtered by
workspace, the minimize/maximize/close actions in the right-click
menu apply to all application windows on all workspaces.
This is fairly confusing, so restrict the actions to only apply
to windows that do appear in the left-click list.

https://bugzilla.gnome.org/show_bug.cgi?id=724134
2014-02-11 17:58:14 +01:00
Florian Müllner 0bcb1571da auto-move-windows: Adjust to API changes
https://bugzilla.gnome.org/show_bug.cgi?id=724119
2014-02-11 17:17:22 +01:00
Daniel Korostil eb568d90f0 Updated Ukranian 2014-02-09 23:19:46 +02:00
Ryan Lortie 726a419bc6 autogen.sh: use #!/bin/sh instead of #!/bin/bash
We don't have any bashisms in this file, so we may as well use sh.

https://bugzilla.gnome.org/show_bug.cgi?id=722342
2014-02-09 11:00:37 -05:00
Florian Müllner 9c23b52c1e window-list: Update keyboard position on fullscreen changes
The visibility of the window list changes when a monitor enters or
exits fullscreen, so we should update the OSK position accordingly.

https://bugzilla.gnome.org/show_bug.cgi?id=723693
2014-02-06 19:51:19 +01:00
Giovanni Campagna ff64bb5432 Revert "window-list: fix overview animation"
This reverts commit bf789608df.
Pushed by mistake.
2014-02-05 17:28:16 +01:00
Giovanni Campagna bf789608df window-list: fix overview animation
Animate showing and hiding the window list when toggling the
overview (with a translation on and off the screen). Don't actually
change the visible status of the actor, because we don't want
to change struts.
2014-02-05 17:27:36 +01:00
Giovanni Campagna 85c7b9b85b places-menu: fix for gnome-shell changes
Making sure something appears on screen is not equivalent to
working...
2014-02-05 17:27:36 +01:00
Muhammet Kara 4c670d10a2 [l10n]Updated Turkish translation 2014-02-05 12:09:53 +02:00
Giovanni Campagna 2bf50a76ed window-list: fix font-style of notifications
Notifications are reparented to the bottom panel when there is
one, so they would inherit the bold font. Avoid that.
2014-02-05 01:08:45 +01:00
Giovanni Campagna a519c9fe91 drive-menu: fix interesting check
In case of shadowed mounts, mounts can become uninteresting
after they are added, according to whether our handler or gvfs
runs first, so we need to watch for changes. The easiest way
is to create an item for all mounts, and only show the interesting
ones.
2014-02-05 01:00:35 +01:00
Giovanni Campagna 66216993e0 window-list: import gettext for the right domain
Default _ is gettext from gnome-shell domain, which doesn't have
the strings we need.
We could use mutter's, but translators already did their job
on pretty much all supported languages, so...
2014-02-05 00:50:27 +01:00
Giovanni Campagna 74fd9ba8e3 Update NEWS
Forgot to save before committing the release...
No big news anyway.
2014-02-05 00:48:52 +01:00
Giovanni Campagna a39902b287 Bump version to 3.11.5
To go along GNOME Shell 3.11.5
2014-02-05 00:43:45 +01:00
Giovanni Campagna 68adf77012 window-list: update for gnome-shell changes
Shell.WindowTracker.is_window_interesting() was removed, and
replaced with the skip_taskbar MetaWindow property.
2014-02-05 00:42:25 +01:00
Shankar Prasad d566ffbb8f updated kn.po 2014-02-03 17:05:24 +05:30
Giovanni Campagna 33b472a0ec Use my GNOME email in the doap file
Otherwise Frederic's report fails to find an active maintainer
and lowers the score.
2014-01-30 17:18:54 +01:00
Giovanni Campagna 1d38b69691 Bump version to 3.11.4
To go along GNOME Shell 3.11.4
2014-01-16 20:00:48 +01:00
Giovanni Campagna 53e9074058 window-list: remove our use of Hash module
It was removed in core shell and replaced with ES6 Map.
2014-01-16 20:00:44 +01:00
Ray Strode e08d527d51 data: set shell classic mode via env variable instead of command line
Currently, we start gnome-shell in classic mode by passing
--mode=classic to the gnome-shell command line. This --mode=classic
gets stripped away when the session is saved, which breaks classic
mode on subsequent login attempts.

This commit changes the session file to set the
GNOME_SHELL_SESSION_MODE environment variable instead.

https://bugzilla.gnome.org/show_bug.cgi?id=720894
2014-01-07 15:29:02 -05:00
Shankar Prasad 07a4c7eb25 Updated the kn.po 2013-12-30 16:47:28 +05:30
Shankar Prasad 0b399fba7a Added kn entry in the LINGUAS file 2013-12-30 16:45:42 +05:30
Shankar Prasad 1aa8561497 Added and updated the kn.po file which was partially translated by prabodh P C <prabodhcp AT gmail DOT com>. I reviewed his translation and added mine too 2013-12-30 16:44:46 +05:30
Jorge Pérez Pérez 719ec25cb7 Updated Aragonese translation 2013-12-22 21:16:36 +01:00
Giovanni Campagna 4aa27c533e Bump version to 3.11.3
To go along GNOME Shell 3.11.3.
2013-12-20 19:43:48 +01:00
Khaled Hosny 75f11da08f Update Arabic translation 2013-12-13 22:20:22 +02:00
Maciek Borzecki 12e3f39ccd Align workspace indicator label vertically to center
https://bugzilla.gnome.org/show_bug.cgi?id=711823
2013-12-13 19:27:52 +01:00
Krishnababu Krothapalli d16fb714a3 Updated Telugu Translations 2013-12-12 18:17:07 +05:30
Shantha kumar b5cc38c9dd Tamil Translations Updated 2013-11-25 14:01:16 +05:30
Ryan Lortie 6b73c8e488 Update Esperanto translation
Review by Kristjan Schmidt
2013-11-23 19:03:47 -05:00
Florian Müllner e801c614e1 Bump version to 3.11.2
To go along GNOME Shell 3.11.2.
2013-11-13 22:29:18 +01:00
甘露(Gan Lu) 0477282fed Update Chinese simplified translation 2013-11-10 11:36:01 +08:00
Florian Müllner 61308c4efa Bump version to 3.11.1
To go along GNOME Shell 3.11.1
2013-11-08 16:51:17 +00:00
Florian Müllner 7dac0859f5 apps-menu: Fix for gnome-shell master
Some convenience functions were dropped from ShellAppSystem.
2013-11-08 16:26:17 +00:00
Efstathios Iosifidis a7f7db59c7 Updated Greek translation 2013-11-05 15:20:02 +02:00
Kittiphong Meesawat e4a448b097 Added Thai translation. 2013-11-01 20:35:40 +07:00
Tim Lunn e73752118d Stringify the xml definitions for E4X removal
https://bugzilla.gnome.org/show_bug.cgi?id=691409
2013-10-25 10:57:28 +11:00
Giovanni Campagna a21def6e6e drive-menu: ignore shadowed mounts
Shadow mounts are created by the GVolume infrastructure to wrap
daemon mounts managed by volume monitors, and are an implementation
detail that should not be exposed to the user.
2013-10-20 17:49:12 +02:00
Florian Müllner b62a65e1a8 Bump version to 3.10.1
To go along GNOME Shell 3.10.1
2013-10-15 21:19:06 +02:00
António Lima 232ea7ba32 Updated Portuguese translation 2013-10-13 12:24:57 +01:00
Wouter Bolsterlee 12cc44c351 Updated Dutch translation 2013-10-12 20:01:20 +02:00
Gabor Kelemen 4e88a2b294 Updated Hungarian translation 2013-10-10 14:16:01 +02:00
Carles Ferrando dca52fef8b [l10n] Added Catalan (Valencian) translation 2013-10-06 21:59:08 +02:00
Gil Forcada 5ffe200918 [l10n] Update Catalan translation 2013-10-06 21:12:43 +02:00
Arash Mousavi 431a8f5eed L10N: Updated Persian translations 2013-10-05 18:35:44 +03:30
Arash Mousavi 7739ef2096 L10N: Updated Persian translations 2013-10-05 18:31:49 +03:30
Мирослав Николић bbe7b93cd7 Updated Serbian translation 2013-10-05 06:16:32 +02:00
Mattias Põldaru 396f7f8495 [l10n] Updated Estonian translation 2013-10-01 17:14:27 +03:00
Kjartan Maraas 4f0400ca25 Updated Norwegian bokmål translation 2013-09-28 14:54:10 +02:00
Dušan Kazik e8292af0eb Updated Slovak translation 2013-09-27 17:42:47 +01:00
Friedel Wolff 8228a9658c New translation for Afrikaans (af) 2013-09-27 16:18:55 +02:00
Rūdolfs Mazurs a092675cc4 Updated Latvian translation 2013-09-26 23:31:57 +03:00
Osman Karagöz 3bafc2d32d [l10n]Added Turkish translation 2013-09-26 00:23:13 +03:00
Aurimas Černius b740dc7dd3 Updated Lithuanian translation 2013-09-25 23:24:03 +03:00
Christian Kirbach ac7e0cf39e Updated German translation 2013-09-25 15:27:12 +02:00
Inaki Larranaga Murgoitio 2138dacf4a Updated Basque language 2013-09-25 11:18:21 +02:00
A S Alam 4ecee76401 Punjabi Translation updated by Aman 2013-09-24 07:54:08 -05:00
Giovanni Campagna 142ac16b64 Bump version to 3.10.0
To go along GNOME Shell 3.10.0
2013-09-24 14:20:53 +02:00
Nilamdyuti Goswami ff65aaece2 Assamese translation updated 2013-09-24 14:28:55 +05:30
Yuri Myasoedov 43b6e9694f Updated Russian translation 2013-09-24 12:21:19 +04:00
Baurzhan Muftakhidinov b5b9a8e072 Update Kazakh translation 2013-09-24 06:34:56 +06:00
Fran Diéguez 424de06404 Updated Galician translations 2013-09-23 22:21:08 +02:00
Matej Urbančič 2d36a31f33 Updated Slovenian translation 2013-09-23 21:17:04 +02:00
Piotr Drąg 0374a1a320 Updated Polish translation 2013-09-23 20:37:54 +02:00
Kenneth Nielsen b4385ea7a6 Updated Danish translation 2013-09-23 19:34:38 +02:00
Andika Triwidada e9bc16b34d Updated Indonesian translation 2013-09-23 21:27:17 +07:00
Alexandre Franke 651018abe7 Update French translation 2013-09-23 15:37:11 +02:00
Petr Kovar dbc3429e05 Update Czech translation 2013-09-23 15:08:06 +02:00
Daniel Mustieles a0507b957f Updated Spanish translation 2013-09-23 14:31:36 +02:00
Rafael Ferreira 7e59afeaca Updated Brazilian Portuguese translation 2013-09-23 07:36:29 -03:00
Victor Ibragimov 06e90b6c76 Tajik translation updated 2013-09-23 15:32:14 +05:00
Milo Casagrande 5970e29355 [l10n] Updated Italian translation. 2013-09-23 12:25:39 +02:00
Yosef Or Boczko 77088b0404 Updated Hebrew translation
Signed-off-by: Yosef Or Boczko <yoseforb@gmail.com>
2013-09-23 13:23:40 +03:00
Frédéric Péters 9214e47f73 typo fix 2013-09-23 12:19:06 +02:00
Frédéric Péters 01f39bdae5 add missing translation markers 2013-09-23 12:17:33 +02:00
Andika Triwidada cfc0ed6ab6 Updated Indonesian translation 2013-09-23 09:42:30 +07:00
Dmitriy S. Seregin 9c22a5f894 Updated Russian translation 2013-09-22 20:35:33 +04:00
Rūdolfs Mazurs de315e7897 Updated Latvian translatio 2013-09-21 22:51:06 +03:00
Matej Urbančič 853704c509 Updated Slovenian translation 2013-09-21 20:27:15 +02:00
Daniel Korostil 23c0d0a61f Updated Ukrainian 2013-09-21 12:23:02 +03:00
Timo Jyrinki bf139e7636 Finnish translation update 2013-09-20 21:33:06 +03:00
Aurimas Černius 13201a5c76 Updated Lithuanian translation 2013-09-20 21:23:09 +03:00
Priit Laes 261120dc4b Add Estonian (et) to LINGUAS 2013-09-20 09:53:29 +03:00
Mattias Põldaru 09f43d4f84 [l10n] Updated Estonian translation 2013-09-20 09:52:18 +03:00
Chao-Hsiung Liao 0590b9123d Updated Traditional Chinese translation(Hong Kong and Taiwan) 2013-09-20 13:44:43 +08:00
Fernando Carvalho e271231e77 Updated Portuguese translation 2013-09-18 23:55:51 +01:00
A S Alam 8b97f068c7 Punjabi Translation updated by Aman 2013-09-17 22:16:28 -05:00
Ask H. Larsen a5344e3fe0 Updated Danish translation 2013-09-17 18:40:55 +02:00
Nilamdyuti Goswami 096fff8b3f Assamese translation updated 2013-09-17 16:06:33 +05:30
Giovanni Campagna caa9d6e423 Bump version to 3.9.92
To go along GNOME Shell 3.9.92
2013-09-17 10:54:49 +02:00
Giovanni Campagna 65bec3cdb1 apps-menu: fix for gnome-shell master
PopupMenu.isEmpty() only checks for regular menu items, which
the application menu doesn't use, so we need a fake implementation.
2013-09-17 10:52:03 +02:00
Giovanni Campagna d060657bf4 systemMonitor: update for gnome-shell master
Reparent the message tray menu button so that the indicators
don't cover it.
2013-09-17 10:51:34 +02:00
Dimitris Spingos 342dd7c64d Updated Greek translation 2013-09-16 22:27:19 +03:00
Yosef Or Boczko 011860b476 Updated Hebrew translation 2013-09-16 22:17:17 +03:00
Inaki Larranaga Murgoitio 31c459304e Updated Basque language 2013-09-16 21:00:15 +02:00
Marek Černocký 604d280c8c Updated Czech translation 2013-09-16 19:46:06 +02:00
Daniel Mustieles d9c00ab646 Updated Spanish translation 2013-09-16 13:25:51 +02:00
Victor Ibragimov 756d3c74e8 Tajik translation updated 2013-09-16 15:17:20 +05:00
Milo Casagrande c368d8d968 [l10n] Updated Italian translation. 2013-09-16 09:01:39 +02:00
Reinout van Schouwen f33087d2ad Updated Dutch translation 2013-09-15 22:20:15 +02:00
Benjamin Steinwender 25e5ddf17c Updated German translation 2013-09-15 21:35:20 +02:00
Changwoo Ryu 9811636e3c Updated Korean translation 2013-09-16 03:26:02 +09:00
Fran Diéguez 16379e2233 Updated Galician translations 2013-09-15 17:23:22 +02:00
Baurzhan Muftakhidinov 6e5cbec7a0 Initial Kazakh translation 2013-09-15 14:31:28 +06:00
Peter Mráz 5901738896 Updated slovak translation 2013-09-15 10:24:16 +02:00
Enrico Nicoletto b3829b0359 Updated Brazilian Portuguese translation 2013-09-14 21:58:04 -03:00
Piotr Drąg 6ed8b84368 Updated Polish translation 2013-09-15 02:43:12 +02:00
Piotr Drąg 23981289d5 Fix a translatable string
So the old gettext would pick it up. Not a string freeze break.
2013-09-15 02:43:12 +02:00
Kris Thomsen 2d0142426a Updated Danish translation 2013-09-13 22:20:55 +02:00
Changwoo Ryu b4b989be0b Updated Korean translation 2013-09-14 04:35:21 +09:00
Gabor Kelemen e7e62f5c8e Updated Hungarian translation 2013-09-12 16:05:41 +02:00
Jiro Matsuzawa 17663f5f20 apps-menu: Respect user's favorite apps order
https://bugzilla.gnome.org/show_bug.cgi?id=704248
2013-09-12 07:14:48 +09:00
victory c1fead9dad l10n: Update Japanese translation 2013-09-11 23:32:03 +09:00
Rūdolfs Mazurs caba979752 Updated Latvian translation 2013-09-10 21:48:05 +03:00
Nilamdyuti Goswami addd62bef9 Assamese Translation Updated 2013-09-10 20:51:21 +05:30
Khaled Hosny 06f85e842a Update Arabic translation 2013-09-09 23:22:34 +02:00
Khaled Hosny f625ae110f Typo 2013-09-09 23:18:36 +02:00
sanad 54c4e1ca96 Update Arabic translation 2013-09-09 23:17:56 +02:00
A S Alam a0e9e49914 Punjabi Translation updated by Aman 2013-09-09 14:13:38 -05:00
Kjartan Maraas 00a133a314 Updated Norwegian bokmål translation 2013-09-08 19:51:26 +02:00
Giovanni Campagna cccd46b513 window-list: insist more that the indicators should be at the very right end
The new box layout is just annoying...
2013-09-05 10:30:20 +02:00
Stas Solovey 8e1db160ca Updated Russian translation 2013-09-05 09:55:00 +04:00
Timo Jyrinki 9b516aa0d9 Finnish translation update 2013-09-04 11:02:28 +03:00
Мирослав Николић ec5d03d754 Updated Serbian translation 2013-09-04 06:33:10 +02:00
Shantha kumar 987f67f288 Tamil Translations Updated 2013-09-03 16:05:43 +05:30
Shantha kumar ea18bd7cdb Tamil Translations Updated 2013-09-03 16:03:03 +05:30
Giovanni Campagna fd030fa52f Bump version to 3.9.91
To go along GNOME Shell 3.9.91
2013-09-03 10:38:15 +02:00
Giovanni Campagna 01f168341f windowsNavigator: update for gnome-shell changes 2013-09-03 10:36:31 +02:00
Giovanni Campagna ec8f269107 window-list: fix regression from StBoxLayout refactoring
Make sure that the workspace indicator is always packed at the
end of the window list
2013-09-03 10:34:13 +02:00
Benjamin Steinwender 2b45617d6a Updated German translation 2013-09-01 00:49:51 +02:00
Chao-Hsiung Liao 37f24a88de Updated Traditional Chinese translation(Hong Kong and Taiwan) 2013-08-29 21:55:39 +08:00
Dušan Kazik 88b1bf8964 Updated slovak translation 2013-08-27 21:45:52 +02:00
Aurimas Černius 5f639ec972 Updated Lithuanian translation 2013-08-26 22:59:35 +03:00
Allan Day d8cef9d6f5 tweak the system menu theme
https://bugzilla.gnome.org/show_bug.cgi?id=706666
2013-08-26 18:00:45 +02:00
Giovanni Campagna d4845f3e24 classic: update the theme for 3.9.90
Fix the colors in the system menu elements.

https://bugzilla.gnome.org/show_bug.cgi?id=706666
2013-08-26 17:59:53 +02:00
Giovanni Campagna 5b021256c9 classic: update the session mode for 3.9.90
The status menus were consolidated into the aggregate menu.

https://bugzilla.gnome.org/show_bug.cgi?id=706666
2013-08-26 14:58:42 +02:00
Enrico Nicoletto 806f345e51 Updated Brazilian Portuguese translation 2013-08-26 00:34:49 -03:00
Milo Casagrande f47133f897 [l10n] Updated Italian translation. 2013-08-25 17:33:49 +02:00
Reinout van Schouwen 67b84f8cf0 Initial Dutch translation 2013-08-24 14:17:08 +02:00
Piotr Drąg 32ed396ebf Updated Polish translation 2013-08-23 00:52:16 +02:00
Giovanni Campagna 85c7fa6483 Bump version to 3.9.90
To go along GNOME Shell 3.9.90
2013-08-22 10:06:36 +02:00
Andika Triwidada d0c17d038d Updated Indonesian translation 2013-08-21 17:31:44 +07:00
Fran Diéguez cc91b26ed3 Updated Galician translations 2013-08-21 00:47:40 +02:00
Giovanni Campagna 7decfe92c9 <name> should match repository's name.
Andrea's been patching every module in GNOME for this, let's make
his life easier.
2013-08-21 00:06:58 +02:00
Matej Urbančič ff0e0205ef Updated Slovenian translation 2013-08-19 21:54:02 +02:00
Victor Ibragimov 6a493a3eea Tajik translation updated 2013-08-19 23:52:05 +05:00
Marek Černocký 103ec6d43f Updated Czech translation 2013-08-19 15:01:04 +02:00
Daniel Mustieles a47ff4a54e Updated Spanish translation 2013-08-19 11:44:01 +02:00
Florian Müllner f1f16f262b window-list: Add context menu
gnome-panel's window list had context menus on buttons, that gave
easy access to common operations like close, minimize and maximize.
Add something similar to the window-list.

https://bugzilla.gnome.org/show_bug.cgi?id=699251
2013-08-19 10:21:23 +02:00
Piotr Drąg db3800500c Updated POTFILES.in 2013-08-18 22:07:07 +02:00
Giovanni Campagna 63653406a3 Update all extensions for gnome-shell 3.9.90
addActor() gone from PopupBaseMenuItem, arrows in menus,
SystemStatusButton gone.
The auto-move-windows cleanup is probably older, weird noone
noticed before.

Anyway, I need a pitch fork.
2013-08-18 22:01:35 +02:00
Giovanni Campagna e2b2f125b4 Remove the xrandr extension
This can't work without a significant rework (because we can't
use GnomeRR in the mutter process, now that's DBus API implemented
by mutter itself, and the monitor config API is private to mutter
for now), and I doubt it's really useful to anyone.
Also, we have an orientation lock button, which kind of serves
a similar purpose
2013-08-18 19:28:34 +02:00
Matej Urbančič 373bc5e709 Updated Slovenian translation 2013-08-17 16:54:03 +02:00
Fabio Tomat 9d80df7a6d Added Friulian language 2013-08-15 12:11:16 +02:00
Fabio Tomat c79d0b9d52 Added Friulian translation 2013-08-15 12:10:53 +02:00
Nishio Futoshi 282cd8564a l10n: Update Japanese translation 2013-08-11 09:53:43 +09:00
tuhaihe 6f184424d9 Update Chinese simplified translation 2013-08-03 22:11:10 +08:00
Chao-Hsiung Liao 1aed1799a0 Updated Traditional Chinese translation(Hong Kong and Taiwan) 2013-08-02 10:51:23 +08:00
Gabor Kelemen 3a58e0c12f Updated Hungarian translation by Attila Hammer <hammera at pickup dot hu> 2013-07-31 21:54:19 +02:00
Yaron Shahrabani 19b61be6a6 Updated Hebrew translation. 2013-07-31 12:24:05 +03:00
Giovanni Campagna 79055cf7a0 Bump version to 3.9.5
To go along GNOME Shell 3.9.5

And fix distcheck at the same time.
2013-07-30 15:34:13 +02:00
Giovanni Campagna 2e5d8c7384 Fix a number of undeclared variable warnings
"for (prop in object)" needs a "var prop" before, or it declares
a global property.
2013-07-30 13:23:47 +02:00
Giovanni Campagna 1d6f85c8f4 apps-menu: update to work with gnome-shell master
The span parameter was removed from the PopupMenuItem API.
2013-07-30 13:20:33 +02:00
Giovanni Campagna fb8ad70db6 Remove alternative-status-menu extension
As part of the new unified status menu, the old status menu
was reworked considerably in 3.9.5, and the extension as it
was written does not make sense.
If hibernation is needed, it should be added (through another
extension) in the shutdown dialog.
2013-07-30 13:17:00 +02:00
Nilamdyuti Goswami f67db2a2af Added Assamese LINGUAS 2013-07-29 13:10:41 +05:30
Nilamdyuti Goswami 13c3512ed0 Assamese translation updated 2013-07-29 13:08:57 +05:30
Yuri Myasoedov 71f19d8391 Updated Russian translation 2013-07-27 15:41:39 +04:00
Emmanuele Bassi 7173fa9e9e Revert "Added Assamese to LINGUAS"
This reverts commit e71d48853d.

The Assamese PO file does not exist in the repository. It should be
committed before modifying the LINGUAS file, to avoid breaking the
build.
2013-07-26 11:08:23 +01:00
Nilamdyuti Goswami e71d48853d Added Assamese to LINGUAS 2013-07-26 15:30:45 +05:30
Sweta Kothari f5c8ddf6cd Added gu in LINGUAS file 2013-07-19 14:31:20 +05:30
Sweta Kothari 55d80ea091 Updated Gujarati Translations 2013-07-19 14:18:27 +05:30
Milo Casagrande 66d4b0adc4 [l10n] Updated Italian translation. 2013-07-19 09:34:12 +02:00
Giovanni Campagna 1673dc6e9b Bump version to 3.9.4
To go along GNOME Shell 3.9.4
2013-07-18 12:45:07 +02:00
Anish A 6105afed0d Updated Malayalam Translation 2013-07-17 21:06:17 +05:30
Giovanni Campagna ae9df9f001 user-theme: look for gnome-shell themes in ~/.local/share too
Just like we look in XDG_DATA_DIRS, we should honor XDG_DATA_HOME
as well.
For compatibility reasons, we look in ~/.themes first, then ~/.local/share,
then /usr/share.
2013-07-14 15:19:14 +02:00
tuhaihe 05e42a4b95 update Simplified Chinese (zh_CN) translation 2013-07-12 21:12:14 +08:00
Benjamin Steinwender 9e5079bd83 Updated German translation 2013-07-08 17:23:34 +02:00
Trần Ngọc Quân b408fc4d17 Updated Vietnamese translation 2013-07-06 18:23:13 +07:00
Nguyễn Thái Ngọc Duy 0c6825d2c5 po/vi: import from Damned Lies 2013-07-06 18:21:03 +07:00
Giovanni Campagna 6fbc63e9e6 alternative-status-menu: unpack the result of CanHibernate
The DBus call yields a GVariant, which we need to unpack to
obtain the JS value to compare.

https://bugzilla.gnome.org/show_bug.cgi?id=702300
2013-07-04 16:51:35 +02:00
Giovanni Campagna a2f14c57c5 apps-menu: don't store the hot corner at creation
HotCorners become invalid when the xrandr configuration changes,
so instead of storing it fetch it directly from layoutManager when
needed.

https://bugzilla.gnome.org/show_bug.cgi?id=702038
2013-07-04 16:06:24 +02:00
Andika Triwidada e03343d4a8 Updated Indonesian translation 2013-07-04 18:35:01 +07:00
Rafael Ferreira 9df6831f64 Updated Brazilian Portuguese translation 2013-06-30 08:58:07 -03:00
187 changed files with 27757 additions and 11923 deletions
+11 -5
View File
@@ -1,14 +1,22 @@
ABOUT-NLS
Makefile Makefile
Makefile.in Makefile.in
Makefile.in.in Makefile.in.in
aclocal.m4
autom4te.cache/
config/
configure configure
config.log config.log
config.status config.status
aclocal.m4
autom4te.cache/
data/*.json data/*.json
po/gnome-shell-extensions.pot m4/
po/*.header
po/*.sed
po/*.sin
po/Makevars.template
po/POTFILES po/POTFILES
po/Rules-quot
po/gnome-shell-extensions.pot
po/stamp-it po/stamp-it
staging/ staging/
zip-files/ zip-files/
@@ -17,7 +25,5 @@ zip-files/
*.gmo *.gmo
metadata.json metadata.json
*.desktop *.desktop
*.desktop.in
*.gschema.xml
*.gschema.valid *.gschema.valid
*.session *.session
+13
View File
@@ -0,0 +1,13 @@
image: fedora:latest
stages:
- build
before_script:
- dnf install -y meson gettext mozjs52-devel
build-shell-extensions:
stage: build
script:
- meson _build .
- ninja -C _build test install
+3
View File
@@ -0,0 +1,3 @@
[submodule "data/gnome-shell-sass"]
path = data/gnome-shell-sass
url = https://gitlab.gnome.org/GNOME/gnome-shell-sass.git
-31
View File
@@ -1,31 +0,0 @@
--- Creating a New Extension ---
To create a new extension, add a subdirectory in extensions.
Then create a Makefile.am like the one in example, replacing
the EXTENSION_ID with the basename of your extension, which
must match the UUID in metadata.json.
If you need additional files, add them to EXTENSION_EXTRA.
Then modify extensions/Makefile.am and configure.ac. It should
be pretty self-explanatory.
Don't forget to add any translatable file to po/POTFILES.in, and
then you're done.
The Gettext domain you should choose is gnome-shell-extensions,
not gnome-shell, unless you're sure there is the string you
need in gnome-shell.
--- Coding Style ---
Generally, we follow GJS coding style (you can find it at
http://git.gnome.org/browse/gjs/tree/doc/Style_Guide.txt), which
in short is: indent 4 spaces, no tabs, space after comma, no space
after function call.
The Emacs mode line for this
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
Imports should be at the top, in two groups, one for standard
imports (like imports.lang or imports.dbus) and introspection,
the other for Shell API. Within the same group, put everything
in alphabetic order.
+31
View File
@@ -0,0 +1,31 @@
## Creating a New Extension
To create a new extension, add a subdirectory in extensions. Then create
a meson.build from the provided [template](extensions/meson.build.template).
If you need additional sources, add them to extension_sources. Similarily add
GSettings schemas to extension_schemas and other files to extension_data.
Then modify the [toplevel Meson file](meson.build) to add the new
extension name in the appropriate set (that is one of classic_extensions,
default_extensions or all_extensions).
Don't forget to add any translatable file to po/POTFILES.in, and
then you're done.
The Gettext domain you should choose is gnome-shell-extensions,
not gnome-shell, unless you're sure there is the string you
need in gnome-shell.
## Coding Style
Generally, we follow [GJS coding style][coding-style], which in short is:
indent 4 spaces, no tabs, space after comma, no space after function call.
The Emacs mode line for this
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
Imports should be at the top, in two groups, one for standard
imports (like imports.lang or imports.dbus) and introspection,
the other for Shell API. Within the same group, put everything
in alphabetic order.
[coding-style]: https://gitlab.gnome.org/GNOME/gjs/blob/master/doc/Style_Guide.md
-52
View File
@@ -1,52 +0,0 @@
ACLOCAL_AMFLAGS = -I m4 ${ACLOCAL_FLAGS}
DIST_SUBDIRS = data extensions po
SUBDIRS = extensions po
if CLASSIC_MODE
SUBDIRS += data
endif
EXTRA_DIST = lib/convenience.js
DISTCHECK_CONFIGURE_FLAGS = --enable-extensions=all
include include.mk
zip-file: all
-rm -fR $(builddir)/_build
-rm -fR $(builddir)/zip-files
$(MKDIR_P) $(builddir)/_build; \
$(MKDIR_P) $(builddir)/zip-files; \
$(MAKE) install DESTDIR="$(abs_builddir)/_build"; \
for i in $(ENABLED_EXTENSIONS); do \
mv "$(builddir)/_build$(topextensiondir)/$${i}$(extensionbase)" "$(builddir)/_build/"; \
cp -r "$(builddir)/_build$(datadir)/locale" "$(builddir)/_build/$${i}$(extensionbase)"; \
cp "$(srcdir)/COPYING" -t "$(builddir)/_build/$${i}$(extensionbase)"; \
cp "$(srcdir)/NEWS" -t "$(builddir)/_build/$${i}$(extensionbase)"; \
if [ -f "$(builddir)/_build$(datadir)/glib-2.0/schemas/$(gschemabase).$${i}.gschema.xml" ]; then \
$(MKDIR_P) "$(builddir)/_build/$${i}$(extensionbase)/schemas"; \
mv "$(builddir)/_build$(datadir)/glib-2.0/schemas/$(gschemabase).$${i}.gschema.xml" "$(builddir)/_build/$${i}$(extensionbase)/schemas"; \
glib-compile-schemas "$(builddir)/_build/$${i}$(extensionbase)/schemas"; \
fi; \
(cd "$(builddir)/_build/$${i}$(extensionbase)"; \
zip -qr "$(abs_builddir)/zip-files/$${i}$(extensionbase).shell-extension.zip" .; \
); \
done
-rm -fR $(builddir)/_build
localprefix = $(HOME)/.local/share/gnome-shell/extensions
local-install: zip-file
for i in $(ENABLED_EXTENSIONS); do \
uuid="$${i}$(extensionbase)"; \
zip_file="$(abs_builddir)/zip-files/$${uuid}.shell-extension.zip"; \
if [ -d "$(localprefix)/$${uuid}" ]; then \
rm -fR "$(localprefix)/$${uuid}"; \
fi; \
$(MKDIR_P) $(localprefix)/$${uuid}; \
(cd $(localprefix)/$${uuid}; \
unzip -q $${zip_file}; \
); \
done
+500
View File
@@ -1,3 +1,503 @@
3.31.2
======
* Remove obsolete alternate-tab extension [Florian; #786496]
* Adjust to gnome-shell changes [Florian; #113]
Contributors:
Florian Müllner
3.30.1
======
* apps-menu: Fix height on HiDPI systems [Florian; #102]
* window-list: Only switch between windows on active workspace when scrolling
[Florian; #78]
Contributors:
Florian Müllner
3.30.0
======
* Bump version
3.29.91
=======
* Misc. bug fixes [Florian; #90]
Contributors:
Florian Müllner
3.29.90
=======
* Misc. bug fixes [Florian; #786496]
Contributors:
Florian Müllner
3.29.3
======
* Adjust to global.screen removal [Jonas; #759538]
Contributors:
Jonas Ådahl, Florian Müllner
3.29.2
======
* Misc. bug fixes [Florian; #69]
Contributors:
Florian Müllner
3.28.1
======
* Misc. bug fixes [Xiaoguang, Florian; #59, #62]
Contributors:
Florian Müllner, Xiaoguang Wang
Translators:
Dz Chen [zh_CN]
3.28.0
======
Contributors:
Florian Müllner, Xiaoguang Wang
Translators:
Aman Alam [pa], Bruce Cowan [en_GB]
3.27.92
=======
Contributors:
Florian Müllner
Translators:
Piotr Drąg [es], GNOME Translation Robot [gd], Daniel Șerbănescu [ro]
3.27.91
=======
* places-menu: Support unmounting ejectable places [Rémy; #17]
* apps-menu: Support separators and custom sort order [Florian; #27]
* Port to meson [Florian; #31, #45]
* window-list: Fix missing icons on wayland [Florian; #10]
* places-menu: Fix terminating gnome-shell with recent gjs [Florian; #44]
* auto-move: Make it work with wayland windows [Florian; #33]
* Classic theme fixes [Florian, Jonas; #26, #41, #39, #40]
* Require sassc for classic styling [Florian; !28]
* Misc. bug fixes [Piotr, Florian; #772211, #32, #30]
Contributors:
Jeremy Bicha, Piotr Drąg, Jonas Kümmerlin, Rémy Lefevre, Iñigo Martínez,
Florian Müllner
Translators:
Matej Urbančič [sl], Kjartan Maraas [nb]
3.27.1
======
* updated translations (ca@valencia)
3.26.1
======
* native-window-placement: Adjust to gnome-shell changes
* updated translations: el, fa, ru, sv
3.26.0
======
* updated translations (be, bg, ca, da, eu, fi, is, it, ko, lv, ml,
nl, pt_BR, vi, zh_TW)
3.25.91
=======
* updated translations (ca, fr, it, pl, pt_BR, sr, sr@latin, tr)
3.25.90
=======
* updated translations (es, gl, hr, hu, kk, sl, sv, sv)
3.25.4
======
* screenshot-window-sizer: Fix backward cycling
* updated translations (ar, be, ca, cs, de, fur, id, lt, pl, sk)
3.25.3
======
* places-menu: Use mount operation if necessary
* window-list: Respect MWM hints
* updated translations (es, fur, kk)
3.25.2
======
* places-menu: Make URI launching asynchronous
* updated translations (de, fur, hr, hu, id, sl)
3.25.1
======
* apps-menu: Mark copied launchers as trusted
* places-menu: Make icon lookup asynchronous
* updated translations (hr)
3.24.1
======
* apps-menu: Allow creating desktop launchers via DND
* updated translations (el, vi)
3.24.0
======
* updated translations (lv, tr)
3.23.92
=======
* update classic theme
* updated translations (be, ko, ca, da, cs, ru, lt)
3.23.91
=======
* updated translations (de, es, eu, fi, fr, fur, gl, hu, id, it, kk, nb, pl, pt_BR,
sk, sr, sr@latin, sv, uk, zh_TW)
3.23.90
=======
* window-list: Improve styling
* window-list: Hide workspace indicator when there's a single (static) workspace
* new translation (be)
3.23.2
======
* alternateTab: Don't take over 'switch-group' shortcut
* updated translations (zh_CN)
3.22.1
======
* window-list: Update icon on app changes
3.22.0
======
* updated translations (en_GB)
3.21.92
=======
* update style
* updated translations (pl, vi)
3.21.91
=======
* updated translations (pl)
3.21.90
=======
* updated translations (es, gu)
3.21.4
======
* apps-menu: Fix entries from non-standard AppDir directories
3.21.3
======
* adjust to gnome-shell changes
* updated translations (oc)
3.21.2
======
* version bump, nothing to see here
3.20.1
======
* update classic style
* updated translations (gd, oc)
3.20.0
======
* version bump, nothing to see here
3.19.92
=======
* version bump, nothing to see here
3.19.91
=======
* updated translations (oc)
3.19.90
=======
* version bump, nothing to see here
3.19.4
======
* screenshot-window-sizer: HiDPI support
* Fix gnome-shell component in classic session
* updated translations (lt)
3.19.3
======
* native-window-placement: Don't let border overlap title
* apps-menu: Fix handling of .desktop files in subdirectories
* updated translations (is)
3.19.2
======
* updated translations (gd)
3.19.1
======
* Fix some theme issues
3.18.1
======
* window-list: Fix accessibility of window buttons
* apps-menu: Fix unreliable highlight
* updated translations (ar)
3.18.0
======
* Bump version
3.17.92
=======
* places: Include DESKTOP when desktop icons are enabled
* updated translations (fa)
3.17.91
=======
* updated translations (nl, pl, zh_TW)
3.17.90
=======
* window-list: Improve application ordering
* workspace-indicator: Use consistent workspace numbering
3.17.4
======
* updated translations (fur)
3.17.3
======
* window-list: Adjust with text-scaling-factor
* classic style updates
* updated translations (pt, ro)
3.17.2
======
* updated translations (oc, pt, zh_CN)
3.17.1
======
* style updates
* updated translations (oc)
3.16.1
======
* window-list: Fix workspace indicators popup menu position
* apps-menu: Fix taking over panel-main-menu shortcut
* updated translations (et, ja, lv)
3.16.0
======
* updated translations (ca)
3.15.92
=======
* classic: Update theme
* update for mutter API changes
* updated translations (bg, bs, da, fi, pa, ru, sr, sr@latin, tg)
3.15.91
=======
* classic: Update theme
* systemMonitor extension was removed, as the message tray where it
put its indicator no longer exists
* window-list: Adjust for gnome-shell changes
* updated translations (gl, it, kk, ko, lt, pl, sk, uk, zh_TW)
3.15.90
=======
* classic: Visual refresh based on new shell theme
* window-list: Adjust for gnome-shell changes
* updated translations (an, el, eo, eu, fr, he, is, sv, tr)
3.15.4
======
* window-list: Improve interaction with system modal dialogs
* updated translations (cs, de, es, eu, fur, hu, id, nb, pt_BR, ru, sl, vi)
3.15.3.1
========
* adjust to gnome-shell change
3.15.3
======
* classic-mode: Add high-contrast theme variant, drop .desktop file
* places-menu: Fix error when XDG user directories are not set up
* window-list: Add option to show on all monitors
* updated translations (eu, hu, kk, ro, tr)
3.15.2
======
* removable-drive, user-theme, window-list: Update for gnome-shell changes
* apps-menu: Fix some visual glitches
* Fix classic mode style
* updated translations (an, cs, he, vi)
3.15.1
======
* updated translations (es, nb)
3.14.1
======
* alternateTab: Fix dismissing popup with Escape
* some improvements to the window-list
(spacing in app buttons, no flash when closing windows with auto-grouping)
* updated translations (lv, it, pt, bg)
3.14.0
======
* updated translations (bn_IN, hi, kn, sr, sr@latin, uk)
3.13.92
=======
* new extension: screenshot-window-sizer
* window-list: Don't add sticky windows more than once
* updated translations (da, de, fi, ko, mr, ms, ne, pa, pl, sk, sv, ta, te, tr)
3.13.91
=======
* window-list: restore fitts'ability of workspace button
* updated for gnome-shell changes
* updated translations (cs, kk, fr, or, fa, ja, gu, id)
3.13.90
=======
* updated translations (as, ca, eu, nl, zh_CN, zh_HK, zh_TW)
3.13.4
======
* Updated for gnome-shell changes
* updated translations (el, gl, ru)
3.13.3
======
* Tweak preference UIs some more
* Fix classic mode schema overrides
* updated translations (es, he, hu, lt, nb, pt_BR, sl, tr)
3.13.2
======
* Fix sorting of grouped buttons in window list
* Tweak preference UIs
* updated translations (en_GB)
3.13.1
======
* add DesktopNames key to the classic session file
* classic theme: remove rounded corners from tile previews
* window-list: don't shift message tray on other monitors
* auto-move-windows: several fixes and updates for api changes
* launch-new-instances: updates for api changes
* updated translations (ja, km)
3.12.0
======
* updated translations (zh_HK, zh_TW)
3.11.92
=======
* nothing to see here, move on
3.11.91
=======
* updated translations (ko, fur)
3.11.90
=======
* several fixes and improvements to the window-list
(can be scrolled, works correctly with the OSD
keyboard, filters skip-taskbar windows, does not
force all notifications to bold)
* drive-menu fixed not to show shadowed mounts
* updates for gnome-shell changes (launch-new-instance,
auto-move-windows, places-menu)
* build system fixes for systems without /bin/bash
* updated translations (or, tr, uk)
3.11.5
======
* updates for gnome-shell changes
* updated translations (kn)
3.11.4
======
* classic mode now supports session saving
* updates for gnome-shell changes
* updated translations (ar, kn)
3.11.3
======
* workspace-indicator is vertically aligned now
* updated translations (ar, eo, ta, te)
3.11.2
======
* updated translations (zh_CN)
3.11.1
======
* ignore shadowed mounts in drive-menu extension
* updates for gnome-shell/gjs changes
* updated translations (el, th)
3.10.1
======
* updated translations (af, ca, ca@valencia, de, et, eu, fa,
hu, lt, lv, nb, nl, pa, pt, sk, sr, sr@latin, tr)
3.10.0
======
* updated translations (as, cs, da, es, et, fi, fr, gl,
he, id, it, kk, lt, lv, pa, pl, pt, pt_BR, ru, sl, tg,
uk, zh_HK, zh_TW)
3.9.92
======
* more updates and fixes for gnome-shell master changes
and regressions (systemMonitor, window-list, apps-menu)
* lots of updated translations (ar, as, cs, da, de, el, es,
eu, fi, gl, he, hu, it, ja, kk, ko, lv, nb, nl, pa, pl,
pt_BR, ru, sk, sr, sr@latin, ta, tg)
3.9.91
======
* update the classic mode session and theme to work with the
new system menu
* the usual round of updates and fixes for gnome-shell
API changes
* updated translations (de, it, lt, nl, pl, pt_BR, sk,
zh_HK, zh_TW)
3.9.90
======
* xrandr-indicator was removed, as the implementation
was incompatible with the new DisplayConfig mutter API
* various extensions were updated for the 3.9.90 gnome-shell API
* updated translations (cs, es, fur, gl, he, hu, id, ja, sl, tg,
zh_CN, zh_HK, zh_TW)
3.9.5
=====
* alternative-status-menu was removed entirely, as
it does not fit in the designs of the new unified
status menu
* updated translations (as, gu, it, ru)
3.9.4
=====
* apps-menu: fixed handling of hot corner in case
of screen reconfiguration
* alternative-status-menu now correctly honors polkit
for hibernation
* user-menu now loads themes from $XDG_DATA_HOME too
* translation updates (de, id, pt_BR, vi, zh_CN, ml)
3.9.3 3.9.3
===== =====
* classic mode mini extensions were replaced with a * classic mode mini extensions were replaced with a
-92
View File
@@ -1,92 +0,0 @@
GNOME Shell Extensions is a collection of extensions providing additional
and optional functionality to GNOME Shell.
Since GNOME Shell is not API stable, extensions work only against a very
specific version of the shell, usually the same as this package (see
"configure --version"). Also, since extensions are built from many
individual contributors, we cannot guarantee stability or quality for any
specific extension.
For these reasons, distributions are advised to avoid installing or packaging
this module by defaul.
For more information about GNOME Shell Extensions
http://live.gnome.org/GnomeShell/Extensions
For general information about GNOME Shell
http://live.gnome.org/GnomeShell
Bugs should be reported at http://bugzilla.gnome.org against the 'gnome-shell'
product, with the 'extensions' component.
Extensions
==========
alternate-tab
Lets you use classic Alt+Tab (window-based instead of app-based) in GNOME Shell.
alternative-status-menu
For those who want a power off item visible at all the time, replaces GNOME Shell
status menu with one featuring separate Suspend and Power Off. Adds the ability to
hibernate as well.
apps-menu
Lets you reach an application using gnome 2.x style menu on the panel.
auto-move-windows
Lets you manage your workspaces more easily, assigning a specific workspace to
each application as soon as it creates a window, in a manner configurable with a
GSettings key.
dock
Shows a dock-style task switcher on the right side of the screen.
drive-menu
Shows a status menu for rapid unmount and power off of external storage devices
(i.e. pendrives)
example
A minimal example illustrating how to write extensions.
gajim
Integration with Gajim, a Jabber/XMPP instant messaging client.
native-window-placement
An alternative algorithm for layouting the thumbnails in the windows overview, that
more closely reflects the actual positions and sizes.
places-menu
Shows a status Indicator for navigating to Places.
systemMonitor
An message tray indicator showing CPU and memory loads.
user-theme
Loads a shell theme from ~/.themes/<name>/gnome-shell.
windowsNavigator
Allow keyboard selection of windows and workspaces in overlay mode.
xrandr-indicator
Replace the GTK+ based indicator from gnome-settings-daemon with
a native one. Lets the user rotate the laptop monitor and open
display preferences quickly.
License
=======
GNOME Shell Extensions are distributed under the terms of the GNU General Public License,
version 2 or later. See the COPYING file for details.
Individual extensions may be licensed under different terms, see each source
file for details.
+76
View File
@@ -0,0 +1,76 @@
# GNOME Shell Extensions
GNOME Shell Extensions is a collection of extensions providing additional
and optional functionality to GNOME Shell.
Since GNOME Shell is not API stable, extensions work only against a very
specific version of the shell, usually the same as this package (see
"configure --version"). The extensions in this package are supported by GNOME
and will be updated to reflect future API changes in GNOME Shell.
The GNOME wiki has more information about [GNOME Shell Extensions][project-page],
as well as some general information about [GNOME Shell][shell-page].
Bugs should be reported to the GNOME [bug tracking system][bug-tracker].
## Extensions
* apps-menu
Lets you reach an application using gnome 2.x style menu on the panel.
* auto-move-windows
Lets you manage your workspaces more easily, assigning a specific workspace to
each application as soon as it creates a window, in a manner configurable with a
GSettings key.
* drive-menu
Shows a status menu for rapid unmount and power off of external storage devices
(i.e. pendrives)
* launch-new-instance
Changes application icons to always launch a new instance when activated.
* native-window-placement
An alternative algorithm for layouting the thumbnails in the windows overview, that
more closely reflects the actual positions and sizes.
* places-menu
Shows a status Indicator for navigating to Places.
* screenshot-window-sizer
Adds a shortcut for resizing the focus window to a size that is suitable for GNOME Software screenshots
* user-theme
Loads a shell theme from ~/.themes/<name>/gnome-shell.
* window-list
Adds a bottom panel with a traditional window list.
* windowsNavigator
Allow keyboard selection of windows and workspaces in overlay mode.
* workspace-indicator
Adds a simple workspace switcher to the top bar.
## License
GNOME Shell Extensions are distributed under the terms of the GNU General
Public License, version 2 or later. See the [COPYING file][license] for details.
Individual extensions may be licensed under different terms, see each source
file for details.
[project-page]: https://wiki.gnome.org/Projects/GnomeShell/Extensions
[shell-page]: https://wiki.gnome.org/Projects/GnomeShell
[bug-tracker]: https://gitlab.gnome.org/GNOME/gnome-shell-extensions/issues
[license]: COPYING
-20
View File
@@ -1,20 +0,0 @@
#!/bin/bash
# Run this to generate all the initial makefiles, etc.
srcdir=`dirname $0`
test -z "$srcdir" && srcdir=.
PKG_NAME="gnome-shell-extensions"
test -f $srcdir/configure.ac || {
echo -n "**Error**: Directory "\`$srcdir\'" does not look like the"
echo " top-level gnome-shell-extensions directory"
exit 1
}
which gnome-autogen.sh || {
echo "You need to install gnome-common from GNOME Git (or from"
echo "your OS vendor's package manager)."
exit 1
}
. gnome-autogen.sh
-3
View File
@@ -1,3 +0,0 @@
install-sh
mkinstalldirs
missing
-106
View File
@@ -1,106 +0,0 @@
AC_PREREQ(2.63)
AC_INIT([gnome-shell-extensions],[3.9.3],[https://bugzilla.gnome.org/enter_bug.cgi?product=gnome-shell&component=extensions])
AC_CONFIG_MACRO_DIR([m4])
AC_CONFIG_AUX_DIR([config])
AM_INIT_AUTOMAKE([1.10 dist-xz no-dist-gzip foreign tar-ustar])
m4_ifdef([AM_SILENT_RULES],[AM_SILENT_RULES([yes])])
GETTEXT_PACKAGE=gnome-shell-extensions
AC_SUBST(GETTEXT_PACKAGE)
AC_DEFINE_UNQUOTED(GETTEXT_PACKAGE, "$GETTEXT_PACKAGE",
[The prefix for our gettext translation domains.])
IT_PROG_INTLTOOL(0.26)
PKG_PROG_PKG_CONFIG([0.22])
GLIB_GSETTINGS
SHELL_VERSION="$PACKAGE_VERSION"
shell_major=`echo "$PACKAGE_VERSION" | cut -d'.' -f1`
shell_minor=`echo "$PACKAGE_VERSION" | cut -d'.' -f2`
if test "$(($shell_minor % 2))" -eq 0; then
SHELL_VERSION="$shell_major.$shell_minor"
fi
AC_SUBST([SHELL_VERSION])
dnl keep this in alphabetic order
CLASSIC_EXTENSIONS="apps-menu places-menu alternate-tab launch-new-instance window-list"
DEFAULT_EXTENSIONS="$CLASSIC_EXTENSIONS alternative-status-menu drive-menu windowsNavigator workspace-indicator"
ALL_EXTENSIONS="$DEFAULT_EXTENSIONS auto-move-windows example native-window-placement systemMonitor user-theme xrandr-indicator"
AC_SUBST(CLASSIC_EXTENSIONS, [$CLASSIC_EXTENSIONS])
AC_SUBST(ALL_EXTENSIONS, [$ALL_EXTENSIONS])
AC_ARG_ENABLE([extensions],
[AS_HELP_STRING([--enable-extensions],[Space separated list of extensions to enable.
The default is to build and distribute all extensions that can be installed in the home directory and have no external depedencies.
Use "all" to enable all available extensions, or "classic-mode" to enable extensions that restore GNOME 2 functionality.])],
[],
[enable_extensions=$DEFAULT_EXTENSIONS]
)
if test x"$enable_extensions" = xall; then
enable_extensions="$ALL_EXTENSIONS"
enable_classic_mode_default=yes
elif test x"$enable_extensions" = xclassic-mode; then
enable_extensions="$CLASSIC_EXTENSIONS"
enable_classic_mode_default=yes
else
enable_classic_mode_default=no
fi
AC_ARG_ENABLE([classic-mode],
[AS_HELP_STRING([--enable-classic-mode],[Enable installing data files for classic mode.
Defaults to yes if enabling all or classic-mode extensions, and no otherwise.])],
[],
[enable_classic_mode=$enable_classic_mode_default])
AM_CONDITIONAL([CLASSIC_MODE], [test x"$enable_classic_mode" != xno])
ENABLED_EXTENSIONS=
for e in $enable_extensions; do
case $e in
systemMonitor)
PKG_CHECK_MODULES(GTOP, libgtop-2.0 >= 2.28.3,
[ENABLED_EXTENSIONS="$ENABLED_EXTENSIONS $e"],
[AC_MSG_WARN([libgtop-2.0 not found, disabling systemMonitor])])
;;
xrandr-indicator)
PKG_CHECK_MODULES(GNOME_DESKTOP, gnome-desktop-3.0 >= 2.91.6,
[ENABLED_EXTENSIONS="$ENABLED_EXTENSIONS $e"],
[AC_MSG_WARN([gnome-desktop-3.0 not found, disabling xrandr-indicator])])
;;
dnl keep this in alphabetic order
alternate-tab|alternative-status-menu|apps-menu|auto-move-windows|drive-menu|example|launch-new-instance|native-window-placement|places-menu|user-theme|window-list|windowsNavigator|workspace-indicator)
ENABLED_EXTENSIONS="$ENABLED_EXTENSIONS $e"
;;
*)
AC_MSG_ERROR([invalid extension $e])
esac
done
AC_SUBST(ENABLED_EXTENSIONS, [$ENABLED_EXTENSIONS])
dnl Please keep this sorted alphabetically
AC_CONFIG_FILES([
data/Makefile
extensions/alternate-tab/Makefile
extensions/alternative-status-menu/Makefile
extensions/apps-menu/Makefile
extensions/auto-move-windows/Makefile
extensions/drive-menu/Makefile
extensions/example/Makefile
extensions/launch-new-instance/Makefile
extensions/native-window-placement/Makefile
extensions/places-menu/Makefile
extensions/systemMonitor/Makefile
extensions/user-theme/Makefile
extensions/window-list/Makefile
extensions/windowsNavigator/Makefile
extensions/workspace-indicator/Makefile
extensions/xrandr-indicator/Makefile
extensions/Makefile
Makefile
po/Makefile.in
])
AC_OUTPUT
@@ -0,0 +1,9 @@
[org.gnome.mutter:GNOME-Classic]
dynamic-workspaces=false
[org.gnome.desktop.wm.preferences:GNOME-Classic]
button-layout='appmenu:minimize,maximize,close'
[org.gnome.desktop.wm.keybindings:GNOME-Classic]
switch-applications=[]
switch-windows=['<Super>Tab','<Alt>Tab']
+2
View File
@@ -0,0 +1,2 @@
To update the gnome-shell-sass submodule to latest upstream commit:
git submodule update --rebase
-72
View File
@@ -1,72 +0,0 @@
include $(top_srcdir)/include.mk
desktopdir = $(datadir)/applications
desktop_in_in_files = gnome-shell-classic.desktop.in.in
desktop_in_files = $(desktop_in_in_files:.desktop.in.in=.desktop.in)
desktop_DATA = $(desktop_in_files:.desktop.in=.desktop)
sessiondir = $(datadir)/gnome-session/sessions
session_in_in_files = gnome-classic.session.desktop.in.in
session_in_files = $(session_in_in_files:.session.desktop.in.in=.session.desktop.in)
session_DATA = $(session_in_files:.session.desktop.in=.session)
xsessiondir = $(datadir)/xsessions
xsession_in_files = gnome-classic.desktop.in
xsession_DATA = $(xsession_in_files:.desktop.in=.desktop)
modedir = $(datadir)/gnome-shell/modes
mode_in_files = classic.json.in
mode_DATA = $(mode_in_files:.json.in=.json)
themedir = $(datadir)/gnome-shell/theme
theme_DATA = \
$(srcdir)/classic-process-working.svg \
$(srcdir)/classic-toggle-off-intl.svg \
$(srcdir)/classic-toggle-off-us.svg \
$(srcdir)/classic-toggle-on-intl.svg \
$(srcdir)/classic-toggle-on-us.svg \
$(srcdir)/gnome-classic.css \
$(NULL)
gsettings_in_files = org.gnome.shell.extensions.classic-overrides.gschema.xml.in
gsettings_SCHEMAS = $(gsettings_in_files:.xml.in=.xml)
@INTLTOOL_XML_NOMERGE_RULE@
@GSETTINGS_RULES@
%.desktop.in:%.desktop.in.in
$(AM_V_GEN) sed \
-e "s|\@bindir\@|$(bindir)|" \
-e "s|\@VERSION\@|$(VERSION)|" \
$< > $@
comma:=,
empty:=
space:= $(empty) $(empty)
extensions:=$(patsubst %,\"%$(extensionbase)\",$(CLASSIC_EXTENSIONS))
extension_list:=$(subst $(space),$(comma),$(extensions))
%.json:%.json.in
$(AM_V_GEN) sed \
-e "s|\@CLASSIC_EXTENSIONS\@|$(extension_list)|g" \
$< > $@
%.session: %.session.desktop.in $(INTLTOOL_MERGE) $(wildcard $(top_srcdir)/po/*.po) ; LC_ALL=C $(INTLTOOL_MERGE) -d -u -c $(top_builddir)/po/.intltool-merge-cache $(top_srcdir)/po $< $@
@INTLTOOL_DESKTOP_RULE@
EXTRA_DIST = \
$(desktop_in_in_files) \
$(session_in_in_files) \
$(xsession_in_files) \
$(mode_in_files) \
$(gsettings_in_files) \
$(theme_DATA) \
$(NULL)
CLEANFILES = \
$(desktop_DATA) \
$(session_DATA) \
$(xsession_DATA) \
$(mode_DATA) \
$(gsettings_SCHEMAS) \
$(NULL)
+178
View File
@@ -0,0 +1,178 @@
<?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="24"
height="24"
id="svg10621"
version="1.1"
inkscape:version="0.91 r13725"
sodipodi:docname="calendar-today.svg">
<defs
id="defs10623">
<radialGradient
inkscape:collect="always"
xlink:href="#linearGradient34508-1-3"
id="radialGradient99561-1"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(0.72146227,0,0,0.27484277,14.205424,21.754717)"
cx="51"
cy="30"
fx="51"
fy="30"
r="42" />
<linearGradient
inkscape:collect="always"
id="linearGradient34508-1-3">
<stop
style="stop-color:#ffffff;stop-opacity:1;"
offset="0"
id="stop34510-1-9" />
<stop
style="stop-color:#ffffff;stop-opacity:0;"
offset="1"
id="stop34512-4-5" />
</linearGradient>
<radialGradient
r="42"
fy="30"
fx="51"
cy="30"
cx="51"
gradientTransform="matrix(0.72146227,0,0,0.27484277,14.205424,21.754717)"
gradientUnits="userSpaceOnUse"
id="radialGradient10592"
xlink:href="#linearGradient34508-1-3"
inkscape:collect="always" />
<radialGradient
inkscape:collect="always"
xlink:href="#linearGradient34508-1-3"
id="radialGradient3770"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(0.72146227,0,0,0.27484277,14.205424,21.754717)"
cx="51"
cy="30"
fx="51"
fy="30"
r="42" />
<radialGradient
inkscape:collect="always"
xlink:href="#linearGradient34508-1-3"
id="radialGradient3001"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(0.72146227,0,0,0.27484277,14.205424,21.754717)"
cx="51"
cy="30"
fx="51"
fy="30"
r="42" />
<radialGradient
inkscape:collect="always"
xlink:href="#linearGradient34508-1-3"
id="radialGradient3007"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(0.72146227,0,0,0.27484277,14.205424,21.754717)"
cx="51"
cy="30"
fx="51"
fy="30"
r="42" />
<radialGradient
inkscape:collect="always"
xlink:href="#linearGradient34508-1-3"
id="radialGradient3067"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(0.72146227,0,0,0.27484277,14.205424,21.754717)"
cx="51"
cy="30"
fx="51"
fy="30"
r="42" />
<radialGradient
inkscape:collect="always"
xlink:href="#linearGradient34508-1-3"
id="radialGradient3072"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(0.72146227,0,0,0.27484277,14.205424,21.754717)"
cx="51"
cy="30"
fx="51"
fy="30"
r="42" />
<radialGradient
inkscape:collect="always"
xlink:href="#linearGradient34508-1-3"
id="radialGradient2997"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(0.72146227,0,0,0.27484277,14.205424,21.754717)"
cx="51"
cy="30"
fx="51"
fy="30"
r="42" />
</defs>
<sodipodi:namedview
id="base"
pagecolor="#d3d3d3"
bordercolor="#666666"
borderopacity="1.0"
inkscape:pageopacity="0"
inkscape:pageshadow="2"
inkscape:zoom="8"
inkscape:cx="-55.349829"
inkscape:cy="-31.442864"
inkscape:document-units="px"
inkscape:current-layer="layer1"
showgrid="false"
fit-margin-top="0"
fit-margin-left="0"
fit-margin-right="0"
fit-margin-bottom="0"
inkscape:window-width="2133"
inkscape:window-height="1241"
inkscape:window-x="238"
inkscape:window-y="89"
inkscape:window-maximized="0"
borderlayer="true"
inkscape:showpageshadow="false">
<inkscape:grid
type="xygrid"
id="grid3109"
empspacing="5"
visible="true"
enabled="true"
snapvisiblegridlinesonly="true" />
</sodipodi:namedview>
<metadata
id="metadata10626">
<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></dc:title>
</cc:Work>
</rdf:RDF>
</metadata>
<g
inkscape:label="Layer 1"
inkscape:groupmode="layer"
id="layer1"
transform="translate(-469.08263,-537.99307)">
<circle
style="color:#000000;clip-rule:nonzero;display:inline;overflow:visible;visibility:visible;opacity:1;isolation:auto;mix-blend-mode:normal;color-interpolation:sRGB;color-interpolation-filters:linearRGB;solid-color:#000000;solid-opacity:1;fill:#555753;fill-opacity:0.23756906;fill-rule:nonzero;stroke:none;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;marker-start:none;marker-mid:none;marker-end:none;paint-order:normal;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto;enable-background:accumulate"
id="path7305"
cx="481.57138"
cy="559.4649"
r="1.5" />
</g>
</svg>

After

Width:  |  Height:  |  Size: 5.6 KiB

File diff suppressed because it is too large Load Diff

Before

Width:  |  Height:  |  Size: 22 KiB

After

Width:  |  Height:  |  Size: 100 KiB

+84 -72
View File
@@ -14,20 +14,10 @@
height="22" height="22"
id="svg10865" id="svg10865"
version="1.1" version="1.1"
inkscape:version="0.48.4 r9939" inkscape:version="0.91 r13725"
sodipodi:docname="toggle-off-us.svg"> sodipodi:docname="classic-toggle-off-intl.svg">
<defs <defs
id="defs10867"> id="defs10867">
<linearGradient
inkscape:collect="always"
xlink:href="#linearGradient62852-6-5"
id="linearGradient62981-1-1"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(0.85639946,0,0,0.81059641,27.810405,92.069729)"
x1="740"
y1="486.10501"
x2="740"
y2="505.3204" />
<linearGradient <linearGradient
id="linearGradient62852-6-5"> id="linearGradient62852-6-5">
<stop <stop
@@ -77,16 +67,6 @@
effect="spiro" effect="spiro"
id="path-effect62829-6-8-0" id="path-effect62829-6-8-0"
is_visible="true" /> is_visible="true" />
<linearGradient
inkscape:collect="always"
xlink:href="#linearGradient62821-5-8-1"
id="linearGradient62864-0-3-1"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(1.3066667,0,0,1,-197.64667,0)"
x1="702.58966"
y1="484.49405"
x2="702.58966"
y2="507.42715" />
<linearGradient <linearGradient
id="linearGradient62821-5-8-1"> id="linearGradient62821-5-8-1">
<stop <stop
@@ -108,6 +88,76 @@
id="linearGradient11647" id="linearGradient11647"
xlink:href="#linearGradient62821-5-8-1" xlink:href="#linearGradient62821-5-8-1"
inkscape:collect="always" /> inkscape:collect="always" />
<clipPath
clipPathUnits="userSpaceOnUse"
id="clipPath65663">
<rect
style="color:#000000;display:inline;overflow:visible;visibility:visible;fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1;marker:none;enable-background:new"
id="rect65665"
width="96.999924"
height="24.292892"
x="708.71954"
y="406.96973"
rx="3.1139846"
ry="1.9595497"
inkscape:export-filename="/home/lapo.fedora/SparkleShare/gnome-mockups/content selection/content-selection.png"
inkscape:export-xdpi="90"
inkscape:export-ydpi="90" />
</clipPath>
<linearGradient
inkscape:collect="always"
xlink:href="#linearGradient5378-2-5-9-9-0-80-7-6-8-4-5-7-3-6-2-9"
id="linearGradient65582"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(0.5250827,0,0,0.72144839,620.16092,156.4917)"
x1="207.17195"
y1="497.39584"
x2="207.17195"
y2="531.48669" />
<linearGradient
inkscape:collect="always"
id="linearGradient5378-2-5-9-9-0-80-7-6-8-4-5-7-3-6-2-9">
<stop
style="stop-color:#f4f6f4;stop-opacity:1"
offset="0"
id="stop5380-6-1-1-9-3-6-3-6-45-6-4-4-9-9-8-9" />
<stop
style="stop-color:#d7dad7;stop-opacity:1"
offset="1"
id="stop5382-06-3-6-4-2-4-6-8-0-9-6-8-7-7-6-7" />
</linearGradient>
<linearGradient
inkscape:collect="always"
id="linearGradient65584">
<stop
style="stop-color:#f1f1f1;stop-opacity:1"
offset="0"
id="stop65586" />
<stop
style="stop-color:#a7aba7;stop-opacity:0;"
offset="1"
id="stop65588" />
</linearGradient>
<linearGradient
inkscape:collect="always"
xlink:href="#linearGradient5378-2-5-9-9-0-80-7-6-8-4-5-7-3-6-2-9"
id="linearGradient65582-5"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(0.5250827,0,0,0.72144839,-75.348673,-359.16458)"
x1="207.17195"
y1="497.39584"
x2="207.17195"
y2="531.48669" />
<linearGradient
inkscape:collect="always"
xlink:href="#linearGradient65584"
id="linearGradient65590-6"
x1="716.62506"
y1="537.23358"
x2="716.62506"
y2="535.23358"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(1.0139469,0,0,1.0139469,-705.52354,-521.99915)" />
</defs> </defs>
<sodipodi:namedview <sodipodi:namedview
id="base" id="base"
@@ -117,8 +167,8 @@
inkscape:pageopacity="0.0" inkscape:pageopacity="0.0"
inkscape:pageshadow="2" inkscape:pageshadow="2"
inkscape:zoom="1" inkscape:zoom="1"
inkscape:cx="-133.20351" inkscape:cx="23.565368"
inkscape:cy="20.84411" inkscape:cy="19.596892"
inkscape:document-units="px" inkscape:document-units="px"
inkscape:current-layer="g62929" inkscape:current-layer="g62929"
showgrid="false" showgrid="false"
@@ -129,8 +179,8 @@
inkscape:bbox-paths="true" inkscape:bbox-paths="true"
inkscape:snap-others="false" inkscape:snap-others="false"
inkscape:window-width="2560" inkscape:window-width="2560"
inkscape:window-height="1380" inkscape:window-height="1342"
inkscape:window-x="1600" inkscape:window-x="0"
inkscape:window-y="28" inkscape:window-y="28"
inkscape:window-maximized="1" inkscape:window-maximized="1"
showborder="false"> showborder="false">
@@ -146,7 +196,7 @@
<dc:format>image/svg+xml</dc:format> <dc:format>image/svg+xml</dc:format>
<dc:type <dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
<dc:title></dc:title> <dc:title />
</cc:Work> </cc:Work>
</rdf:RDF> </rdf:RDF>
</metadata> </metadata>
@@ -166,7 +216,7 @@
transform="translate(0,30)" transform="translate(0,30)"
id="g62931"> id="g62931">
<rect <rect
style="fill:url(#linearGradient62864-0-3-1);fill-opacity:1;stroke:#a6a8a6;stroke-width:1;stroke-linecap:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;color:#000000;color-interpolation:sRGB;color-interpolation-filters:linearRGB;fill-rule:nonzero;stroke-linejoin:miter;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;clip-rule:nonzero" style="fill:#cecece;fill-opacity:1;stroke:#a7a7a7;stroke-width:1;stroke-linecap:butt;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;color:#000000;color-interpolation:sRGB;color-interpolation-filters:linearRGB;fill-rule:nonzero;stroke-linejoin:miter;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:new;clip-rule:nonzero;opacity:1;isolation:auto;mix-blend-mode:normal;solid-color:#000000;solid-opacity:1;marker-start:none;marker-mid:none;marker-end:none;paint-order:normal;filter-blend-mode:normal;filter-gaussianBlur-deviation:0;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto"
id="rect62935" id="rect62935"
width="63.856125" width="63.856125"
height="21.093594" height="21.093594"
@@ -175,7 +225,7 @@
rx="2" rx="2"
ry="2" /> ry="2" />
<rect <rect
style="fill:url(#linearGradient62981-1-1);fill-opacity:1;stroke:#777b7a;stroke-width:1;stroke-linecap:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" style="fill:url(#linearGradient65582);fill-opacity:1;stroke:#a7a7a7;stroke-width:0.97313344;stroke-linecap:butt;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline;color:#000000;clip-rule:nonzero;overflow:visible;visibility:visible;opacity:1;isolation:auto;mix-blend-mode:normal;color-interpolation:sRGB;color-interpolation-filters:linearRGB;solid-color:#000000;solid-opacity:1;fill-rule:nonzero;stroke-linejoin:miter;stroke-dashoffset:0;marker:none;marker-start:none;marker-mid:none;marker-end:none;paint-order:normal;filter-blend-mode:normal;filter-gaussianBlur-deviation:0;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto;enable-background:accumulate"
id="rect62937" id="rect62937"
width="29.97398" width="29.97398"
height="17.022524" height="17.022524"
@@ -185,56 +235,18 @@
ry="1" /> ry="1" />
<g <g
transform="translate(-38.048674,-1.9445437)" transform="translate(-38.048674,-1.9445437)"
id="g62939"> id="g62939" />
<rect
ry="1"
rx="1"
y="492"
x="695"
height="8"
width="2"
id="rect62941"
style="fill:#e8e8e5;fill-opacity:1;stroke:none;display:inline" />
<rect
ry="1"
rx="1"
y="492"
x="699"
height="8"
width="2"
id="rect62943"
style="fill:#e8e8e5;fill-opacity:1;stroke:none;display:inline" />
<rect
ry="1"
rx="1"
y="492"
x="703"
height="8"
width="2"
id="rect62945"
style="fill:#e8e8e5;fill-opacity:1;stroke:none;display:inline" />
</g>
<path <path
inkscape:connector-curvature="0" inkscape:connector-curvature="0"
inkscape:original-d="m 647.78624,486.57192 27.94632,0" inkscape:original-d="m 647.78241,486.57192 27.73523,0"
inkscape:path-effect="#path-effect62989-8-0" inkscape:path-effect="#path-effect62989-8-0"
id="path62947" id="path62947"
d="m 647.78624,486.57192 27.94632,0" d="m 647.78241,486.57192 27.73523,0"
style="fill:none;stroke:#ffffff;stroke-width:1px;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1" /> style="fill:none;stroke:#ffffff;stroke-width:1px;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1" />
</g> </g>
<g <g
id="g11665" id="g11665"
transform="matrix(0.78906097,0,0,0.78906097,178.78814,111.57844)" /> transform="matrix(0.78906097,0,0,0.78906097,178.78814,111.57844)" />
<path
style="fill:none;stroke:#ffffff;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
transform="translate(642.41421,514.02037)"
d="m 55,11.875 a 4.625,4.625 0 1 1 -9.25,0 4.625,4.625 0 1 1 9.25,0 z"
sodipodi:ry="4.625"
sodipodi:rx="4.625"
sodipodi:cy="11.875"
sodipodi:cx="50.375"
id="path3786"
sodipodi:type="arc" />
<path <path
sodipodi:type="arc" sodipodi:type="arc"
id="path3016" id="path3016"
@@ -242,9 +254,9 @@
sodipodi:cy="11.875" sodipodi:cy="11.875"
sodipodi:rx="4.625" sodipodi:rx="4.625"
sodipodi:ry="4.625" sodipodi:ry="4.625"
d="m 55,11.875 a 4.625,4.625 0 1 1 -9.25,0 4.625,4.625 0 1 1 9.25,0 z" d="M 55,11.875 A 4.625,4.625 0 0 1 50.375,16.5 4.625,4.625 0 0 1 45.75,11.875 4.625,4.625 0 0 1 50.375,7.25 4.625,4.625 0 0 1 55,11.875 Z"
transform="translate(642.41421,512.02037)" transform="translate(642.41421,512.02037)"
style="fill:none;stroke:#555753;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" /> style="fill:none;stroke:#2e3436;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" />
</g> </g>
</g> </g>
</svg> </svg>

Before

Width:  |  Height:  |  Size: 8.1 KiB

After

Width:  |  Height:  |  Size: 9.5 KiB

+40 -73
View File
@@ -14,20 +14,10 @@
height="22" height="22"
id="svg10865" id="svg10865"
version="1.1" version="1.1"
inkscape:version="0.48+devel r12050" inkscape:version="0.91 r13725"
sodipodi:docname="toggle-off-us.svg"> sodipodi:docname="classic-toggle-off-us.svg">
<defs <defs
id="defs10867"> id="defs10867">
<linearGradient
inkscape:collect="always"
xlink:href="#linearGradient62852-6-5"
id="linearGradient62981-1-1"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(0.85639946,0,0,0.81059641,27.810405,92.069729)"
x1="740"
y1="486.10501"
x2="740"
y2="505.3204" />
<linearGradient <linearGradient
id="linearGradient62852-6-5"> id="linearGradient62852-6-5">
<stop <stop
@@ -77,16 +67,6 @@
effect="spiro" effect="spiro"
id="path-effect62829-6-8-0" id="path-effect62829-6-8-0"
is_visible="true" /> is_visible="true" />
<linearGradient
inkscape:collect="always"
xlink:href="#linearGradient62821-5-8-1"
id="linearGradient62864-0-3-1"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(1.3066667,0,0,1,-197.64667,0)"
x1="702.58966"
y1="484.49405"
x2="702.58966"
y2="507.42715" />
<linearGradient <linearGradient
id="linearGradient62821-5-8-1"> id="linearGradient62821-5-8-1">
<stop <stop
@@ -108,6 +88,32 @@
id="linearGradient11647" id="linearGradient11647"
xlink:href="#linearGradient62821-5-8-1" xlink:href="#linearGradient62821-5-8-1"
inkscape:collect="always" /> inkscape:collect="always" />
<linearGradient
inkscape:collect="always"
xlink:href="#linearGradient5378-2-5-9-9-0-80-7-6-8-4-5-7-3-6-2-9"
id="linearGradient65582"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(0.5250827,0,0,0.72144839,620.16092,156.4917)"
x1="207.17195"
y1="497.39584"
x2="207.17195"
y2="531.48669" />
<linearGradient
inkscape:collect="always"
id="linearGradient5378-2-5-9-9-0-80-7-6-8-4-5-7-3-6-2-9">
<stop
style="stop-color:#f4f6f4;stop-opacity:1"
offset="0"
id="stop5380-6-1-1-9-3-6-3-6-45-6-4-4-9-9-8-9" />
<stop
style="stop-color:#d7dad7;stop-opacity:1"
offset="1"
id="stop5382-06-3-6-4-2-4-6-8-0-9-6-8-7-7-6-7" />
</linearGradient>
<inkscape:path-effect
is_visible="true"
id="path-effect62989-8-0-6"
effect="spiro" />
</defs> </defs>
<sodipodi:namedview <sodipodi:namedview
id="base" id="base"
@@ -117,8 +123,8 @@
inkscape:pageopacity="0.0" inkscape:pageopacity="0.0"
inkscape:pageshadow="2" inkscape:pageshadow="2"
inkscape:zoom="1" inkscape:zoom="1"
inkscape:cx="50.925774" inkscape:cx="78.222729"
inkscape:cy="11.296867" inkscape:cy="-3.6620078"
inkscape:document-units="px" inkscape:document-units="px"
inkscape:current-layer="g62929" inkscape:current-layer="g62929"
showgrid="false" showgrid="false"
@@ -129,8 +135,8 @@
inkscape:bbox-paths="true" inkscape:bbox-paths="true"
inkscape:snap-others="false" inkscape:snap-others="false"
inkscape:window-width="2560" inkscape:window-width="2560"
inkscape:window-height="1375" inkscape:window-height="1342"
inkscape:window-x="1600" inkscape:window-x="0"
inkscape:window-y="28" inkscape:window-y="28"
inkscape:window-maximized="1" inkscape:window-maximized="1"
showborder="false"> showborder="false">
@@ -146,7 +152,7 @@
<dc:format>image/svg+xml</dc:format> <dc:format>image/svg+xml</dc:format>
<dc:type <dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
<dc:title></dc:title> <dc:title />
</cc:Work> </cc:Work>
</rdf:RDF> </rdf:RDF>
</metadata> </metadata>
@@ -163,10 +169,11 @@
id="g62929" id="g62929"
transform="translate(-643.91421,517.29894)"> transform="translate(-643.91421,517.29894)">
<g <g
style="display:inline"
transform="translate(0,30)" transform="translate(0,30)"
id="g62931"> id="g62931">
<rect <rect
style="fill:url(#linearGradient62864-0-3-1);fill-opacity:1;stroke:#a6a8a6;stroke-width:1;stroke-linecap:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;color:#000000;color-interpolation:sRGB;color-interpolation-filters:linearRGB;fill-rule:nonzero;stroke-linejoin:miter;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;clip-rule:nonzero" style="color:#000000;clip-rule:nonzero;display:inline;overflow:visible;visibility:visible;opacity:1;isolation:auto;mix-blend-mode:normal;color-interpolation:sRGB;color-interpolation-filters:linearRGB;solid-color:#000000;solid-opacity:1;fill:#cecece;fill-opacity:1;fill-rule:nonzero;stroke:#a7a7a7;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;marker-start:none;marker-mid:none;marker-end:none;paint-order:normal;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto;enable-background:new"
id="rect62935" id="rect62935"
width="63.856125" width="63.856125"
height="21.093594" height="21.093594"
@@ -175,7 +182,7 @@
rx="2" rx="2"
ry="2" /> ry="2" />
<rect <rect
style="fill:url(#linearGradient62981-1-1);fill-opacity:1;stroke:#777b7a;stroke-width:1;stroke-linecap:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" style="color:#000000;clip-rule:nonzero;display:inline;overflow:visible;visibility:visible;opacity:1;isolation:auto;mix-blend-mode:normal;color-interpolation:sRGB;color-interpolation-filters:linearRGB;solid-color:#000000;solid-opacity:1;fill:url(#linearGradient65582);fill-opacity:1;fill-rule:nonzero;stroke:#a7a7a7;stroke-width:0.97313344;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;marker-start:none;marker-mid:none;marker-end:none;paint-order:normal;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto;enable-background:accumulate"
id="rect62937" id="rect62937"
width="29.97398" width="29.97398"
height="17.022524" height="17.022524"
@@ -185,58 +192,18 @@
ry="1" /> ry="1" />
<g <g
transform="translate(-38.048674,-1.9445437)" transform="translate(-38.048674,-1.9445437)"
id="g62939"> id="g62939" />
<rect
ry="1"
rx="1"
y="492"
x="695"
height="8"
width="2"
id="rect62941"
style="fill:#e8e8e5;fill-opacity:1;stroke:none;display:inline" />
<rect
ry="1"
rx="1"
y="492"
x="699"
height="8"
width="2"
id="rect62943"
style="fill:#e8e8e5;fill-opacity:1;stroke:none;display:inline" />
<rect
ry="1"
rx="1"
y="492"
x="703"
height="8"
width="2"
id="rect62945"
style="fill:#e8e8e5;fill-opacity:1;stroke:none;display:inline" />
</g>
<path <path
inkscape:connector-curvature="0" inkscape:connector-curvature="0"
inkscape:original-d="m 647.78624,486.57192 27.94632,0" inkscape:original-d="m 647.78241,486.57192 27.73523,0"
inkscape:path-effect="#path-effect62989-8-0" inkscape:path-effect="#path-effect62989-8-0-6"
id="path62947" id="path62947"
d="m 647.78624,486.57192 27.94632,0" d="m 647.78241,486.57192 27.73523,0"
style="fill:none;stroke:#ffffff;stroke-width:1px;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1" /> style="fill:none;stroke:#ffffff;stroke-width:1px;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1" />
</g> </g>
<g <g
id="g11665" id="g11665"
transform="matrix(0.78906097,0,0,0.78906097,167.78814,111.57844)"> transform="matrix(0.78906097,0,0,0.78906097,167.78814,111.57844)">
<text
xml:space="preserve"
style="font-size:13.14816952px;font-style:normal;font-variant:normal;font-weight:bold;font-stretch:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;display:inline;font-family:Cantarell;-inkscape-font-specification:Cantarell Bold"
x="644.02277"
y="534.94739"
id="text62949-7"
sodipodi:linespacing="125%"
transform="scale(1.0113976,0.98873084)"><tspan
sodipodi:role="line"
id="tspan62951-7"
x="644.02277"
y="534.94739">OFF</tspan></text>
<text <text
xml:space="preserve" xml:space="preserve"
style="font-size:12.69556618px;font-style:normal;font-variant:normal;font-weight:bold;font-stretch:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#2e3436;fill-opacity:1;stroke:none;font-family:Cantarell;-inkscape-font-specification:Cantarell Bold" style="font-size:12.69556618px;font-style:normal;font-variant:normal;font-weight:bold;font-stretch:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#2e3436;fill-opacity:1;stroke:none;font-family:Cantarell;-inkscape-font-specification:Cantarell Bold"

Before

Width:  |  Height:  |  Size: 8.5 KiB

After

Width:  |  Height:  |  Size: 8.0 KiB

+48 -72
View File
@@ -14,42 +14,10 @@
height="22" height="22"
id="svg10865" id="svg10865"
version="1.1" version="1.1"
inkscape:version="0.48.4 r9939" inkscape:version="0.91 r13725"
sodipodi:docname="toggle-on-us.svg"> sodipodi:docname="classic-toggle-on-intl.svg">
<defs <defs
id="defs10867"> id="defs10867">
<linearGradient
inkscape:collect="always"
xlink:href="#linearGradient62991-9-6"
id="linearGradient62979-8-1"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(1.3066667,0,0,1,-197.64667,0)"
x1="702.58966"
y1="484.49405"
x2="702.58966"
y2="507.42715" />
<linearGradient
inkscape:collect="always"
id="linearGradient62991-9-6">
<stop
style="stop-color:#589fe9;stop-opacity:1"
offset="0"
id="stop62993-6-9" />
<stop
style="stop-color:#a3cefe;stop-opacity:1"
offset="1"
id="stop62995-1-6" />
</linearGradient>
<linearGradient
inkscape:collect="always"
xlink:href="#linearGradient62852-6-5"
id="linearGradient62981-1-1"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(0.85639946,0,0,0.81059641,57.747905,92.132229)"
x1="740"
y1="486.10501"
x2="740"
y2="505.3204" />
<linearGradient <linearGradient
id="linearGradient62852-6-5"> id="linearGradient62852-6-5">
<stop <stop
@@ -69,6 +37,41 @@
is_visible="true" is_visible="true"
id="path-effect62989-8-0" id="path-effect62989-8-0"
effect="spiro" /> effect="spiro" />
<linearGradient
inkscape:collect="always"
xlink:href="#linearGradient38513"
id="linearGradient38519"
x1="690"
y1="506.25049"
x2="690"
y2="480.93414"
gradientUnits="userSpaceOnUse" />
<linearGradient
inkscape:collect="always"
id="linearGradient38513">
<stop
style="stop-color:#729fcf;stop-opacity:1"
offset="0"
id="stop38515" />
<stop
style="stop-color:#6f9ccd;stop-opacity:1"
offset="1"
id="stop38517" />
</linearGradient>
<linearGradient
inkscape:collect="always"
xlink:href="#linearGradient62852-6-5"
id="linearGradient62981-1-1"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(0.85639946,0,0,0.81059641,57.747905,92.132229)"
x1="740"
y1="486.10501"
x2="740"
y2="505.3204" />
<inkscape:path-effect
is_visible="true"
id="path-effect62989-8-0-8"
effect="spiro" />
</defs> </defs>
<sodipodi:namedview <sodipodi:namedview
id="base" id="base"
@@ -78,8 +81,8 @@
inkscape:pageopacity="0.0" inkscape:pageopacity="0.0"
inkscape:pageshadow="2" inkscape:pageshadow="2"
inkscape:zoom="1" inkscape:zoom="1"
inkscape:cx="14.199007" inkscape:cx="9.3225163"
inkscape:cy="11.127758" inkscape:cy="-0.1588306"
inkscape:document-units="px" inkscape:document-units="px"
inkscape:current-layer="g62929" inkscape:current-layer="g62929"
showgrid="false" showgrid="false"
@@ -90,8 +93,8 @@
inkscape:bbox-paths="true" inkscape:bbox-paths="true"
inkscape:snap-others="false" inkscape:snap-others="false"
inkscape:window-width="2560" inkscape:window-width="2560"
inkscape:window-height="1380" inkscape:window-height="1342"
inkscape:window-x="1600" inkscape:window-x="0"
inkscape:window-y="28" inkscape:window-y="28"
inkscape:window-maximized="1" inkscape:window-maximized="1"
showborder="false"> showborder="false">
@@ -107,7 +110,7 @@
<dc:format>image/svg+xml</dc:format> <dc:format>image/svg+xml</dc:format>
<dc:type <dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
<dc:title></dc:title> <dc:title />
</cc:Work> </cc:Work>
</rdf:RDF> </rdf:RDF>
</metadata> </metadata>
@@ -124,10 +127,11 @@
id="g62929" id="g62929"
transform="translate(-643.91421,517.29894)"> transform="translate(-643.91421,517.29894)">
<g <g
style="display:inline"
transform="translate(0,30)" transform="translate(0,30)"
id="g62931"> id="g62931">
<rect <rect
style="fill:url(#linearGradient62979-8-1);fill-opacity:1;stroke:#1a71cc;stroke-width:1;stroke-linecap:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" style="color:#000000;clip-rule:nonzero;display:inline;overflow:visible;visibility:visible;opacity:1;isolation:auto;mix-blend-mode:normal;color-interpolation:sRGB;color-interpolation-filters:linearRGB;solid-color:#000000;solid-opacity:1;fill:url(#linearGradient38519);fill-opacity:1;fill-rule:nonzero;stroke:#3465a4;stroke-width:1;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;marker-start:none;marker-mid:none;marker-end:none;paint-order:normal;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto;enable-background:accumulate"
id="rect62935" id="rect62935"
width="63.856125" width="63.856125"
height="21.093594" height="21.093594"
@@ -136,7 +140,7 @@
rx="2" rx="2"
ry="2" /> ry="2" />
<rect <rect
style="fill:url(#linearGradient62981-1-1);fill-opacity:1;stroke:#777b7a;stroke-width:1;stroke-linecap:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" style="display:inline;fill:url(#linearGradient62981-1-1);fill-opacity:1;stroke:#3465a4;stroke-width:1;stroke-linecap:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
id="rect62937" id="rect62937"
width="29.97398" width="29.97398"
height="17.022524" height="17.022524"
@@ -146,39 +150,11 @@
ry="1" /> ry="1" />
<g <g
transform="translate(-7.9861743,-1.9445437)" transform="translate(-7.9861743,-1.9445437)"
id="g62939"> id="g62939" />
<rect
ry="1"
rx="1"
y="492"
x="695"
height="8"
width="2"
id="rect62941"
style="fill:#e8e8e5;fill-opacity:1;stroke:none;display:inline" />
<rect
ry="1"
rx="1"
y="492"
x="699"
height="8"
width="2"
id="rect62943"
style="fill:#e8e8e5;fill-opacity:1;stroke:none;display:inline" />
<rect
ry="1"
rx="1"
y="492"
x="703"
height="8"
width="2"
id="rect62945"
style="fill:#e8e8e5;fill-opacity:1;stroke:none;display:inline" />
</g>
<path <path
inkscape:connector-curvature="0" inkscape:connector-curvature="0"
inkscape:original-d="m 677.59874,486.57192 27.94632,0" inkscape:original-d="m 677.59874,486.57192 27.94632,0"
inkscape:path-effect="#path-effect62989-8-0" inkscape:path-effect="#path-effect62989-8-0-8"
id="path62947" id="path62947"
d="m 677.59874,486.57192 27.94632,0" d="m 677.59874,486.57192 27.94632,0"
style="fill:none;stroke:#ffffff;stroke-width:1px;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1" /> style="fill:none;stroke:#ffffff;stroke-width:1px;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1" />
@@ -187,7 +163,7 @@
inkscape:connector-curvature="0" inkscape:connector-curvature="0"
id="path4444" id="path4444"
d="m 661.91421,522.09451 0,7" d="m 661.91421,522.09451 0,7"
style="fill:none;stroke:#1a71cc;stroke-width:2;stroke-linecap:square;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;color:#000000;fill-opacity:1;fill-rule:nonzero;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" /> style="fill:#3465a4;stroke:#3465a4;stroke-width:2;stroke-linecap:square;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;color:#000000;fill-opacity:1;fill-rule:nonzero;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" />
<path <path
style="fill:none;stroke:#ffffff;stroke-width:2;stroke-linecap:square;stroke-linejoin:miter;stroke-opacity:1;stroke-miterlimit:4;stroke-dasharray:none" style="fill:none;stroke:#ffffff;stroke-width:2;stroke-linecap:square;stroke-linejoin:miter;stroke-opacity:1;stroke-miterlimit:4;stroke-dasharray:none"
d="m 18,7.96875 0,7" d="m 18,7.96875 0,7"

Before

Width:  |  Height:  |  Size: 6.5 KiB

After

Width:  |  Height:  |  Size: 6.2 KiB

+57 -60
View File
@@ -14,32 +14,10 @@
height="22" height="22"
id="svg10865" id="svg10865"
version="1.1" version="1.1"
inkscape:version="0.48+devel r12050" inkscape:version="0.91 r13725"
sodipodi:docname="toggle-on-us.svg"> sodipodi:docname="classic-toggle-on-us.svg">
<defs <defs
id="defs10867"> id="defs10867">
<linearGradient
inkscape:collect="always"
xlink:href="#linearGradient62991-9-6"
id="linearGradient62979-8-1"
gradientUnits="userSpaceOnUse"
gradientTransform="matrix(1.3066667,0,0,1,-197.64667,0)"
x1="702.58966"
y1="484.49405"
x2="702.58966"
y2="507.42715" />
<linearGradient
inkscape:collect="always"
id="linearGradient62991-9-6">
<stop
style="stop-color:#589fe9;stop-opacity:1"
offset="0"
id="stop62993-6-9" />
<stop
style="stop-color:#a3cefe;stop-opacity:1"
offset="1"
id="stop62995-1-6" />
</linearGradient>
<linearGradient <linearGradient
inkscape:collect="always" inkscape:collect="always"
xlink:href="#linearGradient62852-6-5" xlink:href="#linearGradient62852-6-5"
@@ -69,6 +47,53 @@
is_visible="true" is_visible="true"
id="path-effect62989-8-0" id="path-effect62989-8-0"
effect="spiro" /> effect="spiro" />
<clipPath
clipPathUnits="userSpaceOnUse"
id="clipPath65663">
<rect
style="color:#000000;display:inline;overflow:visible;visibility:visible;fill:#729fcf;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1;marker:none;enable-background:new"
id="rect65665"
width="96.999924"
height="24.292892"
x="708.71954"
y="406.96973"
rx="3.1139846"
ry="1.9595497"
inkscape:export-filename="/home/lapo.fedora/SparkleShare/gnome-mockups/content selection/content-selection.png"
inkscape:export-xdpi="90"
inkscape:export-ydpi="90" />
</clipPath>
<linearGradient
inkscape:collect="always"
xlink:href="#linearGradient38513"
id="linearGradient38519"
x1="690"
y1="506.25049"
x2="690"
y2="480.93414"
gradientUnits="userSpaceOnUse" />
<linearGradient
inkscape:collect="always"
id="linearGradient38513">
<stop
style="stop-color:#729fcf;stop-opacity:1"
offset="0"
id="stop38515" />
<stop
style="stop-color:#6f9ccd;stop-opacity:1"
offset="1"
id="stop38517" />
</linearGradient>
<linearGradient
gradientTransform="translate(-644,-483)"
inkscape:collect="always"
xlink:href="#linearGradient38513"
id="linearGradient38519-3"
x1="690"
y1="506.25049"
x2="690"
y2="480.93414"
gradientUnits="userSpaceOnUse" />
</defs> </defs>
<sodipodi:namedview <sodipodi:namedview
id="base" id="base"
@@ -78,8 +103,8 @@
inkscape:pageopacity="0.0" inkscape:pageopacity="0.0"
inkscape:pageshadow="2" inkscape:pageshadow="2"
inkscape:zoom="1" inkscape:zoom="1"
inkscape:cx="8.2018252" inkscape:cx="20.775745"
inkscape:cy="8.0650495" inkscape:cy="7.0434022"
inkscape:document-units="px" inkscape:document-units="px"
inkscape:current-layer="g62929" inkscape:current-layer="g62929"
showgrid="false" showgrid="false"
@@ -90,8 +115,8 @@
inkscape:bbox-paths="true" inkscape:bbox-paths="true"
inkscape:snap-others="false" inkscape:snap-others="false"
inkscape:window-width="2560" inkscape:window-width="2560"
inkscape:window-height="1375" inkscape:window-height="1342"
inkscape:window-x="1600" inkscape:window-x="0"
inkscape:window-y="28" inkscape:window-y="28"
inkscape:window-maximized="1" inkscape:window-maximized="1"
showborder="false"> showborder="false">
@@ -127,7 +152,7 @@
transform="translate(0,30)" transform="translate(0,30)"
id="g62931"> id="g62931">
<rect <rect
style="fill:url(#linearGradient62979-8-1);fill-opacity:1;stroke:#1a71cc;stroke-width:1;stroke-linecap:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" style="fill:url(#linearGradient38519);fill-opacity:1;stroke:#3465a4;stroke-width:1;stroke-linecap:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;color:#000000;clip-rule:nonzero;display:inline;overflow:visible;visibility:visible;opacity:1;isolation:auto;mix-blend-mode:normal;color-interpolation:sRGB;color-interpolation-filters:linearRGB;solid-color:#000000;solid-opacity:1;fill-rule:nonzero;stroke-linejoin:miter;stroke-dashoffset:0;marker:none;marker-start:none;marker-mid:none;marker-end:none;paint-order:normal;filter-blend-mode:normal;filter-gaussianBlur-deviation:0;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto;enable-background:accumulate"
id="rect62935" id="rect62935"
width="63.856125" width="63.856125"
height="21.093594" height="21.093594"
@@ -136,7 +161,7 @@
rx="2" rx="2"
ry="2" /> ry="2" />
<rect <rect
style="fill:url(#linearGradient62981-1-1);fill-opacity:1;stroke:#777b7a;stroke-width:1;stroke-linecap:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" style="fill:url(#linearGradient62981-1-1);fill-opacity:1;stroke:#3465a4;stroke-width:1;stroke-linecap:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
id="rect62937" id="rect62937"
width="29.97398" width="29.97398"
height="17.022524" height="17.022524"
@@ -146,35 +171,7 @@
ry="1" /> ry="1" />
<g <g
transform="translate(-7.9861743,-1.9445437)" transform="translate(-7.9861743,-1.9445437)"
id="g62939"> id="g62939" />
<rect
ry="1"
rx="1"
y="492"
x="695"
height="8"
width="2"
id="rect62941"
style="fill:#e8e8e5;fill-opacity:1;stroke:none;display:inline" />
<rect
ry="1"
rx="1"
y="492"
x="699"
height="8"
width="2"
id="rect62943"
style="fill:#e8e8e5;fill-opacity:1;stroke:none;display:inline" />
<rect
ry="1"
rx="1"
y="492"
x="703"
height="8"
width="2"
id="rect62945"
style="fill:#e8e8e5;fill-opacity:1;stroke:none;display:inline" />
</g>
<path <path
inkscape:connector-curvature="0" inkscape:connector-curvature="0"
inkscape:original-d="m 677.59874,486.57192 27.94632,0" inkscape:original-d="m 677.59874,486.57192 27.94632,0"
@@ -189,7 +186,7 @@
id="text62949-7" id="text62949-7"
y="534.96918" y="534.96918"
x="646.71399" x="646.71399"
style="font-size:10.01104736px;font-style:normal;font-variant:normal;font-weight:bold;font-stretch:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#1a71cc;fill-opacity:1;stroke:none;display:inline;font-family:Cantarell;-inkscape-font-specification:Cantarell Bold" style="font-size:10.01104736px;font-style:normal;font-variant:normal;font-weight:bold;font-stretch:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#3465a4;fill-opacity:1;stroke:none;display:inline;font-family:Cantarell;-inkscape-font-specification:Cantarell Bold;"
xml:space="preserve"><tspan xml:space="preserve"><tspan
y="534.96918" y="534.96918"
x="646.71399" x="646.71399"

Before

Width:  |  Height:  |  Size: 6.9 KiB

After

Width:  |  Height:  |  Size: 7.5 KiB

+1 -3
View File
@@ -1,11 +1,9 @@
{ {
"parentMode": "user", "parentMode": "user",
"stylesheetName": "gnome-classic.css", "stylesheetName": "gnome-classic.css",
"overridesSchema": "org.gnome.shell.extensions.classic-overrides",
"enabledExtensions": [@CLASSIC_EXTENSIONS@], "enabledExtensions": [@CLASSIC_EXTENSIONS@],
"panel": { "left": ["activities", "appMenu"], "panel": { "left": ["activities", "appMenu"],
"center": [], "center": [],
"right": ["a11y", "keyboard", "volume", "bluetooth", "right": ["a11y", "keyboard", "dateMenu", "aggregateMenu"]
"network", "battery", "dateMenu", "userMenu"]
} }
} }
+5
View File
@@ -0,0 +1,5 @@
@import url("gnome-classic.css");
stage {
-st-icon-style: symbolic;
}
-257
View File
@@ -1,257 +0,0 @@
@import url("gnome-shell.css");
/* FIXME:
- white edge highlight with text-shadow and icon-shadow for panel-button
- better shading of the panel (dark 5%) - impossible without multipoint gradients, image-bg is a hack
*/
#panel {
background-color: #e9e9e9 !important;
background-gradient-direction: vertical;
background-gradient-end: #d0d0d0;
border-top-color: #666; /* we don't support non-uniform border-colors and
use the top border color for any border, so we
need to set it even if all we want is a bottom
border */
border-bottom: 1px solid #666;
app-icon-bottom-clip: 0px;
/* hrm, still no multipoint gradients
background-image: linear-gradient(left, rgba(255, 255, 255, 0), rgba(255, 255, 255, 1) 50%, rgba(255, 255, 255, 0)) !important;*/
}
#panel:overview {
background-color: #000 !important;
background-gradient-end: #000 !important;
border-top-color: #000;
border-bottom: 1px solid #000 !important;
}
#panel.lock-screen {
background-color: rgba(0,0,0,0.3) !important;
background-gradient-end: rgba(0,0,0,0.3) !important;
border-top-color: transparent;
}
#panel.unlock-screen {
background-color: transparent !important;
background-gradient-end: transparent !important;
border-top-color: transparent;
}
/* TOP BAR */
.panel-corner,
.panel-corner:active,
.panel-corner:overview,
.panel-corner:focus {
-panel-corner-radius: 0 !important;
}
.panel-button {
color: #555 !important;
-natural-hpadding: 6px !important;
-minimum-hpadding: 3px !important;
}
#panel:overview .panel-button,
#panel.lock-screen .panel-button,
#panel.unlock-screen .panel-button {
color: #ccc !important;
}
.panel-button:hover {
color: #000 !important;
}
#panel:overview .panel-button:hover,
#panel:overview .panel-button:active {
color: white !important;
}
.panel-button > .system-status-icon {
icon-shadow: #fff 0 1px 0 !important; /* FIXME */
}
.panel-button:hover,
.panel-button:active,
.panel-button:overview,
.panel-button:focus {
text-shadow: 0 0 0 transparent !important; /* FIXME: why can't I do none ? */
}
.panel-button:active,
.panel-button:overview,
.panel-button:focus {
background-color: #4a90d9 !important; /* FIXME */
color: #fff !important;
border: none !important;
border-image: none !important;
background-image: none !important;
}
#panelUserMenu {
padding: 0 10px 0 10px !important;
}
#appMenu {
text-shadow: 0 0 0 transparent !important;
spinner-image: url("classic-process-working.svg");
}
/* used for the app menu header only */
.label-shadow {
color: rgba(0,0,0,0.5);
}
.label-shadow {
color: rgba(255,255,255,.5) !important;
}
.panel-button:active .label-shadow,
.panel-button:focus .label-shadow {
color: rgba(0,0,0,.5) !important;
}
.popup-menu-boxpointer {
-arrow-background-color: #e9e9e9 !important;
-arrow-border-width: 1px !important;
-arrow-border-color: #aaa !important;
-arrow-border-radius: 3px !important;
color: #000 !important;
-arrow-base: 11px !important;
-arrow-rise: 5px !important;
}
.popup-combo-menu {
background-color: #e9e9e9 !important;
border: 1px solid #aaa !important;
color: #000 !important;
}
.popup-menu-item:active {
background-color: #4a90d9 !important;
color: #fff !important;
}
.popup-menu-item:insensitive {
color: #888;
}
.popup-separator-menu-item {
-gradient-height: 1px;
-gradient-start: rgba(0,0,0,0.0);
-gradient-end: rgba(0,0,0,0.15);
-margin-horizontal: 24px;
height: 1px;
padding: 8px 0px;
}
.popup-slider-menu-item {
-slider-handle-border-color: #888;
-slider-handle-border-width: 1px;
}
.popup-menu-item:hover .popup-slider-menu-item {
color: #fff;
}
.popup-subtitle-menu-item, .popup-subtitle-menu-item:insensitive {
color: #000;
}
.popup-submenu-menu-item:open {
background-color: #888;
color: #fff;
}
.popup-sub-menu {
background-gradient-start: #ddd;
background-gradient-end: #dfdfdf;
background-gradient-direction: vertical;
box-shadow: inset 0px 1px 3px rgba(0,0,0,0.4);
}
/* SCROLLBARS for POPUP MENU */
.popup-menu StScrollBar StBin#trough {
background-color: transparent;
}
.popup-menu StScrollBar StButton#vhandle, .popup-menu StScrollBar StButton#hhandle {
border-color: #e9e9e9;
background-color: #888;
}
.popup-menu StScrollBar StButton#vhandle:hover,
.popup-menu StScrollBar StButton#hhandle:hover {
background-color: #666;
}
.popup-menu StScrollBar StButton#vhandle:active,
.popup-menu StScrollBar StButton#hhandle:active {
background-color: #4a90d9;
}
/* CALENDAR */
.calendar {}
.calendar-month-label {
color: #333 !important;
}
.datemenu-date-label,
.events-day-header {
color: #666 !important;
}
.calendar-day-base:active {
color: #fff !important;
background-color: #4a90d9 !important;
background-image: none !important;
border-image: none !important;
}
.calendar-today {
background-color: #4a90d9 !important;
background-image: none !important;
border-image: none !important;
}
.calendar-day-base {
color: #666 !important;
}
.calendar-day-base:hover {
background-color: #666 !important;
color: #fff !important;
}
.calendar-nonwork-day {
color: #999 !important;
}
.events-day-dayname,
.events-day-time {
color: #666 !important;
}
/* VOLUME SLIDER */
.popup-slider-menu-item {
-slider-background-color: #e9e9e9;
-slider-border-color: #999;
-slider-active-background-color: #76b0ec;
-slider-active-border-color: #1f6dbc;
}
/* ON OFF switch */
.toggle-switch-us {
background-image: url("classic-toggle-off-us.svg");
background-size: contain;
}
.toggle-switch-us:checked {
background-image: url("classic-toggle-on-us.svg");
background-size: contain;
}
.toggle-switch-intl {
background-image: url("classic-toggle-off-intl.svg");
background-size: contain;
}
.toggle-switch-intl:checked {
background-image: url("classic-toggle-on-intl.svg");
background-size: contain;
}
+4 -4
View File
@@ -1,7 +1,7 @@
[Desktop Entry] [Desktop Entry]
_Name=GNOME Classic Name=GNOME Classic
_Comment=This session logs you into GNOME Classic Comment=This session logs you into GNOME Classic
Exec=gnome-session --session gnome-classic Exec=env GNOME_SHELL_SESSION_MODE=classic gnome-session --session gnome-classic
TryExec=gnome-session TryExec=gnome-session
Icon=
Type=Application Type=Application
DesktopNames=GNOME-Classic;GNOME;
+105
View File
@@ -0,0 +1,105 @@
/* Use the gnome-shell theme, but with light colors */
$variant: 'light';
@import "gnome-shell-sass/_colors"; //use gtk colors
@import "gnome-shell-sass/_drawing";
@import "gnome-shell-sass/_common";
/* Overrides */
#panel, #panel.solid {
font-weight: normal;
background-color: $bg_color;
background-gradient-direction: vertical;
background-gradient-end: darken($bg_color,5%);
border-top-color: #666; /* we don't support non-uniform border-colors and
use the top border color for any border, so we
need to set it even if all we want is a bottom
border */
border-bottom: 1px solid #666;
app-icon-bottom-clip: 0px;
&:overview {
background-color: #000;
background-gradient-end: #000;
border-top-color: #000;
border-bottom: 1px solid #000;
.panel-button { color: #fff; }
}
.panel-button {
-natural-hpadding: 8px;
-minimum-hpadding: 4px;
font-weight: normal;
color: $fg_color;
text-shadow: none;
&:active, &:overview, &:focus, &:checked {
// Trick due to St limitations. It needs a background to draw
// a box-shadow
background-color: $selected_bg_color !important;
color: $selected_fg_color !important;
box-shadow: none;
& > .system-status-icon { icon-shadow: none; }
}
&:hover {
text-shadow: none;
& .system-status-icon { icon-shadow: none; }
}
.app-menu-icon { width: 0; height: 0; margin: 0; } // shell's display:none; :D
.system-status-icon {
icon-shadow: none;
}
}
.panel-corner,
.panel-corner:active,
.panel-corner:overview,
.panel-corner:focus {
-panel-corner-radius: 0;
}
&.lock-screen,
&.unlock-screen,
&.login-screen {
background-color: transparentize($_bubble_bg_color, 0.5);
background-gradient-start: transparentize($_bubble_bg_color, 0.5);
background-gradient-end: transparentize($_bubble_bg_color, 0.5);
border-bottom: none;
.panel-button { color: $osd_fg_color; }
}
.popup-menu-arrow { width: 0; height: 0; } // shell's display: none;
}
#appMenu {
padding: 0 8px 0 8px;
spinner-image: url("classic-process-working.svg");
}
.tile-preview-left.on-primary,
.tile-preview-right.on-primary,
.tile-preview-left.tile-preview-right.on-primary {
/* keep in sync with -panel-corner-radius */
border-radius: 0;
}
@each $v in us, intl {
.toggle-switch-#{$v} {
background-image: url("classic-toggle-off-#{$v}.svg");
&:checked { background-image: url("classic-toggle-on-#{$v}.svg"); }
}
}
.calendar-day-with-events {
background-image: url("calendar-today.svg");
}
.message-list-clear-button.button {
color: $fg_color
}
.notification-banner {
background-color: $bg_color !important;
color: $fg_color;
.notification-button {
background-color: darken($bg_color,5%);
&:hover, &focus { background-color: darken($bg_color,2%); }
}
}
+3
View File
@@ -0,0 +1,3 @@
[GNOME Session]
Name=GNOME Classic
RequiredComponents=org.gnome.Shell;org.gnome.SettingsDaemon.A11ySettings;org.gnome.SettingsDaemon.Clipboard;org.gnome.SettingsDaemon.Color;org.gnome.SettingsDaemon.Datetime;org.gnome.SettingsDaemon.Housekeeping;org.gnome.SettingsDaemon.Keyboard;org.gnome.SettingsDaemon.MediaKeys;org.gnome.SettingsDaemon.Mouse;org.gnome.SettingsDaemon.Power;org.gnome.SettingsDaemon.PrintNotifications;org.gnome.SettingsDaemon.Rfkill;org.gnome.SettingsDaemon.ScreensaverProxy;org.gnome.SettingsDaemon.Sharing;org.gnome.SettingsDaemon.Smartcard;org.gnome.SettingsDaemon.Sound;org.gnome.SettingsDaemon.Wacom;org.gnome.SettingsDaemon.XSettings;
-3
View File
@@ -1,3 +0,0 @@
[GNOME Session]
_Name=GNOME Classic
RequiredComponents=gnome-shell-classic;gnome-settings-daemon;nautilus-classic;
-17
View File
@@ -1,17 +0,0 @@
[Desktop Entry]
Type=Application
_Name=GNOME Shell Classic
_Comment=Window management and application launching
Exec=@bindir@/gnome-shell --mode=classic
TryExec=@bindir@/gnome-shell
X-GNOME-Bugzilla-Bugzilla=GNOME
X-GNOME-Bugzilla-Product=gnome-shell
X-GNOME-Bugzilla-Component=general
X-GNOME-Bugzilla-Version=@VERSION@
Categories=GNOME;GTK;Core;
OnlyShowIn=GNOME;
NoDisplay=true
X-GNOME-Autostart-Phase=WindowManager
X-GNOME-Provides=panel;windowmanager;
X-GNOME-Autostart-Notify=true
X-GNOME-AutoRestart=false
+63
View File
@@ -0,0 +1,63 @@
sessions = [
['gnome-classic.session.desktop.in', sessiondir],
['gnome-classic.desktop.in', xsessiondir]
]
foreach s : sessions
name_array = s[0].split('.')
i18n.merge_file('',
input: s[0],
output: '.'.join([name_array[0], name_array[1]]),
po_dir: '../po',
install: true,
install_dir: s[1],
type: 'desktop'
)
endforeach
classic_uuids = []
foreach e : classic_extensions
classic_uuids += e + uuid_suffix
endforeach
mode_conf = configuration_data()
mode_conf.set('CLASSIC_EXTENSIONS', '"' + '", "'.join(classic_uuids) + '"')
mode_file = 'classic.json'
configure_file(
input: mode_file + '.in',
output: mode_file,
configuration: mode_conf,
install_dir: modedir
)
theme_sources = files(
'gnome-shell-sass/_colors.scss',
'gnome-shell-sass/_common.scss',
'gnome-shell-sass/_drawing.scss',
'gnome-shell-sass/_high-contrast-colors.scss'
)
theme_data = [
'calendar-today.svg',
'classic-process-working.svg',
'classic-toggle-off-intl.svg',
'classic-toggle-off-us.svg',
'classic-toggle-on-intl.svg',
'classic-toggle-on-us.svg',
'gnome-classic-high-contrast.css'
]
style = 'gnome-classic'
custom_target(style + '.css',
input: style + '.scss',
output: style + '.css',
depend_files: theme_sources,
command: [sassc, '-a', '@INPUT@', '@OUTPUT@'],
install: true,
install_dir: themedir
)
install_data(theme_data, install_dir: themedir)
classic_override = '00_org.gnome.shell.extensions.classic.gschema.override'
install_data(classic_override, install_dir: schemadir)
@@ -1,38 +0,0 @@
<schemalist>
<schema id="org.gnome.shell.extensions.classic-overrides"
path="/org/gnome/shell/extensions/classic-overrides/"
gettext-domain="gnome-shell-extensions">
<key name="attach-modal-dialogs" type="b">
<default>true</default>
<_summary>Attach modal dialog to the parent window</_summary>
<_description>
This key overrides the key in org.gnome.mutter when running
GNOME Shell.
</_description>
</key>
<key name="edge-tiling" type="b">
<default>true</default>
<_summary>Enable edge tiling when dropping windows on screen edges</_summary>
<_description>
This key overrides the key in org.gnome.mutter when running GNOME Shell.
</_description>
</key>
<key name="workspaces-only-on-primary" type="b">
<default>true</default>
<_summary>Workspaces only on primary monitor</_summary>
<_description>
This key overrides the key in org.gnome.mutter when running GNOME Shell.
</_description>
</key>
<key name="focus-change-on-pointer-rest" type="b">
<default>true</default>
<summary>Delay focus changes in mouse mode until the pointer stops moving</summary>
<description>
This key overrides the key in org.gnome.mutter when running GNOME Shell.
</description>
</key>
</schema>
</schemalist>
Executable
+37
View File
@@ -0,0 +1,37 @@
#!/bin/sh
srcdir=`dirname $0`
srcdir=`(cd $srcdir && pwd)`
builddir=`mktemp -p $srcdir -d _build.XXXXXX` || exit 1
installdir=`mktemp -p $srcdir -d _install.XXXXXX` || exit 1
meson setup --prefix=$installdir -Dextension_set=all $srcdir $builddir
ninja -C$builddir install
rm -rf $srcdir/zip-files
mkdir $srcdir/zip-files
extensiondir=$installdir/share/gnome-shell/extensions
schemadir=$installdir/share/glib-2.0/schemas
localedir=$installdir/share/locale
for f in $extensiondir/*; do
name=`basename ${f%%@*}`
uuid=$name@gnome-shell-extensions.gcampax.github.com
schema=$schemadir/org.gnome.shell.extensions.$name.gschema.xml
cp $srcdir/NEWS $srcdir/COPYING $f
cp -r $localedir $f
if [ -f $schema ]; then
mkdir $f/schemas
cp $schema $f/schemas;
glib-compile-schemas $f/schemas
fi
(cd $f && zip -rmq $srcdir/zip-files/$uuid.shell-extension.zip .)
done
rm -rf $builddir
rm -rf $installdir
-18
View File
@@ -1,18 +0,0 @@
include $(top_srcdir)/include.mk
dist_extension_DATA = extension.js stylesheet.css $(EXTRA_MODULES)
nodist_extension_DATA = metadata.json $(top_srcdir)/lib/convenience.js $(EXTRA_EXTENSION)
EXTRA_DIST = metadata.json.in
metadata.json: metadata.json.in $(top_builddir)/config.status
$(AM_V_GEN) sed \
-e "s|[@]extension_id@|$(EXTENSION_ID)|" \
-e "s|[@]uuid@|$(uuid)|" \
-e "s|[@]gschemaname@|$(gschemaname)|" \
-e "s|[@]gettext_domain@|$(GETTEXT_PACKAGE)|" \
-e "s|[@]shell_current@|$(SHELL_VERSION)|" \
-e "s|[@]url@|$(extensionurl)|" \
$< > $@
CLEANFILES = metadata.json
-3
View File
@@ -1,3 +0,0 @@
DIST_SUBDIRS = $(ALL_EXTENSIONS)
SUBDIRS = $(ENABLED_EXTENSIONS)
-5
View File
@@ -1,5 +0,0 @@
EXTENSION_ID = alternate-tab
EXTRA_MODULES = prefs.js
include ../../extension.mk
-64
View File
@@ -1,64 +0,0 @@
/* -*- mode: js; js-basic-offset: 4; indent-tabs-mode: nil -*- */
const Clutter = imports.gi.Clutter;
const Lang = imports.lang;
const Meta = imports.gi.Meta;
const Shell = imports.gi.Shell;
const AltTab = imports.ui.altTab;
const Main = imports.ui.main;
let injections = {};
function init(metadata) {
}
function setKeybinding(name, func) {
Main.wm.setCustomKeybindingHandler(name, Shell.KeyBindingMode.NORMAL, func);
}
function enable() {
injections['_initialSelection'] = AltTab.WindowSwitcherPopup.prototype._initialSelection;
AltTab.WindowSwitcherPopup.prototype._initialSelection = function(backward, binding) {
if (binding == 'switch-windows-backward' ||
binding == 'switch-applications-backward' ||
binding == 'switch-group-backward' || backward)
this._select(this._items.length - 1);
else if (this._items.length == 1)
this._select(0);
else
this._select(1);
};
injections['_keyPressHandler'] = AltTab.WindowSwitcherPopup.prototype._keyPressHandler;
AltTab.WindowSwitcherPopup.prototype._keyPressHandler = function(keysym, backwards, action) {
if (action == Meta.KeyBindingAction.SWITCH_WINDOWS ||
action == Meta.KeyBindingAction.SWITCH_APPLICATIONS ||
action == Meta.KeyBindingAction.SWITCH_GROUP) {
this._select(backwards ? this._previous() : this._next());
} else if (action == Meta.KeyBindingAction.SWITCH_WINDOWS_BACKWARD ||
action == Meta.KeyBindingAction.SWITCH_APPLICATIONS_BACKWARD ||
action == Meta.KeyBindingAction.SWITCH_GROUP_BACKWARD) {
this._select(this._previous());
} else {
if (keysym == Clutter.Left)
this._select(this._previous());
else if (keysym == Clutter.Right)
this._select(this._next());
}
};
setKeybinding('switch-applications', Lang.bind(Main.wm, Main.wm._startWindowSwitcher));
setKeybinding('switch-group', Lang.bind(Main.wm, Main.wm._startWindowSwitcher));
setKeybinding('switch-applications-backward', Lang.bind(Main.wm, Main.wm._startWindowSwitcher));
setKeybinding('switch-group-backward', Lang.bind(Main.wm, Main.wm._startWindowSwitcher));
}
function disable() {
setKeybinding('switch-applications', Lang.bind(Main.wm, Main.wm._startAppSwitcher));
setKeybinding('switch-group', Lang.bind(Main.wm, Main.wm._startAppSwitcher));
setKeybinding('switch-applications-backward', Lang.bind(Main.wm, Main.wm._startAppSwitcher));
setKeybinding('switch-group-backward', Lang.bind(Main.wm, Main.wm._startAppSwitcher));
for (prop in injections)
AltTab.WindowSwitcherPopup.prototype[prop] = injections[prop];
}
+7
View File
@@ -0,0 +1,7 @@
extension_data += configure_file(
input: metadata_name + '.in',
output: metadata_name,
configuration: metadata_conf
)
extension_sources += files('prefs.js')
-11
View File
@@ -1,11 +0,0 @@
{
"extension-id": "@extension_id@",
"uuid": "@uuid@",
"settings-schema": "@gschemaname@",
"gettext-domain": "@gettext_domain@",
"name": "AlternateTab",
"description": "Substitute Alt-Tab with a window based switcher that does not group by application.\nThis extension is part of Classic Mode and is officially supported by GNOME. Please do not report bugs using the form below, use GNOME Bugzilla instead.",
"original-authors": [ "jw@bargsten.org", "thomas.bouffon@gmail.com" ],
"shell-version": [ "@shell_current@" ],
"url": "@url@"
}
-78
View File
@@ -1,78 +0,0 @@
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
const Gio = imports.gi.Gio;
const Gtk = imports.gi.Gtk;
const GObject = imports.gi.GObject;
const Lang = imports.lang;
const Gettext = imports.gettext.domain('gnome-shell-extensions');
const _ = Gettext.gettext;
const N_ = function(e) { return e };
const ExtensionUtils = imports.misc.extensionUtils;
const Me = ExtensionUtils.getCurrentExtension();
const Convenience = Me.imports.convenience;
const SETTINGS_APP_ICON_MODE = 'app-icon-mode';
const SETTINGS_CURRENT_WORKSPACE_ONLY = 'current-workspace-only';
const MODES = {
'thumbnail-only': N_("Thumbnail only"),
'app-icon-only': N_("Application icon only"),
'both': N_("Thumbnail and application icon"),
};
const AltTabSettingsWidget = new GObject.Class({
Name: 'AlternateTab.Prefs.AltTabSettingsWidget',
GTypeName: 'AltTabSettingsWidget',
Extends: Gtk.Grid,
_init : function(params) {
this.parent(params);
this.margin = 10;
this.orientation = Gtk.Orientation.VERTICAL;
this._settings = new Gio.Settings({ schema: 'org.gnome.shell.window-switcher' });
let presentLabel = _("Present windows as");
this.add(new Gtk.Label({ label: presentLabel, sensitive: true,
margin_bottom: 10, margin_top: 5 }));
let top = 1;
let radio = null;
let currentMode = this._settings.get_string(SETTINGS_APP_ICON_MODE);
for (let mode in MODES) {
// copy the mode variable because it has function scope, not block scope
// so cannot be used in a closure
let modeCapture = mode;
let name = Gettext.gettext(MODES[mode]);
radio = new Gtk.RadioButton({ group: radio, label: name, valign: Gtk.Align.START });
radio.connect('toggled', Lang.bind(this, function(widget) {
if (widget.active)
this._settings.set_string(SETTINGS_APP_ICON_MODE, modeCapture);
}));
this.add(radio);
if (mode == currentMode)
radio.active = true;
top += 1;
}
let check = new Gtk.CheckButton({ label: _("Show only windows in the current workspace"),
margin_top: 12 });
this._settings.bind(SETTINGS_CURRENT_WORKSPACE_ONLY, check, 'active', Gio.SettingsBindFlags.DEFAULT);
this.add(check);
},
});
function init() {
Convenience.initTranslations();
}
function buildPrefsWidget() {
let widget = new AltTabSettingsWidget();
widget.show_all();
return widget;
}
-1
View File
@@ -1 +0,0 @@
/* This extensions requires no special styling */
@@ -1,4 +0,0 @@
EXTENSION_ID = alternative-status-menu
include ../../extension.mk
include ../../settings.mk
@@ -1,172 +0,0 @@
/* -*- mode: js2 - indent-tabs-mode: nil - js2-basic-offset: 4 -*- */
const Gio = imports.gi.Gio;
const GLib = imports.gi.GLib;
const Lang = imports.lang;
const Mainloop = imports.mainloop;
const St = imports.gi.St;
const BoxPointer = imports.ui.boxpointer;
const Main = imports.ui.main;
const PopupMenu = imports.ui.popupMenu;
const Gettext = imports.gettext.domain('gnome-shell-extensions');
const _ = Gettext.gettext;
const ExtensionUtils = imports.misc.extensionUtils;
const Me = ExtensionUtils.getCurrentExtension();
const Convenience = Me.imports.convenience;
const LOCK_ENABLED_KEY = 'lock-enabled';
let extension;
// Need to reimplement here the missing bits from LoginManager
function loginManager_hibernate() {
if (this._proxy) {
// systemd path
this._proxy.call("Hibernate",
GLib.Variant.new('(b)', [true]),
Gio.DBusCallFlags.NONE,
-1, null, null);
} else {
// Can't do in ConsoleKit
this.emit('prepare-for-sleep', true);
this.emit('prepare-for-sleep', false);
}
}
function loginManager_canHibernate(asyncCallback) {
if (this._proxy) {
// systemd path
this._proxy.call("CanHibernate",
null,
Gio.DBusCallFlags.NONE,
-1, null, function(proxy, asyncResult) {
let result, error;
try {
result = proxy.call_finish(asyncResult);
} catch(e) {
error = e;
}
if (error)
asyncCallback(false);
else
asyncCallback(result[0] != 'no');
});
} else {
Mainloop.idle_add(Lang.bind(this, function() {
asyncCallback(false);
return false;
}));
}
}
function statusMenu_updateHaveHibernate() {
loginManager_canHibernate.call(this._loginManager, Lang.bind(this,
function(result) {
this._haveHibernate = result;
this._updateSuspendOrPowerOff();
}));
}
function statusMenu_updateSuspendOrPowerOff() {
this._suspendOrPowerOffItem.actor.hide();
extension.suspendItem.actor.visible = this._haveSuspend && extension.settings.get_boolean('allow-suspend');
extension.hibernateItem.actor.visible = this._haveHibernate && extension.settings.get_boolean('allow-hibernate');
extension.powerOffItem.actor.visible = this._haveShutdown;
}
function onSuspendActivate(item) {
Main.overview.hide();
this.menu.close(BoxPointer.PopupAnimation.NONE);
this._loginManager.suspend();
}
function onHibernateActivate(item) {
Main.overview.hide();
this.menu.close(BoxPointer.PopupAnimation.NONE);
loginManager_hibernate.call(this._loginManager);
}
const Extension = new Lang.Class({
Name: 'AlternativeStatusMenu.Extension',
_init: function() {
this.suspendItem = null;
this.hibernateItem = null;
this.powerOffItem = null;
Convenience.initTranslations();
this.settings = Convenience.getSettings();
},
enable: function() {
let statusMenu = Main.panel.statusArea.userMenu;
let children = statusMenu.menu._getMenuItems();
let index = children.length;
/* find the old entry */
for (let i = children.length - 1; i >= 0; i--) {
if (children[i] == statusMenu._suspendOrPowerOffItem) {
index = i;
break;
}
}
/* add the new entries */
this.suspendItem = new PopupMenu.PopupMenuItem(_("Suspend"));
this.suspendItem.connect('activate', Lang.bind(statusMenu, onSuspendActivate));
this.hibernateItem = new PopupMenu.PopupMenuItem(_("Hibernate"));
this.hibernateItem.connect('activate', Lang.bind(statusMenu, onHibernateActivate));
this.powerOffItem = new PopupMenu.PopupMenuItem(_("Power Off"));
this.powerOffItem.connect('activate', Lang.bind(statusMenu, function() {
this._session.ShutdownRemote();
}));
/* insert the entries at the found position */
statusMenu.menu.addMenuItem(this.suspendItem, index);
statusMenu.menu.addMenuItem(this.hibernateItem, index + 1);
statusMenu.menu.addMenuItem(this.powerOffItem, index + 2);
this._openStateChangedId = statusMenu.menu.connect('open-state-changed', function() {
statusMenu_updateHaveHibernate.call(statusMenu);
});
this._previousUpdateSuspendOrPowerOff = statusMenu._updateSuspendOrPowerOff;
statusMenu._updateSuspendOrPowerOff = statusMenu_updateSuspendOrPowerOff;
this._settingsChangedId = this.settings.connect('changed', function() {
statusMenu._updateSuspendOrPowerOff();
});
},
disable: function() {
let statusMenu = Main.panel.statusArea.userMenu;
this.suspendItem.destroy();
this.hibernateItem.destroy();
this.powerOffItem.destroy();
statusMenu.menu.disconnect(this._openStateChangedId);
this.settings.disconnect(this._settingsChangedId);
statusMenu._updateSuspendOrPowerOff = this._previousUpdateSuspendOrPowerOff;
statusMenu._updateSuspendOrPowerOff();
},
});
// Put your extension initialization code here
function init(metadata) {
return (extension = new Extension());
}
@@ -1,10 +0,0 @@
{
"extension-id": "@extension_id@",
"uuid": "@uuid@",
"settings-schema": "@gschemaname@",
"gettext-domain": "@gettext_domain@",
"name": "Alternative Status Menu",
"description": "Replaces GNOME Shell Status Menu with one showing Suspend/Hibernate and Power Off as separate items.",
"shell-version": [ "@shell_current@" ],
"url": "@url@"
}
@@ -1,14 +0,0 @@
<schemalist gettext-domain="gnome-shell-extensions">
<schema id="org.gnome.shell.extensions.alternative-status-menu" path="/org/gnome/shell/extensions/alternative-status-menu/">
<key name="allow-suspend" type="b">
<default>true</default>
<_summary>Enable suspending</_summary>
<_description>Control the visibility of the Suspend menu item</_description>
</key>
<key name="allow-hibernate" type="b">
<default>true</default>
<_summary>Enable hibernating</_summary>
<_description>Control the visibility of the Hibernate menu item</_description>
</key>
</schema>
</schemalist>
@@ -1,3 +0,0 @@
.popup-alternating-menu-item:alternate {
font-weight: normal !important;
}
-3
View File
@@ -1,3 +0,0 @@
EXTENSION_ID = apps-menu
include ../../extension.mk
+398 -234
View File
@@ -1,18 +1,20 @@
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */ /* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
const Atk = imports.gi.Atk; const Atk = imports.gi.Atk;
const DND = imports.ui.dnd;
const GMenu = imports.gi.GMenu; const GMenu = imports.gi.GMenu;
const Lang = imports.lang; const GObject = imports.gi.GObject;
const Shell = imports.gi.Shell; const Shell = imports.gi.Shell;
const St = imports.gi.St; const St = imports.gi.St;
const Clutter = imports.gi.Clutter; const Clutter = imports.gi.Clutter;
const Main = imports.ui.main; const Main = imports.ui.main;
const Meta = imports.gi.Meta;
const PanelMenu = imports.ui.panelMenu; const PanelMenu = imports.ui.panelMenu;
const PopupMenu = imports.ui.popupMenu; const PopupMenu = imports.ui.popupMenu;
const Gtk = imports.gi.Gtk; const Gtk = imports.gi.Gtk;
const GLib = imports.gi.GLib; const GLib = imports.gi.GLib;
const Gio = imports.gi.Gio;
const Signals = imports.signals; const Signals = imports.signals;
const Layout = imports.ui.layout;
const Pango = imports.gi.Pango; const Pango = imports.gi.Pango;
const Gettext = imports.gettext.domain('gnome-shell-extensions'); const Gettext = imports.gettext.domain('gnome-shell-extensions');
@@ -29,78 +31,94 @@ const HORIZ_FACTOR = 5;
const MENU_HEIGHT_OFFSET = 132; const MENU_HEIGHT_OFFSET = 132;
const NAVIGATION_REGION_OVERSHOOT = 50; const NAVIGATION_REGION_OVERSHOOT = 50;
const ActivitiesMenuItem = new Lang.Class({ class ActivitiesMenuItem extends PopupMenu.PopupBaseMenuItem {
Name: 'ActivitiesMenuItem', constructor(button) {
Extends: PopupMenu.PopupBaseMenuItem, super();
_init: function(button) {
this.parent();
this._button = button; this._button = button;
this.addActor(new St.Label({ text: _("Activities Overview") })); this.actor.add_child(new St.Label({ text: _("Activities Overview") }));
}, }
activate: function(event) { activate(event) {
this._button.menu.toggle(); this._button.menu.toggle();
Main.overview.toggle(); Main.overview.toggle();
this.parent(event); super.activate(event);
}, }
}); };
const ApplicationMenuItem = new Lang.Class({ class ApplicationMenuItem extends PopupMenu.PopupBaseMenuItem {
Name: 'ApplicationMenuItem', constructor(button, app) {
Extends: PopupMenu.PopupBaseMenuItem, super();
this._app = app;
_init: function(button, app) {
this.parent();
this._app = app;
this._button = button; this._button = button;
this._iconBin = new St.Bin(); this._iconBin = new St.Bin();
this.addActor(this._iconBin); this.actor.add_child(this._iconBin);
let appLabel = new St.Label({ text: app.get_name() }); let appLabel = new St.Label({ text: app.get_name(), y_expand: true,
this.addActor(appLabel, { span: -1, expand: true }); y_align: Clutter.ActorAlign.CENTER });
this.actor.add_child(appLabel);
this.actor.label_actor = appLabel; this.actor.label_actor = appLabel;
let textureCache = St.TextureCache.get_default(); let textureCache = St.TextureCache.get_default();
let iconThemeChangedId = textureCache.connect('icon-theme-changed', let iconThemeChangedId = textureCache.connect('icon-theme-changed',
Lang.bind(this, this._updateIcon)); this._updateIcon.bind(this));
this.actor.connect('destroy', Lang.bind(this, this.actor.connect('destroy', () => {
function() { textureCache.disconnect(iconThemeChangedId);
textureCache.disconnect(iconThemeChangedId); });
}));
this._updateIcon(); this._updateIcon();
},
activate: function(event) { this.actor._delegate = this;
this._app.open_new_window(event.get_time()); let draggable = DND.makeDraggable(this.actor);
let maybeStartDrag = draggable._maybeStartDrag;
draggable._maybeStartDrag = (event) => {
if (this._dragEnabled)
return maybeStartDrag.call(draggable, event);
return false;
};
draggable.connect('drag-begin', () => {
Shell.util_set_hidden_from_pick(Main.legacyTray.actor, true);
});
draggable.connect('drag-end', () => {
Shell.util_set_hidden_from_pick(Main.legacyTray.actor, false);
});
}
activate(event) {
this._app.open_new_window(-1);
this._button.selectCategory(null, null); this._button.selectCategory(null, null);
this._button.menu.toggle(); this._button.menu.toggle();
this.parent(event); super.activate(event);
}, }
setActive: function(active, params) { setActive(active, params) {
if (active) if (active)
this._button.scrollToButton(this); this._button.scrollToButton(this);
this.parent(active, params); super.setActive(active, params);
},
_getPreferredWidth: function(actor, forHeight, alloc) {
alloc.min_size = alloc.natural_size = -1;
},
_updateIcon: function() {
this._iconBin.set_child(this._app.create_icon_texture(APPLICATION_ICON_SIZE));
} }
});
const CategoryMenuItem = new Lang.Class({ setDragEnabled(enable) {
Name: 'CategoryMenuItem', this._dragEnabled = enable;
Extends: PopupMenu.PopupBaseMenuItem, }
_init: function(button, category) { getDragActor() {
this.parent(); return this._app.create_icon_texture(APPLICATION_ICON_SIZE);
this._category = category; }
getDragActorSource() {
return this._iconBin;
}
_updateIcon() {
this._iconBin.set_child(this.getDragActor());
}
};
class CategoryMenuItem extends PopupMenu.PopupBaseMenuItem {
constructor(button, category) {
super();
this._category = category;
this._button = button; this._button = button;
this._oldX = -1; this._oldX = -1;
@@ -112,17 +130,17 @@ const CategoryMenuItem = new Lang.Class({
else else
name = _("Favorites"); name = _("Favorites");
this.addActor(new St.Label({ text: name })); this.actor.add_child(new St.Label({ text: name }));
this.actor.connect('motion-event', Lang.bind(this, this._onMotionEvent)); this.actor.connect('motion-event', this._onMotionEvent.bind(this));
}, }
activate: function(event) { activate(event) {
this._button.selectCategory(this._category, this); this._button.selectCategory(this._category, this);
this._button.scrollToCatButton(this); this._button.scrollToCatButton(this);
this.parent(event); super.activate(event);
}, }
_isNavigatingSubmenu: function([x, y]) { _isNavigatingSubmenu([x, y]) {
let [posX, posY] = this.actor.get_transformed_position(); let [posX, posY] = this.actor.get_transformed_position();
if (this._oldX == -1) { if (this._oldX == -1) {
@@ -177,9 +195,9 @@ const CategoryMenuItem = new Lang.Class({
return true; return true;
return false; return false;
}, }
_onMotionEvent: function(actor, event) { _onMotionEvent(actor, event) {
if (!Clutter.get_pointer_grab()) { if (!Clutter.get_pointer_grab()) {
this._oldX = -1; this._oldX = -1;
this._oldY = -1; this._oldY = -1;
@@ -194,138 +212,300 @@ const CategoryMenuItem = new Lang.Class({
this._oldY = -1; this._oldY = -1;
this.actor.hover = false; this.actor.hover = false;
Clutter.ungrab_pointer(); Clutter.ungrab_pointer();
return false;
},
setActive: function(active, params) { let source = event.get_source();
if (source instanceof St.Widget)
source.sync_hover();
return false;
}
setActive(active, params) {
if (active) { if (active) {
this._button.selectCategory(this._category, this); this._button.selectCategory(this._category, this);
this._button.scrollToCatButton(this); this._button.scrollToCatButton(this);
} }
this.parent(active, params); super.setActive(active, params);
} }
}); };
const HotCorner = new Lang.Class({ class ApplicationsMenu extends PopupMenu.PopupMenu {
Name: 'HotCorner', constructor(sourceActor, arrowAlignment, arrowSide, button) {
Extends: Layout.HotCorner, super(sourceActor, arrowAlignment, arrowSide);
this._button = button;
}
_onCornerEntered : function() { isEmpty() {
if (!this._entered) {
this._entered = true;
if (!Main.overview.animationInProgress) {
this._activationTime = Date.now() / 1000;
this.rippleAnimation();
Main.overview.toggle();
}
}
return false; return false;
} }
});
const ApplicationsMenu = new Lang.Class({ open(animate) {
Name: 'ApplicationsMenu', this._button.hotCorner.setBarrierSize(0);
Extends: PopupMenu.PopupMenu, if (this._button.hotCorner.actor) // fallback corner
this._button.hotCorner.actor.hide();
super.open(animate);
}
_init: function(sourceActor, arrowAlignment, arrowSide, button, hotCorner) { close(animate) {
this.parent(sourceActor, arrowAlignment, arrowSide);
this._button = button;
this._hotCorner = hotCorner;
},
open: function(animate) {
this._hotCorner.setBarrierSize(0);
if (this._hotCorner.actor) // fallback corner
this._hotCorner.actor.hide();
this.parent(animate);
},
close: function(animate) {
let size = Main.layoutManager.panelBox.height; let size = Main.layoutManager.panelBox.height;
this._hotCorner.setBarrierSize(size); this._button.hotCorner.setBarrierSize(size);
if (this._hotCorner.actor) // fallback corner if (this._button.hotCorner.actor) // fallback corner
this._hotCorner.actor.show(); this._button.hotCorner.actor.show();
this.parent(animate); super.close(animate);
}, }
toggle: function() { toggle() {
if (this.isOpen) { if (this.isOpen) {
this._button.selectCategory(null, null); this._button.selectCategory(null, null);
} else { } else {
if (Main.overview.visible) if (Main.overview.visible)
Main.overview.hide(); Main.overview.hide();
} }
this.parent(); super.toggle();
} }
}); };
const ApplicationsButton = new Lang.Class({ class DesktopTarget {
Name: 'ApplicationsButton', constructor() {
Extends: PanelMenu.Button, this._desktop = null;
this._desktopDestroyedId = 0;
_init: function() { this._windowAddedId =
this.parent(1.0, null, false); global.window_group.connect('actor-added',
this._hotCorner = Main.layoutManager.hotCorners[Main.layoutManager.primaryIndex]; this._onWindowAdded.bind(this));
this.setMenu(new ApplicationsMenu(this.actor, 1.0, St.Side.TOP, this, this._hotCorner)); global.get_window_actors().forEach(a => {
this._onWindowAdded(a.get_parent(), a);
});
}
get hasDesktop() {
return this._desktop != null;
}
_onWindowAdded(group, actor) {
if (!(actor instanceof Meta.WindowActor))
return;
if (actor.meta_window.get_window_type() == Meta.WindowType.DESKTOP)
this._setDesktop(actor);
}
_setDesktop(desktop) {
if (this._desktop) {
this._desktop.disconnect(this._desktopDestroyedId);
this._desktopDestroyedId = 0;
delete this._desktop._delegate;
}
this._desktop = desktop;
this.emit('desktop-changed');
if (this._desktop) {
this._desktopDestroyedId = this._desktop.connect('destroy', () => {
this._setDesktop(null);
});
this._desktop._delegate = this;
}
}
_getSourceAppInfo(source) {
if (!(source instanceof ApplicationMenuItem))
return null;
return source._app.app_info;
}
_touchFile(file) {
let queryFlags = Gio.FileQueryInfoFlags.NONE;
let ioPriority = GLib.PRIORITY_DEFAULT;
let info = new Gio.FileInfo();
info.set_attribute_uint64(Gio.FILE_ATTRIBUTE_TIME_ACCESS,
GLib.get_real_time());
file.set_attributes_async (info, queryFlags, ioPriority, null,
(o, res) => {
try {
o.set_attributes_finish(res);
} catch(e) {
log('Failed to update access time: ' + e.message);
}
});
}
_markTrusted(file) {
let modeAttr = Gio.FILE_ATTRIBUTE_UNIX_MODE;
let trustedAttr = 'metadata::trusted';
let queryFlags = Gio.FileQueryInfoFlags.NONE;
let ioPriority = GLib.PRIORITY_DEFAULT;
file.query_info_async(modeAttr, queryFlags, ioPriority, null,
(o, res) => {
try {
let info = o.query_info_finish(res);
let mode = info.get_attribute_uint32(modeAttr) | 0o100;
info.set_attribute_uint32(modeAttr, mode);
info.set_attribute_string(trustedAttr, 'yes');
file.set_attributes_async (info, queryFlags, ioPriority, null,
(o, res) => {
o.set_attributes_finish(res);
// Hack: force nautilus to reload file info
this._touchFile(file);
});
} catch(e) {
log('Failed to mark file as trusted: ' + e.message);
}
});
}
destroy() {
if (this._windowAddedId)
global.window_group.disconnect(this._windowAddedId);
this._windowAddedId = 0;
this._setDesktop(null);
}
handleDragOver(source, actor, x, y, time) {
let appInfo = this._getSourceAppInfo(source);
if (!appInfo)
return DND.DragMotionResult.CONTINUE;
return DND.DragMotionResult.COPY_DROP;
}
acceptDrop(source, actor, x, y, time) {
let appInfo = this._getSourceAppInfo(source);
if (!appInfo)
return false;
this.emit('app-dropped');
let desktop = GLib.get_user_special_dir(GLib.UserDirectory.DIRECTORY_DESKTOP);
let src = Gio.File.new_for_path(appInfo.get_filename());
let dst = Gio.File.new_for_path(GLib.build_filenamev([desktop, src.get_basename()]));
try {
// copy_async() isn't introspectable :-(
src.copy(dst, Gio.FileCopyFlags.OVERWRITE, null, null);
this._markTrusted(dst);
} catch(e) {
log('Failed to copy to desktop: ' + e.message);
}
return true;
}
};
Signals.addSignalMethods(DesktopTarget.prototype);
let ApplicationsButton = GObject.registerClass(
class ApplicationsButton extends PanelMenu.Button {
_init() {
super._init(1.0, null, false);
this.setMenu(new ApplicationsMenu(this, 1.0, St.Side.TOP, this));
Main.panel.menuManager.addMenu(this.menu); Main.panel.menuManager.addMenu(this.menu);
// At this moment applications menu is not keyboard navigable at // At this moment applications menu is not keyboard navigable at
// all (so not accessible), so it doesn't make sense to set as // all (so not accessible), so it doesn't make sense to set as
// role ATK_ROLE_MENU like other elements of the panel. // role ATK_ROLE_MENU like other elements of the panel.
this.actor.accessible_role = Atk.Role.LABEL; this.accessible_role = Atk.Role.LABEL;
this._label = new St.Label({ text: _("Applications") }); let hbox = new St.BoxLayout({ style_class: 'panel-status-menu-box' });
this.actor.add_actor(this._label); this._label = new St.Label({ text: _("Applications"),
this.actor.name = 'panelApplications'; y_expand: true,
this.actor.label_actor = this._label; y_align: Clutter.ActorAlign.CENTER });
hbox.add_child(this._label);
hbox.add_child(PopupMenu.arrowIcon(St.Side.BOTTOM));
this.actor.connect('captured-event', Lang.bind(this, this._onCapturedEvent)); this.add_actor(hbox);
this.name = 'panelApplications';
this.label_actor = this._label;
_showingId = Main.overview.connect('showing', Lang.bind(this, function() { this.connect('captured-event', this._onCapturedEvent.bind(this));
this.actor.add_accessible_state (Atk.StateType.CHECKED);
}));
_hidingId = Main.overview.connect('hiding', Lang.bind(this, function() {
this.actor.remove_accessible_state (Atk.StateType.CHECKED);
}));
this._showingId = Main.overview.connect('showing', () => {
this.add_accessible_state (Atk.StateType.CHECKED);
});
this._hidingId = Main.overview.connect('hiding', () => {
this.remove_accessible_state (Atk.StateType.CHECKED);
});
Main.layoutManager.connect('startup-complete',
this._setKeybinding.bind(this));
this._setKeybinding();
this._desktopTarget = new DesktopTarget();
this._desktopTarget.connect('app-dropped', () => {
this.menu.close();
});
this._desktopTarget.connect('desktop-changed', () => {
this._applicationsButtons.forEach(item => {
item.setDragEnabled(this._desktopTarget.hasDesktop);
});
});
this._tree = new GMenu.Tree({ menu_basename: 'applications.menu' });
this._treeChangedId = this._tree.connect('changed',
this._onTreeChanged.bind(this));
this._applicationsButtons = new Map();
this.reloadFlag = false; this.reloadFlag = false;
this._createLayout(); this._createLayout();
this._display(); this._display();
_installedChangedId = appSys.connect('installed-changed', Lang.bind(this, function() { this._installedChangedId = appSys.connect('installed-changed',
if (this.menu.isOpen) { this._onTreeChanged.bind(this));
this._redisplay(); }
this.mainBox.show();
} else {
this.reloadFlag = true;
}
}));
// Since the hot corner uses stage coordinates, Clutter won't _onTreeChanged() {
// queue relayouts for us when the panel moves. Queue a relayout if (this.menu.isOpen) {
// when that happens. this._redisplay();
_panelBoxChangedId = Main.layoutManager.connect('panel-box-changed', Lang.bind(this, function() { this.mainBox.show();
container.queue_relayout(); } else {
})); this.reloadFlag = true;
}, }
}
_createVertSeparator: function() { get hotCorner() {
return Main.layoutManager.hotCorners[Main.layoutManager.primaryIndex];
}
_createVertSeparator() {
let separator = new St.DrawingArea({ style_class: 'calendar-vertical-separator', let separator = new St.DrawingArea({ style_class: 'calendar-vertical-separator',
pseudo_class: 'highlighted' }); pseudo_class: 'highlighted' });
separator.connect('repaint', Lang.bind(this, this._onVertSepRepaint)); separator.connect('repaint', this._onVertSepRepaint.bind(this));
return separator; return separator;
}, }
_onCapturedEvent: function(actor, event) { _onDestroy() {
Main.overview.disconnect(this._showingId);
Main.overview.disconnect(this._hidingId);
appSys.disconnect(this._installedChangedId);
this._tree.disconnect(this._treeChangedId);
this._tree = null;
Main.wm.setCustomKeybindingHandler('panel-main-menu',
Shell.ActionMode.NORMAL |
Shell.ActionMode.OVERVIEW,
Main.sessionMode.hasOverview ?
Main.overview.toggle.bind(Main.overview) :
null);
this._desktopTarget.destroy();
}
_onCapturedEvent(actor, event) {
if (event.type() == Clutter.EventType.BUTTON_PRESS) { if (event.type() == Clutter.EventType.BUTTON_PRESS) {
if (!Main.overview.shouldToggleByCornerOrButton()) if (!Main.overview.shouldToggleByCornerOrButton())
return true; return true;
} }
return false; return false;
}, }
_onMenuKeyPress: function(actor, event) { _onMenuKeyPress(actor, event) {
let symbol = event.get_key_symbol(); let symbol = event.get_key_symbol();
if (symbol == Clutter.KEY_Left || symbol == Clutter.KEY_Right) { if (symbol == Clutter.KEY_Left || symbol == Clutter.KEY_Right) {
let direction = symbol == Clutter.KEY_Left ? Gtk.DirectionType.LEFT let direction = symbol == Clutter.KEY_Left ? Gtk.DirectionType.LEFT
@@ -333,10 +513,10 @@ const ApplicationsButton = new Lang.Class({
if (this.menu.actor.navigate_focus(global.stage.key_focus, direction, false)) if (this.menu.actor.navigate_focus(global.stage.key_focus, direction, false))
return true; return true;
} }
return this.parent(actor, event); return super._onMenuKeyPress(actor, event);
}, }
_onVertSepRepaint: function(area) { _onVertSepRepaint(area) {
let cr = area.get_context(); let cr = area.get_context();
let themeNode = area.get_theme_node(); let themeNode = area.get_theme_node();
let [width, height] = area.get_surface_size(); let [width, height] = area.get_surface_size();
@@ -349,9 +529,9 @@ const ApplicationsButton = new Lang.Class({
cr.setDash([1, 3], 1); // Hard-code for now cr.setDash([1, 3], 1); // Hard-code for now
cr.setLineWidth(stippleWidth); cr.setLineWidth(stippleWidth);
cr.stroke(); cr.stroke();
}, }
_onOpenStateChanged: function(menu, open) { _onOpenStateChanged(menu, open) {
if (open) { if (open) {
if (this.reloadFlag) { if (this.reloadFlag) {
this._redisplay(); this._redisplay();
@@ -359,35 +539,50 @@ const ApplicationsButton = new Lang.Class({
} }
this.mainBox.show(); this.mainBox.show();
} }
this.parent(menu, open); super._onOpenStateChanged(menu, open);
}, }
_redisplay: function() { _setKeybinding() {
Main.wm.setCustomKeybindingHandler('panel-main-menu',
Shell.ActionMode.NORMAL |
Shell.ActionMode.OVERVIEW,
() => { this.menu.toggle(); });
}
_redisplay() {
this.applicationsBox.destroy_all_children(); this.applicationsBox.destroy_all_children();
this.categoriesBox.destroy_all_children(); this.categoriesBox.destroy_all_children();
this._display(); this._display();
}, }
_loadCategory: function(categoryId, dir) { _loadCategory(categoryId, dir) {
let iter = dir.iter(); let iter = dir.iter();
let nextType; let nextType;
while ((nextType = iter.next()) != GMenu.TreeItemType.INVALID) { while ((nextType = iter.next()) != GMenu.TreeItemType.INVALID) {
if (nextType == GMenu.TreeItemType.ENTRY) { if (nextType == GMenu.TreeItemType.ENTRY) {
let entry = iter.get_entry(); let entry = iter.get_entry();
if (!entry.get_app_info().get_nodisplay()) { let id;
let app = appSys.lookup_app_by_tree_entry(entry); try {
let menu_id = dir.get_menu_id(); id = entry.get_desktop_file_id(); // catch non-UTF8 filenames
this.applicationsByCategory[categoryId].push(app); } catch(e) {
continue;
} }
let app = appSys.lookup_app(id);
if (!app)
app = new Shell.App({ app_info: entry.get_app_info() });
if (app.get_app_info().should_show())
this.applicationsByCategory[categoryId].push(app);
} else if (nextType == GMenu.TreeItemType.SEPARATOR) {
this.applicationsByCategory[categoryId].push('separator');
} else if (nextType == GMenu.TreeItemType.DIRECTORY) { } else if (nextType == GMenu.TreeItemType.DIRECTORY) {
let subdir = iter.get_directory(); let subdir = iter.get_directory();
if (!subdir.get_is_nodisplay()) if (!subdir.get_is_nodisplay())
this._loadCategory(categoryId, subdir); this._loadCategory(categoryId, subdir);
} }
} }
}, }
scrollToButton: function(button) { scrollToButton(button) {
let appsScrollBoxAdj = this.applicationsScrollBox.get_vscroll_bar().get_adjustment(); let appsScrollBoxAdj = this.applicationsScrollBox.get_vscroll_bar().get_adjustment();
let appsScrollBoxAlloc = this.applicationsScrollBox.get_allocation_box(); let appsScrollBoxAlloc = this.applicationsScrollBox.get_allocation_box();
let currentScrollValue = appsScrollBoxAdj.get_value(); let currentScrollValue = appsScrollBoxAdj.get_value();
@@ -400,9 +595,9 @@ const ApplicationsButton = new Lang.Class({
newScrollValue = buttonAlloc.y2 - boxHeight + 10; newScrollValue = buttonAlloc.y2 - boxHeight + 10;
if (newScrollValue != currentScrollValue) if (newScrollValue != currentScrollValue)
appsScrollBoxAdj.set_value(newScrollValue); appsScrollBoxAdj.set_value(newScrollValue);
}, }
scrollToCatButton: function(button) { scrollToCatButton(button) {
let catsScrollBoxAdj = this.categoriesScrollBox.get_vscroll_bar().get_adjustment(); let catsScrollBoxAdj = this.categoriesScrollBox.get_vscroll_bar().get_adjustment();
let catsScrollBoxAlloc = this.categoriesScrollBox.get_allocation_box(); let catsScrollBoxAlloc = this.categoriesScrollBox.get_allocation_box();
let currentScrollValue = catsScrollBoxAdj.get_value(); let currentScrollValue = catsScrollBoxAdj.get_value();
@@ -415,9 +610,9 @@ const ApplicationsButton = new Lang.Class({
newScrollValue = buttonAlloc.y2 - boxHeight + 10; newScrollValue = buttonAlloc.y2 - boxHeight + 10;
if (newScrollValue != currentScrollValue) if (newScrollValue != currentScrollValue)
catsScrollBoxAdj.set_value(newScrollValue); catsScrollBoxAdj.set_value(newScrollValue);
}, }
_createLayout: function() { _createLayout() {
let section = new PopupMenu.PopupMenuSection(); let section = new PopupMenu.PopupMenuSection();
this.menu.addMenuItem(section); this.menu.addMenuItem(section);
this.mainBox = new St.BoxLayout({ vertical: false }); this.mainBox = new St.BoxLayout({ vertical: false });
@@ -427,23 +622,19 @@ const ApplicationsButton = new Lang.Class({
style_class: 'apps-menu vfade' }); style_class: 'apps-menu vfade' });
this.applicationsScrollBox.set_policy(Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC); this.applicationsScrollBox.set_policy(Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC);
let vscroll = this.applicationsScrollBox.get_vscroll_bar(); let vscroll = this.applicationsScrollBox.get_vscroll_bar();
vscroll.connect('scroll-start', Lang.bind(this, function() { vscroll.connect('scroll-start', () => {
this.menu.passEvents = true; this.menu.passEvents = true;
})); });
vscroll.connect('scroll-stop', Lang.bind(this, function() { vscroll.connect('scroll-stop', () => {
this.menu.passEvents = false; this.menu.passEvents = false;
})); });
this.categoriesScrollBox = new St.ScrollView({ x_fill: true, y_fill: false, this.categoriesScrollBox = new St.ScrollView({ x_fill: true, y_fill: false,
y_align: St.Align.START, y_align: St.Align.START,
style_class: 'vfade' }); style_class: 'vfade' });
this.categoriesScrollBox.set_policy(Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC); this.categoriesScrollBox.set_policy(Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC);
vscroll = this.categoriesScrollBox.get_vscroll_bar(); vscroll = this.categoriesScrollBox.get_vscroll_bar();
vscroll.connect('scroll-start', Lang.bind(this, function() { vscroll.connect('scroll-start', () => { this.menu.passEvents = true; });
this.menu.passEvents = true; vscroll.connect('scroll-stop', () => { this.menu.passEvents = false; });
}));
vscroll.connect('scroll-stop', Lang.bind(this, function() {
this.menu.passEvents = false;
}));
this.leftBox.add(this.categoriesScrollBox, { expand: true, this.leftBox.add(this.categoriesScrollBox, { expand: true,
x_fill: true, y_fill: true, x_fill: true, y_fill: true,
y_align: St.Align.START }); y_align: St.Align.START });
@@ -456,23 +647,23 @@ const ApplicationsButton = new Lang.Class({
this.applicationsBox = new St.BoxLayout({ vertical: true }); this.applicationsBox = new St.BoxLayout({ vertical: true });
this.applicationsScrollBox.add_actor(this.applicationsBox); this.applicationsScrollBox.add_actor(this.applicationsBox);
this.categoriesBox = new St.BoxLayout({ vertical: true }); this.categoriesBox = new St.BoxLayout({ vertical: true });
this.categoriesScrollBox.add_actor(this.categoriesBox, { expand: true, x_fill: false }); this.categoriesScrollBox.add_actor(this.categoriesBox);
this.mainBox.add(this.leftBox); this.mainBox.add(this.leftBox);
this.mainBox.add(this._createVertSeparator(), { expand: false, x_fill: false, y_fill: true}); this.mainBox.add(this._createVertSeparator(), { expand: false, x_fill: false, y_fill: true});
this.mainBox.add(this.applicationsScrollBox, { expand: true, x_fill: true, y_fill: true }); this.mainBox.add(this.applicationsScrollBox, { expand: true, x_fill: true, y_fill: true });
section.actor.add_actor(this.mainBox); section.actor.add_actor(this.mainBox);
}, }
_display: function() { _display() {
this._applicationsButtons = new Array(); this._applicationsButtons.clear();
this.mainBox.style=('width: 640px;'); this.mainBox.style=('width: 35em;');
this.mainBox.hide(); this.mainBox.hide();
//Load categories //Load categories
this.applicationsByCategory = {}; this.applicationsByCategory = {};
let tree = appSys.get_tree(); this._tree.load_sync();
let root = tree.get_root_directory(); let root = this._tree.get_root_directory();
let categoryMenuItem = new CategoryMenuItem(this, null); let categoryMenuItem = new CategoryMenuItem(this, null);
this.categoriesBox.add_actor(categoryMenuItem.actor); this.categoriesBox.add_actor(categoryMenuItem.actor);
let iter = root.iter(); let iter = root.iter();
@@ -495,45 +686,48 @@ const ApplicationsButton = new Lang.Class({
//Load applications //Load applications
this._displayButtons(this._listApplications(null)); this._displayButtons(this._listApplications(null));
let height = this.categoriesBox.height + MENU_HEIGHT_OFFSET + 'px'; let themeContext = St.ThemeContext.get_for_stage(global.stage);
let scaleFactor = themeContext.scale_factor;
let categoriesHeight = this.categoriesBox.height / scaleFactor;
let height = Math.round(categoriesHeight) + MENU_HEIGHT_OFFSET + 'px';
this.mainBox.style+=('height: ' + height); this.mainBox.style+=('height: ' + height);
}, }
_clearApplicationsBox: function(selectedActor) { selectCategory(dir, categoryMenuItem) {
let actors = this.applicationsBox.get_children(); this.applicationsBox.get_children().forEach(c => {
for (let i = 0; i < actors.length; i++) { if (c._delegate instanceof PopupMenu.PopupSeparatorMenuItem)
let actor = actors[i]; c._delegate.destroy();
this.applicationsBox.remove_actor(actor); else
} this.applicationsBox.remove_actor(c);
}, });
selectCategory: function(dir, categoryMenuItem) {
if (categoryMenuItem)
this._clearApplicationsBox(categoryMenuItem.actor);
else
this._clearApplicationsBox(null);
if (dir) if (dir)
this._displayButtons(this._listApplications(dir.get_menu_id())); this._displayButtons(this._listApplications(dir.get_menu_id()));
else else
this._displayButtons(this._listApplications(null)); this._displayButtons(this._listApplications(null));
}, }
_displayButtons: function(apps) { _displayButtons(apps) {
if (apps) { if (apps) {
for (let i = 0; i < apps.length; i++) { for (let i = 0; i < apps.length; i++) {
let app = apps[i]; let app = apps[i];
if (!this._applicationsButtons[app]) { let item;
let applicationMenuItem = new ApplicationMenuItem(this, app); if (app instanceof Shell.App)
this._applicationsButtons[app] = applicationMenuItem; item = this._applicationsButtons.get(app);
else
item = new PopupMenu.PopupSeparatorMenuItem();
if (!item) {
item = new ApplicationMenuItem(this, app);
item.setDragEnabled(this._desktopTarget.hasDesktop);
this._applicationsButtons.set(app, item);
} }
if (!this._applicationsButtons[app].actor.get_parent()) if (!item.actor.get_parent())
this.applicationsBox.add_actor(this._applicationsButtons[app].actor); this.applicationsBox.add_actor(item.actor);
} }
} }
}, }
_listApplications: function(category_menu_id) { _listApplications(category_menu_id) {
let applist; let applist;
if (category_menu_id) { if (category_menu_id) {
@@ -548,54 +742,24 @@ const ApplicationsButton = new Lang.Class({
} }
} }
applist.sort(function(a,b) {
return a.get_name().toLowerCase() > b.get_name().toLowerCase();
});
return applist; return applist;
},
destroy: function() {
this.menu.actor.get_children().forEach(function(c) { c.destroy() });
this.parent();
} }
}); });
let appsMenuButton; let appsMenuButton;
let activitiesButton; let activitiesButton;
let _hidingId;
let _installedChangedId;
let _panelBoxChangedId;
let _showingId;
function enable() { function enable() {
activitiesButton = Main.panel.statusArea['activities']; activitiesButton = Main.panel.statusArea['activities'];
activitiesButton.container.hide(); activitiesButton.container.hide();
appsMenuButton = new ApplicationsButton(); appsMenuButton = new ApplicationsButton();
Main.panel.addToStatusArea('apps-menu', appsMenuButton, 1, 'left'); Main.panel.addToStatusArea('apps-menu', appsMenuButton, 1, 'left');
Main.wm.setCustomKeybindingHandler('panel-main-menu',
Shell.KeyBindingMode.NORMAL |
Shell.KeyBindingMode.OVERVIEW,
function() {
appsMenuButton.menu.toggle();
});
} }
function disable() { function disable() {
Main.panel.menuManager.removeMenu(appsMenuButton.menu); Main.panel.menuManager.removeMenu(appsMenuButton.menu);
appSys.disconnect(_installedChangedId);
Main.layoutManager.disconnect(_panelBoxChangedId);
Main.overview.disconnect(_hidingId);
Main.overview.disconnect(_showingId);
appsMenuButton.destroy(); appsMenuButton.destroy();
activitiesButton.container.show(); activitiesButton.container.show();
Main.wm.setCustomKeybindingHandler('panel-main-menu',
Shell.KeyBindingMode.NORMAL |
Shell.KeyBindingMode.OVERVIEW,
Main.sessionMode.hasOverview ?
Lang.bind(Main.overview, Main.overview.toggle) :
null);
} }
function init(metadata) { function init(metadata) {
+5
View File
@@ -0,0 +1,5 @@
extension_data += configure_file(
input: metadata_name + '.in',
output: metadata_name,
configuration: metadata_conf
)
+1 -1
View File
@@ -3,7 +3,7 @@
"uuid": "@uuid@", "uuid": "@uuid@",
"gettext-domain": "@gettext_domain@", "gettext-domain": "@gettext_domain@",
"name": "Applications Menu", "name": "Applications Menu",
"description": "Add a category-based menu for applications.\nThis extension is part of Classic Mode and is officially supported by GNOME. Please do not report bugs using the form below, use GNOME Bugzilla instead.", "description": "Add a category-based menu for applications.\nThis extension is part of Classic Mode and is officially supported by GNOME. Please do not report bugs using the form below, use GNOME's GitLab instance instead.",
"original-authors": [ "e2002@bk.ru", "debarshir@gnome.org" ], "original-authors": [ "e2002@bk.ru", "debarshir@gnome.org" ],
"shell-version": [ "@shell_current@" ], "shell-version": [ "@shell_current@" ],
"url": "@url@" "url": "@url@"
-7
View File
@@ -1,7 +0,0 @@
EXTENSION_ID = auto-move-windows
EXTRA_MODULES = prefs.js
include ../../extension.mk
include ../../settings.mk
+109 -130
View File
@@ -1,13 +1,7 @@
// -*- mode: js2; indent-tabs-mode: nil; js2-basic-offset: 4 -*- // -*- mode: js2; indent-tabs-mode: nil; js2-basic-offset: 4 -*-
// Start apps on custom workspaces // Start apps on custom workspaces
const Glib = imports.gi.GLib;
const Gio = imports.gi.Gio;
const Lang = imports.lang;
const Mainloop = imports.mainloop;
const Meta = imports.gi.Meta;
const Shell = imports.gi.Shell; const Shell = imports.gi.Shell;
const St = imports.gi.St;
const Main = imports.ui.main; const Main = imports.ui.main;
@@ -15,153 +9,138 @@ const ExtensionUtils = imports.misc.extensionUtils;
const Me = ExtensionUtils.getCurrentExtension(); const Me = ExtensionUtils.getCurrentExtension();
const Convenience = Me.imports.convenience; const Convenience = Me.imports.convenience;
const SETTINGS_KEY = 'application-list'; class WindowMover {
constructor() {
this._settings = Convenience.getSettings();
this._appSystem = Shell.AppSystem.get_default();
this._appConfigs = new Map();
this._appData = new Map();
let settings; this._appsChangedId =
this._appSystem.connect('installed-changed',
this._updateAppData.bind(this));
const WindowMover = new Lang.Class({ this._settings.connect('changed', this._updateAppConfigs.bind(this));
Name: 'AutoMoveWindows.WindowMover', this._updateAppConfigs();
_init: function() {
this._settings = settings;
this._windowTracker = Shell.WindowTracker.get_default();
let display = global.screen.get_display();
// Connect after so the handler from ShellWindowTracker has already run
this._windowCreatedId = display.connect_after('window-created', Lang.bind(this, this._findAndMove));
},
destroy: function() {
if (this._windowCreatedId) {
global.screen.get_display().disconnect(this._windowCreatedId);
this._windowCreatedId = 0;
}
},
_ensureAtLeastWorkspaces: function(num, window) {
for (let j = global.screen.n_workspaces; j <= num; j++) {
window.change_workspace_by_index(j-1, false, global.get_current_time());
global.screen.append_new_workspace(false, 0);
}
},
_findAndMove: function(display, window, noRecurse) {
if (!this._windowTracker.is_window_interesting(window))
return;
let spaces = this._settings.get_strv(SETTINGS_KEY);
let app = this._windowTracker.get_window_app(window);
if (!app) {
if (!noRecurse) {
// window is not tracked yet
Mainloop.idle_add(Lang.bind(this, function() {
this._findAndMove(display, window, true);
return false;
}));
} else
log ('Cannot find application for window');
return;
}
let app_id = app.get_id();
for ( let j = 0 ; j < spaces.length; j++ ) {
let apps_to_space = spaces[j].split(":");
// Match application id
if (apps_to_space[0] == app_id) {
let workspace_num = parseInt(apps_to_space[1]) - 1;
if (workspace_num >= global.screen.n_workspaces)
this._ensureAtLeastWorkspaces(workspace_num, window);
window.change_workspace_by_index(workspace_num, false, global.get_current_time());
}
}
} }
});
_updateAppConfigs() {
this._appConfigs.clear();
this._settings.get_strv('application-list').forEach(v => {
let [appId, num] = v.split(':');
this._appConfigs.set(appId, parseInt(num) - 1);
});
this._updateAppData();
}
_updateAppData() {
let ids = [...this._appConfigs.keys()];
let removedApps = [...this._appData.keys()].filter(
a => !ids.includes(a.id)
);
removedApps.forEach(app => {
app.disconnect(this._appData.get(app).windowsChangedId);
this._appData.delete(app);
});
let addedApps = ids.map(id => this._appSystem.lookup_app(id)).filter(
app => app != null && !this._appData.has(app)
);
addedApps.forEach(app => {
let data = {
windowsChangedId: app.connect('windows-changed',
this._appWindowsChanged.bind(this)),
moveWindowsId: 0,
windows: app.get_windows()
}
this._appData.set(app, data);
});
}
destroy() {
if (this._appsChangedId) {
this._appSystem.disconnect(this._appsChangedId);
this._appsChangedId = 0;
}
if (this._settings) {
this._settings.run_dispose();
this._settings = null;
}
this._appConfigs.clear();
this._updateAppData();
}
_moveWindow(window, workspaceNum) {
if (window.skip_taskbar)
return;
// ensure we have the required number of workspaces
let workspaceManager = global.workspace_manager;
for (let i = workspaceManager.n_workspaces; i <= workspaceNum; i++) {
window.change_workspace_by_index(i - 1, false);
workspaceManager.append_new_workspace(false, 0);
}
window.change_workspace_by_index(workspaceNum, false);
}
_appWindowsChanged(app) {
let data = this._appData.get(app);
let windows = app.get_windows();
// If get_compositor_private() returns non-NULL on a removed windows,
// the window still exists and is just moved to a different workspace
// or something; assume it'll be added back immediately, so keep it
// to avoid moving it again
windows.push(...data.windows.filter(
w => !windows.includes(w) && w.get_compositor_private() != null
));
let workspaceNum = this._appConfigs.get(app.id);
windows.filter(w => !data.windows.includes(w)).forEach(window => {
this._moveWindow(window, workspaceNum);
});
data.windows = windows;
}
};
let prevCheckWorkspaces; let prevCheckWorkspaces;
let winMover; let winMover;
function init() { function init() {
Convenience.initTranslations(); Convenience.initTranslations();
settings = Convenience.getSettings();
} }
function myCheckWorkspaces() { function myCheckWorkspaces() {
let i; let keepAliveWorkspaces = [];
let emptyWorkspaces = new Array(Main._workspaces.length); let foundNonEmpty = false;
for (let i = this._workspaces.length - 1; i >= 0; i--) {
for (i = 0; i < Main._workspaces.length; i++) { if (!foundNonEmpty)
let lastRemoved = Main._workspaces[i]._lastRemovedWindow; foundNonEmpty = this._workspaces[i].list_windows().length > 0;
if (lastRemoved && else if (!this._workspaces[i]._keepAliveId)
(lastRemoved.get_window_type() == Meta.WindowType.SPLASHSCREEN || keepAliveWorkspaces.push(this._workspaces[i]);
lastRemoved.get_window_type() == Meta.WindowType.DIALOG ||
lastRemoved.get_window_type() == Meta.WindowType.MODAL_DIALOG))
emptyWorkspaces[i] = false;
else
emptyWorkspaces[i] = true;
} }
let windows = global.get_window_actors(); // make sure the original method only removes empty workspaces at the end
for (i = 0; i < windows.length; i++) { keepAliveWorkspaces.forEach(ws => { ws._keepAliveId = 1; });
let win = windows[i]; prevCheckWorkspaces.call(this);
keepAliveWorkspaces.forEach(ws => { delete ws._keepAliveId; });
if (win.get_meta_window().is_on_all_workspaces())
continue;
let workspaceIndex = win.get_workspace();
emptyWorkspaces[workspaceIndex] = false;
}
// If we don't have an empty workspace at the end, add one
if (!emptyWorkspaces[emptyWorkspaces.length -1]) {
global.screen.append_new_workspace(false, global.get_current_time());
emptyWorkspaces.push(false);
}
let activeWorkspaceIndex = global.screen.get_active_workspace_index();
let activeIsLast = activeWorkspaceIndex == global.screen.n_workspaces - 2;
let removingTrailWorkspaces = (emptyWorkspaces[activeWorkspaceIndex] &&
activeIsLast);
// Don't enter the overview when removing multiple empty workspaces at startup
let showOverview = (removingTrailWorkspaces &&
!emptyWorkspaces.every(function(x) { return x; }));
if (removingTrailWorkspaces) {
// "Merge" the empty workspace we are removing with the one at the end
Main.wm.blockAnimations();
}
// Delete other empty workspaces; do it from the end to avoid index changes
for (i = emptyWorkspaces.length - 2; i >= 0; i--) {
if (emptyWorkspaces[i])
global.screen.remove_workspace(Main._workspaces[i], global.get_current_time());
else
break;
}
if (removingTrailWorkspaces) {
global.screen.get_workspace_by_index(global.screen.n_workspaces - 1).activate(global.get_current_time());
Main.wm.unblockAnimations();
if (!Main.overview.visible && showOverview)
Main.overview.show();
}
Main._checkWorkspacesId = 0;
return false; return false;
} }
function enable() { function enable() {
prevCheckWorkspaces = Main._checkWorkspaces; prevCheckWorkspaces = Main.wm._workspaceTracker._checkWorkspaces;
if (Meta.prefs_get_dynamic_workspaces()) Main.wm._workspaceTracker._checkWorkspaces = myCheckWorkspaces;
Main._checkWorkspaces = myCheckWorkspaces;
winMover = new WindowMover(); winMover = new WindowMover();
} }
function disable() { function disable() {
Main._checkWorkspaces = prevCheckWorkspaces; Main.wm._workspaceTracker._checkWorkspaces = prevCheckWorkspaces;
winMover.destroy(); winMover.destroy();
} }
+8
View File
@@ -0,0 +1,8 @@
extension_data += configure_file(
input: metadata_name + '.in',
output: metadata_name,
configuration: metadata_conf
)
extension_sources += files('prefs.js')
extension_schemas += files(metadata_conf.get('gschemaname') + '.gschema.xml')
@@ -3,8 +3,8 @@
<key name="application-list" type="as"> <key name="application-list" type="as">
<!-- FIXME: should be a(su), when JS supports more of GVariant --> <!-- FIXME: should be a(su), when JS supports more of GVariant -->
<default>[ ]</default> <default>[ ]</default>
<_summary>Application and workspace list</_summary> <summary>Application and workspace list</summary>
<_description>A list of strings, each containing an application id (desktop file name), followed by a colon and the workspace number</_description> <description>A list of strings, each containing an application id (desktop file name), followed by a colon and the workspace number</description>
</key> </key>
</schema> </schema>
</schemalist> </schemalist>
+175 -175
View File
@@ -1,18 +1,13 @@
// -*- mode: js2; indent-tabs-mode: nil; js2-basic-offset: 4 -*- // -*- mode: js2; indent-tabs-mode: nil; js2-basic-offset: 4 -*-
// Start apps on custom workspaces // Start apps on custom workspaces
const GdkPixbuf = imports.gi.GdkPixbuf;
const Gio = imports.gi.Gio; const Gio = imports.gi.Gio;
const GLib = imports.gi.GLib;
const GObject = imports.gi.GObject; const GObject = imports.gi.GObject;
const GMenu = imports.gi.GMenu;
const Gtk = imports.gi.Gtk; const Gtk = imports.gi.Gtk;
const Lang = imports.lang;
const Mainloop = imports.mainloop;
const Gettext = imports.gettext.domain('gnome-shell-extensions'); const Gettext = imports.gettext.domain('gnome-shell-extensions');
const _ = Gettext.gettext; const _ = Gettext.gettext;
const N_ = function(e) { return e }; const N_ = e => e;
const ExtensionUtils = imports.misc.extensionUtils; const ExtensionUtils = imports.misc.extensionUtils;
const Me = ExtensionUtils.getCurrentExtension(); const Me = ExtensionUtils.getCurrentExtension();
@@ -30,220 +25,225 @@ const Columns = {
ADJUSTMENT: 4 ADJUSTMENT: 4
}; };
const Widget = new GObject.Class({ const Widget = GObject.registerClass({
Name: 'AutoMoveWindows.Prefs.Widget',
GTypeName: 'AutoMoveWindowsPrefsWidget', GTypeName: 'AutoMoveWindowsPrefsWidget',
Extends: Gtk.Grid, }, class Widget extends Gtk.Grid {
_init(params) {
super._init(params);
this.set_orientation(Gtk.Orientation.VERTICAL);
_init: function(params) { this._settings = Convenience.getSettings();
this.parent(params); this._settings.connect('changed', this._refresh.bind(this));
this.set_orientation(Gtk.Orientation.VERTICAL); this._changedPermitted = false;
this._settings = Convenience.getSettings(); this._store = new Gtk.ListStore();
this._settings.connect('changed', Lang.bind(this, this._refresh)); this._store.set_column_types([Gio.AppInfo, GObject.TYPE_STRING, Gio.Icon, GObject.TYPE_INT,
this._changedPermitted = false;
this._store = new Gtk.ListStore();
this._store.set_column_types([Gio.AppInfo, GObject.TYPE_STRING, Gio.Icon, GObject.TYPE_INT,
Gtk.Adjustment]); Gtk.Adjustment]);
this._treeView = new Gtk.TreeView({ model: this._store, let scrolled = new Gtk.ScrolledWindow({ shadow_type: Gtk.ShadowType.IN});
scrolled.set_policy(Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC);
this.add(scrolled);
this._treeView = new Gtk.TreeView({ model: this._store,
hexpand: true, vexpand: true }); hexpand: true, vexpand: true });
this._treeView.get_selection().set_mode(Gtk.SelectionMode.SINGLE); this._treeView.get_selection().set_mode(Gtk.SelectionMode.SINGLE);
let appColumn = new Gtk.TreeViewColumn({ expand: true, sort_column_id: Columns.DISPLAY_NAME, let appColumn = new Gtk.TreeViewColumn({ expand: true, sort_column_id: Columns.DISPLAY_NAME,
title: _("Application") }); title: _("Application") });
let iconRenderer = new Gtk.CellRendererPixbuf; let iconRenderer = new Gtk.CellRendererPixbuf;
appColumn.pack_start(iconRenderer, false); appColumn.pack_start(iconRenderer, false);
appColumn.add_attribute(iconRenderer, "gicon", Columns.ICON); appColumn.add_attribute(iconRenderer, "gicon", Columns.ICON);
let nameRenderer = new Gtk.CellRendererText; let nameRenderer = new Gtk.CellRendererText;
appColumn.pack_start(nameRenderer, true); appColumn.pack_start(nameRenderer, true);
appColumn.add_attribute(nameRenderer, "text", Columns.DISPLAY_NAME); appColumn.add_attribute(nameRenderer, "text", Columns.DISPLAY_NAME);
this._treeView.append_column(appColumn); this._treeView.append_column(appColumn);
let workspaceColumn = new Gtk.TreeViewColumn({ title: _("Workspace"), let workspaceColumn = new Gtk.TreeViewColumn({ title: _("Workspace"),
sort_column_id: Columns.WORKSPACE }); sort_column_id: Columns.WORKSPACE });
let workspaceRenderer = new Gtk.CellRendererSpin({ editable: true }); let workspaceRenderer = new Gtk.CellRendererSpin({ editable: true });
workspaceRenderer.connect('edited', Lang.bind(this, this._workspaceEdited)); workspaceRenderer.connect('edited', this._workspaceEdited.bind(this));
workspaceColumn.pack_start(workspaceRenderer, true); workspaceColumn.pack_start(workspaceRenderer, true);
workspaceColumn.add_attribute(workspaceRenderer, "adjustment", Columns.ADJUSTMENT); workspaceColumn.add_attribute(workspaceRenderer, "adjustment", Columns.ADJUSTMENT);
workspaceColumn.add_attribute(workspaceRenderer, "text", Columns.WORKSPACE); workspaceColumn.add_attribute(workspaceRenderer, "text", Columns.WORKSPACE);
this._treeView.append_column(workspaceColumn); this._treeView.append_column(workspaceColumn);
this.add(this._treeView); scrolled.add(this._treeView);
let toolbar = new Gtk.Toolbar(); let toolbar = new Gtk.Toolbar({ icon_size: Gtk.IconSize.SMALL_TOOLBAR });
toolbar.get_style_context().add_class(Gtk.STYLE_CLASS_INLINE_TOOLBAR); toolbar.get_style_context().add_class(Gtk.STYLE_CLASS_INLINE_TOOLBAR);
this.add(toolbar); this.add(toolbar);
let newButton = new Gtk.ToolButton({ stock_id: Gtk.STOCK_NEW, let newButton = new Gtk.ToolButton({ icon_name: 'bookmark-new-symbolic',
label: _("Add rule"), label: _("Add Rule"),
is_important: true }); is_important: true });
newButton.connect('clicked', Lang.bind(this, this._createNew)); newButton.connect('clicked', this._createNew.bind(this));
toolbar.add(newButton); toolbar.add(newButton);
let delButton = new Gtk.ToolButton({ stock_id: Gtk.STOCK_DELETE }); let delButton = new Gtk.ToolButton({ icon_name: 'edit-delete-symbolic' });
delButton.connect('clicked', Lang.bind(this, this._deleteSelected)); delButton.connect('clicked', this._deleteSelected.bind(this));
toolbar.add(delButton); toolbar.add(delButton);
this._changedPermitted = true; let selection = this._treeView.get_selection();
this._refresh(); selection.connect('changed', () => {
}, delButton.sensitive = selection.count_selected_rows() > 0;
});
delButton.sensitive = selection.count_selected_rows() > 0;
_createNew: function() { this._changedPermitted = true;
let dialog = new Gtk.Dialog({ title: _("Create new matching rule"), this._refresh();
transient_for: this.get_toplevel(), }
modal: true });
dialog.add_button(Gtk.STOCK_CANCEL, Gtk.ResponseType.CANCEL); _createNew() {
dialog.add_button(_("Add"), Gtk.ResponseType.OK); let dialog = new Gtk.Dialog({ title: _("Create new matching rule"),
transient_for: this.get_toplevel(),
use_header_bar: true,
modal: true });
dialog.add_button(Gtk.STOCK_CANCEL, Gtk.ResponseType.CANCEL);
let addButton = dialog.add_button(_("Add"), Gtk.ResponseType.OK);
dialog.set_default_response(Gtk.ResponseType.OK); dialog.set_default_response(Gtk.ResponseType.OK);
let grid = new Gtk.Grid({ column_spacing: 10, let grid = new Gtk.Grid({ column_spacing: 10,
row_spacing: 15, row_spacing: 15,
margin: 10 }); margin: 10 });
dialog._appChooser = new Gtk.AppChooserWidget({ show_all: true }); dialog._appChooser = new Gtk.AppChooserWidget({ show_all: true });
grid.attach(dialog._appChooser, 0, 0, 2, 1); dialog._appChooser.connect('application-selected', (w, appInfo) => {
grid.attach(new Gtk.Label({ label: _("Workspace") }), addButton.sensitive = appInfo && this._checkId(appInfo.get_id());
0, 1, 1, 1); });
let adjustment = new Gtk.Adjustment({ lower: 1, let appInfo = dialog._appChooser.get_app_info();
upper: WORKSPACE_MAX, addButton.sensitive = appInfo && this._checkId(appInfo.get_id());
step_increment: 1
grid.attach(dialog._appChooser, 0, 0, 2, 1);
grid.attach(new Gtk.Label({ label: _("Workspace"),
halign: Gtk.Align.END }), 0, 1, 1, 1);
let adjustment = new Gtk.Adjustment({ lower: 1,
upper: WORKSPACE_MAX,
step_increment: 1
}); });
dialog._spin = new Gtk.SpinButton({ adjustment: adjustment, dialog._spin = new Gtk.SpinButton({ adjustment: adjustment,
snap_to_ticks: true }); snap_to_ticks: true });
dialog._spin.set_value(1); dialog._spin.set_value(1);
grid.attach(dialog._spin, 1, 1, 1, 1); grid.attach(dialog._spin, 1, 1, 1, 1);
dialog.get_content_area().add(grid); dialog.get_content_area().add(grid);
dialog.connect('response', Lang.bind(this, function(dialog, id) { dialog.connect('response', (dialog, id) => {
if (id != Gtk.ResponseType.OK) { if (id != Gtk.ResponseType.OK) {
dialog.destroy(); dialog.destroy();
return;
}
let appInfo = dialog._appChooser.get_app_info();
if (!appInfo)
return;
let index = Math.floor(dialog._spin.value);
if (isNaN(index) || index < 0)
index = 1;
this._changedPermitted = false;
if (!this._appendItem(appInfo.get_id(), index)) {
this._changedPermitted = true;
return; return;
} }
let iter = this._store.append();
let adj = new Gtk.Adjustment({ lower: 1, let appInfo = dialog._appChooser.get_app_info();
upper: WORKSPACE_MAX, if (!appInfo)
step_increment: 1, return;
let index = Math.floor(dialog._spin.value);
if (isNaN(index) || index < 0)
index = 1;
this._changedPermitted = false;
this._appendItem(appInfo.get_id(), index);
this._changedPermitted = true;
let iter = this._store.append();
let adj = new Gtk.Adjustment({ lower: 1,
upper: WORKSPACE_MAX,
step_increment: 1,
value: index }); value: index });
this._store.set(iter, this._store.set(iter,
[Columns.APPINFO, Columns.ICON, Columns.DISPLAY_NAME, Columns.WORKSPACE, Columns.ADJUSTMENT], [Columns.APPINFO, Columns.ICON, Columns.DISPLAY_NAME, Columns.WORKSPACE, Columns.ADJUSTMENT],
[appInfo, appInfo.get_icon(), appInfo.get_display_name(), index, adj]); [appInfo, appInfo.get_icon(), appInfo.get_display_name(), index, adj]);
this._changedPermitted = true;
dialog.destroy(); dialog.destroy();
})); });
dialog.show_all(); dialog.show_all();
}, }
_deleteSelected: function() { _deleteSelected() {
let [any, model, iter] = this._treeView.get_selection().get_selected(); let [any, model, iter] = this._treeView.get_selection().get_selected();
if (any) { if (any) {
let appInfo = this._store.get_value(iter, Columns.APPINFO); let appInfo = this._store.get_value(iter, Columns.APPINFO);
this._changedPermitted = false; this._changedPermitted = false;
this._removeItem(appInfo.get_id()); this._removeItem(appInfo.get_id());
this._store.remove(iter); this._changedPermitted = true;
this._changedPermitted = true; this._store.remove(iter);
} }
}, }
_workspaceEdited: function(renderer, pathString, text) { _workspaceEdited(renderer, pathString, text) {
let index = parseInt(text); let index = parseInt(text);
if (isNaN(index) || index < 0) if (isNaN(index) || index < 0)
index = 1; index = 1;
let path = Gtk.TreePath.new_from_string(pathString); let path = Gtk.TreePath.new_from_string(pathString);
let [model, iter] = this._store.get_iter(path); let [model, iter] = this._store.get_iter(path);
let appInfo = this._store.get_value(iter, Columns.APPINFO); let appInfo = this._store.get_value(iter, Columns.APPINFO);
this._changedPermitted = false; this._changedPermitted = false;
this._changeItem(appInfo.get_id(), index); this._changeItem(appInfo.get_id(), index);
this._store.set_value(iter, Columns.WORKSPACE, index); this._store.set_value(iter, Columns.WORKSPACE, index);
this._changedPermitted = true; this._changedPermitted = true;
}, }
_refresh: function() { _refresh() {
if (!this._changedPermitted) if (!this._changedPermitted)
// Ignore this notification, model is being modified outside // Ignore this notification, model is being modified outside
return; return;
this._store.clear(); this._store.clear();
let currentItems = this._settings.get_strv(SETTINGS_KEY); let currentItems = this._settings.get_strv(SETTINGS_KEY);
let validItems = [ ]; let validItems = [ ];
for (let i = 0; i < currentItems.length; i++) { for (let i = 0; i < currentItems.length; i++) {
let [id, index] = currentItems[i].split(':'); let [id, index] = currentItems[i].split(':');
let appInfo = Gio.DesktopAppInfo.new(id); let appInfo = Gio.DesktopAppInfo.new(id);
if (!appInfo) if (!appInfo)
continue; continue;
validItems.push(currentItems[i]); validItems.push(currentItems[i]);
let iter = this._store.append(); let iter = this._store.append();
let adj = new Gtk.Adjustment({ lower: 1, let adj = new Gtk.Adjustment({ lower: 1,
upper: WORKSPACE_MAX, upper: WORKSPACE_MAX,
step_increment: 1, step_increment: 1,
value: index }); value: index });
this._store.set(iter, this._store.set(iter,
[Columns.APPINFO, Columns.ICON, Columns.DISPLAY_NAME, Columns.WORKSPACE, Columns.ADJUSTMENT], [Columns.APPINFO, Columns.ICON, Columns.DISPLAY_NAME, Columns.WORKSPACE, Columns.ADJUSTMENT],
[appInfo, appInfo.get_icon(), appInfo.get_display_name(), parseInt(index), adj]); [appInfo, appInfo.get_icon(), appInfo.get_display_name(), parseInt(index), adj]);
}
if (validItems.length != currentItems.length) // some items were filtered out
this._settings.set_strv(SETTINGS_KEY, validItems);
},
_appendItem: function(id, workspace) {
let currentItems = this._settings.get_strv(SETTINGS_KEY);
let alreadyHave = currentItems.map(function(el) {
return el.split(':')[0];
}).indexOf(id) != -1;
if (alreadyHave) {
printerr("Already have an item for this id");
return false;
} }
currentItems.push(id + ':' + workspace); if (validItems.length != currentItems.length) // some items were filtered out
this._settings.set_strv(SETTINGS_KEY, currentItems); this._settings.set_strv(SETTINGS_KEY, validItems);
return true; }
},
_removeItem: function(id) { _checkId(id) {
let currentItems = this._settings.get_strv(SETTINGS_KEY); let items = this._settings.get_strv(SETTINGS_KEY);
let index = currentItems.map(function(el) { return !items.some(i => i.startsWith(id + ':'));
return el.split(':')[0]; }
}).indexOf(id);
if (index < 0) _appendItem(id, workspace) {
return; let currentItems = this._settings.get_strv(SETTINGS_KEY);
currentItems.splice(index, 1); currentItems.push(id + ':' + workspace);
this._settings.set_strv(SETTINGS_KEY, currentItems); this._settings.set_strv(SETTINGS_KEY, currentItems);
}, }
_changeItem: function(id, workspace) { _removeItem(id) {
let currentItems = this._settings.get_strv(SETTINGS_KEY); let currentItems = this._settings.get_strv(SETTINGS_KEY);
let index = currentItems.map(function(el) { let index = currentItems.map(el => el.split(':')[0]).indexOf(id);
return el.split(':')[0];
}).indexOf(id);
if (index < 0) if (index < 0)
currentItems.push(id + ':' + workspace); return;
else currentItems.splice(index, 1);
currentItems[index] = id + ':' + workspace; this._settings.set_strv(SETTINGS_KEY, currentItems);
this._settings.set_strv(SETTINGS_KEY, currentItems); }
_changeItem(id, workspace) {
let currentItems = this._settings.get_strv(SETTINGS_KEY);
let index = currentItems.map(el => el.split(':')[0]).indexOf(id);
if (index < 0)
currentItems.push(id + ':' + workspace);
else
currentItems[index] = id + ':' + workspace;
this._settings.set_strv(SETTINGS_KEY, currentItems);
} }
}); });
@@ -253,7 +253,7 @@ function init() {
} }
function buildPrefsWidget() { function buildPrefsWidget() {
let widget = new Widget(); let widget = new Widget({ margin: 12 });
widget.show_all(); widget.show_all();
return widget; return widget;
-3
View File
@@ -1,3 +0,0 @@
EXTENSION_ID = drive-menu
include ../../extension.mk
+144 -126
View File
@@ -1,6 +1,7 @@
// Drive menu extension // Drive menu extension
const Clutter = imports.gi.Clutter;
const Gio = imports.gi.Gio; const Gio = imports.gi.Gio;
const Lang = imports.lang; const GObject = imports.gi.GObject;
const St = imports.gi.St; const St = imports.gi.St;
const Shell = imports.gi.Shell; const Shell = imports.gi.Shell;
@@ -17,113 +18,42 @@ const ExtensionUtils = imports.misc.extensionUtils;
const Me = ExtensionUtils.getCurrentExtension(); const Me = ExtensionUtils.getCurrentExtension();
const Convenience = Me.imports.convenience; const Convenience = Me.imports.convenience;
const MountMenuItem = new Lang.Class({ class MountMenuItem extends PopupMenu.PopupBaseMenuItem {
Name: 'DriveMenu.MountMenuItem', constructor(mount) {
Extends: PopupMenu.PopupBaseMenuItem, super();
_init: function(mount) { this.label = new St.Label({ text: mount.get_name() });
this.parent(); this.actor.add(this.label, { expand: true });
this.label = new St.Label({ text: mount.get_name() });
this.addActor(this.label);
this.actor.label_actor = this.label; this.actor.label_actor = this.label;
this.mount = mount; this.mount = mount;
let ejectIcon = new St.Icon({ icon_name: 'media-eject-symbolic', let ejectIcon = new St.Icon({ icon_name: 'media-eject-symbolic',
style_class: 'popup-menu-icon ' }); style_class: 'popup-menu-icon ' });
let ejectButton = new St.Button({ child: ejectIcon }); let ejectButton = new St.Button({ child: ejectIcon });
ejectButton.connect('clicked', Lang.bind(this, this._eject)); ejectButton.connect('clicked', this._eject.bind(this));
this.addActor(ejectButton); this.actor.add(ejectButton);
},
_eject: function() { this._changedId = mount.connect('changed', this._syncVisibility.bind(this));
let mountOp = new ShellMountOperation.ShellMountOperation(this.mount); this._syncVisibility();
if (this.mount.can_eject())
this.mount.eject_with_operation(Gio.MountUnmountFlags.NONE,
mountOp.mountOp,
null, // Gio.Cancellable
Lang.bind(this, this._ejectFinish));
else
this.mount.unmount_with_operation(Gio.MountUnmountFlags.NONE,
mountOp.mountOp,
null, // Gio.Cancellable
Lang.bind(this, this._unmountFinish));
},
_unmountFinish: function(mount, result) {
try {
mount.unmount_with_operation_finish(result);
} catch(e) {
this._reportFailure(e);
}
},
_ejectFinish: function(mount, result) {
try {
mount.eject_with_operation_finish(result);
} catch(e) {
this._reportFailure(e);
}
},
_reportFailure: function(exception) {
let msg = _("Ejecting drive '%s' failed:").format(this.mount.get_name());
Main.notifyError(msg, exception.message);
},
activate: function(event) {
Gio.AppInfo.launch_default_for_uri(this.mount.get_root().get_uri(),
global.create_app_launch_context());
this.parent(event);
} }
});
const DriveMenu = new Lang.Class({ destroy() {
Name: 'DriveMenu.DriveMenu', if (this._changedId) {
Extends: PanelMenu.SystemStatusButton, this.mount.disconnect(this._changedId);
this._changedId = 0;
}
_init: function() { super.destroy();
this.parent('media-eject-symbolic', _("Removable devices")); }
this._monitor = Gio.VolumeMonitor.get(); _isInteresting() {
this._addedId = this._monitor.connect('mount-added', Lang.bind(this, function(monitor, mount) { if (!this.mount.can_eject() && !this.mount.can_unmount())
this._addMount(mount); return false;
this._updateMenuVisibility(); if (this.mount.is_shadowed())
}));
this._removedId = this._monitor.connect('mount-removed', Lang.bind(this, function(monitor, mount) {
this._removeMount(mount);
this._updateMenuVisibility();
}));
this._mounts = [ ];
this._monitor.get_mounts().forEach(Lang.bind(this, this._addMount));
this.menu.addMenuItem(new PopupMenu.PopupSeparatorMenuItem());
this.menu.addAction(_("Open File"), function(event) {
let appSystem = Shell.AppSystem.get_default();
let app = appSystem.lookup_app('nautilus.desktop');
app.activate_full(-1, event.get_time());
});
this._updateMenuVisibility();
},
_updateMenuVisibility: function() {
if (this._mounts.length > 0)
this.actor.show();
else
this.actor.hide();
},
_isMountInteresting: function(mount) {
if (!mount.can_eject() && !mount.can_unmount())
return false; return false;
let volume = mount.get_volume(); let volume = this.mount.get_volume();
if (volume == null) { if (volume == null) {
// probably a GDaemonMount, could be network or // probably a GDaemonMount, could be network or
@@ -132,42 +62,130 @@ const DriveMenu = new Lang.Class({
} }
return volume.get_identifier('class') != 'network'; return volume.get_identifier('class') != 'network';
}, }
_addMount: function(mount) { _syncVisibility() {
if (!this._isMountInteresting(mount)) this.actor.visible = this._isInteresting();
return; }
let item = new MountMenuItem(mount); _eject() {
this._mounts.unshift(item); let mountOp = new ShellMountOperation.ShellMountOperation(this.mount);
this.menu.addMenuItem(item, 0);
},
_removeMount: function(mount) { if (this.mount.can_eject())
if (!this._isMountInteresting(mount)) this.mount.eject_with_operation(Gio.MountUnmountFlags.NONE,
return; mountOp.mountOp,
null, // Gio.Cancellable
this._ejectFinish.bind(this));
else
this.mount.unmount_with_operation(Gio.MountUnmountFlags.NONE,
mountOp.mountOp,
null, // Gio.Cancellable
this._unmountFinish.bind(this));
}
for (let i = 0; i < this._mounts.length; i++) { _unmountFinish(mount, result) {
let item = this._mounts[i]; try {
if (item.mount == mount) { mount.unmount_with_operation_finish(result);
item.destroy(); } catch(e) {
this._mounts.splice(i, 1); this._reportFailure(e);
return; }
} }
}
log ('Removing a mount that was never added to the menu');
},
destroy: function() { _ejectFinish(mount, result) {
if (this._connectedId) { try {
this._monitor.disconnect(this._connectedId); mount.eject_with_operation_finish(result);
this._monitor.disconnect(this._disconnectedId); } catch(e) {
this._connectedId = 0; this._reportFailure(e);
this._disconnectedId = 0; }
}
_reportFailure(exception) {
// TRANSLATORS: %s is the filesystem name
let msg = _("Ejecting drive “%s” failed:").format(this.mount.get_name());
Main.notifyError(msg, exception.message);
}
activate(event) {
let context = global.create_app_launch_context(event.get_time(), -1);
Gio.AppInfo.launch_default_for_uri(this.mount.get_root().get_uri(),
context);
super.activate(event);
}
};
let DriveMenu = GObject.registerClass(
class DriveMenu extends PanelMenu.Button {
_init() {
super._init(0.0, _("Removable devices"));
let hbox = new St.BoxLayout({ style_class: 'panel-status-menu-box' });
let icon = new St.Icon({ icon_name: 'media-eject-symbolic',
style_class: 'system-status-icon' });
hbox.add_child(icon);
hbox.add_child(PopupMenu.arrowIcon(St.Side.BOTTOM));
this.add_child(hbox);
this._monitor = Gio.VolumeMonitor.get();
this._addedId = this._monitor.connect('mount-added', (monitor, mount) => {
this._addMount(mount);
this._updateMenuVisibility();
});
this._removedId = this._monitor.connect('mount-removed', (monitor, mount) => {
this._removeMount(mount);
this._updateMenuVisibility();
});
this._mounts = [ ];
this._monitor.get_mounts().forEach(this._addMount.bind(this));
this.menu.addMenuItem(new PopupMenu.PopupSeparatorMenuItem());
this.menu.addAction(_("Open Files"), event => {
let appSystem = Shell.AppSystem.get_default();
let app = appSystem.lookup_app('org.gnome.Nautilus.desktop');
app.activate_full(-1, event.get_time());
});
this._updateMenuVisibility();
}
_updateMenuVisibility() {
if (this._mounts.filter(i => i.actor.visible).length > 0)
this.show();
else
this.hide();
}
_addMount(mount) {
let item = new MountMenuItem(mount);
this._mounts.unshift(item);
this.menu.addMenuItem(item, 0);
}
_removeMount(mount) {
for (let i = 0; i < this._mounts.length; i++) {
let item = this._mounts[i];
if (item.mount == mount) {
item.destroy();
this._mounts.splice(i, 1);
return;
}
}
log ('Removing a mount that was never added to the menu');
}
_onDestroy() {
if (this._addedId) {
this._monitor.disconnect(this._addedId);
this._monitor.disconnect(this._removedId);
this._addedId = 0;
this._removedId = 0;
} }
this.parent(); super._onDestroy();
}, }
}); });
function init() { function init() {
+5
View File
@@ -0,0 +1,5 @@
extension_data += configure_file(
input: metadata_name + '.in',
output: metadata_name,
configuration: metadata_conf
)
-6
View File
@@ -1,6 +0,0 @@
EXTENSION_ID = example
EXTRA_MODULES = prefs.js
include ../../extension.mk
include ../../settings.mk
-49
View File
@@ -1,49 +0,0 @@
// -*- mode: js2; indent-tabs-mode: nil; js2-basic-offset: 4 -*-
// Sample extension code, makes clicking on the panel show a message
const St = imports.gi.St;
const Mainloop = imports.mainloop;
const Gettext = imports.gettext.domain('gnome-shell-extensions');
const _ = Gettext.gettext;
const Main = imports.ui.main;
const ExtensionUtils = imports.misc.extensionUtils;
const Me = ExtensionUtils.getCurrentExtension();
const Convenience = Me.imports.convenience;
function _showHello() {
let settings = Convenience.getSettings();
let text = settings.get_string('hello-text') || _("Hello, world!");
let label = new St.Label({ style_class: 'helloworld-label', text: text });
let monitor = Main.layoutManager.primaryMonitor;
global.stage.add_actor(label);
label.set_position(Math.floor (monitor.width / 2 - label.width / 2), Math.floor(monitor.height / 2 - label.height / 2));
Mainloop.timeout_add(3000, function () { label.destroy(); });
}
// Put your extension initialization code here
function init(metadata) {
log ('Example extension initalized');
Convenience.initTranslations();
}
let signalId;
function enable() {
log ('Example extension enabled');
Main.panel.actor.reactive = true;
signalId = Main.panel.actor.connect('button-release-event', _showHello);
}
function disable() {
log ('Example extension disabled');
if (signalId) {
Main.panel.actor.disconnect(signalId);
signalId = 0;
}
}
-10
View File
@@ -1,10 +0,0 @@
{
"extension-id": "@extension_id@",
"uuid": "@uuid@",
"settings-schema": "@gschemaname@",
"gettext-domain": "@gettext_domain@",
"name": "Hello, World!",
"description": "An example extension to show how it works. Shows Hello, world when clicking on the top panel.",
"shell-version": [ "@shell_current@" ],
"url": "@url@"
}
@@ -1,9 +0,0 @@
<schemalist gettext-domain="gnome-shell-extensions">
<schema id="org.gnome.shell.extensions.example" path="/org/gnome/shell/extensions/example/">
<key name="hello-text" type="s">
<default>''</default>
<_summary>Alternative greeting text.</_summary>
<_description>If not empty, it contains the text that will be shown when clicking on the panel.</_description>
</key>
</schema>
</schemalist>
-52
View File
@@ -1,52 +0,0 @@
// -*- mode: js2; indent-tabs-mode: nil; js2-basic-offset: 4 -*-
const GLib = imports.gi.GLib;
const GObject = imports.gi.GObject;
const Gio = imports.gi.Gio;
const Gtk = imports.gi.Gtk;
const Gettext = imports.gettext.domain('gnome-shell-extensions');
const _ = Gettext.gettext;
const ExtensionUtils = imports.misc.extensionUtils;
const Me = ExtensionUtils.getCurrentExtension();
const Convenience = Me.imports.convenience;
function init() {
Convenience.initTranslations();
}
const ExamplePrefsWidget = new GObject.Class({
Name: 'Example.Prefs.Widget',
GTypeName: 'ExamplePrefsWidget',
Extends: Gtk.Grid,
_init: function(params) {
this.parent(params);
this.margin = this.row_spacing = this.column_spacing = 10;
// TRANSLATORS: Example is the name of the extension, should not be
// translated
let primaryText = _("Example aims to show how to build well behaved \
extensions for the Shell and as such it has little functionality on its own.\n\
Nevertheless it's possible to customize the greeting message.");
this.attach(new Gtk.Label({ label: primaryText, wrap: true }), 0, 0, 2, 1);
this.attach(new Gtk.Label({ label: '<b>' + _("Message:") + '</b>', use_markup: true }),
0, 1, 1, 1);
let entry = new Gtk.Entry({ hexpand: true });
this.attach(entry, 1, 1, 1, 1);
this._settings = Convenience.getSettings();
this._settings.bind('hello-text', entry, 'text', Gio.SettingsBindFlags.DEFAULT);
}
});
function buildPrefsWidget() {
let widget = new ExamplePrefsWidget();
widget.show_all();
return widget;
}
@@ -1,3 +0,0 @@
EXTENSION_ID = launch-new-instance
include ../../extension.mk
+6 -26
View File
@@ -1,37 +1,17 @@
const Main = imports.ui.main;
const AppDisplay = imports.ui.appDisplay; const AppDisplay = imports.ui.appDisplay;
var _onActivateOriginal = null; let _activateOriginal = null;
var _activateResultOriginal = null;
function _onActivate(event) {
this.emit('launching');
if (this._onActivateOverride) {
this._onActivateOverride(event);
} else {
this.app.open_new_window(-1);
}
Main.overview.hide();
}
function _activateResult(app) {
app.open_new_window(-1);
}
function init() { function init() {
} }
function enable() { function enable() {
_onActivateOriginal = AppDisplay.AppIcon.prototype._onActivate; _activateOriginal = AppDisplay.AppIcon.prototype.activate;
AppDisplay.AppIcon.prototype._onActivate = _onActivate; AppDisplay.AppIcon.prototype.activate = function() {
_activateOriginal.call(this, 2);
_activateResultOriginal = AppDisplay.AppSearchProvider.prototype.activateResult; };
AppDisplay.AppSearchProvider.prototype.activateResult = _activateResult;
} }
function disable() { function disable() {
AppDisplay.AppIcon.prototype._onActivate = _onActivateOriginal; AppDisplay.AppIcon.prototype.activate = _activateOriginal;
AppDisplay.AppSearchProvider.prototype.activateResult = _activateResultOriginal;
} }
@@ -0,0 +1,5 @@
extension_data += configure_file(
input: metadata_name + '.in',
output: metadata_name,
configuration: metadata_conf
)
@@ -4,7 +4,7 @@
"settings-schema": "@gschemaname@", "settings-schema": "@gschemaname@",
"gettext-domain": "@gettext_domain@", "gettext-domain": "@gettext_domain@",
"name": "Launch new instance", "name": "Launch new instance",
"description": "Always launch a new instance when clicking in the dash or the application view.\nThis extension is part of Classic Mode and is officially supported by GNOME. Please do not report bugs using the form below, use GNOME Bugzilla instead.", "description": "Always launch a new instance when clicking in the dash or the application view.\nThis extension is part of Classic Mode and is officially supported by GNOME. Please do not report bugs using the form below, use GNOME's GitLab instance instead.",
"shell-version": [ "@shell_current@" ], "shell-version": [ "@shell_current@" ],
"url": "@url@" "url": "@url@"
} }
+45
View File
@@ -0,0 +1,45 @@
extension_schemas = []
js_sources = extensionlib
metadata_name = 'metadata.json'
foreach e : all_extensions
uuid = e + uuid_suffix
metadata_conf = configuration_data()
metadata_conf.set('extension_id', e)
metadata_conf.set('uuid', uuid)
metadata_conf.set('gschemaname', 'org.gnome.shell.extensions.' + e)
metadata_conf.set('gettext_domain', gettext_domain)
metadata_conf.set('shell_current', shell_version)
metadata_conf.set('url', 'https://gitlab.gnome.org/GNOME/gnome-shell-extensions')
extension_sources = files(e + '/extension.js')
extension_data = files(e + '/stylesheet.css')
subdir(e)
js_sources += extension_sources
if (enabled_extensions.contains(e))
install_data (extension_sources + extension_data + extensionlib,
install_dir: join_paths(extensiondir, uuid)
)
endif
endforeach
install_data (extension_schemas,
install_dir: schemadir
)
foreach js_source : js_sources
if (js52.found())
path_array = '@0@'.format(js_source).split('/')
name = join_paths(path_array[-2], path_array[-1])
test('Checking syntax of ' + name, js52,
args: ['-s', '-c', js_source],
workdir: meson.current_source_dir()
)
endif
endforeach
+8
View File
@@ -0,0 +1,8 @@
extension_data += configure_file(
input: metadata_name + '.in',
output: metadata_name,
configuration: metadata_conf
)
# extension_sources += files('prefs.js')
# extension_schemas += files(metadata_conf.get('gschemaname') + '.gschema.xml')
@@ -1,5 +0,0 @@
EXTENSION_ID = native-window-placement
include ../../extension.mk
include ../../settings.mk
+53 -251
View File
@@ -1,24 +1,5 @@
// -*- mode: js2; indent-tabs-mode: nil; js2-basic-offset: 4 -*- // -*- mode: js2; indent-tabs-mode: nil; js2-basic-offset: 4 -*-
// import just everything from workspace.js:
const Clutter = imports.gi.Clutter;
const Gio = imports.gi.Gio;
const Lang = imports.lang;
const Mainloop = imports.mainloop;
const Meta = imports.gi.Meta;
const Pango = imports.gi.Pango;
const Shell = imports.gi.Shell;
const St = imports.gi.St;
const Signals = imports.signals;
const DND = imports.ui.dnd;
const Lightbox = imports.ui.lightbox;
const Main = imports.ui.main;
const Overview = imports.ui.overview;
const Panel = imports.ui.panel;
const Tweener = imports.ui.tweener;
const Workspace = imports.ui.workspace; const Workspace = imports.ui.workspace;
const WindowPositionFlags = Workspace.WindowPositionFlags;
const ExtensionUtils = imports.misc.extensionUtils; const ExtensionUtils = imports.misc.extensionUtils;
const Me = ExtensionUtils.getCurrentExtension(); const Me = ExtensionUtils.getCurrentExtension();
@@ -31,40 +12,19 @@ const WINDOW_PLACEMENT_NATURAL_ACCURACY = 20; // accuracy
const WINDOW_PLACEMENT_NATURAL_GAPS = 5; // half of the minimum gap between windows const WINDOW_PLACEMENT_NATURAL_GAPS = 5; // half of the minimum gap between windows
const WINDOW_PLACEMENT_NATURAL_MAX_TRANSLATIONS = 5000; // safety limit for preventing endless loop if something is wrong in the algorithm const WINDOW_PLACEMENT_NATURAL_MAX_TRANSLATIONS = 5000; // safety limit for preventing endless loop if something is wrong in the algorithm
const PLACE_WINDOW_CAPTIONS_ON_TOP = true; // place window titles in overview on top of windows with overlap parameter class Rect {
constructor(x, y, width, height) {
const WORKSPACE_BORDER_GAP = 10; // minimum gap between the workspace area and the workspace selector
const WINDOW_AREA_TOP_GAP = 20; // minimum gap between the workspace area and the top border. This keeps window captions and close buttons visible. 13px (26/2) should currently be enough.
const BUTTON_LAYOUT_SCHEMA = 'org.gnome.shell.overrides';
const BUTTON_LAYOUT_KEY = 'button-layout';
function injectToFunction(parent, name, func) {
let origin = parent[name];
parent[name] = function() {
let ret;
ret = origin.apply(this, arguments);
if (ret === undefined)
ret = func.apply(this, arguments);
return ret;
}
}
const Rect = new Lang.Class({
Name: 'NativeWindowPlacement.Rect',
_init: function(x, y, width, height) {
[this.x, this.y, this.width, this.height] = [x, y, width, height]; [this.x, this.y, this.width, this.height] = [x, y, width, height];
}, }
/** /**
* used in _calculateWindowTransformationsNatural to replace Meta.Rectangle that is too slow. * used in _calculateWindowTransformationsNatural to replace Meta.Rectangle that is too slow.
*/ */
copy: function() { copy() {
return new Rect(this.x, this.y, this.width, this.height); return new Rect(this.x, this.y, this.width, this.height);
}, }
union: function(rect2) { union(rect2) {
let dest = this.copy(); let dest = this.copy();
if (rect2.x < dest.x) if (rect2.x < dest.x)
{ {
@@ -82,75 +42,64 @@ const Rect = new Lang.Class({
dest.height = rect2.y + rect2.height - dest.y; dest.height = rect2.y + rect2.height - dest.y;
return dest; return dest;
}, }
adjusted: function(dx, dy, dx2, dy2) { adjusted(dx, dy, dx2, dy2) {
let dest = this.copy(); let dest = this.copy();
dest.x += dx; dest.x += dx;
dest.y += dy; dest.y += dy;
dest.width += -dx + dx2; dest.width += -dx + dx2;
dest.height += -dy + dy2; dest.height += -dy + dy2;
return dest; return dest;
}, }
overlap: function(rect2) { overlap(rect2) {
return !((this.x + this.width <= rect2.x) || return !((this.x + this.width <= rect2.x) ||
(rect2.x + rect2.width <= this.x) || (rect2.x + rect2.width <= this.x) ||
(this.y + this.height <= rect2.y) || (this.y + this.height <= rect2.y) ||
(rect2.y + rect2.height <= this.y)); (rect2.y + rect2.height <= this.y));
}, }
center: function() { center() {
return [this.x + this.width / 2, this.y + this.height / 2]; return [this.x + this.width / 2, this.y + this.height / 2];
}, }
translate: function(dx, dy) { translate(dx, dy) {
this.x += dx; this.x += dx;
this.y += dy; this.y += dy;
} }
}); };
let winInjections, workspaceInjections, connectedSignals; class NaturalLayoutStrategy extends Workspace.LayoutStrategy {
constructor(settings) {
super();
this._settings = settings;
}
function resetState() { computeLayout(windows, layout) {
winInjections = { }; layout.windows = windows;
workspaceInjections = { }; }
connectedSignals = [ ];
}
function enable() {
resetState();
let settings = Convenience.getSettings();
let useMoreScreen = settings.get_boolean('use-more-screen');
let windowCaptionsOnTop = settings.get_boolean('window-captions-on-top');
let signalId = settings.connect('changed::use-more-screen', function() {
useMoreScreen = settings.get_boolean('use-more-screen');
});
connectedSignals.push({ obj: settings, id: signalId });
/** /**
* _calculateWindowTransformationsNatural:
* @clones: Array of #MetaWindow
*
* Returns clones with matching target coordinates and scales to arrange windows in a natural way that no overlap exists and relative window size is preserved. * Returns clones with matching target coordinates and scales to arrange windows in a natural way that no overlap exists and relative window size is preserved.
* This function is almost a 1:1 copy of the function * This function is almost a 1:1 copy of the function
* PresentWindowsEffect::calculateWindowTransformationsNatural() from KDE, see: * PresentWindowsEffect::calculateWindowTransformationsNatural() from KDE, see:
* https://projects.kde.org/projects/kde/kdebase/kde-workspace/repository/revisions/master/entry/kwin/effects/presentwindows/presentwindows.cpp * https://projects.kde.org/projects/kde/kdebase/kde-workspace/repository/revisions/master/entry/kwin/effects/presentwindows/presentwindows.cpp
*/ */
Workspace.Workspace.prototype._calculateWindowTransformationsNatural = function(clones, area) { computeWindowSlots(layout, area) {
// As we are using pseudo-random movement (See "slot") we need to make sure the list // As we are using pseudo-random movement (See "slot") we need to make sure the list
// is always sorted the same way no matter which window is currently active. // is always sorted the same way no matter which window is currently active.
let area_rect = new Rect(area.x, area.y, area.width, area.height); let area_rect = new Rect(area.x, area.y, area.width, area.height);
let bounds = area_rect.copy(); let bounds = area_rect.copy();
let clones = layout.windows;
let direction = 0; let direction = 0;
let directions = []; let directions = [];
let rects = []; let rects = [];
for (let i = 0; i < clones.length; i++) { for (let i = 0; i < clones.length; i++) {
// save rectangles into 4-dimensional arrays representing two corners of the rectangular: [left_x, top_y, right_x, bottom_y] // save rectangles into 4-dimensional arrays representing two corners of the rectangular: [left_x, top_y, right_x, bottom_y]
let rect = clones[i].metaWindow.get_outer_rect(); let rect = clones[i].metaWindow.get_frame_rect();
rects[i] = new Rect(rect.x, rect.y, rect.width, rect.height); rects[i] = new Rect(rect.x, rect.y, rect.width, rect.height);
bounds = bounds.union(rects[i]); bounds = bounds.union(rects[i]);
@@ -201,7 +150,7 @@ function enable() {
rects[j].translate(diff[0], diff[1]); rects[j].translate(diff[0], diff[1]);
if (useMoreScreen) { if (this._settings.get_boolean('use-more-screen')) {
// Try to keep the bounding rect the same aspect as the screen so that more // Try to keep the bounding rect the same aspect as the screen so that more
// screen real estate is utilised. We do this by splitting the screen into nine // screen real estate is utilised. We do this by splitting the screen into nine
// equal sections, if the window center is in any of the corner sections pull the // equal sections, if the window center is in any of the corner sections pull the
@@ -291,185 +240,39 @@ function enable() {
return slots; return slots;
} }
workspaceInjections['_calculateWindowTransformationsNatural'] = undefined; };
/** let winInjections, workspaceInjections;
* _updateWindowPositions:
* @flags:
* INITIAL - this is the initial positioning of the windows.
* ANIMATE - Indicates that we need animate changing position.
*/
workspaceInjections['_updateWindowPositions'] = Workspace.Workspace.prototype._updateWindowPositions;
Workspace.Workspace.prototype._updateWindowPositions = function(flags) {
if (this._currentLayout == null) {
this._recalculateWindowPositions(flags);
return;
}
let initialPositioning = flags & WindowPositionFlags.INITIAL; function resetState() {
let animate = flags & WindowPositionFlags.ANIMATE; winInjections = { };
workspaceInjections = { };
}
let layout = this._currentLayout; function enable() {
let strategy = layout.strategy; resetState();
let [, , padding] = this._getSpacingAndPadding(); let settings = Convenience.getSettings();
let area = Workspace.padArea(this._actualGeometry, padding);
/// EDIT replace this version by our own:
//let slots = strategy.computeWindowSlots(layout, area);
/// EDIT copied from _realRecalculateWindowPositions:
let clones = this._windows.slice();
if (clones.length == 0)
return;
clones.sort(function(a, b) {
return a.metaWindow.get_stable_sequence() - b.metaWindow.get_stable_sequence();
});
if (this._reservedSlot)
clones.push(this._reservedSlot);
/// EDIT our own window placement function:
let slots = this._calculateWindowTransformationsNatural(clones, area);
let currentWorkspace = global.screen.get_active_workspace();
let isOnCurrentWorkspace = this.metaWorkspace == null || this.metaWorkspace == currentWorkspace;
for (let i = 0; i < slots.length; i++) {
let slot = slots[i];
let [x, y, scale, clone] = slot;
let metaWindow = clone.metaWindow;
let overlay = clone.overlay;
clone.slotId = i;
// Positioning a window currently being dragged must be avoided;
// we'll just leave a blank spot in the layout for it.
if (clone.inDrag)
continue;
let cloneWidth = clone.actor.width * scale;
let cloneHeight = clone.actor.height * scale;
clone.slot = [x, y, cloneWidth, cloneHeight];
if (overlay && (initialPositioning || !clone.positioned))
overlay.hide();
if (!clone.positioned) {
// This window appeared after the overview was already up
// Grow the clone from the center of the slot
clone.actor.x = x + cloneWidth / 2;
clone.actor.y = y + cloneHeight / 2;
clone.actor.scale_x = 0;
clone.actor.scale_y = 0;
clone.positioned = true;
}
if (animate && isOnCurrentWorkspace) {
if (!metaWindow.showing_on_its_workspace()) {
/* Hidden windows should fade in and grow
* therefore we need to resize them now so they
* can be scaled up later */
if (initialPositioning) {
clone.actor.opacity = 0;
clone.actor.scale_x = 0;
clone.actor.scale_y = 0;
clone.actor.x = x;
clone.actor.y = y;
}
Tweener.addTween(clone.actor,
{ opacity: 255,
time: Overview.ANIMATION_TIME,
transition: 'easeInQuad'
});
}
this._animateClone(clone, overlay, x, y, scale, initialPositioning);
} else {
// cancel any active tweens (otherwise they might override our changes)
Tweener.removeTweens(clone.actor);
clone.actor.set_position(x, y);
clone.actor.set_scale(scale, scale);
clone.overlay.relayout(false);
this._showWindowOverlay(clone, overlay, isOnCurrentWorkspace);
}
}
}
workspaceInjections['_getBestLayout'] = Workspace.Workspace.prototype._getBestLayout;
Workspace.Workspace.prototype._getBestLayout = function(windows) {
let strategy = new NaturalLayoutStrategy(settings);
let layout = { strategy };
strategy.computeLayout(windows, layout);
return layout;
}
/// position window titles on top of windows in overlay //// /// position window titles on top of windows in overlay ////
if (windowCaptionsOnTop) { winInjections['relayout'] = Workspace.WindowOverlay.prototype.relayout;
Workspace.WindowOverlay.prototype.relayout = function(animate) {
if (settings.get_boolean('window-captions-on-top')) {
let [, , , cloneHeight] = this._windowClone.slot;
this.title.translation_y = -cloneHeight;
}
/// This is almost a direct copy of the original relayout function. Differences are marked. winInjections['relayout'].call(this, animate);
winInjections['relayout'] = Workspace.WindowOverlay.prototype.relayout; };
Workspace.WindowOverlay.prototype.relayout = function(animate) {
let button = this.closeButton;
let title = this.title;
let border = this.border;
Tweener.removeTweens(button);
Tweener.removeTweens(title);
Tweener.removeTweens(border);
let [cloneX, cloneY, cloneWidth, cloneHeight] = this._windowClone.slot;
let layout = Meta.prefs_get_button_layout();
let side = layout.left_buttons.indexOf(Meta.ButtonFunction.CLOSE) > -1 ? St.Side.LEFT : St.Side.RIGHT;
let buttonX;
let buttonY = cloneY - (button.height - button._overlap);
if (side == St.Side.LEFT)
buttonX = cloneX - (button.width - button._overlap);
else
buttonX = cloneX + (cloneWidth - button._overlap);
if (animate)
this._animateOverlayActor(button, Math.floor(buttonX), Math.floor(buttonY), button.width);
else
button.set_position(Math.floor(buttonX), Math.floor(buttonY));
// Clutter.Actor.get_preferred_width() will return the fixed width if one
// is set, so we need to reset the width by calling set_width(-1), to forward
// the call down to StLabel.
// We also need to save and restore the current width, otherwise the animation
// starts from the wrong point.
let prevTitleWidth = title.width;
title.set_width(-1);
let [titleMinWidth, titleNatWidth] = title.get_preferred_width(-1);
let titleWidth = Math.max(titleMinWidth, Math.min(titleNatWidth, cloneWidth));
title.width = prevTitleWidth;
let titleX = cloneX + (cloneWidth - titleWidth) / 2;
/// this is the actual difference to original gnome-shell:
//let titleY = cloneY + cloneHeight + title._spacing;
let titleY = cloneY - title.height + title._spacing;
if (animate)
this._animateOverlayActor(title, Math.floor(titleX), Math.floor(titleY), titleWidth);
else {
title.width = titleWidth;
title.set_position(Math.floor(titleX), Math.floor(titleY));
}
let borderX = cloneX - this.borderSize;
let borderY = cloneY - this.borderSize;
let borderWidth = cloneWidth + 2 * this.borderSize;
let borderHeight = cloneHeight + 2 * this.borderSize;
if (animate) {
this._animateOverlayActor(this.border, borderX, borderY,
borderWidth, borderHeight);
} else {
this.border.set_position(borderX, borderY);
this.border.set_size(borderWidth, borderHeight);
}
};
}
} }
function removeInjection(object, injection, name) { function removeInjection(object, injection, name) {
@@ -480,14 +283,13 @@ function removeInjection(object, injection, name) {
} }
function disable() { function disable() {
var i;
for (i in workspaceInjections) for (i in workspaceInjections)
removeInjection(Workspace.Workspace.prototype, workspaceInjections, i); removeInjection(Workspace.Workspace.prototype, workspaceInjections, i);
for (i in winInjections) for (i in winInjections)
removeInjection(Workspace.WindowOverlay.prototype, winInjections, i); removeInjection(Workspace.WindowOverlay.prototype, winInjections, i);
for each (i in connectedSignals)
i.obj.disconnect(i.id);
global.stage.queue_relayout(); global.stage.queue_relayout();
resetState(); resetState();
} }
@@ -0,0 +1,7 @@
extension_data += configure_file(
input: metadata_name + '.in',
output: metadata_name,
configuration: metadata_conf
)
extension_schemas += files(metadata_conf.get('gschemaname') + '.gschema.xml')
@@ -2,15 +2,15 @@
<schema id="org.gnome.shell.extensions.native-window-placement" path="/org/gnome/shell/extensions/native-window-placement/"> <schema id="org.gnome.shell.extensions.native-window-placement" path="/org/gnome/shell/extensions/native-window-placement/">
<key name="use-more-screen" type="b"> <key name="use-more-screen" type="b">
<default>true</default> <default>true</default>
<_summary>Use more screen for windows</_summary> <summary>Use more screen for windows</summary>
<_description>Try to use more screen for placing window thumbnails by adapting to screen aspect ratio, and consolidating <description>Try to use more screen for placing window thumbnails by adapting to screen aspect ratio, and consolidating
them further to reduce the bounding box. This setting applies only with the natural placement strategy.</_description> them further to reduce the bounding box. This setting applies only with the natural placement strategy.</description>
</key> </key>
<key name="window-captions-on-top" type="b"> <key name="window-captions-on-top" type="b">
<default>true</default> <default>true</default>
<_summary>Place window captions on top</_summary> <summary>Place window captions on top</summary>
<_description>If true, place window captions on top the respective thumbnail, overriding shell default of placing it at <description>If true, place window captions on top the respective thumbnail, overriding shell default of placing it at
the bottom. Changing this setting requires restarting the shell to have any effect.</_description> the bottom. Changing this setting requires restarting the shell to have any effect.</description>
</key> </key>
</schema> </schema>
</schemalist> </schemalist>
-5
View File
@@ -1,5 +0,0 @@
EXTENSION_ID = places-menu
EXTRA_MODULES = placeDisplay.js
include ../../extension.mk
+63 -53
View File
@@ -1,8 +1,9 @@
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */ /* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
const Clutter = imports.gi.Clutter;
const Gio = imports.gi.Gio; const Gio = imports.gi.Gio;
const GLib = imports.gi.GLib; const GLib = imports.gi.GLib;
const Lang = imports.lang; const GObject = imports.gi.GObject;
const Shell = imports.gi.Shell; const Shell = imports.gi.Shell;
const St = imports.gi.St; const St = imports.gi.St;
@@ -13,7 +14,7 @@ const Panel = imports.ui.panel;
const Gettext = imports.gettext.domain('gnome-shell-extensions'); const Gettext = imports.gettext.domain('gnome-shell-extensions');
const _ = Gettext.gettext; const _ = Gettext.gettext;
const N_ = function(x) { return x; } const N_ = x => x;
const ExtensionUtils = imports.misc.extensionUtils; const ExtensionUtils = imports.misc.extensionUtils;
const Me = ExtensionUtils.getCurrentExtension(); const Me = ExtensionUtils.getCurrentExtension();
@@ -22,45 +23,50 @@ const PlaceDisplay = Me.imports.placeDisplay;
const PLACE_ICON_SIZE = 16; const PLACE_ICON_SIZE = 16;
const PlaceMenuItem = new Lang.Class({ class PlaceMenuItem extends PopupMenu.PopupBaseMenuItem {
Name: 'PlaceMenuItem', constructor(info) {
Extends: PopupMenu.PopupBaseMenuItem, super();
this._info = info;
_init: function(info) {
this.parent();
this._info = info;
this._icon = new St.Icon({ gicon: info.icon, this._icon = new St.Icon({ gicon: info.icon,
icon_size: PLACE_ICON_SIZE }); icon_size: PLACE_ICON_SIZE });
this.addActor(this._icon); this.actor.add_child(this._icon);
this._label = new St.Label({ text: info.name }); this._label = new St.Label({ text: info.name, x_expand: true });
this.addActor(this._label); this.actor.add_child(this._label);
if (info.isRemovable()) {
this._ejectIcon = new St.Icon({ icon_name: 'media-eject-symbolic',
style_class: 'popup-menu-icon ' });
this._ejectButton = new St.Button({ child: this._ejectIcon });
this._ejectButton.connect('clicked', info.eject.bind(info));
this.actor.add_child(this._ejectButton);
}
this._changedId = info.connect('changed', this._changedId = info.connect('changed',
Lang.bind(this, this._propertiesChanged)); this._propertiesChanged.bind(this));
}, }
destroy: function() { destroy() {
if (this._changedId) { if (this._changedId) {
this._info.disconnect(this._changedId); this._info.disconnect(this._changedId);
this._changedId = 0; this._changedId = 0;
} }
this.parent(); super.destroy();
}, }
activate: function(event) { activate(event) {
this._info.launch(event.get_time()); this._info.launch(event.get_time());
this.parent(event); super.activate(event);
}, }
_propertiesChanged: function(info) { _propertiesChanged(info) {
this._icon.gicon = info.icon; this._icon.gicon = info.icon;
this._label.text = info.name; this._label.text = info.name;
}, }
}); };
const SECTIONS = [ const SECTIONS = [
'special', 'special',
@@ -69,50 +75,54 @@ const SECTIONS = [
'network' 'network'
] ]
const PlacesMenu = new Lang.Class({ let PlacesMenu = GObject.registerClass(
Name: 'PlacesMenu.PlacesMenu', class PlacesMenu extends PanelMenu.Button {
Extends: PanelMenu.Button, _init() {
super._init(0.0, _("Places"));
_init: function() { let hbox = new St.BoxLayout({ style_class: 'panel-status-menu-box' });
let label = new St.Label({ text: _("Places") }); let label = new St.Label({ text: _("Places"),
this.parent(0.0, label.text); y_expand: true,
this.actor.add_actor(label); y_align: Clutter.ActorAlign.CENTER });
hbox.add_child(label);
hbox.add_child(PopupMenu.arrowIcon(St.Side.BOTTOM));
this.add_actor(hbox);
this.placesManager = new PlaceDisplay.PlacesManager(); this.placesManager = new PlaceDisplay.PlacesManager();
this._sections = { }; this._sections = { };
for (let i=0; i < SECTIONS.length; i++) { for (let i=0; i < SECTIONS.length; i++) {
let id = SECTIONS[i]; let id = SECTIONS[i];
this._sections[id] = new PopupMenu.PopupMenuSection(); this._sections[id] = new PopupMenu.PopupMenuSection();
this.placesManager.connect(id + '-updated', Lang.bind(this, function() { this.placesManager.connect(id + '-updated', () => {
this._redisplay(id); this._redisplay(id);
})); });
this._create(id); this._create(id);
this.menu.addMenuItem(this._sections[id]); this.menu.addMenuItem(this._sections[id]);
this.menu.addMenuItem(new PopupMenu.PopupSeparatorMenuItem()); this.menu.addMenuItem(new PopupMenu.PopupSeparatorMenuItem());
} }
}, }
destroy: function() { _onDestroy() {
this.placesManager.destroy(); this.placesManager.destroy();
this.parent(); super._onDestroy();
}, }
_redisplay: function(id) { _redisplay(id) {
this._sections[id].removeAll(); this._sections[id].removeAll();
this._create(id); this._create(id);
}, }
_create: function(id) { _create(id) {
let places = this.placesManager.get(id); let places = this.placesManager.get(id);
for (let i = 0; i < places.length; i++) for (let i = 0; i < places.length; i++)
this._sections[id].addMenuItem(new PlaceMenuItem(places[i])); this._sections[id].addMenuItem(new PlaceMenuItem(places[i]));
this._sections[id].actor.visible = places.length > 0; this._sections[id].actor.visible = places.length > 0;
} }
}); });
@@ -127,7 +137,7 @@ function enable() {
let pos = 1; let pos = 1;
if ('apps-menu' in Main.panel.statusArea) if ('apps-menu' in Main.panel.statusArea)
pos = 2; pos = 2;
Main.panel.addToStatusArea('places-menu', _indicator, pos, 'left'); Main.panel.addToStatusArea('places-menu', _indicator, pos, 'left');
} }
+7
View File
@@ -0,0 +1,7 @@
extension_data += configure_file(
input: metadata_name + '.in',
output: metadata_name,
configuration: metadata_conf
)
extension_sources += files('placeDisplay.js')
+1 -1
View File
@@ -4,7 +4,7 @@
"settings-schema": "@gschemaname@", "settings-schema": "@gschemaname@",
"gettext-domain": "@gettext_domain@", "gettext-domain": "@gettext_domain@",
"name": "Places Status Indicator", "name": "Places Status Indicator",
"description": "Add a menu for quickly navigating places in the system.\nThis extension is part of Classic Mode and is officially supported by GNOME. Please do not report bugs using the form below, use GNOME Bugzilla instead.", "description": "Add a menu for quickly navigating places in the system.\nThis extension is part of Classic Mode and is officially supported by GNOME. Please do not report bugs using the form below, use GNOME's GitLab instance instead.",
"shell-version": [ "@shell_current@" ], "shell-version": [ "@shell_current@" ],
"url": "@url@" "url": "@url@"
} }
+266 -162
View File
@@ -3,7 +3,6 @@
const GLib = imports.gi.GLib; const GLib = imports.gi.GLib;
const Gio = imports.gi.Gio; const Gio = imports.gi.Gio;
const Shell = imports.gi.Shell; const Shell = imports.gi.Shell;
const Lang = imports.lang;
const Mainloop = imports.mainloop; const Mainloop = imports.mainloop;
const Signals = imports.signals; const Signals = imports.signals;
const St = imports.gi.St; const St = imports.gi.St;
@@ -12,166 +11,247 @@ const DND = imports.ui.dnd;
const Main = imports.ui.main; const Main = imports.ui.main;
const Params = imports.misc.params; const Params = imports.misc.params;
const Search = imports.ui.search; const Search = imports.ui.search;
const ShellMountOperation = imports.ui.shellMountOperation;
const Util = imports.misc.util; const Util = imports.misc.util;
const Gettext = imports.gettext.domain('gnome-shell-extensions'); const Gettext = imports.gettext.domain('gnome-shell-extensions');
const _ = Gettext.gettext; const _ = Gettext.gettext;
const N_ = function(x) { return x; } const N_ = x => x;
const Hostname1Iface = <interface name="org.freedesktop.hostname1"> const BACKGROUND_SCHEMA = 'org.gnome.desktop.background';
<property name="PrettyHostname" type="s" access="read" />
</interface>; const Hostname1Iface = '<node> \
<interface name="org.freedesktop.hostname1"> \
<property name="PrettyHostname" type="s" access="read" /> \
</interface> \
</node>';
const Hostname1 = Gio.DBusProxy.makeProxyWrapper(Hostname1Iface); const Hostname1 = Gio.DBusProxy.makeProxyWrapper(Hostname1Iface);
const PlaceInfo = new Lang.Class({ class PlaceInfo {
Name: 'PlaceInfo', constructor() {
this._init.apply(this, arguments);
}
_init: function(kind, file, name, icon) { _init(kind, file, name, icon) {
this.kind = kind; this.kind = kind;
this.file = file; this.file = file;
this.name = name || this._getFileName(); this.name = name || this._getFileName();
this.icon = icon ? new Gio.ThemedIcon({ name: icon }) : this.getIcon(); this.icon = icon ? new Gio.ThemedIcon({ name: icon }) : this.getIcon();
}, }
destroy: function() { destroy() {
}, }
isRemovable: function() { isRemovable() {
return false; return false;
}, }
launch: function(timestamp) { _createLaunchCallback(launchContext, tryMount) {
let launchContext = global.create_app_launch_context(); return (_ignored, result) => {
launchContext.set_timestamp(timestamp); try {
Gio.AppInfo.launch_default_for_uri_finish(result);
} catch(e) {
if (e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.NOT_MOUNTED)) {
let source = {
get_icon: () => { return this.icon; }
};
let op = new ShellMountOperation.ShellMountOperation(source);
this.file.mount_enclosing_volume(0, op.mountOp, null, (file, result) => {
try {
op.close();
file.mount_enclosing_volume_finish(result);
} catch(e) {
if (e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.FAILED_HANDLED))
// e.g. user canceled the password dialog
return;
Main.notifyError(_("Failed to mount volume for “%s”").format(this.name), e.message);
return;
}
try { if (tryMount) {
Gio.AppInfo.launch_default_for_uri(this.file.get_uri(), let callback = this._createLaunchCallback(launchContext, false);
launchContext); Gio.AppInfo.launch_default_for_uri_async(file.get_uri(),
} catch(e if e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.NOT_MOUNTED)) { launchContext,
this.file.mount_enclosing_volume(0, null, null, function(file, result) { null,
file.mount_enclosing_volume_finish(result); callback);
Gio.AppInfo.launch_default_for_uri(file.get_uri(), launchContext); }
}); });
} catch(e) { } else {
Main.notifyError(_("Failed to launch \"%s\"").format(this.name), e.message); Main.notifyError(_("Failed to launch “%s”").format(this.name), e.message);
} }
},
getIcon: function() {
try {
let info = this.file.query_info('standard::symbolic-icon', 0, null);
return info.get_symbolic_icon();
} catch(e if e instanceof Gio.IOErrorEnum) {
// return a generic icon for this kind
switch (this.kind) {
case 'network':
return new Gio.ThemedIcon({ name: 'folder-remote-symbolic' });
case 'devices':
return new Gio.ThemedIcon({ name: 'drive-harddisk-symbolic' });
case 'special':
case 'bookmarks':
default:
if (!this.file.is_native())
return new Gio.ThemedIcon({ name: 'folder-remote-symbolic' });
else
return new Gio.ThemedIcon({ name: 'folder-symbolic' });
} }
} }
}, }
_getFileName: function() { launch(timestamp) {
let launchContext = global.create_app_launch_context(timestamp, -1);
let callback = this._createLaunchCallback(launchContext, true);
Gio.AppInfo.launch_default_for_uri_async(this.file.get_uri(),
launchContext,
null,
callback);
}
getIcon() {
this.file.query_info_async('standard::symbolic-icon', 0, 0, null,
(file, result) => {
try {
let info = file.query_info_finish(result);
this.icon = info.get_symbolic_icon();
this.emit('changed');
} catch(e) {
if (e instanceof Gio.IOErrorEnum)
return;
throw e;
}
});
// return a generic icon for this kind for now, until we have the
// icon from the query info above
switch (this.kind) {
case 'network':
return new Gio.ThemedIcon({ name: 'folder-remote-symbolic' });
case 'devices':
return new Gio.ThemedIcon({ name: 'drive-harddisk-symbolic' });
case 'special':
case 'bookmarks':
default:
if (!this.file.is_native())
return new Gio.ThemedIcon({ name: 'folder-remote-symbolic' });
else
return new Gio.ThemedIcon({ name: 'folder-symbolic' });
}
}
_getFileName() {
try { try {
let info = this.file.query_info('standard::display-name', 0, null); let info = this.file.query_info('standard::display-name', 0, null);
return info.get_display_name(); return info.get_display_name();
} catch(e if e instanceof Gio.IOErrorEnum) { } catch(e) {
return this.file.get_basename(); if (e instanceof Gio.IOErrorEnum)
return this.file.get_basename();
throw e;
} }
}, }
}); };
Signals.addSignalMethods(PlaceInfo.prototype); Signals.addSignalMethods(PlaceInfo.prototype);
const RootInfo = new Lang.Class({ class RootInfo extends PlaceInfo {
Name: 'RootInfo', _init() {
Extends: PlaceInfo, super._init('devices', Gio.File.new_for_path('/'), _("Computer"));
_init: function() { let busName = 'org.freedesktop.hostname1';
this.parent('devices', Gio.File.new_for_path('/'), _("Computer")); let objPath = '/org/freedesktop/hostname1';
new Hostname1(Gio.DBus.system, busName, objPath, (obj, error) => {
if (error)
return;
this._proxy = new Hostname1(Gio.DBus.system, this._proxy = obj;
'org.freedesktop.hostname1', this._proxy.connect('g-properties-changed',
'/org/freedesktop/hostname1', this._propertiesChanged.bind(this));
Lang.bind(this, function(obj, error) { this._propertiesChanged(obj);
if (error) });
return; }
this._proxy.connect('g-properties-changed', getIcon() {
Lang.bind(this, this._propertiesChanged));
this._propertiesChanged(obj);
}));
},
getIcon: function() {
return new Gio.ThemedIcon({ name: 'drive-harddisk-symbolic' }); return new Gio.ThemedIcon({ name: 'drive-harddisk-symbolic' });
}, }
_propertiesChanged: function(proxy) { _propertiesChanged(proxy) {
// GDBusProxy will emit a g-properties-changed when hostname1 goes down // GDBusProxy will emit a g-properties-changed when hostname1 goes down
// ignore it // ignore it
if (proxy.g_name_owner) { if (proxy.g_name_owner) {
this.name = proxy.PrettyHostname || _("Computer"); this.name = proxy.PrettyHostname || _("Computer");
this.emit('changed'); this.emit('changed');
} }
},
destroy: function() {
this._proxy.run_dispose();
this.parent();
} }
});
destroy() {
if (this._proxy) {
this._proxy.run_dispose();
this._proxy = null;
}
super.destroy();
}
};
const PlaceDeviceInfo = new Lang.Class({ class PlaceDeviceInfo extends PlaceInfo {
Name: 'PlaceDeviceInfo', _init(kind, mount) {
Extends: PlaceInfo,
_init: function(kind, mount) {
this._mount = mount; this._mount = mount;
this.parent(kind, mount.get_root(), mount.get_name()); super._init(kind, mount.get_root(), mount.get_name());
}, }
getIcon: function() { getIcon() {
return this._mount.get_symbolic_icon(); return this._mount.get_symbolic_icon();
} }
});
const PlaceVolumeInfo = new Lang.Class({ isRemovable() {
Name: 'PlaceVolumeInfo', return this._mount.can_eject();
Extends: PlaceInfo, }
_init: function(kind, volume) { eject() {
let mountOp = new ShellMountOperation.ShellMountOperation(this._mount);
if (this._mount.can_eject())
this._mount.eject_with_operation(Gio.MountUnmountFlags.NONE,
mountOp.mountOp,
null, // Gio.Cancellable
this._ejectFinish.bind(this));
else
this._mount.unmount_with_operation(Gio.MountUnmountFlags.NONE,
mountOp.mountOp,
null, // Gio.Cancellable
this._unmountFinish.bind(this));
}
_ejectFinish(mount, result) {
try {
mount.eject_with_operation_finish(result);
} catch(e) {
this._reportFailure(e);
}
}
_unmountFinish(mount, result) {
try {
mount.unmount_with_operation_finish(result);
} catch(e) {
this._reportFailure(e);
}
}
_reportFailure(exception) {
let msg = _("Ejecting drive “%s” failed:").format(this._mount.get_name());
Main.notifyError(msg, exception.message);
}
};
class PlaceVolumeInfo extends PlaceInfo {
_init(kind, volume) {
this._volume = volume; this._volume = volume;
this.parent(kind, volume.get_activation_root(), volume.get_name()); super._init(kind, volume.get_activation_root(), volume.get_name());
}, }
launch: function(timestamp) { launch(timestamp) {
if (this.file) { if (this.file) {
this.parent(timestamp); super.launch(timestamp);
return; return;
} }
this._volume.mount(0, null, null, Lang.bind(this, function(volume, result) { this._volume.mount(0, null, null, (volume, result) => {
volume.mount_finish(result); volume.mount_finish(result);
let mount = volume.get_mount(); let mount = volume.get_mount();
this.file = mount.get_root(); this.file = mount.get_root();
this.parent(timestamp); super.launch(timestamp);
})); });
}, }
getIcon: function() { getIcon() {
return this._volume.get_symbolic_icon(); return this._volume.get_symbolic_icon();
} }
}); };
const DEFAULT_DIRECTORIES = [ const DEFAULT_DIRECTORIES = [
GLib.UserDirectory.DIRECTORY_DOCUMENTS, GLib.UserDirectory.DIRECTORY_DOCUMENTS,
@@ -181,10 +261,8 @@ const DEFAULT_DIRECTORIES = [
GLib.UserDirectory.DIRECTORY_VIDEOS, GLib.UserDirectory.DIRECTORY_VIDEOS,
]; ];
const PlacesManager = new Lang.Class({ var PlacesManager = class {
Name: 'PlacesManager', constructor() {
_init: function() {
this._places = { this._places = {
special: [], special: [],
devices: [], devices: [],
@@ -192,32 +270,11 @@ const PlacesManager = new Lang.Class({
network: [], network: [],
}; };
let homePath = GLib.get_home_dir(); this._settings = new Gio.Settings({ schema_id: BACKGROUND_SCHEMA });
this._showDesktopIconsChangedId =
this._places.special.push(new PlaceInfo('special', this._settings.connect('changed::show-desktop-icons',
Gio.File.new_for_path(homePath), this._updateSpecials.bind(this));
_("Home"))); this._updateSpecials();
let specials = [];
for (let i = 0; i < DEFAULT_DIRECTORIES.length; i++) {
let specialPath = GLib.get_user_special_dir(DEFAULT_DIRECTORIES[i]);
if (specialPath == homePath)
continue;
let file = Gio.File.new_for_path(specialPath), info;
try {
info = new PlaceInfo('special', file);
} catch(e if e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.NOT_FOUND)) {
continue;
}
specials.push(info);
}
specials.sort(function(a, b) {
return GLib.utf8_collate(a.name, b.name);
});
this._places.special = this._places.special.concat(specials);
/* /*
* Show devices, code more or less ported from nautilus-places-sidebar.c * Show devices, code more or less ported from nautilus-places-sidebar.c
@@ -232,35 +289,39 @@ const PlacesManager = new Lang.Class({
if (this._bookmarksFile) { if (this._bookmarksFile) {
this._monitor = this._bookmarksFile.monitor_file(Gio.FileMonitorFlags.NONE, null); this._monitor = this._bookmarksFile.monitor_file(Gio.FileMonitorFlags.NONE, null);
this._monitor.connect('changed', Lang.bind(this, function () { this._monitor.connect('changed', () => {
if (this._bookmarkTimeoutId > 0) if (this._bookmarkTimeoutId > 0)
return; return;
/* Defensive event compression */ /* Defensive event compression */
this._bookmarkTimeoutId = Mainloop.timeout_add(100, Lang.bind(this, function () { this._bookmarkTimeoutId = Mainloop.timeout_add(100, () => {
this._bookmarkTimeoutId = 0; this._bookmarkTimeoutId = 0;
this._reloadBookmarks(); this._reloadBookmarks();
return false; return false;
})); });
})); });
this._reloadBookmarks(); this._reloadBookmarks();
} }
}, }
_connectVolumeMonitorSignals: function() { _connectVolumeMonitorSignals() {
const signals = ['volume-added', 'volume-removed', 'volume-changed', const signals = ['volume-added', 'volume-removed', 'volume-changed',
'mount-added', 'mount-removed', 'mount-changed', 'mount-added', 'mount-removed', 'mount-changed',
'drive-connected', 'drive-disconnected', 'drive-changed']; 'drive-connected', 'drive-disconnected', 'drive-changed'];
this._volumeMonitorSignals = []; this._volumeMonitorSignals = [];
let func = Lang.bind(this, this._updateMounts); let func = this._updateMounts.bind(this);
for (let i = 0; i < signals.length; i++) { for (let i = 0; i < signals.length; i++) {
let id = this._volumeMonitor.connect(signals[i], func); let id = this._volumeMonitor.connect(signals[i], func);
this._volumeMonitorSignals.push(id); this._volumeMonitorSignals.push(id);
} }
}, }
destroy() {
if (this._settings)
this._settings.disconnect(this._showDesktopIconsChangedId);
this._settings = null;
destroy: function() {
for (let i = 0; i < this._volumeMonitorSignals.length; i++) for (let i = 0; i < this._volumeMonitorSignals.length; i++)
this._volumeMonitor.disconnect(this._volumeMonitorSignals[i]); this._volumeMonitor.disconnect(this._volumeMonitorSignals[i]);
@@ -268,15 +329,54 @@ const PlacesManager = new Lang.Class({
this._monitor.cancel(); this._monitor.cancel();
if (this._bookmarkTimeoutId) if (this._bookmarkTimeoutId)
Mainloop.source_remove(this._bookmarkTimeoutId); Mainloop.source_remove(this._bookmarkTimeoutId);
}, }
_updateMounts: function() { _updateSpecials() {
this._places.special.forEach(p => { p.destroy(); });
this._places.special = [];
let homePath = GLib.get_home_dir();
this._places.special.push(new PlaceInfo('special',
Gio.File.new_for_path(homePath),
_("Home")));
let specials = [];
let dirs = DEFAULT_DIRECTORIES.slice();
if (this._settings.get_boolean('show-desktop-icons'))
dirs.push(GLib.UserDirectory.DIRECTORY_DESKTOP);
for (let i = 0; i < dirs.length; i++) {
let specialPath = GLib.get_user_special_dir(dirs[i]);
if (specialPath == null || specialPath == homePath)
continue;
let file = Gio.File.new_for_path(specialPath), info;
try {
info = new PlaceInfo('special', file);
} catch(e) {
if (e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.NOT_FOUND))
continue;
throw e;
}
specials.push(info);
}
specials.sort((a, b) => GLib.utf8_collate(a.name, b.name));
this._places.special = this._places.special.concat(specials);
this.emit('special-updated');
}
_updateMounts() {
let networkMounts = []; let networkMounts = [];
let networkVolumes = []; let networkVolumes = [];
this._places.devices.forEach(function (p) { p.destroy(); }); this._places.devices.forEach(p => { p.destroy(); });
this._places.devices = []; this._places.devices = [];
this._places.network.forEach(function (p) { p.destroy(); }); this._places.network.forEach(p => { p.destroy(); });
this._places.network = []; this._places.network = [];
/* Add standard places */ /* Add standard places */
@@ -293,7 +393,7 @@ const PlacesManager = new Lang.Class({
for(let j = 0; j < volumes.length; j++) { for(let j = 0; j < volumes.length; j++) {
let identifier = volumes[j].get_identifier('class'); let identifier = volumes[j].get_identifier('class');
if (identifier && identifier.indexOf('network') >= 0) { if (identifier && identifier.includes('network')) {
networkVolumes.push(volumes[j]); networkVolumes.push(volumes[j]);
} else { } else {
let mount = volumes[j].get_mount(); let mount = volumes[j].get_mount();
@@ -310,7 +410,7 @@ const PlacesManager = new Lang.Class({
continue; continue;
let identifier = volumes[i].get_identifier('class'); let identifier = volumes[i].get_identifier('class');
if (identifier && identifier.indexOf('network') >= 0) { if (identifier && identifier.includes('network')) {
networkVolumes.push(volumes[i]); networkVolumes.push(volumes[i]);
} else { } else {
let mount = volumes[i].get_mount(); let mount = volumes[i].get_mount();
@@ -351,9 +451,9 @@ const PlacesManager = new Lang.Class({
this.emit('devices-updated'); this.emit('devices-updated');
this.emit('network-updated'); this.emit('network-updated');
}, }
_findBookmarksFile: function() { _findBookmarksFile() {
let paths = [ let paths = [
GLib.build_filenamev([GLib.get_user_config_dir(), 'gtk-3.0', 'bookmarks']), GLib.build_filenamev([GLib.get_user_config_dir(), 'gtk-3.0', 'bookmarks']),
GLib.build_filenamev([GLib.get_home_dir(), '.gtk-bookmarks']), GLib.build_filenamev([GLib.get_home_dir(), '.gtk-bookmarks']),
@@ -365,9 +465,9 @@ const PlacesManager = new Lang.Class({
} }
return null; return null;
}, }
_reloadBookmarks: function() { _reloadBookmarks() {
this._bookmarks = []; this._bookmarks = [];
@@ -415,34 +515,38 @@ const PlacesManager = new Lang.Class({
this._places.bookmarks = bookmarks; this._places.bookmarks = bookmarks;
this.emit('bookmarks-updated'); this.emit('bookmarks-updated');
}, }
_addMount: function(kind, mount) { _addMount(kind, mount) {
let devItem; let devItem;
try { try {
devItem = new PlaceDeviceInfo(kind, mount); devItem = new PlaceDeviceInfo(kind, mount);
} catch(e if e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.NOT_FOUND)) { } catch(e) {
return; if (e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.NOT_FOUND))
return;
throw e;
} }
this._places[kind].push(devItem); this._places[kind].push(devItem);
}, }
_addVolume: function(kind, volume) { _addVolume(kind, volume) {
let volItem; let volItem;
try { try {
volItem = new PlaceVolumeInfo(kind, volume); volItem = new PlaceVolumeInfo(kind, volume);
} catch(e if e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.NOT_FOUND)) { } catch(e) {
return; if (e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.NOT_FOUND))
return;
throw e;
} }
this._places[kind].push(volItem); this._places[kind].push(volItem);
}, }
get: function (kind) { get(kind) {
return this._places[kind]; return this._places[kind];
} }
}); };
Signals.addSignalMethods(PlacesManager.prototype); Signals.addSignalMethods(PlacesManager.prototype);
@@ -0,0 +1,160 @@
/* Screenshot Window Sizer for Gnome Shell
*
* Copyright (c) 2013 Owen Taylor <otaylor@redhat.com>
* Copyright (c) 2013 Richard Hughes <richard@hughsie.com>
*
* 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
* of the License, 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, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
const Gio = imports.gi.Gio;
const Meta = imports.gi.Meta;
const Shell = imports.gi.Shell;
const St = imports.gi.St;
const Main = imports.ui.main;
const Tweener = imports.ui.tweener;
const ExtensionUtils = imports.misc.extensionUtils;
const Me = ExtensionUtils.getCurrentExtension();
const Convenience = Me.imports.convenience;
const MESSAGE_FADE_TIME = 2;
let text, button;
function hideMessage() {
text.destroy();
text = null;
}
function flashMessage(message) {
if (!text) {
text = new St.Label({ style_class: 'screenshot-sizer-message' });
Main.uiGroup.add_actor(text);
}
Tweener.removeTweens(text);
text.text = message;
text.opacity = 255;
let monitor = Main.layoutManager.primaryMonitor;
text.set_position(monitor.x + Math.floor(monitor.width / 2 - text.width / 2),
monitor.y + Math.floor(monitor.height / 2 - text.height / 2));
Tweener.addTween(text,
{ opacity: 0,
time: MESSAGE_FADE_TIME,
transition: 'easeOutQuad',
onComplete: hideMessage });
}
let SIZES = [
[624, 351],
[800, 450],
[1024, 576],
[1200, 675],
[1600, 900]
];
function cycleScreenshotSizes(display, window, binding) {
// Probably this isn't useful with 5 sizes, but you can decrease instead
// of increase by holding down shift.
let modifiers = binding.get_modifiers();
let backwards = (modifiers & Meta.VirtualModifier.SHIFT_MASK) != 0;
// Unmaximize first
if (window.maximized_horizontally || window.maximizedVertically)
window.unmaximize(Meta.MaximizeFlags.HORIZONTAL | Meta.MaximizeFlags.VERTICAL);
let workArea = window.get_work_area_current_monitor();
let outerRect = window.get_frame_rect();
// Double both axes if on a hidpi display
let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor;
let scaledSizes = SIZES.map(size => size.map(wh => wh * scaleFactor));
// Find the nearest 16:9 size for the current window size
let nearestIndex;
let nearestError;
for (let i = 0; i < scaledSizes.length; i++) {
let [width, height] = scaledSizes[i];
// ignore sizes bigger than the workArea
if (width > workArea.width || height > workArea.height)
continue;
// get the best initial window size
let error = Math.abs(width - outerRect.width) + Math.abs(height - outerRect.height);
if (nearestIndex == null || error < nearestError) {
nearestIndex = i;
nearestError = error;
}
}
// get the next size up or down from ideal
let newIndex = (nearestIndex + (backwards ? -1 : 1)) % scaledSizes.length;
let newWidth, newHeight;
[newWidth, newHeight] = scaledSizes[newIndex];
if (newWidth > workArea.width || newHeight > workArea.height)
[newWidth, newHeight] = scaledSizes[0];
// Push the window onscreen if it would be resized offscreen
let newX = outerRect.x;
let newY = outerRect.y;
if (newX + newWidth > workArea.x + workArea.width)
newX = Math.max(workArea.x + workArea.width - newWidth);
if (newY + newHeight > workArea.y + workArea.height)
newY = Math.max(workArea.y + workArea.height - newHeight);
window.move_resize_frame(true, newX, newY, newWidth, newHeight);
let newOuterRect = window.get_frame_rect();
let message = '%d×%d'.format(
(newOuterRect.width / scaleFactor),
(newOuterRect.height / scaleFactor));
// The new size might have been constrained by geometry hints (e.g. for
// a terminal) - in that case, include the actual ratio to the message
// we flash
let actualNumerator = (newOuterRect.width / newOuterRect.height) * 9;
if (Math.abs(actualNumerator - 16) > 0.01)
message += ' (%.2f:9)'.format(actualNumerator);
flashMessage(message);
}
function init() {
}
function enable() {
Main.wm.addKeybinding('cycle-screenshot-sizes',
Convenience.getSettings(),
Meta.KeyBindingFlags.PER_WINDOW,
Shell.ActionMode.NORMAL,
cycleScreenshotSizes);
Main.wm.addKeybinding('cycle-screenshot-sizes-backward',
Convenience.getSettings(),
Meta.KeyBindingFlags.PER_WINDOW |
Meta.KeyBindingFlags.IS_REVERSED,
Shell.ActionMode.NORMAL,
cycleScreenshotSizes);
}
function disable() {
Main.wm.removeKeybinding('cycle-screenshot-sizes');
Main.wm.removeKeybinding('cycle-screenshot-sizes-backward');
}
@@ -0,0 +1,7 @@
extension_data += configure_file(
input: metadata_name + '.in',
output: metadata_name,
configuration: metadata_conf
)
extension_schemas += files(metadata_conf.get('gschemaname') + '.gschema.xml')
@@ -3,8 +3,8 @@
"uuid": "@uuid@", "uuid": "@uuid@",
"settings-schema": "@gschemaname@", "settings-schema": "@gschemaname@",
"gettext-domain": "@gettext_domain@", "gettext-domain": "@gettext_domain@",
"name": "Monitor Status Indicator", "name": "Screenshot Window Sizer",
"description": "Add a system status menu for rotating monitors.", "description": "Resize windows for GNOME Software screenshots",
"shell-version": [ "@shell_current@" ], "shell-version": [ "@shell_current@" ],
"url": "@url@" "url": "@url@"
} }
@@ -0,0 +1,14 @@
<?xml version="1.0" encoding="UTF-8"?>
<schemalist gettext-domain="gnome-shell-extensions">
<schema id="org.gnome.shell.extensions.screenshot-window-sizer"
path="/org/gnome/shell/extensions/screenshot-window-sizer/">
<key type="as" name="cycle-screenshot-sizes">
<default><![CDATA[['<Alt><Control>s']]]></default>
<summary>Cycle Screenshot Sizes</summary>
</key>
<key type="as" name="cycle-screenshot-sizes-backward">
<default><![CDATA[['<Shift><Alt><Control>s']]]></default>
<summary>Cycle Screenshot Sizes Backward</summary>
</key>
</schema>
</schemalist>
@@ -1,8 +1,8 @@
/* Example stylesheet */ .screenshot-sizer-message {
.helloworld-label {
font-size: 36px; font-size: 36px;
font-weight: bold; font-weight: bold;
color: #ffffff; color: #ffffff;
background-color: rgba(10,10,10,0.7); background-color: rgba(10,10,10,0.7);
border-radius: 5px; border-radius: 5px;
padding: .5em;
} }
-3
View File
@@ -1,3 +0,0 @@
EXTENSION_ID = systemMonitor
include ../../extension.mk
-361
View File
@@ -1,361 +0,0 @@
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
const Clutter = imports.gi.Clutter;
const GTop = imports.gi.GTop;
const Lang = imports.lang;
const Mainloop = imports.mainloop;
const St = imports.gi.St;
const Shell = imports.gi.Shell;
const Main = imports.ui.main;
const Tweener = imports.ui.tweener;
const Gettext = imports.gettext.domain('gnome-shell-extensions');
const _ = Gettext.gettext;
const ExtensionUtils = imports.misc.extensionUtils;
const Me = ExtensionUtils.getCurrentExtension();
const Convenience = Me.imports.convenience;
const INDICATOR_UPDATE_INTERVAL = 500;
const INDICATOR_NUM_GRID_LINES = 3;
const ITEM_LABEL_SHOW_TIME = 0.15;
const ITEM_LABEL_HIDE_TIME = 0.1;
const ITEM_HOVER_TIMEOUT = 300;
const Indicator = new Lang.Class({
Name: 'SystemMonitor.Indicator',
_init: function() {
this._initValues();
this.drawing_area = new St.DrawingArea({ reactive: true });
this.drawing_area.connect('repaint', Lang.bind(this, this._draw));
this.drawing_area.connect('button-press-event', function() {
let app = Shell.AppSystem.get_default().lookup_app('gnome-system-monitor.desktop');
app.open_new_window(-1);
return true;
});
this.actor = new St.Bin({ style_class: "extension-systemMonitor-indicator-area",
reactive: true, track_hover: true,
x_fill: true, y_fill: true });
this.actor.add_actor(this.drawing_area);
this._timeout = Mainloop.timeout_add(INDICATOR_UPDATE_INTERVAL, Lang.bind(this, function () {
this._updateValues();
this.drawing_area.queue_repaint();
return true;
}));
},
showLabel: function() {
if (this.label == null)
return;
this.label.opacity = 0;
this.label.show();
let [stageX, stageY] = this.actor.get_transformed_position();
let itemWidth = this.actor.allocation.x2 - this.actor.allocation.x1;
let itemHeight = this.actor.allocation.y2 - this.actor.allocation.y1;
let labelWidth = this.label.width;
let labelHeight = this.label.height;
let xOffset = Math.floor((itemWidth - labelWidth) / 2)
let x = stageX + xOffset;
let node = this.label.get_theme_node();
let yOffset = node.get_length('-y-offset');
let y = stageY - this.label.get_height() - yOffset;
this.label.set_position(x, y);
Tweener.addTween(this.label,
{ opacity: 255,
time: ITEM_LABEL_SHOW_TIME,
transition: 'easeOutQuad',
});
},
setLabelText: function(text) {
if (this.label == null)
this.label = new St.Label({ style_class: 'extension-systemMonitor-indicator-label'});
this.label.set_text(text);
Main.layoutManager.addChrome(this.label);
this.label.hide();
},
hideLabel: function () {
Tweener.addTween(this.label,
{ opacity: 0,
time: ITEM_LABEL_HIDE_TIME,
transition: 'easeOutQuad',
onComplete: Lang.bind(this, function() {
this.label.hide();
})
});
},
destroy: function() {
Mainloop.source_remove(this._timeout);
this.actor.destroy();
if (this.label)
this.label.destroy();
},
_initValues: function() {
},
_updateValues: function() {
},
_draw: function(area) {
let [width, height] = area.get_surface_size();
let themeNode = this.actor.get_theme_node();
let cr = area.get_context();
//draw the background grid
let color = themeNode.get_color(this.gridColor);
let gridOffset = Math.floor(height / (INDICATOR_NUM_GRID_LINES + 1));
for (let i = 1; i <= INDICATOR_NUM_GRID_LINES; ++i) {
cr.moveTo(0, i * gridOffset + .5);
cr.lineTo(width, i * gridOffset + .5);
}
Clutter.cairo_set_source_color(cr, color);
cr.setLineWidth(1);
cr.setDash([4,1], 0);
cr.stroke();
//draw the foreground
function makePath(values, reverse, nudge) {
if (nudge == null) {
nudge = 0;
}
//if we are going in reverse, we are completing the bottom of a chart, so use lineTo
if (reverse) {
cr.lineTo(values.length - 1, (1 - values[values.length - 1]) * height + nudge);
for (let k = values.length - 2; k >= 0; --k) {
cr.lineTo(k, (1 - values[k]) * height + nudge);
}
} else {
cr.moveTo(0, (1 - values[0]) * height + nudge);
for (let k = 1; k < values.length; ++k) {
cr.lineTo(k, (1 - values[k]) * height + nudge);
}
}
}
let renderStats = this.renderStats;
// Make sure we don't have more sample points than pixels
renderStats.map(Lang.bind(this, function(k){
let stat = this.stats[k];
if (stat.values.length > width) {
stat.values = stat.values.slice(stat.values.length - width, stat.values.length);
}
}));
for (let i = 0; i < renderStats.length; ++i) {
let stat = this.stats[renderStats[i]];
// We outline at full opacity and fill with 40% opacity
let outlineColor = themeNode.get_color(stat.color);
let color = new Clutter.Color(outlineColor);
color.alpha = color.alpha * .4;
// Render the background between us and the next level
makePath(stat.values, false);
// If there is a process below us, render the cpu between us and it, otherwise,
// render to the bottom of the chart
if (i == renderStats.length - 1) {
cr.lineTo(stat.values.length - 1, height);
cr.lineTo(0, height);
cr.closePath();
} else {
let nextStat = this.stats[renderStats[i+1]];
makePath(nextStat.values, true);
}
cr.closePath()
Clutter.cairo_set_source_color(cr, color);
cr.fill();
// Render the outline of this level
makePath(stat.values, false, .5);
Clutter.cairo_set_source_color(cr, outlineColor);
cr.setLineWidth(1.0);
cr.setDash([], 0);
cr.stroke();
}
}
});
const CpuIndicator = new Lang.Class({
Name: 'SystemMonitor.CpuIndicator',
Extends: Indicator,
_init: function() {
this.parent();
this.gridColor = '-grid-color';
this.renderStats = [ 'cpu-user', 'cpu-sys', 'cpu-iowait' ];
// Make sure renderStats is sorted as necessary for rendering
let renderStatOrder = {'cpu-total': 0, 'cpu-user': 1, 'cpu-sys': 2, 'cpu-iowait': 3};
this.renderStats = this.renderStats.sort(function(a,b) {
return renderStatOrder[a] - renderStatOrder[b];
});
this.setLabelText(_("CPU"));
},
_initValues: function() {
this._prev = new GTop.glibtop_cpu;
GTop.glibtop_get_cpu(this._prev);
this.stats = {
'cpu-user': {color: '-cpu-user-color', values: []},
'cpu-sys': {color: '-cpu-sys-color', values: []},
'cpu-iowait': {color: '-cpu-iowait-color', values: []},
'cpu-total': {color: '-cpu-total-color', values: []}
};
},
_updateValues: function() {
let cpu = new GTop.glibtop_cpu;
let t = 0.0;
GTop.glibtop_get_cpu(cpu);
let total = cpu.total - this._prev.total;
let user = cpu.user - this._prev.user;
let sys = cpu.sys - this._prev.sys;
let iowait = cpu.iowait - this._prev.iowait;
let idle = cpu.idle - this._prev.idle;
t += iowait / total;
this.stats['cpu-iowait'].values.push(t);
t += sys / total;
this.stats['cpu-sys'].values.push(t);
t += user / total;
this.stats['cpu-user'].values.push(t);
this.stats['cpu-total'].values.push(1 - idle / total);
this._prev = cpu;
}
});
const MemoryIndicator = new Lang.Class({
Name: 'SystemMonitor.MemoryIndicator',
Extends: Indicator,
_init: function() {
this.parent();
this.gridColor = '-grid-color';
this.renderStats = [ 'mem-user', 'mem-other', 'mem-cached' ];
// Make sure renderStats is sorted as necessary for rendering
let renderStatOrder = { 'mem-cached': 0, 'mem-other': 1, 'mem-user': 2 };
this.renderStats = this.renderStats.sort(function(a,b) {
return renderStatOrder[a] - renderStatOrder[b];
});
this.setLabelText(_("Memory"));
},
_initValues: function() {
this.mem = new GTop.glibtop_mem;
this.stats = {
'mem-user': { color: "-mem-user-color", values: [] },
'mem-other': { color: "-mem-other-color", values: [] },
'mem-cached': { color: "-mem-cached-color", values: [] }
};
},
_updateValues: function() {
GTop.glibtop_get_mem(this.mem);
let t = this.mem.user / this.mem.total;
this.stats['mem-user'].values.push(t);
t += (this.mem.used - this.mem.user - this.mem.cached) / this.mem.total;
this.stats['mem-other'].values.push(t);
t += this.mem.cached / this.mem.total;
this.stats['mem-cached'].values.push(t);
}
});
const INDICATORS = [CpuIndicator, MemoryIndicator];
const Extension = new Lang.Class({
Name: 'SystemMonitor.Extension',
_init: function() {
Convenience.initTranslations();
this._showLabelTimeoutId = 0;
this._resetHoverTimeoutId = 0;
this._labelShowing = false;
},
enable: function() {
this._box = new St.BoxLayout({ style_class: 'extension-systemMonitor-container',
x_align: Clutter.ActorAlign.START,
x_expand: true });
this._indicators = [ ];
for (let i = 0; i < INDICATORS.length; i++) {
let indicator = new (INDICATORS[i])();
indicator.actor.connect('notify::hover', Lang.bind(this, function() {
this._onHover(indicator);
}));
this._box.add_actor(indicator.actor);
this._indicators.push(indicator);
}
Main.messageTray.actor.add_actor(this._box);
},
disable: function() {
this._indicators.forEach(function(i) { i.destroy(); });
this._box.destroy();
},
_onHover: function (item) {
if (item.actor.get_hover()) {
if (this._showLabelTimeoutId == 0) {
let timeout = this._labelShowing ? 0 : ITEM_HOVER_TIMEOUT;
this._showLabelTimeoutId = Mainloop.timeout_add(timeout,
Lang.bind(this, function() {
this._labelShowing = true;
item.showLabel();
return false;
}));
if (this._resetHoverTimeoutId > 0) {
Mainloop.source_remove(this._resetHoverTimeoutId);
this._resetHoverTimeoutId = 0;
}
}
} else {
if (this._showLabelTimeoutId > 0)
Mainloop.source_remove(this._showLabelTimeoutId);
this._showLabelTimeoutId = 0;
item.hideLabel();
if (this._labelShowing) {
this._resetHoverTimeoutId = Mainloop.timeout_add(ITEM_HOVER_TIMEOUT,
Lang.bind(this, function() {
this._labelShowing = false;
return false;
}));
}
}
},
});
function init() {
return new Extension();
}
-11
View File
@@ -1,11 +0,0 @@
{
"shell-version": ["@shell_current@" ],
"uuid": "@uuid@",
"extension-id": "@extension_id@",
"settings-schema": "@gschemaname@",
"gettext-domain": "@gettext_domain@",
"original-author": "zaspire@rambler.ru",
"name": "SystemMonitor",
"description": "System monitor showing CPU and memory usage in the message tray.",
"url": "@url@"
}
-35
View File
@@ -1,35 +0,0 @@
.extension-systemMonitor-container {
spacing: 5px;
padding-left: 5px;
padding-right: 5px;
padding-bottom: 10px;
padding-top: 10px;
}
.extension-systemMonitor-indicator-area {
border: 1px solid #8d8d8d;
border-radius: 3px;
width: 100px;
/* message tray is 72px, so 20px padding of the container,
2px of border, makes it 50px */
height: 50px;
-grid-color: #575757;
-cpu-total-color: rgb(0,154,62);
-cpu-user-color: rgb(69,154,0);
-cpu-sys-color: rgb(255,253,81);
-cpu-iowait-color: rgb(210,148,0);
-mem-user-color: rgb(210,148,0);
-mem-cached-color: rgb(90,90,90);
-mem-other-color: rgb(205,203,41);
background-color: #1e1e1e;
}
.extension-systemMonitor-indicator-label {
border-radius: 7px;
padding: 4px 12px;
background-color: rgba(0,0,0,0.9);
text-align: center;
-y-offset: 8px;
font-size: 9pt;
font-weight: bold;
}
-5
View File
@@ -1,5 +0,0 @@
EXTENSION_ID = user-theme
include ../../extension.mk
include ../../settings.mk
+11 -13
View File
@@ -3,7 +3,6 @@
const GLib = imports.gi.GLib; const GLib = imports.gi.GLib;
const Gio = imports.gi.Gio; const Gio = imports.gi.Gio;
const Lang = imports.lang;
const Main = imports.ui.main; const Main = imports.ui.main;
const SETTINGS_KEY = 'name'; const SETTINGS_KEY = 'name';
@@ -12,19 +11,17 @@ const ExtensionUtils = imports.misc.extensionUtils;
const Me = ExtensionUtils.getCurrentExtension(); const Me = ExtensionUtils.getCurrentExtension();
const Convenience = Me.imports.convenience; const Convenience = Me.imports.convenience;
const ThemeManager = new Lang.Class({ class ThemeManager {
Name: 'UserTheme.ThemeManager', constructor() {
_init: function() {
this._settings = Convenience.getSettings(); this._settings = Convenience.getSettings();
}, }
enable: function() { enable() {
this._changedId = this._settings.connect('changed::'+SETTINGS_KEY, Lang.bind(this, this._changeTheme)); this._changedId = this._settings.connect('changed::'+SETTINGS_KEY, this._changeTheme.bind(this));
this._changeTheme(); this._changeTheme();
}, }
disable: function() { disable() {
if (this._changedId) { if (this._changedId) {
this._settings.disconnect(this._changedId); this._settings.disconnect(this._changedId);
this._changedId = 0; this._changedId = 0;
@@ -32,9 +29,9 @@ const ThemeManager = new Lang.Class({
Main.setThemeStylesheet(null); Main.setThemeStylesheet(null);
Main.loadTheme(); Main.loadTheme();
}, }
_changeTheme: function() { _changeTheme() {
let _stylesheet = null; let _stylesheet = null;
let _themeName = this._settings.get_string(SETTINGS_KEY); let _themeName = this._settings.get_string(SETTINGS_KEY);
@@ -45,6 +42,7 @@ const ThemeManager = new Lang.Class({
_stylesheet = _userCssStylesheet; _stylesheet = _userCssStylesheet;
else { else {
let sysdirs = GLib.get_system_data_dirs(); let sysdirs = GLib.get_system_data_dirs();
sysdirs.unshift(GLib.get_user_data_dir());
for (let i = 0; i < sysdirs.length; i++) { for (let i = 0; i < sysdirs.length; i++) {
_userCssStylesheet = sysdirs[i] + '/themes/' + _themeName + '/gnome-shell/gnome-shell.css'; _userCssStylesheet = sysdirs[i] + '/themes/' + _themeName + '/gnome-shell/gnome-shell.css';
let file = Gio.file_new_for_path(_userCssStylesheet); let file = Gio.file_new_for_path(_userCssStylesheet);
@@ -63,7 +61,7 @@ const ThemeManager = new Lang.Class({
Main.setThemeStylesheet(_stylesheet); Main.setThemeStylesheet(_stylesheet);
Main.loadTheme(); Main.loadTheme();
} }
}); };
function init() { function init() {
return new ThemeManager(); return new ThemeManager();
+7
View File
@@ -0,0 +1,7 @@
extension_data += configure_file(
input: metadata_name + '.in',
output: metadata_name,
configuration: metadata_conf
)
extension_schemas += files(metadata_conf.get('gschemaname') + '.gschema.xml')
@@ -2,8 +2,8 @@
<schema id="org.gnome.shell.extensions.user-theme" path="/org/gnome/shell/extensions/user-theme/"> <schema id="org.gnome.shell.extensions.user-theme" path="/org/gnome/shell/extensions/user-theme/">
<key name="name" type="s"> <key name="name" type="s">
<default>""</default> <default>""</default>
<_summary>Theme name</_summary> <summary>Theme name</summary>
<_description>The name of the theme, to be loaded from ~/.themes/name/gnome-shell</_description> <description>The name of the theme, to be loaded from ~/.themes/name/gnome-shell</description>
</key> </key>
</schema> </schema>
</schemalist> </schemalist>
-10
View File
@@ -1,10 +0,0 @@
EXTENSION_ID = window-list
EXTRA_MODULES = prefs.js
if CLASSIC_MODE
EXTRA_MODULES += classic.css
endif
include ../../extension.mk
include ../../settings.mk
+22 -20
View File
@@ -3,42 +3,44 @@
#panel.bottom-panel { #panel.bottom-panel {
border-top-width: 1px; border-top-width: 1px;
border-bottom-width: 0px; border-bottom-width: 0px;
height: 32px !important; height: 2.25em ;
} }
.bottom-panel .window-button > StWidget { .bottom-panel .window-button > StWidget {
background-color: #e9e9e9 !important; background-gradient-drection: vertical;
background-gradient-direction: vertical; background-color: #fff;
background-gradient-end: #d0d0d0; background-gradient-start: #fff;
color: #555 !important; background-gradient-end: #eee;
border-radius: 2px !important; color: #000;
padding: 4px 6px 2px !important; -st-natural-width: 18.7em;
max-width: 18.75em;
color: #2e3436;
background-color: #eee;
border-radius: 2px;
padding: 3px 6px 1px;
box-shadow: inset -1px -1px 1px rgba(0,0,0,0.5);
text-shadow: 0 0 transparent; text-shadow: 0 0 transparent;
box-shadow: inset -1px -1px 1px rgba(0,0,0,0.5) !important;
} }
.bottom-panel .window-button:hover > StWidget { .bottom-panel .window-button:hover > StWidget {
background-color: #f9f9f9 !important; background-color: #f9f9f9;
background-gradient-end: #e0e0e0;
} }
.bottom-panel .window-button:active > StWidget { .bottom-panel .window-button:active > StWidget,
box-shadow: inset 1px 1px 2px rgba(0,0,0,0.5) !important; .bottom-panel .window-button:focus > StWidget {
box-shadow: inset 1px 1px 2px rgba(0,0,0,0.5);
} }
.bottom-panel .window-button.focused > StWidget { .bottom-panel .window-button.focused > StWidget {
background-color: #a9a9a9 !important; background-color: #ddd;
background-gradient-end: #b0b0b0; box-shadow: inset 1px 1px 1px rgba(0,0,0,0.5);
box-shadow: inset 1px 1px 2px rgba(0,0,0,0.5) !important;
} }
.bottom-panel .window-button.focused:hover > StWidget { .bottom-panel .window-button.focused:hover > StWidget {
background-color: #b9b9b9 !important; background-color: #e9e9e9;
background-gradient-end: #c0c0c0;
} }
.bottom-panel .window-button.minimized > StWidget { .bottom-panel .window-button.minimized > StWidget {
color: #888 !important; color: #888;
box-shadow: inset -1px -1px 1px rgba(0,0,0,0.4) !important; box-shadow: inset -1px -1px 1px rgba(0,0,0,0.5);
} }
File diff suppressed because it is too large Load Diff
+12
View File
@@ -0,0 +1,12 @@
extension_data += configure_file(
input: metadata_name + '.in',
output: metadata_name,
configuration: metadata_conf
)
extension_sources += files('prefs.js')
extension_schemas += files(metadata_conf.get('gschemaname') + '.gschema.xml')
if classic_mode_enabled
extension_data += files('classic.css')
endif
+1 -1
View File
@@ -4,7 +4,7 @@
"settings-schema": "@gschemaname@", "settings-schema": "@gschemaname@",
"gettext-domain": "@gettext_domain@", "gettext-domain": "@gettext_domain@",
"name": "Window List", "name": "Window List",
"description": "Display a window list at the bottom of the screen.\nThis extension is part of Classic Mode and is officially supported by GNOME. Please do not report bugs using the form below, use GNOME Bugzilla instead.", "description": "Display a window list at the bottom of the screen.\nThis extension is part of Classic Mode and is officially supported by GNOME. Please do not report bugs using the form below, use GNOME's GitLab instance instead.",
"shell-version": [ "@shell_current@" ], "shell-version": [ "@shell_current@" ],
"url": "@url@" "url": "@url@"
} }
@@ -9,11 +9,19 @@
<key name="grouping-mode" <key name="grouping-mode"
enum="org.gnome.shell.extensions.window-list.GroupingMode"> enum="org.gnome.shell.extensions.window-list.GroupingMode">
<default>'never'</default> <default>'never'</default>
<_summary>When to group windows</_summary> <summary>When to group windows</summary>
<_description> <description>
Decides when to group windows from the same application on the Decides when to group windows from the same application on the
window list. Possible values are "never", "auto" and "always". window list. Possible values are never, auto and always.
</_description> </description>
</key>
<key name="show-on-all-monitors" type="b">
<default>false</default>
<summary>Show the window list on all monitors</summary>
<description>
Whether to show the window list on all connected monitors or
only on the primary one.
</description>
</key> </key>
</schema> </schema>
</schemalist> </schemalist>
+18 -16
View File
@@ -1,8 +1,8 @@
// -*- mode: js2; indent-tabs-mode: nil; js2-basic-offset: 4 -*- // -*- mode: js2; indent-tabs-mode: nil; js2-basic-offset: 4 -*-
const Gio = imports.gi.Gio;
const GObject = imports.gi.GObject; const GObject = imports.gi.GObject;
const Gtk = imports.gi.Gtk; const Gtk = imports.gi.Gtk;
const Lang = imports.lang;
const Gettext = imports.gettext.domain('gnome-shell-extensions'); const Gettext = imports.gettext.domain('gnome-shell-extensions');
const _ = Gettext.gettext; const _ = Gettext.gettext;
@@ -16,28 +16,25 @@ function init() {
Convenience.initTranslations(); Convenience.initTranslations();
} }
const WindowListPrefsWidget = new GObject.Class({ const WindowListPrefsWidget = GObject.registerClass(
Name: 'WindowList.Prefs.Widget', class WindowListPrefsWidget extends Gtk.Grid {
GTypeName: 'WindowListPrefsWidget', _init(params) {
Extends: Gtk.Frame, super._init(params);
_init: function(params) {
this.parent(params);
this.shadow_type = Gtk.ShadowType.NONE;
this.margin = 24; this.margin = 24;
this.row_spacing = 6;
this.orientation = Gtk.Orientation.VERTICAL;
let title = '<b>' + _("Window Grouping") + '</b>'; let groupingLabel = '<b>' + _("Window Grouping") + '</b>';
let titleLabel = new Gtk.Label({ use_markup: true, label: title }); this.add(new Gtk.Label({ label: groupingLabel, use_markup: true,
this.set_label_widget(titleLabel); halign: Gtk.Align.START }));
let align = new Gtk.Alignment({ left_padding: 12 }); let align = new Gtk.Alignment({ left_padding: 12 });
this.add(align); this.add(align);
let grid = new Gtk.Grid({ orientation: Gtk.Orientation.VERTICAL, let grid = new Gtk.Grid({ orientation: Gtk.Orientation.VERTICAL,
row_spacing: 6, row_spacing: 6,
column_spacing: 6, column_spacing: 6 });
margin_top: 6 });
align.add(grid); align.add(grid);
this._settings = Convenience.getSettings(); this._settings = Convenience.getSettings();
@@ -65,11 +62,16 @@ const WindowListPrefsWidget = new GObject.Class({
group: radio }); group: radio });
grid.add(radio); grid.add(radio);
radio.connect('toggled', Lang.bind(this, function(button) { radio.connect('toggled', button => {
if (button.active) if (button.active)
this._settings.set_string('grouping-mode', mode); this._settings.set_string('grouping-mode', mode);
})); });
} }
let check = new Gtk.CheckButton({ label: _("Show on all monitors"),
margin_top: 6 });
this._settings.bind('show-on-all-monitors', check, 'active', Gio.SettingsBindFlags.DEFAULT);
this.add(check);
} }
}); });
+13 -6
View File
@@ -2,7 +2,7 @@
/* .window-button-icon height + /* .window-button-icon height +
.window-button vertical padding + .window-button vertical padding +
.window-button > StWidget vertical padding) */ .window-button > StWidget vertical padding) */
height: 30px; height: 2.25em;
} }
.window-list { .window-list {
@@ -22,16 +22,19 @@
padding-right: 2px; padding-right: 2px;
} }
.window-button-box {
spacing: 4px;
}
.window-button > StWidget { .window-button > StWidget {
-st-natural-width: 250px; -st-natural-width: 18.75em;
max-width: 250px; max-width: 18.75em;
color: #bbb; color: #bbb;
background-color: black; background-color: black;
border-radius: 4px; border-radius: 4px;
padding: 3px 6px 1px; padding: 3px 6px 1px;
box-shadow: inset 1px 1px 4px rgba(255,255,255,0.5); box-shadow: inset 1px 1px 4px rgba(255,255,255,0.5);
text-shadow: 1px 1px 4px rgba(0,0,0,0.8); text-shadow: 1px 1px 4px rgba(0,0,0,0.8);
spacing: 4px;
} }
.window-button:hover > StWidget { .window-button:hover > StWidget {
@@ -68,10 +71,14 @@
} }
.window-list-workspace-indicator { .window-list-workspace-indicator {
padding: 3px;
}
.window-list-workspace-indicator > StWidget {
background-color: rgba(200, 200, 200, .3); background-color: rgba(200, 200, 200, .3);
border: 1px solid #cccccc; border: 1px solid #cccccc;
} }
.window-list-workspace-indicator > StLabel { .notification {
padding: 0 2px; font-weight: normal;
} }
-3
View File
@@ -1,3 +0,0 @@
EXTENSION_ID = windowsNavigator
include ../../extension.mk

Some files were not shown because too many files have changed in this diff Show More