Compare commits
243 Commits
wip/wobbly
...
wip/sassWi
Author | SHA1 | Date | |
---|---|---|---|
80d754916d | |||
26fd0b7e7c | |||
d476da8a69 | |||
b2970f576c | |||
77e3e61840 | |||
aceb9fe825 | |||
1842466069 | |||
a92cf654d1 | |||
ff700d3a28 | |||
3b86d23e09 | |||
74a8fbfdaf | |||
8891261dea | |||
c5daf63976 | |||
e4f1db8f09 | |||
1242beae1e | |||
ca5a8bf57e | |||
25ccc6ebd4 | |||
f68421dca1 | |||
4222e62b5a | |||
075f53b5fa | |||
161b86dc63 | |||
3566933c04 | |||
a1793d727f | |||
ec0fc8bb8a | |||
35a3aff8a4 | |||
5f0b0094fb | |||
32dd326d19 | |||
f3a5571f46 | |||
a0fe9909b3 | |||
b9cf164e0b | |||
5803ce5151 | |||
4d8239a9a1 | |||
082d403829 | |||
2dbc7b5c51 | |||
8ab1bbb2ad | |||
1291bcd0c8 | |||
73362beb0b | |||
52503c4c38 | |||
219b0bf987 | |||
cbfd6a8128 | |||
21d11b3638 | |||
455595f2b2 | |||
316f825b2a | |||
35fcd16992 | |||
084f7a36b1 | |||
1fe3ab8f68 | |||
be3c3c64c1 | |||
568454abb8 | |||
5014434b9a | |||
b05ab0eaeb | |||
e402ed1fe4 | |||
4801d1dd7f | |||
24c0a1a1d4 | |||
4a1f939e2b | |||
111a9e13f2 | |||
926f76635e | |||
72a43a6001 | |||
5180ab262c | |||
5fca85cd28 | |||
fb5b368ca7 | |||
62b6419332 | |||
65c136f4ed | |||
34606c0a8c | |||
260657c0b8 | |||
f5cc579272 | |||
b4ce0e7208 | |||
eb3fc7815e | |||
2f5a226bc2 | |||
01eb79a3cc | |||
7ea364ae8b | |||
48a6e6f309 | |||
0f63ad0fc1 | |||
49c4ba5656 | |||
642bf2b778 | |||
328bb1c21b | |||
38add2e78b | |||
2dc41c944e | |||
ea552ea157 | |||
a72dca3610 | |||
5e5035a0f7 | |||
ffdb85e003 | |||
6a969b934f | |||
8d3ff56846 | |||
d8d046f2b3 | |||
0bec76b6ee | |||
aa3aea7520 | |||
49fcc93a4b | |||
eaec459ee9 | |||
72c6f0025d | |||
aa3caff714 | |||
522ccaba3f | |||
3d00864599 | |||
bd3dfb8f6a | |||
1b3c89f32b | |||
a4475465f1 | |||
84f14cb61c | |||
d0de411a59 | |||
2b9645b268 | |||
4f08bebbf0 | |||
4e8c476153 | |||
1d374ac8bd | |||
83f0f4ea36 | |||
18f569280c | |||
fc0c98805f | |||
6722b69b8a | |||
f9d909f985 | |||
dd42cfa853 | |||
4ed4bb330e | |||
f02b007337 | |||
0035de4ab7 | |||
28552d4b38 | |||
42066a7c46 | |||
45847470d1 | |||
72b0a3d78f | |||
fc3ad390b7 | |||
926de53c0c | |||
e6cd112379 | |||
2cefc8be27 | |||
991179835e | |||
0ca2fee54f | |||
778ef365d9 | |||
45937ed85d | |||
65a9c09c9c | |||
67b14d5fe5 | |||
f976e46c46 | |||
7026209eae | |||
1e82d6edc2 | |||
50ac1dd197 | |||
9d933356e1 | |||
c2a5c00111 | |||
edb561a6ff | |||
14c2460fe4 | |||
598362448a | |||
845273d4c0 | |||
3aebfdc319 | |||
f423c371c8 | |||
6fe1ad62ba | |||
63efe1db11 | |||
002ae0e7f1 | |||
4f5e5e1999 | |||
f4feb409ff | |||
05a035e6fd | |||
7c2a3cc233 | |||
7f660fd4d7 | |||
c0730b610e | |||
b0cfcc4842 | |||
1afc9fefcc | |||
90bea5785e | |||
61dacf3d91 | |||
3ae45bddad | |||
9ad4070d58 | |||
1981b21ea8 | |||
9896135c97 | |||
0d340099da | |||
cacc780111 | |||
a9a6da08a1 | |||
ccb6b93b65 | |||
5623f3b4b5 | |||
a227d595f5 | |||
012955e341 | |||
a41cd7d3cc | |||
11d947f1e5 | |||
2bb717b0b7 | |||
770f8c6538 | |||
e76e0042a8 | |||
91e266113c | |||
ed2956a2ea | |||
aa6f352cb0 | |||
5a42a91ee0 | |||
4d682c7861 | |||
20fec42496 | |||
437df2f0bd | |||
445aa54622 | |||
7fa9ca0a9c | |||
0fe7ae1810 | |||
9c251d85cf | |||
959b5fe5cf | |||
75a8bf626a | |||
eb514f335c | |||
ad77b4ddfc | |||
534bf2b000 | |||
3821fd04a4 | |||
b55b9cc7a9 | |||
ac6462c7c6 | |||
aa7b0a285b | |||
0a63de8c8d | |||
0992bd41ed | |||
ed52a5a58b | |||
79bf770783 | |||
c7e3b68dcd | |||
1b9318c82f | |||
6a142c4260 | |||
c49f2e1384 | |||
9208473e59 | |||
08ece4c186 | |||
99c29366ee | |||
7a11964dfb | |||
c4922f6624 | |||
4f2070a7c6 | |||
03177dc474 | |||
b9b4886a6f | |||
33e35f269f | |||
b886656f61 | |||
8589bfb62e | |||
6a36a68f32 | |||
a0a701757e | |||
effe6fab3a | |||
8e560f98d1 | |||
58aabfcf5b | |||
19e3f794f8 | |||
2b1077aaa1 | |||
547cdf86cc | |||
7653175c6f | |||
a4c1b55111 | |||
93205eefb9 | |||
ec3f8d4b85 | |||
0258c7a518 | |||
ebfdb8ec3c | |||
6823bad2d8 | |||
491100c7ee | |||
762e770c84 | |||
c214e3b07a | |||
b656b1c22f | |||
d211680534 | |||
d44c3d0cd3 | |||
6cb1692841 | |||
593acb954d | |||
d209bc69b6 | |||
4d64bbcf7d | |||
5bd4329b11 | |||
02870e5363 | |||
2a59478b37 | |||
04030f22a6 | |||
2cc4558018 | |||
215eb5c65f | |||
5faef316b8 | |||
6751ca4c18 | |||
84e0a20701 | |||
e04e507659 | |||
6a48dee037 | |||
ea3fd0cf65 | |||
9c614057be | |||
8096e71c53 |
1
.gitignore
vendored
@ -23,6 +23,7 @@ data/gnome-shell-wayland.desktop
|
|||||||
data/gnome-shell-wayland.desktop.in
|
data/gnome-shell-wayland.desktop.in
|
||||||
data/gnome-shell-extension-prefs.desktop
|
data/gnome-shell-extension-prefs.desktop
|
||||||
data/gnome-shell-extension-prefs.desktop.in
|
data/gnome-shell-extension-prefs.desktop.in
|
||||||
|
data/gnome-shell-theme.gresource
|
||||||
data/gschemas.compiled
|
data/gschemas.compiled
|
||||||
data/perf-background.xml
|
data/perf-background.xml
|
||||||
data/org.gnome.shell.gschema.xml
|
data/org.gnome.shell.gschema.xml
|
||||||
|
98
NEWS
@ -1,3 +1,101 @@
|
|||||||
|
3.15.1
|
||||||
|
======
|
||||||
|
* Use GResources for theme loading [Cosimo; #736936]
|
||||||
|
* Reset the OSK to primary on monitor changes [Rui; #738536]
|
||||||
|
* Use LC_TIME locale for format string translations [Florian; #738640]
|
||||||
|
* Summarize queued up notifications [Devyani; #702460]
|
||||||
|
* Improve handling of multi-day events [Andreas; #727302]
|
||||||
|
* Support EXTERNAL scroll policy type [Florian; #739379]
|
||||||
|
* Misc. bugfixes [Owen, Rui; #738652, #739252]
|
||||||
|
|
||||||
|
Contributors:
|
||||||
|
Andreas Brauchli, Cosimo Cecchi, Devyani Kota, Rui Matos, Florian Müllner,
|
||||||
|
Jasper St. Pierre, Owen W. Taylor
|
||||||
|
|
||||||
|
Translations:
|
||||||
|
Bahodir Mansurov [uz@cyrillic]
|
||||||
|
|
||||||
|
3.14.1
|
||||||
|
======
|
||||||
|
* Fix pulse animation for scrolled app folders [Florian; #736885]
|
||||||
|
* Fix updating background on file changes [Owen; #710756]
|
||||||
|
* Obtain keyboard variant from IBus [Jinkyu; #735066]
|
||||||
|
* Implement Ctrl-u / Ctrl-k keybindings in entries [Florian; #737346]
|
||||||
|
* Pass VPN hints to auth dialog [Dan; #737592]
|
||||||
|
* Only allow one screenshot request at a time [Adel; #737456]
|
||||||
|
* Respect disable-save-to-disc lockdown setting [Florian; #737846]
|
||||||
|
* Respect scaling-factor for profile pictures [Darcy; #735419]
|
||||||
|
* Focus login screen after lifting the lock screen shield [Ray; #708105]
|
||||||
|
* Speed up pulse animation for few items [Carlos S.; #737017]
|
||||||
|
* Fix gap between workspace switcher and screen edge [Florian; #728899]
|
||||||
|
* Disable unredirection during recordings [Adel; #738226]
|
||||||
|
* Ensure there's always at least one input source [Rui; #738303]
|
||||||
|
* Restrict width of dash icons' context menus [Adel; #738054]
|
||||||
|
* Misc. bug fixes [Jasper, Florian, Carlos G., Owen; #736999, #737382, #737001,
|
||||||
|
#738314, #738256, #738147]
|
||||||
|
|
||||||
|
Contributors:
|
||||||
|
Darcy Beurle, Cosimo Cecchi, Adel Gadllah, Carlos Garnacho, Rui Matos,
|
||||||
|
Florian Müllner, Carlos Soriano, Jasper St. Pierre, Ray Strode, Patrick Ward,
|
||||||
|
Dan Williams, Owen W. Taylor, Jinkyu Yi
|
||||||
|
|
||||||
|
Translations:
|
||||||
|
Мирослав Николић po/sr, sr@latin.po, Fran Diéguez [gl], Marek Černocký [cs],
|
||||||
|
Saibal Ray [bn_IN], Rajesh Ranjan [hi], Friedel Wolff [af],
|
||||||
|
Zhou Fang [zh_CN], Krishnababu Krothapalli [te], Kjartan Maraas [nb],
|
||||||
|
Rūdolfs Mazurs [lv], Sweta Kothari [gu], Christian Kirbach [de],
|
||||||
|
Cheng-Chia Tseng [zh_TW], Pedro Albuquerque [pt], Daniel Mustieles [es],
|
||||||
|
Luca Ferretti [it], Baurzhan Muftakhidinov [kk], Arash Mousavi [fa],
|
||||||
|
Milo Casagrande [it]
|
||||||
|
|
||||||
|
3.14.0
|
||||||
|
======
|
||||||
|
* Fix exposure of the accessible tree [Alejandro; #736821]
|
||||||
|
* Hide empty app folders in app picker [Florian; #736910]
|
||||||
|
|
||||||
|
Contributors:
|
||||||
|
Florian Müllner, Alejandro Piñeiro
|
||||||
|
|
||||||
|
Translations:
|
||||||
|
Yuri Myasoedov [ru], Pawan Chitrakar [ne], Manoj Kumar Giri [or],
|
||||||
|
Daniel Mustieles [es], GNOME Translation Robot [de], Rajesh Ranjan [hi],
|
||||||
|
Shankar Prasad [kn], Kenneth Nielsen [da], Daniel Korostil [uk],
|
||||||
|
Changwoo Ryu [ko], A S Alam [pa], Tom Tryfonidis [el], Petr Kovar [cs]
|
||||||
|
|
||||||
|
3.13.92
|
||||||
|
=======
|
||||||
|
* Fix submenu arrow animations [Hashem; #728927]
|
||||||
|
* Always initialize clutter accessibility [Alejandro; #735908]
|
||||||
|
* Adapt to mutter background changes [Owen; #735638]
|
||||||
|
* Improve handling of outOfDate extensions in prefs [Florian; #736185]
|
||||||
|
* Port offline updates to PackageKit's DBus interface [Kalev; #736337]
|
||||||
|
* location: Translate accuracy levels for geoclue [Zeeshan; #736479]
|
||||||
|
* Implement input source switching [Rui; #736435]
|
||||||
|
* Fix crash when dragging window from workspace switcher [Carlos G.; #735972]
|
||||||
|
* Clean out list of default favorites [Elad; #735682]
|
||||||
|
* Add settings link to location submenu [Florian; #736542]
|
||||||
|
* Fix keynav of message tray menu button [Florian; #707799]
|
||||||
|
* Misc. bug fixes [Carlos G., Florian, Rui; #736110, #736329, #736343,
|
||||||
|
#735927, #735976]
|
||||||
|
|
||||||
|
Contributors:
|
||||||
|
Elad Alfassa, Zeeshan Ali (Khattak), Michael Catanzaro, Adel Gadllah,
|
||||||
|
Carlos Garnacho, Kalev Lember, Rui Matos, Florian Müllner, Hashem Nasarat,
|
||||||
|
Alejandro Piñeiro, Carlos Soriano, Jasper St. Pierre, Owen W. Taylor
|
||||||
|
|
||||||
|
Translations:
|
||||||
|
Piotr Drąg [pl], Changwoo Ryu [ko], Yuri Myasoedov [ru], Zhou Fang [ja],
|
||||||
|
Peter Mráz [sk], Ville-Pekka Vainio [fi], Sweta Kothari [gu],
|
||||||
|
Marek Černocký [cs], A S Alam [pa], Christian Kirbach [de],
|
||||||
|
Alexandre Franke [fr], Aurimas Černius [lt], Khaled Hosny [ar],
|
||||||
|
Enrico Nicoletto [pt_BR], Andika Triwidada [id], Shantha kumar [ta],
|
||||||
|
Matej Urbančič [sl], Pawan Chitrakar [ne], Yosef Or Boczko [he],
|
||||||
|
Balázs Úr [hu], Dušan Kazik [sk], Gil Forcada [ca],
|
||||||
|
Carles Ferrando [ca@valencia], Nilamdyuti Goswami [as], Ivaylo Valkov [bg],
|
||||||
|
Sandeep Sheshrao Shedmake [mr], Umarzuki Bin Mochlis Moktar [ms],
|
||||||
|
Muhammet Kara [tr], Jiro Matsuzawa [ja], Kris Thomsen [da],
|
||||||
|
Mattias Eriksson [sv]
|
||||||
|
|
||||||
3.13.91
|
3.13.91
|
||||||
=======
|
=======
|
||||||
* Fix keynav into session menu on login screen [Florian; #735614]
|
* Fix keynav into session menu on login screen [Florian; #735614]
|
||||||
|
12
configure.ac
@ -1,5 +1,5 @@
|
|||||||
AC_PREREQ(2.63)
|
AC_PREREQ(2.63)
|
||||||
AC_INIT([gnome-shell],[3.13.91],[https://bugzilla.gnome.org/enter_bug.cgi?product=gnome-shell],[gnome-shell])
|
AC_INIT([gnome-shell],[3.15.1],[https://bugzilla.gnome.org/enter_bug.cgi?product=gnome-shell],[gnome-shell])
|
||||||
|
|
||||||
AC_CONFIG_HEADERS([config.h])
|
AC_CONFIG_HEADERS([config.h])
|
||||||
AC_CONFIG_SRCDIR([src/shell-global.c])
|
AC_CONFIG_SRCDIR([src/shell-global.c])
|
||||||
@ -37,7 +37,7 @@ AC_PATH_PROG([XSLTPROC], [xsltproc])
|
|||||||
GLIB_GSETTINGS
|
GLIB_GSETTINGS
|
||||||
|
|
||||||
# Get a value to substitute into gnome-shell.in
|
# Get a value to substitute into gnome-shell.in
|
||||||
AM_PATH_PYTHON([2.5])
|
AM_PATH_PYTHON([3])
|
||||||
AC_SUBST(PYTHON)
|
AC_SUBST(PYTHON)
|
||||||
|
|
||||||
# We need at least this, since gst_plugin_register_static() was added
|
# We need at least this, since gst_plugin_register_static() was added
|
||||||
@ -76,8 +76,8 @@ AC_MSG_RESULT($enable_systemd)
|
|||||||
CLUTTER_MIN_VERSION=1.15.90
|
CLUTTER_MIN_VERSION=1.15.90
|
||||||
GOBJECT_INTROSPECTION_MIN_VERSION=0.10.1
|
GOBJECT_INTROSPECTION_MIN_VERSION=0.10.1
|
||||||
GJS_MIN_VERSION=1.39.0
|
GJS_MIN_VERSION=1.39.0
|
||||||
MUTTER_MIN_VERSION=3.13.91
|
MUTTER_MIN_VERSION=3.15.1
|
||||||
GTK_MIN_VERSION=3.7.9
|
GTK_MIN_VERSION=3.15.0
|
||||||
GIO_MIN_VERSION=2.37.0
|
GIO_MIN_VERSION=2.37.0
|
||||||
LIBECAL_MIN_VERSION=3.5.3
|
LIBECAL_MIN_VERSION=3.5.3
|
||||||
LIBEDATASERVER_MIN_VERSION=3.5.3
|
LIBEDATASERVER_MIN_VERSION=3.5.3
|
||||||
@ -232,7 +232,9 @@ esac
|
|||||||
AM_CFLAGS="$AM_CFLAGS $WARN_CFLAGS"
|
AM_CFLAGS="$AM_CFLAGS $WARN_CFLAGS"
|
||||||
AC_SUBST(AM_CFLAGS)
|
AC_SUBST(AM_CFLAGS)
|
||||||
|
|
||||||
BROWSER_PLUGIN_DIR="${BROWSER_PLUGIN_DIR:-"\${libdir}/mozilla/plugins"}"
|
if test -z "${BROWSER_PLUGIN_DIR}"; then
|
||||||
|
BROWSER_PLUGIN_DIR="\${libdir}/mozilla/plugins"
|
||||||
|
fi
|
||||||
AC_ARG_VAR([BROWSER_PLUGIN_DIR],[Where to install the plugin to])
|
AC_ARG_VAR([BROWSER_PLUGIN_DIR],[Where to install the plugin to])
|
||||||
|
|
||||||
AC_CONFIG_FILES([
|
AC_CONFIG_FILES([
|
||||||
|
@ -35,44 +35,11 @@ introspection_DATA = \
|
|||||||
org.gnome.ShellSearchProvider.xml \
|
org.gnome.ShellSearchProvider.xml \
|
||||||
org.gnome.ShellSearchProvider2.xml
|
org.gnome.ShellSearchProvider2.xml
|
||||||
|
|
||||||
themedir = $(pkgdatadir)/theme
|
resource_files = $(shell $(GLIB_COMPILE_RESOURCES) --sourcedir=$(srcdir)/theme --generate-dependencies $(srcdir)/gnome-shell-theme.gresource.xml)
|
||||||
dist_theme_DATA = \
|
gnome-shell-theme.gresource: gnome-shell-theme.gresource.xml $(resource_files)
|
||||||
theme/calendar-arrow-left.svg \
|
$(AM_V_GEN) $(GLIB_COMPILE_RESOURCES) --target=$@ --sourcedir=$(srcdir)/theme $<
|
||||||
theme/calendar-arrow-right.svg \
|
resourcedir = $(pkgdatadir)
|
||||||
theme/calendar-today.svg \
|
resource_DATA = gnome-shell-theme.gresource
|
||||||
theme/checkbox-focused.svg \
|
|
||||||
theme/checkbox-off-focused.svg \
|
|
||||||
theme/checkbox-off.svg \
|
|
||||||
theme/checkbox.svg \
|
|
||||||
theme/close-window.svg \
|
|
||||||
theme/close.svg \
|
|
||||||
theme/corner-ripple-ltr.png \
|
|
||||||
theme/corner-ripple-rtl.png \
|
|
||||||
theme/dash-placeholder.svg \
|
|
||||||
theme/filter-selected-ltr.svg \
|
|
||||||
theme/filter-selected-rtl.svg \
|
|
||||||
theme/gnome-shell.css \
|
|
||||||
theme/logged-in-indicator.svg \
|
|
||||||
theme/message-tray-background.png \
|
|
||||||
theme/more-results.svg \
|
|
||||||
theme/noise-texture.png \
|
|
||||||
theme/page-indicator-active.svg \
|
|
||||||
theme/page-indicator-inactive.svg \
|
|
||||||
theme/page-indicator-checked.svg \
|
|
||||||
theme/page-indicator-hover.svg \
|
|
||||||
theme/panel-button-border.svg \
|
|
||||||
theme/panel-button-highlight-narrow.svg \
|
|
||||||
theme/panel-button-highlight-wide.svg \
|
|
||||||
theme/process-working.svg \
|
|
||||||
theme/running-indicator.svg \
|
|
||||||
theme/source-button-border.svg \
|
|
||||||
theme/summary-counter.svg \
|
|
||||||
theme/toggle-off-us.svg \
|
|
||||||
theme/toggle-off-intl.svg \
|
|
||||||
theme/toggle-on-us.svg \
|
|
||||||
theme/toggle-on-intl.svg \
|
|
||||||
theme/ws-switch-arrow-up.png \
|
|
||||||
theme/ws-switch-arrow-down.png
|
|
||||||
|
|
||||||
backgrounddir = $(pkgdatadir)
|
backgrounddir = $(pkgdatadir)
|
||||||
background_DATA = perf-background.xml
|
background_DATA = perf-background.xml
|
||||||
@ -116,7 +83,9 @@ EXTRA_DIST = \
|
|||||||
perf-background.xml.in \
|
perf-background.xml.in \
|
||||||
org.gnome.Shell.PortalHelper.desktop.in \
|
org.gnome.Shell.PortalHelper.desktop.in \
|
||||||
org.gnome.Shell.PortalHelper.service.in \
|
org.gnome.Shell.PortalHelper.service.in \
|
||||||
org.gnome.shell.gschema.xml.in.in
|
org.gnome.shell.gschema.xml.in.in \
|
||||||
|
gnome-shell-theme.gresource.xml \
|
||||||
|
$(resource_files)
|
||||||
|
|
||||||
CLEANFILES += \
|
CLEANFILES += \
|
||||||
gnome-shell.desktop.in \
|
gnome-shell.desktop.in \
|
||||||
@ -128,4 +97,5 @@ CLEANFILES += \
|
|||||||
perf-background.xml \
|
perf-background.xml \
|
||||||
gschemas.compiled \
|
gschemas.compiled \
|
||||||
org.gnome.shell.gschema.valid \
|
org.gnome.shell.gschema.valid \
|
||||||
org.gnome.shell.gschema.xml.in
|
org.gnome.shell.gschema.xml.in \
|
||||||
|
gnome-shell-theme.gresource
|
||||||
|
37
data/gnome-shell-theme.gresource.xml
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<gresources>
|
||||||
|
<gresource prefix="/org/gnome/shell/theme">
|
||||||
|
<file>calendar-arrow-left.svg</file>
|
||||||
|
<file>calendar-arrow-right.svg</file>
|
||||||
|
<file>calendar-today.svg</file>
|
||||||
|
<file>checkbox-focused.svg</file>
|
||||||
|
<file>checkbox-off-focused.svg</file>
|
||||||
|
<file>checkbox-off.svg</file>
|
||||||
|
<file>checkbox.svg</file>
|
||||||
|
<file>close-window.svg</file>
|
||||||
|
<file>close.svg</file>
|
||||||
|
<file>corner-ripple-ltr.png</file>
|
||||||
|
<file>corner-ripple-rtl.png</file>
|
||||||
|
<file>dash-placeholder.svg</file>
|
||||||
|
<file>filter-selected-ltr.svg</file>
|
||||||
|
<file>filter-selected-rtl.svg</file>
|
||||||
|
<file>gnome-shell.css</file>
|
||||||
|
<file>logged-in-indicator.svg</file>
|
||||||
|
<file>more-results.svg</file>
|
||||||
|
<file>noise-texture.png</file>
|
||||||
|
<file>page-indicator-active.svg</file>
|
||||||
|
<file>page-indicator-inactive.svg</file>
|
||||||
|
<file>page-indicator-checked.svg</file>
|
||||||
|
<file>page-indicator-hover.svg</file>
|
||||||
|
<file>process-working.svg</file>
|
||||||
|
<file>running-indicator.svg</file>
|
||||||
|
<file>source-button-border.svg</file>
|
||||||
|
<file>summary-counter.svg</file>
|
||||||
|
<file>toggle-off-us.svg</file>
|
||||||
|
<file>toggle-off-intl.svg</file>
|
||||||
|
<file>toggle-on-us.svg</file>
|
||||||
|
<file>toggle-on-intl.svg</file>
|
||||||
|
<file>ws-switch-arrow-up.png</file>
|
||||||
|
<file>ws-switch-arrow-down.png</file>
|
||||||
|
</gresource>
|
||||||
|
</gresources>
|
@ -1,5 +1,5 @@
|
|||||||
[Desktop Entry]
|
[Desktop Entry]
|
||||||
_Name=Captive Portal
|
_Name=Network Login
|
||||||
Type=Application
|
Type=Application
|
||||||
Exec=gapplication launch org.gnome.Shell.PortalHelper
|
Exec=gapplication launch org.gnome.Shell.PortalHelper
|
||||||
DBusActivatable=true
|
DBusActivatable=true
|
||||||
|
@ -31,7 +31,7 @@
|
|||||||
</_description>
|
</_description>
|
||||||
</key>
|
</key>
|
||||||
<key name="favorite-apps" type="as">
|
<key name="favorite-apps" type="as">
|
||||||
<default>[ 'epiphany.desktop', 'evolution.desktop', 'empathy.desktop', 'rhythmbox.desktop', 'shotwell.desktop', 'libreoffice-writer.desktop', 'org.gnome.Nautilus.desktop', 'org.gnome.Documents.desktop', 'org.gnome.Software.desktop' ]</default>
|
<default>[ 'epiphany.desktop', 'evolution.desktop', 'rhythmbox.desktop', 'shotwell.desktop', 'org.gnome.Nautilus.desktop', 'org.gnome.Software.desktop' ]</default>
|
||||||
<_summary>List of desktop file IDs for favorite applications</_summary>
|
<_summary>List of desktop file IDs for favorite applications</_summary>
|
||||||
<_description>
|
<_description>
|
||||||
The applications corresponding to these identifiers
|
The applications corresponding to these identifiers
|
||||||
|
44
data/theme/_colors.scss
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
// When color definition differs for dark and light variant,
|
||||||
|
// it gets @if ed depending on $variant
|
||||||
|
|
||||||
|
|
||||||
|
$base_color: if($variant =='light', #ffffff, #292929);
|
||||||
|
$bg_color: if($variant =='light', #ededed, #393f3f);
|
||||||
|
$fg_color: if($variant =='light', #2e3436, #eeeeec);
|
||||||
|
|
||||||
|
$selected_fg_color: #ffffff;
|
||||||
|
$selected_bg_color: if($variant == 'light', #4a90d9, darken(#4a90d9,20%));
|
||||||
|
$selected_borders_color: if($variant=='light', darken($selected_bg_color, 30%),
|
||||||
|
darken($selected_bg_color, 20%));
|
||||||
|
$borders_color: if($variant =='light', darken($bg_color,30%), darken($bg_color,12%));
|
||||||
|
$borders_edge: if($variant =='light', white, transparentize($fg_color, 0.9));
|
||||||
|
$link_color: if($variant == 'light', darken($selected_bg_color,10%),
|
||||||
|
lighten($selected_bg_color,20%));
|
||||||
|
$link_visited_color: if($variant == 'light', darken($selected_bg_color,20%),
|
||||||
|
lighten($selected_bg_color,10%));
|
||||||
|
$top_hilight: $borders_edge;
|
||||||
|
|
||||||
|
$warning_color: #f57900;
|
||||||
|
$error_color: #cc0000;
|
||||||
|
$success_color: if($variant =='light', #73d216, darken(#73d216,10%));
|
||||||
|
$destructive_color: if($variant =='light', #ef2929, darken(#ef2929,10%));
|
||||||
|
|
||||||
|
$osd_fg_color: #eeeeec;
|
||||||
|
$osd_bg_color: #2e3436;
|
||||||
|
$osd_borders_color: transparentize(black, 0.3);
|
||||||
|
$osd_outer_borders_color: transparentize(white, 0.9);
|
||||||
|
|
||||||
|
$tooltip_borders_color: $osd_outer_borders_color;
|
||||||
|
|
||||||
|
//insensitive state derived colors
|
||||||
|
$insensitive_fg_color: mix($fg_color, $bg_color, 50%);
|
||||||
|
$insensitive_bg_color: mix($bg_color, $base_color, 60%);
|
||||||
|
$insensitive_borders_color: $borders_color;
|
||||||
|
|
||||||
|
//colors for the backdrop state, derived from the main colors.
|
||||||
|
$backdrop_base_color: if($variant =='light', darken($base_color,1%), lighten($base_color,1%));
|
||||||
|
$backdrop_bg_color: $bg_color;
|
||||||
|
$backdrop_fg_color: mix($fg_color, $backdrop_bg_color, 80%);
|
||||||
|
$backdrop_insensitive_color: if($variant =='light', darken($backdrop_bg_color,15%), lighten($backdrop_bg_color,15%));
|
||||||
|
$backdrop_borders_color: mix($borders_color, $bg_color, 90%);
|
||||||
|
$backdrop_dark_fill: mix($backdrop_borders_color,$backdrop_bg_color, 35%);
|
963
data/theme/_common.scss
Normal file
@ -0,0 +1,963 @@
|
|||||||
|
//This is the RIGHT PLACE to edit the stylesheet
|
||||||
|
|
||||||
|
//let's start by telling people not to edit the generated CSS:
|
||||||
|
$cakeisalie: "This stylesheet is generated, DO NOT EDIT";
|
||||||
|
/* #{$cakeisalie} */
|
||||||
|
|
||||||
|
/* Copyright 2009, Red Hat, Inc.
|
||||||
|
*
|
||||||
|
* Portions adapted from Mx's data/style/default.css
|
||||||
|
* Copyright 2009 Intel Corporation
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms and conditions of the GNU Lesser General Public License,
|
||||||
|
* version 2.1, as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope it will be useful, but WITHOUT ANY
|
||||||
|
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
||||||
|
* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public License
|
||||||
|
* along with this program; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/* GLOBALS */
|
||||||
|
$font-size: 11;
|
||||||
|
$font-family: Cantarell, Sans-Serif;
|
||||||
|
|
||||||
|
stage {
|
||||||
|
font-family: $font-family;
|
||||||
|
@include fontsize($font-size);
|
||||||
|
color: $fg_color;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* WIDGETS */
|
||||||
|
|
||||||
|
/* Buttons */
|
||||||
|
// one would think we may want a generic button class:
|
||||||
|
// bug #737785
|
||||||
|
.candidate-page-button,
|
||||||
|
.notification-button,
|
||||||
|
.notification-icon-button,
|
||||||
|
.hotplug-notification-item,
|
||||||
|
.hotplug-resident-eject-button,
|
||||||
|
.modal-dialog-button,
|
||||||
|
.app-view-control {
|
||||||
|
border-radius: 3px;
|
||||||
|
border-width: 1px;
|
||||||
|
padding: 4px 32px;
|
||||||
|
@include button(normal);
|
||||||
|
&:hover { @include button(hover); }
|
||||||
|
&:focus { @include button(focus); }
|
||||||
|
&:insensitive { @include button(insensitive); }
|
||||||
|
&:active { @include button(active); }
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Entries */
|
||||||
|
StEntry {
|
||||||
|
border-radius: 3px;
|
||||||
|
padding: 4px;
|
||||||
|
border-width: 1px;
|
||||||
|
color: $fg_color;
|
||||||
|
@include entry(normal);
|
||||||
|
//&:hover { @include entry(hover);}
|
||||||
|
&:focus { @include entry(focus,$fc:transparentize($fg_color,0.5));}
|
||||||
|
&:insensitive { @include entry(insensitive);}
|
||||||
|
selection-background-color: $selected_bg_color;
|
||||||
|
selected-color: $selected_fg_color;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Scrollbars */
|
||||||
|
|
||||||
|
StScrollBar {
|
||||||
|
padding: 0;
|
||||||
|
&.vfade { -st-vfade-offset: 68px; }
|
||||||
|
&.hfade { -st-hfade-offset: 68px; }
|
||||||
|
|
||||||
|
StScrollView & {
|
||||||
|
min-width: 14px;
|
||||||
|
min-height: 14px;
|
||||||
|
}
|
||||||
|
|
||||||
|
StBin#trough {
|
||||||
|
border-radius: 0;
|
||||||
|
background-color: darken($bg_color,10%);
|
||||||
|
}
|
||||||
|
|
||||||
|
StButton#vhandle, StButton#hhandle {
|
||||||
|
border-radius: 8px;
|
||||||
|
background-color: $bg_color;
|
||||||
|
border: 3px solid darken($bg_color,10%); //would be nice to margin or at least to transparent
|
||||||
|
&:hover { background-color: lighten($bg_color,10%); }
|
||||||
|
&:active { background-color: $selected_bg_color; }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Slider */
|
||||||
|
|
||||||
|
.slider {
|
||||||
|
height: 1em;
|
||||||
|
-slider-height: 0.3em;
|
||||||
|
-slider-background-color: $insensitive_bg_color; //background of the trough
|
||||||
|
-slider-border-color: $borders_color; //trough border color
|
||||||
|
-slider-active-background-color: $selected_bg_color; //active trough fill
|
||||||
|
-slider-active-border-color: darken($selected_bg_color,10%); //active trough border
|
||||||
|
-slider-border-width: 1px;
|
||||||
|
-slider-handle-radius: 6px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Check Boxes */
|
||||||
|
|
||||||
|
.check-box {
|
||||||
|
StBoxLayout { spacing: .8em; }
|
||||||
|
StBin {
|
||||||
|
width: 24px;
|
||||||
|
height: 22px;
|
||||||
|
background-image: url("checkbox-off.svg");
|
||||||
|
}
|
||||||
|
&:focus Stbin { background-image: url("checkbox-off-focused.svg"); }
|
||||||
|
&:checked Stbin { background-image: url("checkbox.svg"); }
|
||||||
|
&:focus:checked Stbin { background-image: url("checkbox-focused.svg"); }
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Switches */
|
||||||
|
.toggle-switch {
|
||||||
|
width: 65px;
|
||||||
|
height: 22px;
|
||||||
|
background-size: contain;
|
||||||
|
}
|
||||||
|
|
||||||
|
@each $v in us, intl {
|
||||||
|
.toggle-switch-#{$v} {
|
||||||
|
background-image: url("toggle-off-#{$v}.svg");
|
||||||
|
&:checked { background-image: url("toggle-on-#{$v}.svg"); }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* links */
|
||||||
|
.shell-link {
|
||||||
|
color: $link_color;
|
||||||
|
&:hover { color: lighten($link_color,10%); }
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Modal Dialogs */
|
||||||
|
|
||||||
|
.lightbox { background-color: black; } //FIXME where is this?
|
||||||
|
.flashspot { background-color: white; } //FIXME where is this?
|
||||||
|
|
||||||
|
.modal-dialog {
|
||||||
|
border-radius: 5px;
|
||||||
|
background-color: transparentize(darken($bg_color,10%),0.05);
|
||||||
|
border: 1px solid $borders_color;
|
||||||
|
padding: 24px;
|
||||||
|
|
||||||
|
.run-dialog-entry { width: 20em; }
|
||||||
|
.run-dialog-error-box {
|
||||||
|
padding-top: 16px;
|
||||||
|
spacing: 6px;
|
||||||
|
}
|
||||||
|
.run-dialog-button-box { padding-top: 1em; }
|
||||||
|
.run-dialog-label {
|
||||||
|
font-size: fontsize($font-size + 1.1);
|
||||||
|
font-weight: bold;
|
||||||
|
color: darken($fg_color,10%);
|
||||||
|
padding-bottom: .4em;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
.button-dialog-button-box {
|
||||||
|
spacing: 18px;
|
||||||
|
padding-top: 48px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.show-processes-dialog-subject,
|
||||||
|
.mount-question-dialog-subject,
|
||||||
|
.end-session-dialog-subject { //this should be a generic header class
|
||||||
|
font-size: fontsize($font-size * 1.3);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Popvers/Menus */
|
||||||
|
|
||||||
|
.popup-menu {
|
||||||
|
min-width: 200px;
|
||||||
|
|
||||||
|
.popup-menu-arrow { } //defined globally in the TOP BAR
|
||||||
|
.popup-sub-menu {
|
||||||
|
background-color: darken($bg_color,2%);
|
||||||
|
border-top: 1px solid lighten($borders_color,5%);
|
||||||
|
border-bottom: 1px solid lighten($borders_color,5%);
|
||||||
|
}
|
||||||
|
|
||||||
|
.popup-menu-content { padding: 1em 0em; }
|
||||||
|
.popup-menu-item {
|
||||||
|
spacing: 12px;
|
||||||
|
|
||||||
|
&:ltr { padding: .4em 1.75em .4em 0em; }
|
||||||
|
&:rtl { padding: .4em 0em .4em 1.75em; }
|
||||||
|
&:active { background-color: lighten($bg_color,10%); }
|
||||||
|
&:insensitive { background-color: transparentize($bg_color,.5); }
|
||||||
|
}
|
||||||
|
.popup-inactive-menu-item { //all icons and other graphical elements
|
||||||
|
color: $fg_color;
|
||||||
|
|
||||||
|
&:insensitive { color: transparentize($fg_color,0.5); }
|
||||||
|
}
|
||||||
|
//.popup-status-menu-item { font-weight: normal; color: pink; } //dunno what that is
|
||||||
|
}
|
||||||
|
|
||||||
|
.popup-menu-ornament {
|
||||||
|
text-align: right;
|
||||||
|
width: 1em;
|
||||||
|
}
|
||||||
|
.popup-menu-boxpointer,
|
||||||
|
.candidate-popup-boxpointer {
|
||||||
|
-arrow-border-radius: 3px;
|
||||||
|
-arrow-background-color: $bg_color;
|
||||||
|
-arrow-border-width: 1px;
|
||||||
|
-arrow-border-color: $borders_color;
|
||||||
|
-arrow-base: 24px;
|
||||||
|
-arrow-rise: 11px;
|
||||||
|
-arrow-box-shadow: 0 1px 3px red; //dreaming. bug #689995
|
||||||
|
}
|
||||||
|
|
||||||
|
.popup-separator-menu-item {
|
||||||
|
-margin-horizontal: 24px;
|
||||||
|
height: 1px; //not really the whole box
|
||||||
|
padding: 0; //not really centered
|
||||||
|
background-color: transparent;
|
||||||
|
border-color: lighten($borders_color,10%);
|
||||||
|
border-bottom-width: 1px;
|
||||||
|
border-bottom-style: solid;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* fallback menu
|
||||||
|
- odd thing for styling App menu when apparently not running under shell. Light Adwaita styled
|
||||||
|
app menu inside the main app window itself rather than the top bar
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* TOP BAR */
|
||||||
|
|
||||||
|
#panel {
|
||||||
|
background-color: black;
|
||||||
|
font-weight: bold;
|
||||||
|
height: 1.86em;
|
||||||
|
|
||||||
|
&.unlock-screen,
|
||||||
|
&.login-screen,
|
||||||
|
&.lock-screen {
|
||||||
|
background-color: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
#panelLeft, #panelCenter { // spacing between activities<>app menu and such
|
||||||
|
spacing: 4px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.panel-corner {
|
||||||
|
-panel-corner-radius: 6px;
|
||||||
|
-panel-corner-background-color: black;
|
||||||
|
-panel-corner-border-width: 2px;
|
||||||
|
-panel-corner-border-color: transparent;
|
||||||
|
|
||||||
|
&:active, &:overview, &:focus {
|
||||||
|
-panel-corner-border-color: lighten($selected_bg_color,5%);
|
||||||
|
}
|
||||||
|
|
||||||
|
&.lock-screen, &.login-screen, &unlock-screen {
|
||||||
|
-panel-corner-radius: 0;
|
||||||
|
-panel-corner-background-color: transparent;
|
||||||
|
-panel-corner-border-color: transparent;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.panel-button {
|
||||||
|
padding: 0px 12px;
|
||||||
|
font-weight: bold;
|
||||||
|
color: #ccc;
|
||||||
|
transition-duration: 100ms;
|
||||||
|
|
||||||
|
#appMenuIcon {
|
||||||
|
app-icon-bottom-clip: 1px;
|
||||||
|
|
||||||
|
.panel-button:active &,
|
||||||
|
.panel-button:overview &,
|
||||||
|
.panel-button:focus &,
|
||||||
|
.panel-button:checked & {
|
||||||
|
app-icon-bottom-clip: 2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
&:hover {
|
||||||
|
color: lighten($fg_color, 10%);
|
||||||
|
text-shadow: black 0 2px 2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:active, &:overview, &:focus, &:checked {
|
||||||
|
// Trick due to St limitations. It needs a background to draw
|
||||||
|
// a box-shadow
|
||||||
|
background-color: rgba(0, 0, 0, 0.01);
|
||||||
|
box-shadow: inset 0 -2px 0px lighten($selected_bg_color,5%);
|
||||||
|
color: lighten($fg_color,10%);
|
||||||
|
text-shadow: black 0px 2px 2px;
|
||||||
|
|
||||||
|
& > .system-status-icon { icon-shadow: black 0 2px 2px; }
|
||||||
|
}
|
||||||
|
|
||||||
|
.system-status-icon { icon-size: 1.09em; padding: 0 5px; }
|
||||||
|
.unlock-screen &,
|
||||||
|
.login-screen &,
|
||||||
|
.lock-screen & {
|
||||||
|
color: lighten($fg_color, 10%);
|
||||||
|
&:focus, &:hover, &:active { color: lighten($fg_color, 10%); }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.panel-status-button {
|
||||||
|
|
||||||
|
&:active, &:overview, &:focus, &:checked {
|
||||||
|
border-color: lighten($selected_bg_color,5%);
|
||||||
|
border-bottom-width: 2px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.panel-menu { -boxpointer-gap: 4px; } //FIXME
|
||||||
|
.panel-status-indicators-box, //FIXME
|
||||||
|
.panel-status-menu-box {
|
||||||
|
spacing: 2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.screencast-indicator { color: $warning_color; }
|
||||||
|
}
|
||||||
|
|
||||||
|
// a little unstructured mess:
|
||||||
|
|
||||||
|
.system-switch-user-submenu-icon {
|
||||||
|
icon-size: 24px;
|
||||||
|
border: 1px solid transparentize($fg_color,0.6);
|
||||||
|
}
|
||||||
|
|
||||||
|
#appMenu {
|
||||||
|
spinner-image: url("process-working.svg");
|
||||||
|
spacing: 4px;
|
||||||
|
|
||||||
|
.label-shadow { color: transparentize(#000,0.5); }
|
||||||
|
}
|
||||||
|
|
||||||
|
.aggregate-menu {
|
||||||
|
width: 360px;
|
||||||
|
.popup-menu-icon { padding: 0 4px; }
|
||||||
|
}
|
||||||
|
|
||||||
|
.system-menu-action {
|
||||||
|
color: $fg_color;
|
||||||
|
border-radius: 32px; /* wish we could do 50% */
|
||||||
|
padding: 13px;
|
||||||
|
border: 1px solid lighten($borders_color,5%);
|
||||||
|
|
||||||
|
&:hover, &:focus {
|
||||||
|
color: lighten($fg_color, 10%);
|
||||||
|
background-color: lighten($bg_color,10%);
|
||||||
|
border: none;
|
||||||
|
padding: 14px;
|
||||||
|
}
|
||||||
|
&:active { background-color: lighten($borders_color,5%); }
|
||||||
|
|
||||||
|
& > StIcon { icon-size: 16px; }
|
||||||
|
}
|
||||||
|
|
||||||
|
// not really top bar only
|
||||||
|
.popup-menu-arrow { width: 16px; height: 16px; }
|
||||||
|
.popup-menu-icon { icon-size: 1.09em; }
|
||||||
|
|
||||||
|
//close buttons
|
||||||
|
|
||||||
|
.window-close, .notification-close {
|
||||||
|
background-image: url("close-window.svg");
|
||||||
|
background-size: 32px;
|
||||||
|
height: 32px;
|
||||||
|
width: 32px;
|
||||||
|
}
|
||||||
|
.window-close {
|
||||||
|
-shell-close-overlap: 16px;
|
||||||
|
&:rtl { -st-background-image-shadow: 2px 2px 6px rgba(0,0,0,0.5); }
|
||||||
|
}
|
||||||
|
.notification-close {
|
||||||
|
-shell-close-overlap-x: 14px;
|
||||||
|
-shell-close-overlap-y: -12px;
|
||||||
|
|
||||||
|
&:rtl { -shell-close-overlap-x: -14px; }
|
||||||
|
}
|
||||||
|
|
||||||
|
/* OVERVIEW */
|
||||||
|
|
||||||
|
#overview {
|
||||||
|
spacing: 24px; //
|
||||||
|
|
||||||
|
}
|
||||||
|
.window-picker { //container around window thumbnails
|
||||||
|
-horizontal-spacing: 32px;
|
||||||
|
-vertical-spacing: 32px;
|
||||||
|
padding-left: 32px;
|
||||||
|
padding-right: 32px;
|
||||||
|
padding-bottom: 48px;
|
||||||
|
|
||||||
|
&.external-monitor { padding: 32px; }
|
||||||
|
}
|
||||||
|
|
||||||
|
.window-clone-border {
|
||||||
|
border: 4px solid $selected_bg_color;
|
||||||
|
border-radius: 4px;
|
||||||
|
}
|
||||||
|
.window-caption {
|
||||||
|
spacing: 25px;
|
||||||
|
background-color: transparentize($bg_color,0.3);
|
||||||
|
border-radius: 8px;
|
||||||
|
padding: 4px 12px;
|
||||||
|
-shell-caption-spacing: 12px;
|
||||||
|
&:hover { background-color: $selected_bg_color; }
|
||||||
|
}
|
||||||
|
|
||||||
|
.messages-indicator { color: transparentize($fg_color,.2); height: 32px; }
|
||||||
|
.messages-indicator-contents { spacing: 12px; padding-bottom: 12px; }
|
||||||
|
|
||||||
|
//search entry
|
||||||
|
.search-entry {
|
||||||
|
width: 320px;
|
||||||
|
padding: 7px 9px;
|
||||||
|
border-radius: 24px;
|
||||||
|
&:focus {
|
||||||
|
padding: 6px 8px;
|
||||||
|
border-width: 2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.search-entry-icon { icon-size: 1em; padding: 0 4px; color: transparentize($fg_color,.3); }
|
||||||
|
|
||||||
|
&:hover, &:focus {
|
||||||
|
.search-entry-icon { color: $fg_color; }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//search results
|
||||||
|
|
||||||
|
#searchResultsBin {
|
||||||
|
max-width: 1000px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#searchResultsContent {
|
||||||
|
padding-left: 20px;
|
||||||
|
padding-right: 20px;
|
||||||
|
spacing: 16px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.search-section { spacing: 16px; } // This should be equal to #searchResultsContent spacing
|
||||||
|
.search-section-content { spacing: 32px; } // This is the space between the provider icon and the results container
|
||||||
|
.search-statustext { // "no results"
|
||||||
|
@extend %status_text;
|
||||||
|
}
|
||||||
|
.list-search-results { spacing: 3px; }
|
||||||
|
|
||||||
|
.search-section-separator {
|
||||||
|
-gradient-height: 1px;
|
||||||
|
-gradient-start: rgba(255,255,255,0);
|
||||||
|
-gradient-end: rgba(255,255,255,0.1);
|
||||||
|
-margin-horizontal: 1.5em;
|
||||||
|
height: 1px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.list-search-result-content { spacing: 12px; padding: 12px; }
|
||||||
|
.list-search-result-title { font-size: 1.5em; color: darken($fg_color,5%); }
|
||||||
|
.list-search-result-description { color: darken($fg_color,15%); }
|
||||||
|
.search-provider-icon { padding: 15px; }
|
||||||
|
.search-provider-icon-more {
|
||||||
|
width: 16px;
|
||||||
|
height: 16px;
|
||||||
|
background-image: url("more-results.svg");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* DASHBOARD */
|
||||||
|
|
||||||
|
#dash {
|
||||||
|
@extend %overview-panel;
|
||||||
|
padding: 4px;
|
||||||
|
border-left: 0px;
|
||||||
|
border-radius: 0px 9px 9px 0px;
|
||||||
|
|
||||||
|
&:rtl {
|
||||||
|
border-left-width: 1px;
|
||||||
|
border-right-width: 0;
|
||||||
|
border-radius: 9px 0 0 9px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.placeholder {
|
||||||
|
background-image: url("dash-placeholder.svg");
|
||||||
|
background-size: contain;
|
||||||
|
height: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.empty-dash-drop-target {
|
||||||
|
width: 24px;
|
||||||
|
height: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
.dash-item-container > StWidget {
|
||||||
|
padding: 4px 8px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.dash-label { //osd tooltip
|
||||||
|
border-radius: 7px;
|
||||||
|
padding: 4px 12px;
|
||||||
|
background-color: transparentize($bg_color,0.3);
|
||||||
|
text-align: center;
|
||||||
|
-x-offset: 8px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* App Vault/Grid */
|
||||||
|
.icon-grid {
|
||||||
|
spacing: 30px;
|
||||||
|
-shell-grid-horizontal-item-size: 136px;
|
||||||
|
-shell-grid-vertical-item-size: 136px;
|
||||||
|
|
||||||
|
.overview-icon { icon-size: 96px; } //FIXME no effect
|
||||||
|
}
|
||||||
|
//.app-display { spacing: 20px; }
|
||||||
|
|
||||||
|
.app-view-controls { //favorties | all toggle container
|
||||||
|
padding-bottom: 32px;
|
||||||
|
}
|
||||||
|
.app-view-control { //favorties | all toggle button
|
||||||
|
padding: 4px 32px;
|
||||||
|
&:checked { @include button(active); }
|
||||||
|
&:first-child {
|
||||||
|
border-right-width: 0;
|
||||||
|
border-radius: 3px 0 0 3px;
|
||||||
|
}
|
||||||
|
&:last-child {
|
||||||
|
border-radius: 0 3px 3px 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//Icon tile
|
||||||
|
.search-provider-icon,
|
||||||
|
.list-search-result {
|
||||||
|
@extend %icon_tile;
|
||||||
|
&:active, &:checked { background-color: transparentize(darken($bg_color,10%),.1); }
|
||||||
|
&:focus, &:selected, &:hover {
|
||||||
|
background-color: transparentize($fg_color,.9);
|
||||||
|
transition-duration: 200ms;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.app-well-app,
|
||||||
|
.app-well-app.app-folder,
|
||||||
|
.show-apps,
|
||||||
|
.grid-search-result {
|
||||||
|
& > .overview-icon {
|
||||||
|
@extend %icon_tile;
|
||||||
|
}
|
||||||
|
&.running > .overview-icon {
|
||||||
|
text-shadow: black 0px 2px 2px;
|
||||||
|
}
|
||||||
|
&:active > .overview-icon,
|
||||||
|
&:checked > .overview-icon {
|
||||||
|
background-color: transparentize(darken($bg_color,10%),.1); //FIXME not working?
|
||||||
|
box-shadow: inset 0 1px 2px $borders_color;
|
||||||
|
}
|
||||||
|
&:hover > .overview-icon,
|
||||||
|
&.running:hover > .overview-icon,
|
||||||
|
&:focus > .overview-icon,
|
||||||
|
&:selected > .overview-icon {
|
||||||
|
background-color: transparentize($fg_color,.9);
|
||||||
|
transition-duration: 0ms;
|
||||||
|
border-image: none;
|
||||||
|
background-image: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
.app-well-app-running-dot { //running apps indicator
|
||||||
|
width: 10px; height: 3px;
|
||||||
|
background-color: $selected_bg_color;
|
||||||
|
margin-bottom: 2px; //FIXME will happen :)
|
||||||
|
}
|
||||||
|
|
||||||
|
%icon_tile {
|
||||||
|
border-radius: 4px;
|
||||||
|
padding: 6px;
|
||||||
|
border: 1px solid transparent;
|
||||||
|
transition-duration: 100ms;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.app-well-app.app-folder > .overview-icon {
|
||||||
|
background-color: transparentize($bg_color,.6);
|
||||||
|
}
|
||||||
|
|
||||||
|
.show-apps:checked .show-apps-icon,
|
||||||
|
.show-apps:focus .show-apps-icon {
|
||||||
|
color: white;
|
||||||
|
transition-duration: 100ms;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Collections
|
||||||
|
.app-folder-popup { //expanded collection
|
||||||
|
-arrow-border-radius: 8px;
|
||||||
|
-arrow-background-color: transparentize($bg_color,0.7);
|
||||||
|
-arrow-base: 24px;
|
||||||
|
-arrow-rise: 11px;
|
||||||
|
}
|
||||||
|
.app-folder-popup-bin { padding: 5px; }
|
||||||
|
.app-folder-icon {
|
||||||
|
padding: 5px;
|
||||||
|
spacing-rows: 5px;
|
||||||
|
spacing-columns: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.page-indicator {
|
||||||
|
padding: 15px 20px;
|
||||||
|
|
||||||
|
.page-indicator-icon {
|
||||||
|
width: 18px;
|
||||||
|
height: 18px;
|
||||||
|
background-image: url(page-indicator-inactive.svg);
|
||||||
|
}
|
||||||
|
|
||||||
|
&:hover .page-indicator-icon { background-image: url(page-indicator-hover.svg); }
|
||||||
|
&:active .page-indicator-icon { background-image: url(page-indicator-active.svg); }
|
||||||
|
&:checked .page-indicator-icon,
|
||||||
|
&:checked:active { background-image: url(page-indicator-checked.svg); }
|
||||||
|
}
|
||||||
|
|
||||||
|
.no-frequent-applications-label { @extend %status_text; }
|
||||||
|
|
||||||
|
.app-well-app > .overview-icon.overview-icon-with-label,
|
||||||
|
.grid-search-result .overview-icon.overview-icon-with-label {
|
||||||
|
padding: 10px 8px 5px 8px;
|
||||||
|
spacing: 4px;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Workspace pager
|
||||||
|
.workspace-thumbnails { //container ala dash
|
||||||
|
@extend %overview-panel;
|
||||||
|
visible-width: 32px; //amount visible before hover
|
||||||
|
spacing: 11px;
|
||||||
|
padding: 8px;
|
||||||
|
border-radius: 9px 0 0 9px;
|
||||||
|
//border-width: 1px 0 1px 1px; //fixme: can't have non unoform borders :(
|
||||||
|
&:rtl { border-radius: 0 9px 9px 0;}
|
||||||
|
}
|
||||||
|
.workspace-thumbnail-indicator {
|
||||||
|
border: 4px solid $selected_bg_color;
|
||||||
|
padding: 1px;
|
||||||
|
}
|
||||||
|
|
||||||
|
//Some hacks I don't even
|
||||||
|
// FIXME
|
||||||
|
.search-display > StBoxLayout,
|
||||||
|
.all-apps,
|
||||||
|
.frequent-apps > StBoxLayout {
|
||||||
|
// horizontal padding to make sure scrollbars or dash don't overlap content
|
||||||
|
padding: 0px 88px 10px 88px;
|
||||||
|
}
|
||||||
|
|
||||||
|
%overview-panel {
|
||||||
|
color: $fg_color;
|
||||||
|
background-color: $bg_color;
|
||||||
|
border: 1px solid transparentize($fg_color,0.8);
|
||||||
|
}
|
||||||
|
|
||||||
|
%status_text {
|
||||||
|
font-size: 2em;
|
||||||
|
font-weight: bold;
|
||||||
|
color: $fg_color;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* NOTIFICATIONS & MESSAGE TRAY */
|
||||||
|
|
||||||
|
#message-tray {
|
||||||
|
background: darken($bg_color,10%) url("noise-texture.png");
|
||||||
|
background-repeat: repeat;
|
||||||
|
height: 72px;
|
||||||
|
box-shadow: inset 0 2px 4px rgba(0,0,0,0.5);
|
||||||
|
padding: 4px;
|
||||||
|
.message-tray-summary { height: 72px; }
|
||||||
|
|
||||||
|
.message-tray-menu-button {
|
||||||
|
StIcon {
|
||||||
|
padding: 0 20px;
|
||||||
|
color: $fg_color;
|
||||||
|
icon-size: 24px;
|
||||||
|
opacity: 1;
|
||||||
|
}
|
||||||
|
&:hover StIcon { color: lighten($fg_color, 15%); }
|
||||||
|
&:active StIcon { color: lighten($selected_bg_color, 10%); }
|
||||||
|
}
|
||||||
|
.no-messages-label { color: darken($fg_color,10%); }
|
||||||
|
}
|
||||||
|
.url-highlighter { link-color: $selected_bg_color; }
|
||||||
|
|
||||||
|
// Banners
|
||||||
|
.notification {
|
||||||
|
font-size: 11pt;
|
||||||
|
width: 34em;
|
||||||
|
border-radius: 6px 6px 0 0;
|
||||||
|
background-color: transparentize(darken($bg_color,8%),.05);
|
||||||
|
border: 1px solid $borders_color;
|
||||||
|
border-bottom-width: 0;
|
||||||
|
//box-shadow: 0 1px 4px black;
|
||||||
|
spacing-rows: 4px;
|
||||||
|
padding: 8px 8px 4px 8px;
|
||||||
|
spacing-columns: 10px;
|
||||||
|
&.multi-line-notification { padding-bottom: 8px; }
|
||||||
|
}
|
||||||
|
.notification-unexpanded {
|
||||||
|
// We want to force the actor at a specific size, irrespective
|
||||||
|
// of its minimum and preferred size, so we override both
|
||||||
|
min-height: 36px;
|
||||||
|
height: 36px;
|
||||||
|
}
|
||||||
|
// We use row-span = 2 for the image cell, which prevents its height preferences to be
|
||||||
|
// taken into account during allocation, so its height ends up being limited by the height
|
||||||
|
// of the content in the other rows. To avoid showing a stretched image, we set the minimum
|
||||||
|
// height of the table to be ICON_SIZE + IMAGE_SIZE + spacing-rows = 24 + 125 + 10 = 159
|
||||||
|
.notification-with-image {
|
||||||
|
min-height: 159px;
|
||||||
|
}
|
||||||
|
.notification-body { spacing: 5px; }
|
||||||
|
.notification-actions {
|
||||||
|
paddinf-top: 18px;
|
||||||
|
spacing: 6px;
|
||||||
|
}
|
||||||
|
//Message tray items
|
||||||
|
.summary-source {
|
||||||
|
border-radius: 0;
|
||||||
|
-st-natural-width: 60px; //FIXME left aligned rather than centered
|
||||||
|
padding: 9px;
|
||||||
|
transition-duration: 100ms;
|
||||||
|
}
|
||||||
|
.summary-source-button {
|
||||||
|
&:hover .summary-source,
|
||||||
|
&:selected .summary-source,
|
||||||
|
&:focus .summary-source { background-color: lighten($bg_color,2%); }
|
||||||
|
}
|
||||||
|
.summary-source-counter {
|
||||||
|
font-size: 10pt;
|
||||||
|
font-weight: bold;
|
||||||
|
height: 1.6em; width: 1.6em;
|
||||||
|
-shell-counter-overlap-x: 3px;
|
||||||
|
-shell-counter-overlap-y: 3px;
|
||||||
|
background-color: $selected_bg_color;
|
||||||
|
border: 2px solid $fg_color;
|
||||||
|
box-shadow: 0 2px 2px rgba(0,0,0,0.5);
|
||||||
|
border-radius: 0.9em; // should be 0.8 but whatever; wish I could do 50%;
|
||||||
|
}
|
||||||
|
|
||||||
|
//Message tray popovers
|
||||||
|
.summary-boxpointer {
|
||||||
|
-arrow-border-radius: 15px;
|
||||||
|
-arrow-background-color: transparentize(darken($bg_color,8%),.05);
|
||||||
|
-arrow-base: 36px;
|
||||||
|
-arrow-rise: 18px;
|
||||||
|
color: $fg_color;
|
||||||
|
-boxpointer-gap: 4px;
|
||||||
|
.notification {
|
||||||
|
border-radius: 9px;
|
||||||
|
border-width: 0; //temporary workaround for border brokenness
|
||||||
|
background-color: transparentize(darken($bg_color,8%),.05) !important;
|
||||||
|
padding-bottom: 12px;
|
||||||
|
}
|
||||||
|
#summary-right-click-menu {
|
||||||
|
padding-top: 12px;
|
||||||
|
padding-bottom: 12px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.summary-notification-stack-scrollview {
|
||||||
|
max-height: 24em;
|
||||||
|
padding-top: 8px;
|
||||||
|
padding-bottom: 8px;
|
||||||
|
&:ltr { padding-right: 8px; }
|
||||||
|
&:rtl { padding-left: 8px; }
|
||||||
|
}
|
||||||
|
.notification-scrollview {
|
||||||
|
max-height: 18em;
|
||||||
|
-st-vfade-offset: 24px;
|
||||||
|
&:ltr > StScrollBar { padding-left: 6px; }
|
||||||
|
&:rtl > StScrollBar { padding-right: 6px; }
|
||||||
|
}
|
||||||
|
.notification-button { -st-natural-width: 140px; }
|
||||||
|
.notification-icon-button {
|
||||||
|
border-radius: 5px;
|
||||||
|
padding: 5px;
|
||||||
|
&:focus { }//FIXME
|
||||||
|
& > StIcon { icons-size: 16px; padding: 8px; }
|
||||||
|
}
|
||||||
|
.secondary-icon { icon-size: 1.09em; } //FIXME
|
||||||
|
|
||||||
|
//chat bubbles
|
||||||
|
.chat-log-message { color: darken($fg_color,10%); }
|
||||||
|
.chat-empty-line { font-size: 4px; }
|
||||||
|
.chat-received {
|
||||||
|
padding-left: 4px;
|
||||||
|
&:rtl { padding-left: 0px; padding-right: 4px; }
|
||||||
|
}
|
||||||
|
.chat-sent {
|
||||||
|
padding-left: 18pt;
|
||||||
|
color: darken($fg_color, 15%);
|
||||||
|
&:rtl { padding-left: 0; padding-right: 18pt; }
|
||||||
|
}
|
||||||
|
.chat-meta-message {
|
||||||
|
padding-left: 4px;
|
||||||
|
font-size: 9pt;
|
||||||
|
font-weight: bold;
|
||||||
|
color: darken($fg_color,20%);
|
||||||
|
&:rtl { padding-left: 0; padding-right: 4px; }
|
||||||
|
}
|
||||||
|
.chat-notification-scrollview { max-height: 22em; }
|
||||||
|
.subscription-message { font-style: italic; }
|
||||||
|
|
||||||
|
//hotplug
|
||||||
|
.hotplug-transient-box {
|
||||||
|
spacing: 6px;
|
||||||
|
padding: 2px 72px 2px 12px;//FIXME wat?
|
||||||
|
}
|
||||||
|
.hotplug-notification-item {
|
||||||
|
padding: 2px 10px;
|
||||||
|
&:focus { padding: 1px 71px 1px 11px; } //FIXME wat?
|
||||||
|
}
|
||||||
|
|
||||||
|
.hotplug-notification-item-icon {
|
||||||
|
icon-size: 24px;
|
||||||
|
padding: 2px 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hotplug-resident-box { spacing: 8px; }
|
||||||
|
|
||||||
|
.hotplug-resident-mount {
|
||||||
|
spacing: 8px;
|
||||||
|
border-radius: 4px;
|
||||||
|
color: green;
|
||||||
|
&:hover {
|
||||||
|
color: red;
|
||||||
|
background-color: blue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.hotplug-resident-mount-label {
|
||||||
|
color: inherit;
|
||||||
|
padding-left: 6px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hotplug-resident-mount-icon {
|
||||||
|
icon-size: 24px;
|
||||||
|
padding-left: 6px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hotplug-resident-eject-icon {
|
||||||
|
icon-size: 16px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hotplug-resident-eject-button {
|
||||||
|
padding: 7px;
|
||||||
|
border-radius: 5px;
|
||||||
|
color: pink;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Eeeky things */
|
||||||
|
//Mess that is Looking Glass
|
||||||
|
|
||||||
|
#LookingGlassDialog {
|
||||||
|
background-color: rgba(0,0,0,0.80);
|
||||||
|
spacing: 4px;
|
||||||
|
padding: 4px;
|
||||||
|
border: 2px solid grey;
|
||||||
|
border-radius: 4px;
|
||||||
|
& > #Toolbar {
|
||||||
|
border: 1px solid grey;
|
||||||
|
border-radius: 4px;
|
||||||
|
}
|
||||||
|
.labels { spacing: 4px; }
|
||||||
|
.notebook-tab {
|
||||||
|
-natural-hpadding: 12px;
|
||||||
|
-minimum-hpadding: 6px;
|
||||||
|
font-weight: bold;
|
||||||
|
color: #ccc;
|
||||||
|
transition-duration: 100ms;
|
||||||
|
padding-left: .3em;
|
||||||
|
padding-right: .3em;
|
||||||
|
&:hover {
|
||||||
|
color: white;
|
||||||
|
text-shadow: black 0px 2px 2px;
|
||||||
|
}
|
||||||
|
&:selected {
|
||||||
|
border-bottom-width: 2px;
|
||||||
|
border-color: lighten($selected_bg_color,5%);
|
||||||
|
color: white;
|
||||||
|
text-shadow: black 0px 2px 2px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
StBoxLayout#EvalBox { padding: 4px; spacing: 4px; }
|
||||||
|
StBoxLayout#ResultsArea { spacing: 4px; }
|
||||||
|
}
|
||||||
|
|
||||||
|
.lg-dialog {
|
||||||
|
StEntry {
|
||||||
|
selection-background-color: #bbbbbb;
|
||||||
|
selected-color: #333333;
|
||||||
|
}
|
||||||
|
.shell-link {
|
||||||
|
color: #999999;
|
||||||
|
&:hover { color: #dddddd; }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.lg-completions-text {
|
||||||
|
font-size: .9em;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
||||||
|
|
||||||
|
.lg-obj-inspector-title {
|
||||||
|
spacing: 4px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.lg-obj-inspector-button {
|
||||||
|
border: 1px solid gray;
|
||||||
|
padding: 4px;
|
||||||
|
border-radius: 4px;
|
||||||
|
&:hover { border: 1px solid #ffffff; }
|
||||||
|
}
|
||||||
|
|
||||||
|
#lookingGlassExtensions { padding: 4px; }
|
||||||
|
|
||||||
|
.lg-extensions-list {
|
||||||
|
padding: 4px;
|
||||||
|
spacing: 6px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.lg-extension {
|
||||||
|
border: 1px solid #6f6f6f;
|
||||||
|
border-radius: 4px;
|
||||||
|
padding: 4px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.lg-extension-name {
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.lg-extension-meta {
|
||||||
|
spacing: 6px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#LookingGlassPropertyInspector {
|
||||||
|
background: rgba(0, 0, 0, 0.8);
|
||||||
|
border: 2px solid grey;
|
||||||
|
border-radius: 4px;
|
||||||
|
padding: 6px;
|
||||||
|
}
|
219
data/theme/_drawing.scss
Normal file
@ -0,0 +1,219 @@
|
|||||||
|
// Drawing mixins
|
||||||
|
|
||||||
|
// generic drawing of more complex things
|
||||||
|
|
||||||
|
@function _widget_edge($c:$borders_edge) {
|
||||||
|
// outer highlight "used" on most widgets
|
||||||
|
@return 0 1px $c;
|
||||||
|
}
|
||||||
|
|
||||||
|
// provide font size in rem, with px fallback
|
||||||
|
@mixin fontsize($size: 24, $base: 16) {
|
||||||
|
font-size: round($size) + pt;
|
||||||
|
//font-size: ($size / $base) * 1rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
@mixin _shadows($shadow1, $shadow2:none, $shadow3:none, $shadow4:none) {
|
||||||
|
//
|
||||||
|
// Helper function to stack up to 4 box-shadows;
|
||||||
|
//
|
||||||
|
@if $shadow4!=none { box-shadow: $shadow1, $shadow2, $shadow3, $shadow4; }
|
||||||
|
@else if $shadow3!=none { box-shadow: $shadow1, $shadow2, $shadow3; }
|
||||||
|
@else if $shadow2!=none { box-shadow: $shadow1, $shadow2; }
|
||||||
|
@else { box-shadow: $shadow1; }
|
||||||
|
}
|
||||||
|
|
||||||
|
// entries
|
||||||
|
|
||||||
|
@mixin entry($t, $fc:$selected_bg_color, $edge: $borders_edge) {
|
||||||
|
//
|
||||||
|
// Entries drawing function
|
||||||
|
//
|
||||||
|
// $t: entry type
|
||||||
|
// $fc: focus color
|
||||||
|
// $edge: set to none to not draw the bottom edge or specify a color to not
|
||||||
|
// use the default one
|
||||||
|
//
|
||||||
|
// possible $t values:
|
||||||
|
// normal, focus, insensitive
|
||||||
|
//
|
||||||
|
$_inner_shadows: inset 0 2px 4px transparentize(black, 0.6);
|
||||||
|
|
||||||
|
@if $t==normal {
|
||||||
|
background-color: $base_color;
|
||||||
|
border-color: $borders_color;
|
||||||
|
@include _shadows($_inner_shadows);
|
||||||
|
|
||||||
|
}
|
||||||
|
@if $t==focus {
|
||||||
|
@include _shadows($_inner_shadows);
|
||||||
|
border-color: if($fc==$selected_bg_color,
|
||||||
|
$selected_borders_color,
|
||||||
|
darken($fc,35%));
|
||||||
|
}
|
||||||
|
@if $t==hover { }
|
||||||
|
@if $t==insensitive {
|
||||||
|
color: $insensitive_fg_color;
|
||||||
|
border-color: $insensitive_bg_color;
|
||||||
|
box-shadow: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// buttons
|
||||||
|
|
||||||
|
@function _border_color ($c) { @return darken($c,25%); } // colored buttons want
|
||||||
|
// the border form the
|
||||||
|
// base color
|
||||||
|
|
||||||
|
@function _text_shadow_color ($tc:$fg_color, $bg:$bg_color) {
|
||||||
|
//
|
||||||
|
// calculate the color of text shadows
|
||||||
|
//
|
||||||
|
// $tc is the text color
|
||||||
|
// $bg is the background color
|
||||||
|
//
|
||||||
|
$_lbg: lightness($bg)/100%;
|
||||||
|
@if lightness($tc)<50% { @return transparentize(white,1-$_lbg/($_lbg*1.3)); }
|
||||||
|
@else { @return transparentize(black,$_lbg*0.8); }
|
||||||
|
}
|
||||||
|
|
||||||
|
@function _button_hilight_color($c) {
|
||||||
|
//
|
||||||
|
// calculate the right top hilight color for buttons
|
||||||
|
//
|
||||||
|
// $c: base color;
|
||||||
|
//
|
||||||
|
@if lightness($c)>90% { @return white; }
|
||||||
|
@else if lightness($c)>80% { @return transparentize(white, 0.3); }
|
||||||
|
@else if lightness($c)>50% { @return transparentize(white, 0.5); }
|
||||||
|
@else if lightness($c)>40% { @return transparentize(white, 0.7); }
|
||||||
|
@else { @return transparentize(white, 0.9); }
|
||||||
|
}
|
||||||
|
|
||||||
|
@mixin _button_text_shadow ($tc:$fg_color, $bg:$bg_color) {
|
||||||
|
//
|
||||||
|
// helper function for the text emboss effect
|
||||||
|
//
|
||||||
|
// $tc is the optional text color, not the shadow color
|
||||||
|
//
|
||||||
|
// TODO: this functions needs a way to deal with special cases
|
||||||
|
//
|
||||||
|
|
||||||
|
$_shadow: _text_shadow_color($tc, $bg);
|
||||||
|
|
||||||
|
@if lightness($tc)<50% {
|
||||||
|
text-shadow: 0 1px $_shadow;
|
||||||
|
icon-shadow: 0 1px $_shadow;
|
||||||
|
}
|
||||||
|
@else {
|
||||||
|
text-shadow: 0 -1px $_shadow;
|
||||||
|
icon-shadow: 0 -1px $_shadow;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@mixin button($t, $c:$osd_bg_color, $tc:$fg_color, $edge: $borders_edge) {
|
||||||
|
//
|
||||||
|
// Button drawing function
|
||||||
|
//
|
||||||
|
// $t: button type,
|
||||||
|
// $c: base button color for colored* types
|
||||||
|
// $tc: optional text color for colored* types
|
||||||
|
// $edge: set to none to not draw the bottom edge or specify a color to not
|
||||||
|
// use the default one
|
||||||
|
//
|
||||||
|
// possible $t values:
|
||||||
|
// normal, hover, active, insensitive, insensitive-active,
|
||||||
|
// backdrop, backdrop-active, backdrop-insensitive, backdrop-insensitive-active,
|
||||||
|
// osd, osd-hover, osd-active, osd-insensitive, osd-backdrop, undecorated
|
||||||
|
//
|
||||||
|
|
||||||
|
$_hilight_color: _button_hilight_color($c);
|
||||||
|
$_button_edge: if($edge == none, none, _widget_edge($edge));
|
||||||
|
$_blank_edge: if($edge == none, none, _widget_edge(transparentize($edge,1)));
|
||||||
|
|
||||||
|
|
||||||
|
@if $t==normal {
|
||||||
|
//
|
||||||
|
// normal button
|
||||||
|
//
|
||||||
|
$_bg: if($c!=$osd_bg_color, transparentize($c, 0.5),
|
||||||
|
$osd_bg_color);
|
||||||
|
|
||||||
|
color: $osd_fg_color;
|
||||||
|
background-color: $_bg;
|
||||||
|
border-color: $osd_borders_color;
|
||||||
|
box-shadow: inset 0 1px lighten($osd_bg_color,10%);
|
||||||
|
text-shadow: 0 1px black;
|
||||||
|
icon-shadow: 0 1px black;
|
||||||
|
}
|
||||||
|
@if $t==focus {
|
||||||
|
//
|
||||||
|
// focused button
|
||||||
|
//
|
||||||
|
$_bg: if($c!=$osd_bg_color, transparentize($c, 0.5),
|
||||||
|
$osd_bg_color);
|
||||||
|
|
||||||
|
color: $osd_fg_color;
|
||||||
|
border-color: $selected_bg_color;
|
||||||
|
box-shadow: inset 0 1px lighten($osd_bg_color,10%);
|
||||||
|
text-shadow: 0 1px black;
|
||||||
|
icon-shadow: 0 1px black;
|
||||||
|
}
|
||||||
|
|
||||||
|
@else if $t==hover {
|
||||||
|
//
|
||||||
|
// active osd button
|
||||||
|
//
|
||||||
|
$_bg: if($c!=$osd_bg_color, transparentize($c, 0.3),
|
||||||
|
lighten($osd_bg_color,10%));
|
||||||
|
|
||||||
|
color: white;
|
||||||
|
border-color: $osd_borders_color;
|
||||||
|
background-color: $_bg;
|
||||||
|
box-shadow: inset 0 1px lighten($osd_bg_color,20%);
|
||||||
|
text-shadow: 0 1px black;
|
||||||
|
icon-shadow: 0 1px black;
|
||||||
|
|
||||||
|
}
|
||||||
|
@else if $t==active {
|
||||||
|
//
|
||||||
|
// active osd button
|
||||||
|
//
|
||||||
|
$_bg: if($c!=$bg_color, $c, $osd_borders_color);
|
||||||
|
|
||||||
|
color: white;
|
||||||
|
border-color: $osd_borders_color;
|
||||||
|
background-color: darken($_bg,5%);
|
||||||
|
box-shadow: none;
|
||||||
|
text-shadow: none;
|
||||||
|
icon-shadow: none;
|
||||||
|
}
|
||||||
|
@else if $t==insensitive {
|
||||||
|
//
|
||||||
|
// insensitive osd button
|
||||||
|
//
|
||||||
|
$_bg: transparentize(mix($insensitive_fg_color,$osd_bg_color,20%),0.3);
|
||||||
|
|
||||||
|
color: $insensitive_fg_color;
|
||||||
|
border-color: $osd_borders_color;
|
||||||
|
background-color: $_bg;
|
||||||
|
box-shadow: none;
|
||||||
|
text-shadow: none;
|
||||||
|
icon-shadow: none;
|
||||||
|
}
|
||||||
|
@else if $t==undecorated {
|
||||||
|
//
|
||||||
|
// reset
|
||||||
|
//
|
||||||
|
border-color: transparent;
|
||||||
|
background-color: transparent;
|
||||||
|
background-image: none;
|
||||||
|
|
||||||
|
@include _shadows(inset 0 1px transparentize(white,1),
|
||||||
|
$_blank_edge);
|
||||||
|
|
||||||
|
text-shadow: none;
|
||||||
|
icon-shadow: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
1157
data/theme/_gnome-shell-old.scss
Normal file
@ -14,7 +14,7 @@
|
|||||||
height="22"
|
height="22"
|
||||||
id="svg3199"
|
id="svg3199"
|
||||||
version="1.1"
|
version="1.1"
|
||||||
inkscape:version="0.48.1 r9760"
|
inkscape:version="0.48.5 r10040"
|
||||||
sodipodi:docname="checkbox.svg">
|
sodipodi:docname="checkbox.svg">
|
||||||
<defs
|
<defs
|
||||||
id="defs3201">
|
id="defs3201">
|
||||||
@ -132,51 +132,54 @@
|
|||||||
xlink:href="#linearGradient10597-5"
|
xlink:href="#linearGradient10597-5"
|
||||||
inkscape:collect="always" />
|
inkscape:collect="always" />
|
||||||
<linearGradient
|
<linearGradient
|
||||||
y2="-388.72955"
|
inkscape:collect="always"
|
||||||
x2="-93.031357"
|
xlink:href="#linearGradient5581-5-2-4-6-8-7-35-8"
|
||||||
y1="-396.34738"
|
id="linearGradient11811"
|
||||||
x1="-93.031357"
|
|
||||||
gradientTransform="matrix(1.5918367,0,0,0.85714285,-256.56122,59.685418)"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
gradientUnits="userSpaceOnUse"
|
||||||
id="linearGradient14219-6"
|
gradientTransform="matrix(3.0317573,0,0,1.0053174,-102.66338,-0.82153381)"
|
||||||
xlink:href="#linearGradient15404-9"
|
x1="63.568954"
|
||||||
inkscape:collect="always" />
|
y1="127.16142"
|
||||||
|
x2="63.568954"
|
||||||
|
y2="152.6618" />
|
||||||
<linearGradient
|
<linearGradient
|
||||||
id="linearGradient15404-9"
|
id="linearGradient5581-5-2-4-6-8-7-35-8">
|
||||||
inkscape:collect="always">
|
|
||||||
<stop
|
<stop
|
||||||
id="stop15406-6"
|
id="stop5583-0-92-8-0-7-6-5-1"
|
||||||
offset="0"
|
offset="0"
|
||||||
style="stop-color:#515151;stop-opacity:1" />
|
style="stop-color:#454c4c;stop-opacity:1;" />
|
||||||
<stop
|
<stop
|
||||||
id="stop15408-7"
|
style="stop-color:#393f3f;stop-opacity:1;"
|
||||||
|
offset="0.40000001"
|
||||||
|
id="stop5585-4-7-2-7-9-9-92-0" />
|
||||||
|
<stop
|
||||||
|
id="stop5587-6-7-2-0-3-1-21-5"
|
||||||
offset="1"
|
offset="1"
|
||||||
style="stop-color:#292929;stop-opacity:1" />
|
style="stop-color:#2d3232;stop-opacity:1;" />
|
||||||
</linearGradient>
|
</linearGradient>
|
||||||
</defs>
|
</defs>
|
||||||
<sodipodi:namedview
|
<sodipodi:namedview
|
||||||
id="base"
|
id="base"
|
||||||
pagecolor="#000000"
|
pagecolor="#a2a2a2"
|
||||||
bordercolor="#2d2d2d"
|
bordercolor="#2d2d2d"
|
||||||
borderopacity="1"
|
borderopacity="1"
|
||||||
inkscape:pageopacity="1"
|
inkscape:pageopacity="1"
|
||||||
inkscape:pageshadow="2"
|
inkscape:pageshadow="2"
|
||||||
inkscape:zoom="1"
|
inkscape:zoom="22.627417"
|
||||||
inkscape:cx="71.516955"
|
inkscape:cx="9.6447897"
|
||||||
inkscape:cy="5.8710559"
|
inkscape:cy="12.591409"
|
||||||
inkscape:document-units="px"
|
inkscape:document-units="px"
|
||||||
inkscape:current-layer="layer1"
|
inkscape:current-layer="layer1"
|
||||||
showgrid="false"
|
showgrid="false"
|
||||||
inkscape:window-width="1412"
|
inkscape:window-width="1412"
|
||||||
inkscape:window-height="1067"
|
inkscape:window-height="1067"
|
||||||
inkscape:window-x="2635"
|
inkscape:window-x="184"
|
||||||
inkscape:window-y="226"
|
inkscape:window-y="233"
|
||||||
inkscape:window-maximized="0"
|
inkscape:window-maximized="0"
|
||||||
borderlayer="true"
|
borderlayer="true"
|
||||||
inkscape:showpageshadow="false"
|
inkscape:showpageshadow="false"
|
||||||
inkscape:snap-nodes="false"
|
inkscape:snap-nodes="false"
|
||||||
inkscape:snap-bbox="true"
|
inkscape:snap-bbox="true"
|
||||||
showborder="false">
|
showborder="true">
|
||||||
<inkscape:grid
|
<inkscape:grid
|
||||||
type="xygrid"
|
type="xygrid"
|
||||||
id="grid14843"
|
id="grid14843"
|
||||||
@ -203,87 +206,56 @@
|
|||||||
id="layer1"
|
id="layer1"
|
||||||
transform="translate(-342.5,-521.36218)">
|
transform="translate(-342.5,-521.36218)">
|
||||||
<g
|
<g
|
||||||
transform="matrix(0.80230061,0,0,0.80230061,-87.624044,-453.10297)"
|
style="display:inline"
|
||||||
id="g14586-0"
|
id="use5671"
|
||||||
style="stroke-width:2.3714385;stroke-miterlimit:4;stroke-dasharray:none">
|
transform="matrix(1.3594109,0,0,1.3564242,319.2059,481.99447)">
|
||||||
<g
|
<rect
|
||||||
inkscape:export-ydpi="90"
|
transform="matrix(0.47304779,0,0,0.4807373,-6.3607039,-29.396216)"
|
||||||
inkscape:export-xdpi="90"
|
rx="4.4136767"
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
y="125.3458"
|
||||||
transform="matrix(1.9969286,0,0,1.9969286,-397.05491,877.00482)"
|
x="50.440369"
|
||||||
id="g15291-9-6"
|
height="29.154205"
|
||||||
style="stroke-width:1.18754292;stroke-miterlimit:4;stroke-dasharray:none;display:inline;enable-background:new">
|
width="29.559635"
|
||||||
<g
|
id="rect11803"
|
||||||
transform="translate(877.50354,-102.83507)"
|
style="color:#000000;fill:url(#linearGradient11811);fill-opacity:1;stroke:#3465a4;stroke-width:1.54426003000000001;stroke-linecap:butt;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
||||||
id="g16853-4-9"
|
ry="4.4233952" />
|
||||||
style="stroke-width:1.18754292;stroke-miterlimit:4;stroke-dasharray:none;enable-background:new">
|
<path
|
||||||
<rect
|
inkscape:connector-curvature="0"
|
||||||
transform="scale(1,-1)"
|
id="path11809"
|
||||||
style="color:#000000;fill:url(#linearGradient14219-6);fill-opacity:1;fill-rule:nonzero;stroke:#3465a4;stroke-width:1.24833274;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:new"
|
d="m 17.87105,33.844107 0,-0.773112 c 0,-1.031264 0.807171,-1.836142 1.811982,-1.836142 l 9.612456,0 c 1.004811,0 1.787822,0.804878 1.787822,1.836142 l 0,0.773112 c 0,-1.031264 -0.783011,-1.836142 -1.787822,-1.836142 l -9.612456,0 c -1.004811,0 -1.811982,0.804878 -1.811982,1.836142 z"
|
||||||
id="rect6506-6"
|
style="font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-indent:0;text-align:start;text-decoration:none;line-height:normal;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;block-progression:tb;writing-mode:lr-tb;text-anchor:start;baseline-shift:baseline;opacity:0.15;color:#000000;fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1.00000012;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;font-family:Sans;-inkscape-font-specification:Sans"
|
||||||
width="11.281681"
|
sodipodi:nodetypes="csssscssc" />
|
||||||
height="11.26221"
|
<path
|
||||||
x="-409.59354"
|
sodipodi:nodetypes="csssscssc"
|
||||||
y="-284.40115"
|
style="font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-indent:0;text-align:start;text-decoration:none;line-height:normal;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;block-progression:tb;writing-mode:lr-tb;text-anchor:start;baseline-shift:baseline;opacity:0.15;color:#000000;fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1.00000012;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;font-family:Sans;-inkscape-font-specification:Sans"
|
||||||
rx="1.0052766"
|
d="m 17.87105,41.158551 0,0.773112 c 0,1.031264 0.807171,1.836142 1.811982,1.836142 l 9.612456,0 c 1.004811,0 1.787822,-0.804878 1.787822,-1.836142 l 0,-0.773112 c 0,1.031264 -0.783011,1.836142 -1.787822,1.836142 l -9.612456,0 c -1.004811,0 -1.811982,-0.804878 -1.811982,-1.836142 z"
|
||||||
ry="1.0052764" />
|
id="path11867"
|
||||||
</g>
|
inkscape:connector-curvature="0" />
|
||||||
</g>
|
<path
|
||||||
<g
|
inkscape:connector-curvature="0"
|
||||||
inkscape:export-ydpi="90"
|
id="path11869"
|
||||||
inkscape:export-xdpi="90"
|
d="m 17.87105,41.895784 0,0.773112 c 0,1.031264 0.644622,1.836142 1.649433,1.836142 l 10.067593,0 c 1.004811,0 1.495234,-0.804878 1.495234,-1.836142 l 0,-0.773112 c 0,1.031264 -0.783011,1.836142 -1.787822,1.836142 l -9.612456,0 c -1.004811,0 -1.811982,-0.804878 -1.811982,-1.836142 z"
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
style="font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-indent:0;text-align:start;text-decoration:none;line-height:normal;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;block-progression:tb;writing-mode:lr-tb;text-anchor:start;baseline-shift:baseline;opacity:0.15;color:#000000;fill:#000000;fill-opacity:0.85253451;fill-rule:nonzero;stroke:none;stroke-width:1.00000012;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;font-family:Sans;-inkscape-font-specification:Sans"
|
||||||
transform="translate(343.99999,987.99997)"
|
sodipodi:nodetypes="csssscssc" />
|
||||||
id="g5886-5"
|
|
||||||
style="stroke-width:2.3714385;stroke-miterlimit:4;stroke-dasharray:none;display:inline;enable-background:new" />
|
|
||||||
</g>
|
|
||||||
<g
|
|
||||||
transform="matrix(0.84337,0,0,0.84337,-110.16632,-503.56182)"
|
|
||||||
id="g14586">
|
|
||||||
<g
|
|
||||||
inkscape:export-ydpi="90"
|
|
||||||
inkscape:export-xdpi="90"
|
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
|
||||||
transform="matrix(1.9969286,0,0,1.9969286,-397.05491,877.00482)"
|
|
||||||
id="g15291-9"
|
|
||||||
style="display:inline;enable-background:new">
|
|
||||||
<g
|
|
||||||
transform="translate(877.50354,-102.83507)"
|
|
||||||
id="g16853-4"
|
|
||||||
style="enable-background:new" />
|
|
||||||
</g>
|
|
||||||
<g
|
|
||||||
inkscape:export-ydpi="90"
|
|
||||||
inkscape:export-xdpi="90"
|
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
|
||||||
transform="translate(343.99999,987.99997)"
|
|
||||||
id="g5886"
|
|
||||||
style="display:inline;enable-background:new">
|
|
||||||
<path
|
|
||||||
style="fill:none;stroke:url(#linearGradient5891-0-4);stroke-width:7.11431503;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
|
|
||||||
d="m 198.5,240 5.25,5.25 13.98616,-14.43081"
|
|
||||||
id="path5835"
|
|
||||||
inkscape:path-effect="#path-effect5837-4-6"
|
|
||||||
inkscape:original-d="m 198.5,240 5.25,5.25 13.98616,-14.43081"
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
sodipodi:nodetypes="ccc" />
|
|
||||||
<path
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
inkscape:original-d="m 198.5,240 5.25,5.25 13.91205,-14.31964"
|
|
||||||
inkscape:path-effect="#path-effect5837-4-6"
|
|
||||||
id="path5880"
|
|
||||||
d="m 198.5,240 5.25,5.25 13.91205,-14.31964"
|
|
||||||
style="fill:none;stroke:#4787c8;stroke-width:3.55715752;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
|
|
||||||
sodipodi:nodetypes="ccc" />
|
|
||||||
<path
|
|
||||||
style="fill:none;stroke:#7ea7d3;stroke-width:1.18571913px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
|
|
||||||
d="m 197.45937,240.47455 c -0.17828,-0.29362 -0.20087,-0.67548 -0.0603,-0.98892 0.14055,-0.31344 0.43739,-0.54812 0.77144,-0.62817 0.33405,-0.08 0.69314,-0.01 0.99635,0.15175 0.30321,0.16144 0.55146,0.40727 0.79165,0.65284 l 3.66429,3.74643 12.87946,-12.98973 c 0.20796,-0.20974 0.42306,-0.41969 0.68548,-0.55522 0.26242,-0.13553 0.57293,-0.19052 0.85827,-0.11426 0.14267,0.0381 0.27708,0.10787 0.38874,0.20452 0.11167,0.0966 0.20021,0.22004 0.25479,0.35726 0.0546,0.13722 0.075,0.28793 0.0585,0.43468 -0.0165,0.14674 -0.07,0.28919 -0.15422,0.41052"
|
|
||||||
id="path5882"
|
|
||||||
inkscape:path-effect="#path-effect5884-4-7"
|
|
||||||
inkscape:original-d="m 197.45937,240.47455 c 0.65604,-0.56057 2.02485,-1.34847 2.49911,-0.8125 l 3.66429,3.74643 12.87946,-12.98973 c 0.6875,-0.6875 2.09152,0.7375 2.09152,0.7375"
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
sodipodi:nodetypes="csccc" />
|
|
||||||
</g>
|
|
||||||
</g>
|
</g>
|
||||||
|
<rect
|
||||||
|
style="color:#000000;fill:none;stroke:none;stroke-width:2;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
||||||
|
id="rect17347"
|
||||||
|
width="21.943846"
|
||||||
|
height="21.943846"
|
||||||
|
x="342.29913"
|
||||||
|
y="521.58435" />
|
||||||
|
<path
|
||||||
|
inkscape:connector-curvature="0"
|
||||||
|
style="opacity:0.8;color:#000000;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.99999994;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
||||||
|
d="m 359.97505,524.8252 -7.88606,7.71465 -2.57155,-2.57155 -2.91442,-0.0427 0,2.35727 4.02875,3.98587 c 0.80342,0.80309 2.111,0.80309 2.91442,0 l 8.18609,-8.22894 0,-0.38573 c 0,-1.24128 0.19944,-1.76801 -0.82915,-2.29836 z"
|
||||||
|
id="rect5147-9-1-5-7-6-5-8-7"
|
||||||
|
sodipodi:nodetypes="ccccccccscc" />
|
||||||
|
<path
|
||||||
|
style="font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-indent:0;text-align:start;text-decoration:none;line-height:normal;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;block-progression:tb;writing-mode:lr-tb;text-anchor:start;baseline-shift:baseline;color:#000000;fill:#eeeeec;fill-opacity:1;stroke:none;stroke-width:3;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;font-family:sans-serif;-inkscape-font-specification:sans-serif"
|
||||||
|
d="m 361.65223,524.52745 -9.5602,9.36735 -2.56345,-2.56344 -2.92846,-0.0214 0.0153,2.32639 4.02203,4.02206 c 0.80341,0.80309 2.10565,0.80309 2.90906,0 l 10.95049,-11.05765 0.003,-2.1502 z"
|
||||||
|
id="path12830-4-17-0"
|
||||||
|
inkscape:connector-curvature="0"
|
||||||
|
sodipodi:nodetypes="cccccccccc" />
|
||||||
</g>
|
</g>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 11 KiB After Width: | Height: | Size: 12 KiB |
@ -14,22 +14,10 @@
|
|||||||
height="22"
|
height="22"
|
||||||
id="svg3199"
|
id="svg3199"
|
||||||
version="1.1"
|
version="1.1"
|
||||||
inkscape:version="0.48.1 r9760"
|
inkscape:version="0.48.5 r10040"
|
||||||
sodipodi:docname="checkbox-off.svg">
|
sodipodi:docname="checkbox-off.svg">
|
||||||
<defs
|
<defs
|
||||||
id="defs3201">
|
id="defs3201">
|
||||||
<linearGradient
|
|
||||||
id="linearGradient15404"
|
|
||||||
inkscape:collect="always">
|
|
||||||
<stop
|
|
||||||
id="stop15406"
|
|
||||||
offset="0"
|
|
||||||
style="stop-color:#515151;stop-opacity:1" />
|
|
||||||
<stop
|
|
||||||
id="stop15408"
|
|
||||||
offset="1"
|
|
||||||
style="stop-color:#292929;stop-opacity:1" />
|
|
||||||
</linearGradient>
|
|
||||||
<inkscape:perspective
|
<inkscape:perspective
|
||||||
sodipodi:type="inkscape:persp3d"
|
sodipodi:type="inkscape:persp3d"
|
||||||
inkscape:vp_x="0 : 526.18109 : 1"
|
inkscape:vp_x="0 : 526.18109 : 1"
|
||||||
@ -56,16 +44,6 @@
|
|||||||
effect="spiro"
|
effect="spiro"
|
||||||
id="path-effect5884-4-7"
|
id="path-effect5884-4-7"
|
||||||
is_visible="true" />
|
is_visible="true" />
|
||||||
<linearGradient
|
|
||||||
y2="-388.72955"
|
|
||||||
x2="-93.031357"
|
|
||||||
y1="-396.34738"
|
|
||||||
x1="-93.031357"
|
|
||||||
gradientTransform="matrix(1.5918367,0,0,0.85714285,-256.56122,59.685418)"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
id="linearGradient14219"
|
|
||||||
xlink:href="#linearGradient15404"
|
|
||||||
inkscape:collect="always" />
|
|
||||||
<linearGradient
|
<linearGradient
|
||||||
inkscape:collect="always"
|
inkscape:collect="always"
|
||||||
id="linearGradient10013-4-63-6">
|
id="linearGradient10013-4-63-6">
|
||||||
@ -110,30 +88,55 @@
|
|||||||
id="linearGradient15376"
|
id="linearGradient15376"
|
||||||
xlink:href="#linearGradient10597-5"
|
xlink:href="#linearGradient10597-5"
|
||||||
inkscape:collect="always" />
|
inkscape:collect="always" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient5581-5-2-4-6-8-7-35-8"
|
||||||
|
id="linearGradient11811"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(3.0317573,0,0,1.0053174,-102.66338,-0.82153381)"
|
||||||
|
x1="63.568954"
|
||||||
|
y1="127.16142"
|
||||||
|
x2="63.568954"
|
||||||
|
y2="152.6618" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient5581-5-2-4-6-8-7-35-8">
|
||||||
|
<stop
|
||||||
|
id="stop5583-0-92-8-0-7-6-5-1"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#454c4c;stop-opacity:1;" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#393f3f;stop-opacity:1;"
|
||||||
|
offset="0.40000001"
|
||||||
|
id="stop5585-4-7-2-7-9-9-92-0" />
|
||||||
|
<stop
|
||||||
|
id="stop5587-6-7-2-0-3-1-21-5"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#2d3232;stop-opacity:1;" />
|
||||||
|
</linearGradient>
|
||||||
</defs>
|
</defs>
|
||||||
<sodipodi:namedview
|
<sodipodi:namedview
|
||||||
id="base"
|
id="base"
|
||||||
pagecolor="#000000"
|
pagecolor="#a2a2a2"
|
||||||
bordercolor="#2d2d2d"
|
bordercolor="#2d2d2d"
|
||||||
borderopacity="1"
|
borderopacity="1"
|
||||||
inkscape:pageopacity="1"
|
inkscape:pageopacity="1"
|
||||||
inkscape:pageshadow="2"
|
inkscape:pageshadow="2"
|
||||||
inkscape:zoom="1"
|
inkscape:zoom="5.6568542"
|
||||||
inkscape:cx="6.1225392"
|
inkscape:cx="19.79113"
|
||||||
inkscape:cy="3.6003241"
|
inkscape:cy="11.232334"
|
||||||
inkscape:document-units="px"
|
inkscape:document-units="px"
|
||||||
inkscape:current-layer="layer1"
|
inkscape:current-layer="layer1"
|
||||||
showgrid="false"
|
showgrid="false"
|
||||||
inkscape:window-width="1412"
|
inkscape:window-width="1412"
|
||||||
inkscape:window-height="1067"
|
inkscape:window-height="1067"
|
||||||
inkscape:window-x="2116"
|
inkscape:window-x="184"
|
||||||
inkscape:window-y="261"
|
inkscape:window-y="233"
|
||||||
inkscape:window-maximized="0"
|
inkscape:window-maximized="0"
|
||||||
borderlayer="true"
|
borderlayer="true"
|
||||||
inkscape:showpageshadow="false"
|
inkscape:showpageshadow="false"
|
||||||
inkscape:snap-nodes="false"
|
inkscape:snap-nodes="false"
|
||||||
inkscape:snap-bbox="true"
|
inkscape:snap-bbox="true"
|
||||||
showborder="false">
|
showborder="true">
|
||||||
<inkscape:grid
|
<inkscape:grid
|
||||||
type="xygrid"
|
type="xygrid"
|
||||||
id="grid14843"
|
id="grid14843"
|
||||||
@ -160,39 +163,44 @@
|
|||||||
id="layer1"
|
id="layer1"
|
||||||
transform="translate(-342.5,-521.36218)">
|
transform="translate(-342.5,-521.36218)">
|
||||||
<g
|
<g
|
||||||
transform="matrix(0.80230061,0,0,0.80230061,-87.624044,-453.10297)"
|
style="display:inline"
|
||||||
id="g14586"
|
id="use5671"
|
||||||
style="stroke-width:2.3714385;stroke-miterlimit:4;stroke-dasharray:none">
|
transform="matrix(1.3594109,0,0,1.3564242,319.2059,481.99447)">
|
||||||
<g
|
<rect
|
||||||
inkscape:export-ydpi="90"
|
transform="matrix(0.47304779,0,0,0.4807373,-6.3607039,-29.396216)"
|
||||||
inkscape:export-xdpi="90"
|
rx="4.4136767"
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
y="125.3458"
|
||||||
transform="matrix(1.9969286,0,0,1.9969286,-397.05491,877.00482)"
|
x="50.440369"
|
||||||
id="g15291-9"
|
height="29.154205"
|
||||||
style="stroke-width:1.18754292;stroke-miterlimit:4;stroke-dasharray:none;display:inline;enable-background:new">
|
width="29.559635"
|
||||||
<g
|
id="rect11803"
|
||||||
transform="translate(877.50354,-102.83507)"
|
style="color:#000000;fill:url(#linearGradient11811);fill-opacity:1;stroke:#3465a4;stroke-width:1.54426003000000001;stroke-linecap:butt;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
||||||
id="g16853-4"
|
ry="4.4233952" />
|
||||||
style="stroke-width:1.18754292;stroke-miterlimit:4;stroke-dasharray:none;enable-background:new">
|
<path
|
||||||
<rect
|
inkscape:connector-curvature="0"
|
||||||
transform="scale(1,-1)"
|
id="path11809"
|
||||||
style="color:#000000;fill:url(#linearGradient14219);fill-opacity:1;fill-rule:nonzero;stroke:#3465a4;stroke-width:1.24833274;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:new"
|
d="m 17.87105,33.844107 0,-0.773112 c 0,-1.031264 0.807171,-1.836142 1.811982,-1.836142 l 9.612456,0 c 1.004811,0 1.787822,0.804878 1.787822,1.836142 l 0,0.773112 c 0,-1.031264 -0.783011,-1.836142 -1.787822,-1.836142 l -9.612456,0 c -1.004811,0 -1.811982,0.804878 -1.811982,1.836142 z"
|
||||||
id="rect6506-6"
|
style="font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-indent:0;text-align:start;text-decoration:none;line-height:normal;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;block-progression:tb;writing-mode:lr-tb;text-anchor:start;baseline-shift:baseline;opacity:0.15;color:#000000;fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1.00000012;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;font-family:Sans;-inkscape-font-specification:Sans"
|
||||||
width="11.281681"
|
sodipodi:nodetypes="csssscssc" />
|
||||||
height="11.26221"
|
<path
|
||||||
x="-409.59354"
|
sodipodi:nodetypes="csssscssc"
|
||||||
y="-284.40115"
|
style="font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-indent:0;text-align:start;text-decoration:none;line-height:normal;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;block-progression:tb;writing-mode:lr-tb;text-anchor:start;baseline-shift:baseline;opacity:0.15;color:#000000;fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1.00000012;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;font-family:Sans;-inkscape-font-specification:Sans"
|
||||||
rx="1.0052766"
|
d="m 17.87105,41.158551 0,0.773112 c 0,1.031264 0.807171,1.836142 1.811982,1.836142 l 9.612456,0 c 1.004811,0 1.787822,-0.804878 1.787822,-1.836142 l 0,-0.773112 c 0,1.031264 -0.783011,1.836142 -1.787822,1.836142 l -9.612456,0 c -1.004811,0 -1.811982,-0.804878 -1.811982,-1.836142 z"
|
||||||
ry="1.0052764" />
|
id="path11867"
|
||||||
</g>
|
inkscape:connector-curvature="0" />
|
||||||
</g>
|
<path
|
||||||
<g
|
inkscape:connector-curvature="0"
|
||||||
inkscape:export-ydpi="90"
|
id="path11869"
|
||||||
inkscape:export-xdpi="90"
|
d="m 17.87105,41.895784 0,0.773112 c 0,1.031264 0.644622,1.836142 1.649433,1.836142 l 10.067593,0 c 1.004811,0 1.495234,-0.804878 1.495234,-1.836142 l 0,-0.773112 c 0,1.031264 -0.783011,1.836142 -1.787822,1.836142 l -9.612456,0 c -1.004811,0 -1.811982,-0.804878 -1.811982,-1.836142 z"
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
style="font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-indent:0;text-align:start;text-decoration:none;line-height:normal;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;block-progression:tb;writing-mode:lr-tb;text-anchor:start;baseline-shift:baseline;opacity:0.15;color:#000000;fill:#000000;fill-opacity:0.85253451;fill-rule:nonzero;stroke:none;stroke-width:1.00000012;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;font-family:Sans;-inkscape-font-specification:Sans"
|
||||||
transform="translate(343.99999,987.99997)"
|
sodipodi:nodetypes="csssscssc" />
|
||||||
id="g5886"
|
|
||||||
style="stroke-width:2.3714385;stroke-miterlimit:4;stroke-dasharray:none;display:inline;enable-background:new" />
|
|
||||||
</g>
|
</g>
|
||||||
|
<rect
|
||||||
|
style="color:#000000;fill:none;stroke:none;stroke-width:2;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
||||||
|
id="rect17347"
|
||||||
|
width="21.943846"
|
||||||
|
height="21.943846"
|
||||||
|
x="342.29913"
|
||||||
|
y="521.58435" />
|
||||||
</g>
|
</g>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 6.5 KiB After Width: | Height: | Size: 8.9 KiB |
@ -14,22 +14,10 @@
|
|||||||
height="22"
|
height="22"
|
||||||
id="svg3199"
|
id="svg3199"
|
||||||
version="1.1"
|
version="1.1"
|
||||||
inkscape:version="0.48.1 r9760"
|
inkscape:version="0.48.5 r10040"
|
||||||
sodipodi:docname="checkbox.svg">
|
sodipodi:docname="checkbox-focused.svg">
|
||||||
<defs
|
<defs
|
||||||
id="defs3201">
|
id="defs3201">
|
||||||
<linearGradient
|
|
||||||
id="linearGradient15404"
|
|
||||||
inkscape:collect="always">
|
|
||||||
<stop
|
|
||||||
id="stop15406"
|
|
||||||
offset="0"
|
|
||||||
style="stop-color:#515151;stop-opacity:1" />
|
|
||||||
<stop
|
|
||||||
id="stop15408"
|
|
||||||
offset="1"
|
|
||||||
style="stop-color:#292929;stop-opacity:1" />
|
|
||||||
</linearGradient>
|
|
||||||
<inkscape:perspective
|
<inkscape:perspective
|
||||||
sodipodi:type="inkscape:persp3d"
|
sodipodi:type="inkscape:persp3d"
|
||||||
inkscape:vp_x="0 : 526.18109 : 1"
|
inkscape:vp_x="0 : 526.18109 : 1"
|
||||||
@ -44,27 +32,6 @@
|
|||||||
inkscape:vp_y="0 : 1000 : 0"
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
inkscape:vp_x="0 : 0.5 : 1"
|
inkscape:vp_x="0 : 0.5 : 1"
|
||||||
sodipodi:type="inkscape:persp3d" />
|
sodipodi:type="inkscape:persp3d" />
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
xlink:href="#linearGradient5872-5-1"
|
|
||||||
id="linearGradient5891-0-4"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
x1="205.84143"
|
|
||||||
y1="246.7094"
|
|
||||||
x2="206.74803"
|
|
||||||
y2="231.24142" />
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
id="linearGradient5872-5-1">
|
|
||||||
<stop
|
|
||||||
style="stop-color:#0b2e52;stop-opacity:1"
|
|
||||||
offset="0"
|
|
||||||
id="stop5874-4-4" />
|
|
||||||
<stop
|
|
||||||
style="stop-color:#1862af;stop-opacity:1"
|
|
||||||
offset="1"
|
|
||||||
id="stop5876-0-5" />
|
|
||||||
</linearGradient>
|
|
||||||
<inkscape:path-effect
|
<inkscape:path-effect
|
||||||
effect="spiro"
|
effect="spiro"
|
||||||
id="path-effect5837-4-6"
|
id="path-effect5837-4-6"
|
||||||
@ -77,16 +44,6 @@
|
|||||||
effect="spiro"
|
effect="spiro"
|
||||||
id="path-effect5884-4-7"
|
id="path-effect5884-4-7"
|
||||||
is_visible="true" />
|
is_visible="true" />
|
||||||
<linearGradient
|
|
||||||
y2="-388.72955"
|
|
||||||
x2="-93.031357"
|
|
||||||
y1="-396.34738"
|
|
||||||
x1="-93.031357"
|
|
||||||
gradientTransform="matrix(1.5918367,0,0,0.85714285,-256.56122,59.685418)"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
id="linearGradient14219"
|
|
||||||
xlink:href="#linearGradient15404"
|
|
||||||
inkscape:collect="always" />
|
|
||||||
<linearGradient
|
<linearGradient
|
||||||
inkscape:collect="always"
|
inkscape:collect="always"
|
||||||
id="linearGradient10013-4-63-6">
|
id="linearGradient10013-4-63-6">
|
||||||
@ -131,30 +88,55 @@
|
|||||||
id="linearGradient15376"
|
id="linearGradient15376"
|
||||||
xlink:href="#linearGradient10597-5"
|
xlink:href="#linearGradient10597-5"
|
||||||
inkscape:collect="always" />
|
inkscape:collect="always" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient5581-5-2-4-6-8-7-35-8"
|
||||||
|
id="linearGradient11811"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(3.0317573,0,0,1.0053174,-102.66338,-0.82153381)"
|
||||||
|
x1="63.568954"
|
||||||
|
y1="127.16142"
|
||||||
|
x2="63.568954"
|
||||||
|
y2="152.6618" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient5581-5-2-4-6-8-7-35-8">
|
||||||
|
<stop
|
||||||
|
id="stop5583-0-92-8-0-7-6-5-1"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#454c4c;stop-opacity:1;" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#393f3f;stop-opacity:1;"
|
||||||
|
offset="0.40000001"
|
||||||
|
id="stop5585-4-7-2-7-9-9-92-0" />
|
||||||
|
<stop
|
||||||
|
id="stop5587-6-7-2-0-3-1-21-5"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#2d3232;stop-opacity:1;" />
|
||||||
|
</linearGradient>
|
||||||
</defs>
|
</defs>
|
||||||
<sodipodi:namedview
|
<sodipodi:namedview
|
||||||
id="base"
|
id="base"
|
||||||
pagecolor="#000000"
|
pagecolor="#a2a2a2"
|
||||||
bordercolor="#2d2d2d"
|
bordercolor="#2d2d2d"
|
||||||
borderopacity="1"
|
borderopacity="1"
|
||||||
inkscape:pageopacity="1"
|
inkscape:pageopacity="1"
|
||||||
inkscape:pageshadow="2"
|
inkscape:pageshadow="2"
|
||||||
inkscape:zoom="4"
|
inkscape:zoom="1"
|
||||||
inkscape:cx="71.247925"
|
inkscape:cx="9.6447897"
|
||||||
inkscape:cy="33.339093"
|
inkscape:cy="12.591409"
|
||||||
inkscape:document-units="px"
|
inkscape:document-units="px"
|
||||||
inkscape:current-layer="layer1"
|
inkscape:current-layer="layer1"
|
||||||
showgrid="false"
|
showgrid="false"
|
||||||
inkscape:window-width="1412"
|
inkscape:window-width="1412"
|
||||||
inkscape:window-height="1067"
|
inkscape:window-height="1067"
|
||||||
inkscape:window-x="2116"
|
inkscape:window-x="184"
|
||||||
inkscape:window-y="261"
|
inkscape:window-y="233"
|
||||||
inkscape:window-maximized="0"
|
inkscape:window-maximized="0"
|
||||||
borderlayer="true"
|
borderlayer="true"
|
||||||
inkscape:showpageshadow="false"
|
inkscape:showpageshadow="false"
|
||||||
inkscape:snap-nodes="false"
|
inkscape:snap-nodes="false"
|
||||||
inkscape:snap-bbox="true"
|
inkscape:snap-bbox="true"
|
||||||
showborder="false">
|
showborder="true">
|
||||||
<inkscape:grid
|
<inkscape:grid
|
||||||
type="xygrid"
|
type="xygrid"
|
||||||
id="grid14843"
|
id="grid14843"
|
||||||
@ -181,38 +163,44 @@
|
|||||||
id="layer1"
|
id="layer1"
|
||||||
transform="translate(-342.5,-521.36218)">
|
transform="translate(-342.5,-521.36218)">
|
||||||
<g
|
<g
|
||||||
transform="matrix(0.84337,0,0,0.84337,-110.16632,-503.56182)"
|
style="display:inline"
|
||||||
id="g14586">
|
id="use5671"
|
||||||
<g
|
transform="matrix(1.3594109,0,0,1.3564242,319.2059,481.99447)">
|
||||||
inkscape:export-ydpi="90"
|
<rect
|
||||||
inkscape:export-xdpi="90"
|
transform="matrix(0.47304779,0,0,0.4807373,-6.3607039,-29.396216)"
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
rx="4.4136767"
|
||||||
transform="matrix(1.9969286,0,0,1.9969286,-397.05491,877.00482)"
|
y="125.3458"
|
||||||
id="g15291-9"
|
x="50.440369"
|
||||||
style="display:inline;enable-background:new">
|
height="29.154205"
|
||||||
<g
|
width="29.559635"
|
||||||
transform="translate(877.50354,-102.83507)"
|
id="rect11803"
|
||||||
id="g16853-4"
|
style="color:#000000;fill:url(#linearGradient11811);fill-opacity:1;stroke:#1c1f1f;stroke-width:1.54426003;stroke-linecap:butt;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
||||||
style="enable-background:new">
|
ry="4.4233952" />
|
||||||
<rect
|
<path
|
||||||
transform="scale(1,-1)"
|
inkscape:connector-curvature="0"
|
||||||
style="color:#000000;fill:url(#linearGradient14219);fill-opacity:1;fill-rule:nonzero;stroke:#868686;stroke-width:0.59377144999999998;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:new"
|
id="path11809"
|
||||||
id="rect6506-6"
|
d="m 17.87105,33.844107 0,-0.773112 c 0,-1.031264 0.807171,-1.836142 1.811982,-1.836142 l 9.612456,0 c 1.004811,0 1.787822,0.804878 1.787822,1.836142 l 0,0.773112 c 0,-1.031264 -0.783011,-1.836142 -1.787822,-1.836142 l -9.612456,0 c -1.004811,0 -1.811982,0.804878 -1.811982,1.836142 z"
|
||||||
width="11.281681"
|
style="font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-indent:0;text-align:start;text-decoration:none;line-height:normal;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;block-progression:tb;writing-mode:lr-tb;text-anchor:start;baseline-shift:baseline;opacity:0.15;color:#000000;fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1.00000012;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;font-family:Sans;-inkscape-font-specification:Sans"
|
||||||
height="11.26221"
|
sodipodi:nodetypes="csssscssc" />
|
||||||
x="-409.59354"
|
<path
|
||||||
y="-284.40115"
|
sodipodi:nodetypes="csssscssc"
|
||||||
rx="0.95632279"
|
style="font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-indent:0;text-align:start;text-decoration:none;line-height:normal;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;block-progression:tb;writing-mode:lr-tb;text-anchor:start;baseline-shift:baseline;opacity:0.15;color:#000000;fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1.00000012;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;font-family:Sans;-inkscape-font-specification:Sans"
|
||||||
ry="0.95632273" />
|
d="m 17.87105,41.158551 0,0.773112 c 0,1.031264 0.807171,1.836142 1.811982,1.836142 l 9.612456,0 c 1.004811,0 1.787822,-0.804878 1.787822,-1.836142 l 0,-0.773112 c 0,1.031264 -0.783011,1.836142 -1.787822,1.836142 l -9.612456,0 c -1.004811,0 -1.811982,-0.804878 -1.811982,-1.836142 z"
|
||||||
</g>
|
id="path11867"
|
||||||
</g>
|
inkscape:connector-curvature="0" />
|
||||||
<g
|
<path
|
||||||
inkscape:export-ydpi="90"
|
inkscape:connector-curvature="0"
|
||||||
inkscape:export-xdpi="90"
|
id="path11869"
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
d="m 17.87105,41.895784 0,0.773112 c 0,1.031264 0.644622,1.836142 1.649433,1.836142 l 10.067593,0 c 1.004811,0 1.495234,-0.804878 1.495234,-1.836142 l 0,-0.773112 c 0,1.031264 -0.783011,1.836142 -1.787822,1.836142 l -9.612456,0 c -1.004811,0 -1.811982,-0.804878 -1.811982,-1.836142 z"
|
||||||
transform="translate(343.99999,987.99997)"
|
style="font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-indent:0;text-align:start;text-decoration:none;line-height:normal;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;block-progression:tb;writing-mode:lr-tb;text-anchor:start;baseline-shift:baseline;opacity:0.15;color:#000000;fill:#000000;fill-opacity:0.85253451;fill-rule:nonzero;stroke:none;stroke-width:1.00000012;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;font-family:Sans;-inkscape-font-specification:Sans"
|
||||||
id="g5886"
|
sodipodi:nodetypes="csssscssc" />
|
||||||
style="display:inline;enable-background:new" />
|
|
||||||
</g>
|
</g>
|
||||||
|
<rect
|
||||||
|
style="color:#000000;fill:none;stroke:none;stroke-width:2;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
||||||
|
id="rect17347"
|
||||||
|
width="21.943846"
|
||||||
|
height="21.943846"
|
||||||
|
x="342.29913"
|
||||||
|
y="521.58435" />
|
||||||
</g>
|
</g>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 6.8 KiB After Width: | Height: | Size: 8.9 KiB |
@ -14,8 +14,8 @@
|
|||||||
height="22"
|
height="22"
|
||||||
id="svg3199"
|
id="svg3199"
|
||||||
version="1.1"
|
version="1.1"
|
||||||
inkscape:version="0.48.1 r9760"
|
inkscape:version="0.48.5 r10040"
|
||||||
sodipodi:docname="checkbox-focused.svg">
|
sodipodi:docname="checkbox.svg">
|
||||||
<defs
|
<defs
|
||||||
id="defs3201">
|
id="defs3201">
|
||||||
<linearGradient
|
<linearGradient
|
||||||
@ -131,30 +131,55 @@
|
|||||||
id="linearGradient15376"
|
id="linearGradient15376"
|
||||||
xlink:href="#linearGradient10597-5"
|
xlink:href="#linearGradient10597-5"
|
||||||
inkscape:collect="always" />
|
inkscape:collect="always" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient5581-5-2-4-6-8-7-35-8"
|
||||||
|
id="linearGradient11811"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(3.0317573,0,0,1.0053174,-102.66338,-0.82153381)"
|
||||||
|
x1="63.568954"
|
||||||
|
y1="127.16142"
|
||||||
|
x2="63.568954"
|
||||||
|
y2="152.6618" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient5581-5-2-4-6-8-7-35-8">
|
||||||
|
<stop
|
||||||
|
id="stop5583-0-92-8-0-7-6-5-1"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#454c4c;stop-opacity:1;" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#393f3f;stop-opacity:1;"
|
||||||
|
offset="0.40000001"
|
||||||
|
id="stop5585-4-7-2-7-9-9-92-0" />
|
||||||
|
<stop
|
||||||
|
id="stop5587-6-7-2-0-3-1-21-5"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#2d3232;stop-opacity:1;" />
|
||||||
|
</linearGradient>
|
||||||
</defs>
|
</defs>
|
||||||
<sodipodi:namedview
|
<sodipodi:namedview
|
||||||
id="base"
|
id="base"
|
||||||
pagecolor="#000000"
|
pagecolor="#a2a2a2"
|
||||||
bordercolor="#2d2d2d"
|
bordercolor="#2d2d2d"
|
||||||
borderopacity="1"
|
borderopacity="1"
|
||||||
inkscape:pageopacity="1"
|
inkscape:pageopacity="1"
|
||||||
inkscape:pageshadow="2"
|
inkscape:pageshadow="2"
|
||||||
inkscape:zoom="1"
|
inkscape:zoom="1"
|
||||||
inkscape:cx="64.516955"
|
inkscape:cx="-0.17876005"
|
||||||
inkscape:cy="13.871056"
|
inkscape:cy="11.944326"
|
||||||
inkscape:document-units="px"
|
inkscape:document-units="px"
|
||||||
inkscape:current-layer="layer1"
|
inkscape:current-layer="layer1"
|
||||||
showgrid="false"
|
showgrid="false"
|
||||||
inkscape:window-width="1412"
|
inkscape:window-width="2560"
|
||||||
inkscape:window-height="1067"
|
inkscape:window-height="1375"
|
||||||
inkscape:window-x="2635"
|
inkscape:window-x="0"
|
||||||
inkscape:window-y="226"
|
inkscape:window-y="27"
|
||||||
inkscape:window-maximized="0"
|
inkscape:window-maximized="1"
|
||||||
borderlayer="true"
|
borderlayer="true"
|
||||||
inkscape:showpageshadow="false"
|
inkscape:showpageshadow="false"
|
||||||
inkscape:snap-nodes="false"
|
inkscape:snap-nodes="false"
|
||||||
inkscape:snap-bbox="true"
|
inkscape:snap-bbox="true"
|
||||||
showborder="false">
|
showborder="true">
|
||||||
<inkscape:grid
|
<inkscape:grid
|
||||||
type="xygrid"
|
type="xygrid"
|
||||||
id="grid14843"
|
id="grid14843"
|
||||||
@ -171,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>
|
||||||
@ -181,63 +206,56 @@
|
|||||||
id="layer1"
|
id="layer1"
|
||||||
transform="translate(-342.5,-521.36218)">
|
transform="translate(-342.5,-521.36218)">
|
||||||
<g
|
<g
|
||||||
transform="matrix(0.84337,0,0,0.84337,-110.16632,-503.56182)"
|
style="display:inline"
|
||||||
id="g14586">
|
id="use5671"
|
||||||
<g
|
transform="matrix(1.3594109,0,0,1.3564242,319.2059,481.99447)">
|
||||||
inkscape:export-ydpi="90"
|
<rect
|
||||||
inkscape:export-xdpi="90"
|
transform="matrix(0.47304779,0,0,0.4807373,-6.3607039,-29.396216)"
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
rx="4.4136767"
|
||||||
transform="matrix(1.9969286,0,0,1.9969286,-397.05491,877.00482)"
|
y="125.3458"
|
||||||
id="g15291-9"
|
x="50.440369"
|
||||||
style="display:inline;enable-background:new">
|
height="29.154205"
|
||||||
<g
|
width="29.559635"
|
||||||
transform="translate(877.50354,-102.83507)"
|
id="rect11803"
|
||||||
id="g16853-4"
|
style="color:#000000;fill:url(#linearGradient11811);fill-opacity:1;stroke:#1c1f1f;stroke-width:1.54426003;stroke-linecap:butt;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
||||||
style="enable-background:new">
|
ry="4.4233952" />
|
||||||
<rect
|
<path
|
||||||
transform="scale(1,-1)"
|
inkscape:connector-curvature="0"
|
||||||
style="color:#000000;fill:url(#linearGradient14219);fill-opacity:1;fill-rule:nonzero;stroke:#868686;stroke-width:0.59377144999999998;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:new"
|
id="path11809"
|
||||||
id="rect6506-6"
|
d="m 17.87105,33.844107 0,-0.773112 c 0,-1.031264 0.807171,-1.836142 1.811982,-1.836142 l 9.612456,0 c 1.004811,0 1.787822,0.804878 1.787822,1.836142 l 0,0.773112 c 0,-1.031264 -0.783011,-1.836142 -1.787822,-1.836142 l -9.612456,0 c -1.004811,0 -1.811982,0.804878 -1.811982,1.836142 z"
|
||||||
width="11.281681"
|
style="font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-indent:0;text-align:start;text-decoration:none;line-height:normal;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;block-progression:tb;writing-mode:lr-tb;text-anchor:start;baseline-shift:baseline;opacity:0.15;color:#000000;fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1.00000012;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;font-family:Sans;-inkscape-font-specification:Sans"
|
||||||
height="11.26221"
|
sodipodi:nodetypes="csssscssc" />
|
||||||
x="-409.59354"
|
<path
|
||||||
y="-284.40115"
|
sodipodi:nodetypes="csssscssc"
|
||||||
rx="0.95632279"
|
style="font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-indent:0;text-align:start;text-decoration:none;line-height:normal;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;block-progression:tb;writing-mode:lr-tb;text-anchor:start;baseline-shift:baseline;opacity:0.15;color:#000000;fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1.00000012;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;font-family:Sans;-inkscape-font-specification:Sans"
|
||||||
ry="0.95632273" />
|
d="m 17.87105,41.158551 0,0.773112 c 0,1.031264 0.807171,1.836142 1.811982,1.836142 l 9.612456,0 c 1.004811,0 1.787822,-0.804878 1.787822,-1.836142 l 0,-0.773112 c 0,1.031264 -0.783011,1.836142 -1.787822,1.836142 l -9.612456,0 c -1.004811,0 -1.811982,-0.804878 -1.811982,-1.836142 z"
|
||||||
</g>
|
id="path11867"
|
||||||
</g>
|
inkscape:connector-curvature="0" />
|
||||||
<g
|
<path
|
||||||
inkscape:export-ydpi="90"
|
inkscape:connector-curvature="0"
|
||||||
inkscape:export-xdpi="90"
|
id="path11869"
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
d="m 17.87105,41.895784 0,0.773112 c 0,1.031264 0.644622,1.836142 1.649433,1.836142 l 10.067593,0 c 1.004811,0 1.495234,-0.804878 1.495234,-1.836142 l 0,-0.773112 c 0,1.031264 -0.783011,1.836142 -1.787822,1.836142 l -9.612456,0 c -1.004811,0 -1.811982,-0.804878 -1.811982,-1.836142 z"
|
||||||
transform="translate(343.99999,987.99997)"
|
style="font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-indent:0;text-align:start;text-decoration:none;line-height:normal;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;block-progression:tb;writing-mode:lr-tb;text-anchor:start;baseline-shift:baseline;opacity:0.15;color:#000000;fill:#000000;fill-opacity:0.85253451;fill-rule:nonzero;stroke:none;stroke-width:1.00000012;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;font-family:Sans;-inkscape-font-specification:Sans"
|
||||||
id="g5886"
|
sodipodi:nodetypes="csssscssc" />
|
||||||
style="display:inline;enable-background:new">
|
|
||||||
<path
|
|
||||||
style="fill:none;stroke:url(#linearGradient5891-0-4);stroke-width:7.11431503;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
|
|
||||||
d="m 198.5,240 5.25,5.25 13.98616,-14.43081"
|
|
||||||
id="path5835"
|
|
||||||
inkscape:path-effect="#path-effect5837-4-6"
|
|
||||||
inkscape:original-d="m 198.5,240 5.25,5.25 13.98616,-14.43081"
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
sodipodi:nodetypes="ccc" />
|
|
||||||
<path
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
inkscape:original-d="m 198.5,240 5.25,5.25 13.91205,-14.31964"
|
|
||||||
inkscape:path-effect="#path-effect5837-4-6"
|
|
||||||
id="path5880"
|
|
||||||
d="m 198.5,240 5.25,5.25 13.91205,-14.31964"
|
|
||||||
style="fill:none;stroke:#4787c8;stroke-width:3.55715752;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
|
|
||||||
sodipodi:nodetypes="ccc" />
|
|
||||||
<path
|
|
||||||
style="fill:none;stroke:#7ea7d3;stroke-width:1.18571913px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
|
|
||||||
d="m 197.45937,240.47455 c -0.17828,-0.29362 -0.20087,-0.67548 -0.0603,-0.98892 0.14055,-0.31344 0.43739,-0.54812 0.77144,-0.62817 0.33405,-0.08 0.69314,-0.01 0.99635,0.15175 0.30321,0.16144 0.55146,0.40727 0.79165,0.65284 l 3.66429,3.74643 12.87946,-12.98973 c 0.20796,-0.20974 0.42306,-0.41969 0.68548,-0.55522 0.26242,-0.13553 0.57293,-0.19052 0.85827,-0.11426 0.14267,0.0381 0.27708,0.10787 0.38874,0.20452 0.11167,0.0966 0.20021,0.22004 0.25479,0.35726 0.0546,0.13722 0.075,0.28793 0.0585,0.43468 -0.0165,0.14674 -0.07,0.28919 -0.15422,0.41052"
|
|
||||||
id="path5882"
|
|
||||||
inkscape:path-effect="#path-effect5884-4-7"
|
|
||||||
inkscape:original-d="m 197.45937,240.47455 c 0.65604,-0.56057 2.02485,-1.34847 2.49911,-0.8125 l 3.66429,3.74643 12.87946,-12.98973 c 0.6875,-0.6875 2.09152,0.7375 2.09152,0.7375"
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
sodipodi:nodetypes="csccc" />
|
|
||||||
</g>
|
|
||||||
</g>
|
</g>
|
||||||
|
<rect
|
||||||
|
style="color:#000000;fill:none;stroke:none;stroke-width:2;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
||||||
|
id="rect17347"
|
||||||
|
width="21.943846"
|
||||||
|
height="21.943846"
|
||||||
|
x="342.29913"
|
||||||
|
y="521.58435" />
|
||||||
|
<path
|
||||||
|
inkscape:connector-curvature="0"
|
||||||
|
style="opacity:0.8;color:#000000;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.99999994;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
||||||
|
d="m 359.97505,524.8252 -7.88606,7.71465 -2.57155,-2.57155 -2.91442,-0.0427 0,2.35727 4.02875,3.98587 c 0.80342,0.80309 2.111,0.80309 2.91442,0 l 8.18609,-8.22894 0,-0.38573 c 0,-1.24128 0.19944,-1.76801 -0.82915,-2.29836 z"
|
||||||
|
id="rect5147-9-1-5-7-6-5-8-7"
|
||||||
|
sodipodi:nodetypes="ccccccccscc" />
|
||||||
|
<path
|
||||||
|
style="font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-indent:0;text-align:start;text-decoration:none;line-height:normal;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;block-progression:tb;writing-mode:lr-tb;text-anchor:start;baseline-shift:baseline;color:#000000;fill:#eeeeec;fill-opacity:1;stroke:none;stroke-width:3;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;font-family:sans-serif;-inkscape-font-specification:sans-serif"
|
||||||
|
d="m 361.65223,524.52745 -9.5602,9.36735 -2.56345,-2.56344 -2.92846,-0.0214 0.0153,2.32639 4.02203,4.02206 c 0.80341,0.80309 2.10565,0.80309 2.90906,0 l 10.95049,-11.05765 0.003,-2.1502 z"
|
||||||
|
id="path12830-4-17-0"
|
||||||
|
inkscape:connector-curvature="0"
|
||||||
|
sodipodi:nodetypes="cccccccccc" />
|
||||||
</g>
|
</g>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 8.8 KiB After Width: | Height: | Size: 12 KiB |
6
data/theme/gnome-shell.scss
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
$variant: 'dark';
|
||||||
|
|
||||||
|
@import "_gnome-shell-old.scss"; //temporary. sadlu shell crashes when trying to build a theme from scratch
|
||||||
|
@import "_colors"; //use gtk colors
|
||||||
|
@import "_drawing";
|
||||||
|
@import "_common";
|
Before Width: | Height: | Size: 25 KiB |
@ -1,74 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
|
||||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
|
||||||
|
|
||||||
<svg
|
|
||||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
|
||||||
xmlns:cc="http://creativecommons.org/ns#"
|
|
||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
|
||||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
|
||||||
width="17"
|
|
||||||
height="10"
|
|
||||||
id="svg2"
|
|
||||||
version="1.1"
|
|
||||||
inkscape:version="0.48.1 r9760"
|
|
||||||
sodipodi:docname="panel-button-border.svg">
|
|
||||||
<defs
|
|
||||||
id="defs4" />
|
|
||||||
<sodipodi:namedview
|
|
||||||
id="base"
|
|
||||||
pagecolor="#000000"
|
|
||||||
bordercolor="#666666"
|
|
||||||
borderopacity="1.0"
|
|
||||||
inkscape:pageopacity="0"
|
|
||||||
inkscape:pageshadow="2"
|
|
||||||
inkscape:zoom="44.8"
|
|
||||||
inkscape:cx="8.6594891"
|
|
||||||
inkscape:cy="5.7029946"
|
|
||||||
inkscape:document-units="px"
|
|
||||||
inkscape:current-layer="layer1"
|
|
||||||
showgrid="true"
|
|
||||||
showguides="true"
|
|
||||||
inkscape:guide-bbox="true"
|
|
||||||
inkscape:window-width="1440"
|
|
||||||
inkscape:window-height="843"
|
|
||||||
inkscape:window-x="0"
|
|
||||||
inkscape:window-y="26"
|
|
||||||
inkscape:window-maximized="1"
|
|
||||||
guidetolerance="10000"
|
|
||||||
objecttolerance="10000">
|
|
||||||
<inkscape:grid
|
|
||||||
type="xygrid"
|
|
||||||
id="grid3792"
|
|
||||||
empspacing="10"
|
|
||||||
visible="true"
|
|
||||||
enabled="true"
|
|
||||||
snapvisiblegridlinesonly="true" />
|
|
||||||
</sodipodi:namedview>
|
|
||||||
<metadata
|
|
||||||
id="metadata7">
|
|
||||||
<rdf:RDF>
|
|
||||||
<cc:Work
|
|
||||||
rdf:about="">
|
|
||||||
<dc:format>image/svg+xml</dc:format>
|
|
||||||
<dc:type
|
|
||||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
|
||||||
<dc:title />
|
|
||||||
</cc:Work>
|
|
||||||
</rdf:RDF>
|
|
||||||
</metadata>
|
|
||||||
<g
|
|
||||||
inkscape:label="Layer 1"
|
|
||||||
inkscape:groupmode="layer"
|
|
||||||
id="layer1">
|
|
||||||
<rect
|
|
||||||
style="opacity:0.8;fill:#ffffff;fill-opacity:1;stroke-width:0.43599999;stroke-miterlimit:4;stroke-dasharray:none"
|
|
||||||
id="rect3796"
|
|
||||||
width="7"
|
|
||||||
height="2"
|
|
||||||
x="5"
|
|
||||||
y="8" />
|
|
||||||
</g>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 2.0 KiB |
@ -1,111 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
|
||||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
|
||||||
|
|
||||||
<svg
|
|
||||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
|
||||||
xmlns:cc="http://creativecommons.org/ns#"
|
|
||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
|
||||||
xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
||||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
|
||||||
width="30"
|
|
||||||
height="25"
|
|
||||||
id="svg10621"
|
|
||||||
version="1.1"
|
|
||||||
inkscape:version="0.48.1 r9760"
|
|
||||||
sodipodi:docname="panel-button-highlight-narrow.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" />
|
|
||||||
</defs>
|
|
||||||
<sodipodi:namedview
|
|
||||||
id="base"
|
|
||||||
pagecolor="#000000"
|
|
||||||
bordercolor="#666666"
|
|
||||||
borderopacity="1.0"
|
|
||||||
inkscape:pageopacity="0"
|
|
||||||
inkscape:pageshadow="2"
|
|
||||||
inkscape:zoom="1.979899"
|
|
||||||
inkscape:cx="-171.36384"
|
|
||||||
inkscape:cy="-53.255157"
|
|
||||||
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="1440"
|
|
||||||
inkscape:window-height="843"
|
|
||||||
inkscape:window-x="0"
|
|
||||||
inkscape:window-y="26"
|
|
||||||
inkscape:window-maximized="1" />
|
|
||||||
<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 />
|
|
||||||
</cc:Work>
|
|
||||||
</rdf:RDF>
|
|
||||||
</metadata>
|
|
||||||
<g
|
|
||||||
inkscape:label="Layer 1"
|
|
||||||
inkscape:groupmode="layer"
|
|
||||||
id="layer1"
|
|
||||||
transform="translate(-468.08632,-537.03477)">
|
|
||||||
<path
|
|
||||||
sodipodi:type="arc"
|
|
||||||
style="opacity:0.4625;color:#000000;fill:url(#radialGradient10592);fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:3;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
|
||||||
id="path34506-3"
|
|
||||||
sodipodi:cx="51"
|
|
||||||
sodipodi:cy="30"
|
|
||||||
sodipodi:rx="42"
|
|
||||||
sodipodi:ry="16"
|
|
||||||
d="M 9,29.999999 C 9.0000011,21.163443 27.804042,14 51.000002,14 74.195961,14 93,21.163444 93,30 l -42,0 z"
|
|
||||||
sodipodi:start="3.1415927"
|
|
||||||
sodipodi:end="6.2831853"
|
|
||||||
transform="matrix(0.35714286,0,0,1.5625,464.87203,515.15977)"
|
|
||||||
inkscape:export-filename="/home/jimmac/src/cvs/gnome/gnome-shell-design/mockups/motion/textures/panel.png"
|
|
||||||
inkscape:export-xdpi="90"
|
|
||||||
inkscape:export-ydpi="90" />
|
|
||||||
</g>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 3.5 KiB |
@ -1,111 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
|
||||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
|
||||||
|
|
||||||
<svg
|
|
||||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
|
||||||
xmlns:cc="http://creativecommons.org/ns#"
|
|
||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
|
||||||
xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
||||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
|
||||||
width="84"
|
|
||||||
height="25"
|
|
||||||
id="svg10621"
|
|
||||||
version="1.1"
|
|
||||||
inkscape:version="0.48.0 r9654"
|
|
||||||
sodipodi:docname="panel-button-highlight-wide.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" />
|
|
||||||
</defs>
|
|
||||||
<sodipodi:namedview
|
|
||||||
id="base"
|
|
||||||
pagecolor="#000000"
|
|
||||||
bordercolor="#666666"
|
|
||||||
borderopacity="1.0"
|
|
||||||
inkscape:pageopacity="0"
|
|
||||||
inkscape:pageshadow="2"
|
|
||||||
inkscape:zoom="1.979899"
|
|
||||||
inkscape:cx="-118.50071"
|
|
||||||
inkscape:cy="27.304508"
|
|
||||||
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="1440"
|
|
||||||
inkscape:window-height="843"
|
|
||||||
inkscape:window-x="0"
|
|
||||||
inkscape:window-y="26"
|
|
||||||
inkscape:window-maximized="1" />
|
|
||||||
<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 />
|
|
||||||
</cc:Work>
|
|
||||||
</rdf:RDF>
|
|
||||||
</metadata>
|
|
||||||
<g
|
|
||||||
inkscape:label="Layer 1"
|
|
||||||
inkscape:groupmode="layer"
|
|
||||||
id="layer1"
|
|
||||||
transform="translate(-441.08632,-537.03477)">
|
|
||||||
<path
|
|
||||||
sodipodi:type="arc"
|
|
||||||
style="opacity:0.4625;color:#000000;fill:url(#radialGradient10592);fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:3;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
|
||||||
id="path34506-3"
|
|
||||||
sodipodi:cx="51"
|
|
||||||
sodipodi:cy="30"
|
|
||||||
sodipodi:rx="42"
|
|
||||||
sodipodi:ry="16"
|
|
||||||
d="M 9,29.999999 C 9.0000011,21.163443 27.804042,14 51.000002,14 74.195961,14 93,21.163444 93,30 l -42,0 z"
|
|
||||||
sodipodi:start="3.1415927"
|
|
||||||
sodipodi:end="6.2831853"
|
|
||||||
transform="matrix(1,0,0,1.5625,432.08632,515.15977)"
|
|
||||||
inkscape:export-filename="/home/jimmac/src/cvs/gnome/gnome-shell-design/mockups/motion/textures/panel.png"
|
|
||||||
inkscape:export-xdpi="90"
|
|
||||||
inkscape:export-ydpi="90" />
|
|
||||||
</g>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 3.5 KiB |
@ -12,7 +12,7 @@
|
|||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
id="svg5369"
|
id="svg5369"
|
||||||
version="1.1"
|
version="1.1"
|
||||||
inkscape:version="0.48+devel r10053 custom"
|
inkscape:version="0.48.5 r10040"
|
||||||
width="96"
|
width="96"
|
||||||
height="48"
|
height="48"
|
||||||
sodipodi:docname="process-working.svg"
|
sodipodi:docname="process-working.svg"
|
||||||
@ -25,12 +25,597 @@
|
|||||||
<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>
|
||||||
<defs
|
<defs
|
||||||
id="defs5373" />
|
id="defs5373">
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient8231-1-4-4-1"
|
||||||
|
id="radialGradient35326"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(2.229454,-1.2865389,1.2087442,2.0939897,-228.90301,-208.08725)"
|
||||||
|
cx="-0.067823187"
|
||||||
|
cy="188.51917"
|
||||||
|
fx="-0.067823187"
|
||||||
|
fy="188.51917"
|
||||||
|
r="27.330345" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient8231-1-4-4-1">
|
||||||
|
<stop
|
||||||
|
id="stop8233-28-5-27-1"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.15428571"
|
||||||
|
offset="0.31861392"
|
||||||
|
id="stop8235-7-3-94-3" />
|
||||||
|
<stop
|
||||||
|
id="stop8237-7-8-20-2"
|
||||||
|
offset="0.54270232"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.33714285" />
|
||||||
|
<stop
|
||||||
|
id="stop8239-2-9-1-9"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient5767-6"
|
||||||
|
id="radialGradient35230"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.1252013,-0.60470548,0.56813832,1.0568583,-107.67128,-11.948108)"
|
||||||
|
cx="0.053942412"
|
||||||
|
cy="189.15244"
|
||||||
|
fx="0.053942412"
|
||||||
|
fy="189.15244"
|
||||||
|
r="27.330345" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient5767-6">
|
||||||
|
<stop
|
||||||
|
id="stop5769-0"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#bebebe;stop-opacity:0" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0"
|
||||||
|
offset="0.31861392"
|
||||||
|
id="stop5771-1" />
|
||||||
|
<stop
|
||||||
|
id="stop5773-7"
|
||||||
|
offset="0.75051737"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.42857143" />
|
||||||
|
<stop
|
||||||
|
id="stop5775-8"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient8231-1-4-4-1"
|
||||||
|
id="radialGradient10255"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(2.229454,-1.2865389,1.2087442,2.0939897,-228.90301,-208.08725)"
|
||||||
|
cx="-0.067823187"
|
||||||
|
cy="188.51917"
|
||||||
|
fx="-0.067823187"
|
||||||
|
fy="188.51917"
|
||||||
|
r="27.330345" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient10257">
|
||||||
|
<stop
|
||||||
|
id="stop10259"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.15428571"
|
||||||
|
offset="0.31861392"
|
||||||
|
id="stop10261" />
|
||||||
|
<stop
|
||||||
|
id="stop10263"
|
||||||
|
offset="0.54270232"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.33714285" />
|
||||||
|
<stop
|
||||||
|
id="stop10265"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient5767-6"
|
||||||
|
id="radialGradient10267"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.1252013,-0.60470548,0.56813832,1.0568583,-107.67128,-11.948108)"
|
||||||
|
cx="0.053942412"
|
||||||
|
cy="189.15244"
|
||||||
|
fx="0.053942412"
|
||||||
|
fy="189.15244"
|
||||||
|
r="27.330345" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient10269">
|
||||||
|
<stop
|
||||||
|
id="stop10271"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#bebebe;stop-opacity:0" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0"
|
||||||
|
offset="0.31861392"
|
||||||
|
id="stop10273" />
|
||||||
|
<stop
|
||||||
|
id="stop10275"
|
||||||
|
offset="0.75051737"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.42857143" />
|
||||||
|
<stop
|
||||||
|
id="stop10277"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient8231-1-4-4-1"
|
||||||
|
id="radialGradient10279"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(2.229454,-1.2865389,1.2087442,2.0939897,-228.90301,-208.08725)"
|
||||||
|
cx="-0.067823187"
|
||||||
|
cy="188.51917"
|
||||||
|
fx="-0.067823187"
|
||||||
|
fy="188.51917"
|
||||||
|
r="27.330345" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient10281">
|
||||||
|
<stop
|
||||||
|
id="stop10283"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.15428571"
|
||||||
|
offset="0.31861392"
|
||||||
|
id="stop10285" />
|
||||||
|
<stop
|
||||||
|
id="stop10287"
|
||||||
|
offset="0.54270232"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.33714285" />
|
||||||
|
<stop
|
||||||
|
id="stop10289"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient5767-6"
|
||||||
|
id="radialGradient10291"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.1252013,-0.60470548,0.56813832,1.0568583,-107.67128,-11.948108)"
|
||||||
|
cx="0.053942412"
|
||||||
|
cy="189.15244"
|
||||||
|
fx="0.053942412"
|
||||||
|
fy="189.15244"
|
||||||
|
r="27.330345" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient10293">
|
||||||
|
<stop
|
||||||
|
id="stop10295"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#bebebe;stop-opacity:0" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0"
|
||||||
|
offset="0.31861392"
|
||||||
|
id="stop10297" />
|
||||||
|
<stop
|
||||||
|
id="stop10299"
|
||||||
|
offset="0.75051737"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.42857143" />
|
||||||
|
<stop
|
||||||
|
id="stop10301"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient8231-1-4-4-1"
|
||||||
|
id="radialGradient10303"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(2.229454,-1.2865389,1.2087442,2.0939897,-228.90301,-208.08725)"
|
||||||
|
cx="-0.067823187"
|
||||||
|
cy="188.51917"
|
||||||
|
fx="-0.067823187"
|
||||||
|
fy="188.51917"
|
||||||
|
r="27.330345" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient10305">
|
||||||
|
<stop
|
||||||
|
id="stop10307"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.15428571"
|
||||||
|
offset="0.31861392"
|
||||||
|
id="stop10309" />
|
||||||
|
<stop
|
||||||
|
id="stop10311"
|
||||||
|
offset="0.54270232"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.33714285" />
|
||||||
|
<stop
|
||||||
|
id="stop10313"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient5767-6"
|
||||||
|
id="radialGradient10315"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.1252013,-0.60470548,0.56813832,1.0568583,-107.67128,-11.948108)"
|
||||||
|
cx="0.053942412"
|
||||||
|
cy="189.15244"
|
||||||
|
fx="0.053942412"
|
||||||
|
fy="189.15244"
|
||||||
|
r="27.330345" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient10317">
|
||||||
|
<stop
|
||||||
|
id="stop10319"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#bebebe;stop-opacity:0" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0"
|
||||||
|
offset="0.31861392"
|
||||||
|
id="stop10321" />
|
||||||
|
<stop
|
||||||
|
id="stop10323"
|
||||||
|
offset="0.75051737"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.42857143" />
|
||||||
|
<stop
|
||||||
|
id="stop10325"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient8231-1-4-4-1"
|
||||||
|
id="radialGradient10327"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(2.229454,-1.2865389,1.2087442,2.0939897,-228.90301,-208.08725)"
|
||||||
|
cx="-0.067823187"
|
||||||
|
cy="188.51917"
|
||||||
|
fx="-0.067823187"
|
||||||
|
fy="188.51917"
|
||||||
|
r="27.330345" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient10329">
|
||||||
|
<stop
|
||||||
|
id="stop10331"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.15428571"
|
||||||
|
offset="0.31861392"
|
||||||
|
id="stop10333" />
|
||||||
|
<stop
|
||||||
|
id="stop10335"
|
||||||
|
offset="0.54270232"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.33714285" />
|
||||||
|
<stop
|
||||||
|
id="stop10337"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient5767-6"
|
||||||
|
id="radialGradient10339"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.1252013,-0.60470548,0.56813832,1.0568583,-107.67128,-11.948108)"
|
||||||
|
cx="0.053942412"
|
||||||
|
cy="189.15244"
|
||||||
|
fx="0.053942412"
|
||||||
|
fy="189.15244"
|
||||||
|
r="27.330345" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient10341">
|
||||||
|
<stop
|
||||||
|
id="stop10343"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#bebebe;stop-opacity:0" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0"
|
||||||
|
offset="0.31861392"
|
||||||
|
id="stop10345" />
|
||||||
|
<stop
|
||||||
|
id="stop10347"
|
||||||
|
offset="0.75051737"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.42857143" />
|
||||||
|
<stop
|
||||||
|
id="stop10349"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient8231-1-4-4-1"
|
||||||
|
id="radialGradient10351"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(2.229454,-1.2865389,1.2087442,2.0939897,-228.90301,-208.08725)"
|
||||||
|
cx="-0.067823187"
|
||||||
|
cy="188.51917"
|
||||||
|
fx="-0.067823187"
|
||||||
|
fy="188.51917"
|
||||||
|
r="27.330345" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient10353">
|
||||||
|
<stop
|
||||||
|
id="stop10355"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.15428571"
|
||||||
|
offset="0.31861392"
|
||||||
|
id="stop10357" />
|
||||||
|
<stop
|
||||||
|
id="stop10359"
|
||||||
|
offset="0.54270232"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.33714285" />
|
||||||
|
<stop
|
||||||
|
id="stop10361"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient5767-6"
|
||||||
|
id="radialGradient10363"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.1252013,-0.60470548,0.56813832,1.0568583,-107.67128,-11.948108)"
|
||||||
|
cx="0.053942412"
|
||||||
|
cy="189.15244"
|
||||||
|
fx="0.053942412"
|
||||||
|
fy="189.15244"
|
||||||
|
r="27.330345" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient10365">
|
||||||
|
<stop
|
||||||
|
id="stop10367"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#bebebe;stop-opacity:0" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0"
|
||||||
|
offset="0.31861392"
|
||||||
|
id="stop10369" />
|
||||||
|
<stop
|
||||||
|
id="stop10371"
|
||||||
|
offset="0.75051737"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.42857143" />
|
||||||
|
<stop
|
||||||
|
id="stop10373"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient8231-1-4-4-1"
|
||||||
|
id="radialGradient10375"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(2.229454,-1.2865389,1.2087442,2.0939897,-228.90301,-208.08725)"
|
||||||
|
cx="-0.067823187"
|
||||||
|
cy="188.51917"
|
||||||
|
fx="-0.067823187"
|
||||||
|
fy="188.51917"
|
||||||
|
r="27.330345" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient10377">
|
||||||
|
<stop
|
||||||
|
id="stop10379"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.15428571"
|
||||||
|
offset="0.31861392"
|
||||||
|
id="stop10381" />
|
||||||
|
<stop
|
||||||
|
id="stop10383"
|
||||||
|
offset="0.54270232"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.33714285" />
|
||||||
|
<stop
|
||||||
|
id="stop10385"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient5767-6"
|
||||||
|
id="radialGradient10387"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.1252013,-0.60470548,0.56813832,1.0568583,-107.67128,-11.948108)"
|
||||||
|
cx="0.053942412"
|
||||||
|
cy="189.15244"
|
||||||
|
fx="0.053942412"
|
||||||
|
fy="189.15244"
|
||||||
|
r="27.330345" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient10389">
|
||||||
|
<stop
|
||||||
|
id="stop10391"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#bebebe;stop-opacity:0" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0"
|
||||||
|
offset="0.31861392"
|
||||||
|
id="stop10393" />
|
||||||
|
<stop
|
||||||
|
id="stop10395"
|
||||||
|
offset="0.75051737"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.42857143" />
|
||||||
|
<stop
|
||||||
|
id="stop10397"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient8231-1-4-4-1"
|
||||||
|
id="radialGradient10399"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(2.229454,-1.2865389,1.2087442,2.0939897,-228.90301,-208.08725)"
|
||||||
|
cx="-0.067823187"
|
||||||
|
cy="188.51917"
|
||||||
|
fx="-0.067823187"
|
||||||
|
fy="188.51917"
|
||||||
|
r="27.330345" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient10401">
|
||||||
|
<stop
|
||||||
|
id="stop10403"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.15428571"
|
||||||
|
offset="0.31861392"
|
||||||
|
id="stop10405" />
|
||||||
|
<stop
|
||||||
|
id="stop10407"
|
||||||
|
offset="0.54270232"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.33714285" />
|
||||||
|
<stop
|
||||||
|
id="stop10409"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient5767-6"
|
||||||
|
id="radialGradient10411"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.1252013,-0.60470548,0.56813832,1.0568583,-107.67128,-11.948108)"
|
||||||
|
cx="0.053942412"
|
||||||
|
cy="189.15244"
|
||||||
|
fx="0.053942412"
|
||||||
|
fy="189.15244"
|
||||||
|
r="27.330345" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient10413">
|
||||||
|
<stop
|
||||||
|
id="stop10415"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#bebebe;stop-opacity:0" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0"
|
||||||
|
offset="0.31861392"
|
||||||
|
id="stop10417" />
|
||||||
|
<stop
|
||||||
|
id="stop10419"
|
||||||
|
offset="0.75051737"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.42857143" />
|
||||||
|
<stop
|
||||||
|
id="stop10421"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient8231-1-4-4-1"
|
||||||
|
id="radialGradient10423"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(2.229454,-1.2865389,1.2087442,2.0939897,-228.90301,-208.08725)"
|
||||||
|
cx="-0.067823187"
|
||||||
|
cy="188.51917"
|
||||||
|
fx="-0.067823187"
|
||||||
|
fy="188.51917"
|
||||||
|
r="27.330345" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient10425">
|
||||||
|
<stop
|
||||||
|
id="stop10427"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.15428571"
|
||||||
|
offset="0.31861392"
|
||||||
|
id="stop10429" />
|
||||||
|
<stop
|
||||||
|
id="stop10431"
|
||||||
|
offset="0.54270232"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.33714285" />
|
||||||
|
<stop
|
||||||
|
id="stop10433"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient5767-6"
|
||||||
|
id="radialGradient10435"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.1252013,-0.60470548,0.56813832,1.0568583,-107.67128,-11.948108)"
|
||||||
|
cx="0.053942412"
|
||||||
|
cy="189.15244"
|
||||||
|
fx="0.053942412"
|
||||||
|
fy="189.15244"
|
||||||
|
r="27.330345" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient10437">
|
||||||
|
<stop
|
||||||
|
id="stop10439"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#bebebe;stop-opacity:0" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0"
|
||||||
|
offset="0.31861392"
|
||||||
|
id="stop10441" />
|
||||||
|
<stop
|
||||||
|
id="stop10443"
|
||||||
|
offset="0.75051737"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0.42857143" />
|
||||||
|
<stop
|
||||||
|
id="stop10445"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient8231-1-4-4-1"
|
||||||
|
id="radialGradient10709"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(2.229454,-1.2865389,1.2087442,2.0939897,-228.90301,-208.08725)"
|
||||||
|
cx="-0.067823187"
|
||||||
|
cy="188.51917"
|
||||||
|
fx="-0.067823187"
|
||||||
|
fy="188.51917"
|
||||||
|
r="27.330345" />
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient5767-6"
|
||||||
|
id="radialGradient10711"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.1252013,-0.60470548,0.56813832,1.0568583,-107.67128,-11.948108)"
|
||||||
|
cx="0.053942412"
|
||||||
|
cy="189.15244"
|
||||||
|
fx="0.053942412"
|
||||||
|
fy="189.15244"
|
||||||
|
r="27.330345" />
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient8231-1-4-4-1"
|
||||||
|
id="radialGradient10713"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(2.229454,-1.2865389,1.2087442,2.0939897,-228.90301,-208.08725)"
|
||||||
|
cx="-0.067823187"
|
||||||
|
cy="188.51917"
|
||||||
|
fx="-0.067823187"
|
||||||
|
fy="188.51917"
|
||||||
|
r="27.330345" />
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient5767-6"
|
||||||
|
id="radialGradient10715"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.1252013,-0.60470548,0.56813832,1.0568583,-107.67128,-11.948108)"
|
||||||
|
cx="0.053942412"
|
||||||
|
cy="189.15244"
|
||||||
|
fx="0.053942412"
|
||||||
|
fy="189.15244"
|
||||||
|
r="27.330345" />
|
||||||
|
</defs>
|
||||||
<sodipodi:namedview
|
<sodipodi:namedview
|
||||||
pagecolor="#808080"
|
pagecolor="#808080"
|
||||||
bordercolor="#666666"
|
bordercolor="#666666"
|
||||||
@ -46,13 +631,15 @@
|
|||||||
showgrid="true"
|
showgrid="true"
|
||||||
borderlayer="true"
|
borderlayer="true"
|
||||||
inkscape:showpageshadow="false"
|
inkscape:showpageshadow="false"
|
||||||
inkscape:zoom="16"
|
inkscape:zoom="5.6568542"
|
||||||
inkscape:cx="53.997662"
|
inkscape:cx="40.82607"
|
||||||
inkscape:cy="22.367695"
|
inkscape:cy="30.594699"
|
||||||
inkscape:window-x="1600"
|
inkscape:window-x="2560"
|
||||||
inkscape:window-y="33"
|
inkscape:window-y="33"
|
||||||
inkscape:window-maximized="0"
|
inkscape:window-maximized="0"
|
||||||
inkscape:current-layer="layer2">
|
inkscape:current-layer="layer2"
|
||||||
|
inkscape:snap-bbox="true"
|
||||||
|
inkscape:snap-nodes="false">
|
||||||
<inkscape:grid
|
<inkscape:grid
|
||||||
type="xygrid"
|
type="xygrid"
|
||||||
id="grid11933"
|
id="grid11933"
|
||||||
@ -128,134 +715,97 @@
|
|||||||
id="layer2"
|
id="layer2"
|
||||||
inkscape:label="spinner">
|
inkscape:label="spinner">
|
||||||
<g
|
<g
|
||||||
transform="matrix(0.28240106,0,0,0.28240106,146.92015,-382.52444)"
|
transform="matrix(0.43142675,0,0,0.43298814,218.13188,-592.92581)"
|
||||||
id="g10450-5"
|
id="g10450-5-3"
|
||||||
style="display:inline">
|
style="display:inline">
|
||||||
<path
|
<path
|
||||||
inkscape:connector-curvature="0"
|
inkscape:export-ydpi="90"
|
||||||
style="opacity:0.6;color:#000000;fill:none;stroke:#ffffff;stroke-width:7.08212566;stroke-linecap:round;stroke-opacity:1;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
inkscape:export-xdpi="90"
|
||||||
d="m -477.76072,1373.3569 0,9.4717"
|
inkscape:export-filename="/home/hbons/Moblin/git/carrick-ng/data/icons/network-connecting.png"
|
||||||
id="path18768"
|
sodipodi:open="true"
|
||||||
sodipodi:nodetypes="cc"
|
sodipodi:end="4.712389"
|
||||||
inkscape:transform-center-y="-4.6808838" />
|
sodipodi:start="0.23191105"
|
||||||
|
sodipodi:type="arc"
|
||||||
|
style="fill:none;stroke:url(#radialGradient10713);stroke-width:12.18051815;stroke-linecap:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
|
||||||
|
id="path10452-5"
|
||||||
|
sodipodi:cx="-25.809397"
|
||||||
|
sodipodi:cy="179.43886"
|
||||||
|
sodipodi:rx="22.98097"
|
||||||
|
sodipodi:ry="22.98097"
|
||||||
|
d="m -3.4436513,184.72075 c -2.9171108,12.35226 -15.2953817,20.00096 -27.6476417,17.08385 -12.35226,-2.91711 -20.00096,-15.29538 -17.083849,-27.64764 2.449452,-10.372 11.708437,-17.69907 22.365746,-17.69907"
|
||||||
|
transform="matrix(-0.16397381,0.61157081,-0.61162275,-0.16377992,-372.32298,1442.5061)" />
|
||||||
<path
|
<path
|
||||||
inkscape:connector-curvature="0"
|
transform="matrix(-0.63300818,0.01438356,-0.01458424,-0.63300359,-491.4014,1510.996)"
|
||||||
inkscape:transform-center-y="-3.3099227"
|
d="m -3.4436513,184.72075 c -2.9171108,12.35226 -15.2953817,20.00096 -27.6476417,17.08385 -12.35226,-2.91711 -20.00096,-15.29538 -17.083849,-27.64764 2.449452,-10.372 11.708437,-17.69907 22.365746,-17.69907"
|
||||||
sodipodi:nodetypes="cc"
|
sodipodi:ry="22.98097"
|
||||||
id="path18770"
|
sodipodi:rx="22.98097"
|
||||||
d="m -461.0171,1380.2922 -7.23427,7.3824"
|
sodipodi:cy="179.43886"
|
||||||
style="opacity:0.7;color:#000000;fill:none;stroke:#ffffff;stroke-width:7.08212566;stroke-linecap:round;stroke-opacity:1;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
sodipodi:cx="-25.809397"
|
||||||
inkscape:transform-center-x="-3.3098966" />
|
id="path10454-7"
|
||||||
<path
|
style="fill:none;stroke:url(#radialGradient10715);stroke-width:12.18051815;stroke-linecap:butt;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
|
||||||
inkscape:connector-curvature="0"
|
sodipodi:type="arc"
|
||||||
inkscape:transform-center-x="-4.6808962"
|
sodipodi:start="0.23191105"
|
||||||
style="opacity:0.8;color:#000000;fill:none;stroke:#ffffff;stroke-width:7.08212566;stroke-linecap:round;stroke-opacity:1;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
sodipodi:end="4.712389"
|
||||||
d="m -454.08163,1397.0359 -9.47165,0"
|
sodipodi:open="true"
|
||||||
id="path18772"
|
inkscape:export-filename="/home/hbons/Moblin/git/carrick-ng/data/icons/network-connecting.png"
|
||||||
sodipodi:nodetypes="cc"
|
inkscape:export-xdpi="90"
|
||||||
inkscape:transform-center-y="-2.6596956e-05" />
|
inkscape:export-ydpi="90" />
|
||||||
<path
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
sodipodi:nodetypes="cc"
|
|
||||||
id="path18774"
|
|
||||||
d="m -461.01709,1413.7796 -6.93831,-7.0864"
|
|
||||||
style="opacity:0.9;color:#000000;fill:none;stroke:#ffffff;stroke-width:7.08212566;stroke-linecap:round;stroke-opacity:1;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
|
||||||
inkscape:transform-center-x="-3.3098966"
|
|
||||||
inkscape:transform-center-y="3.3098652" />
|
|
||||||
<path
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
inkscape:transform-center-y="4.6808757"
|
|
||||||
style="color:#000000;fill:none;stroke:#ffffff;stroke-width:7.08212566;stroke-linecap:round;stroke-opacity:1;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
|
||||||
d="m -477.76074,1420.715 9e-5,-9.4716"
|
|
||||||
id="path18776"
|
|
||||||
sodipodi:nodetypes="cc" />
|
|
||||||
<path
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
sodipodi:nodetypes="cc"
|
|
||||||
id="path18778"
|
|
||||||
d="m -494.50442,1413.7796 6.79048,-6.9384"
|
|
||||||
style="opacity:0.3;color:#000000;fill:none;stroke:#ffffff;stroke-width:7.08212566;stroke-linecap:round;stroke-opacity:1;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
|
||||||
inkscape:transform-center-y="3.3098769"
|
|
||||||
inkscape:transform-center-x="3.3098883" />
|
|
||||||
<path
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
inkscape:transform-center-x="4.6808941"
|
|
||||||
style="opacity:0.4;color:#000000;fill:none;stroke:#ffffff;stroke-width:7.08212566;stroke-linecap:round;stroke-opacity:1;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
|
||||||
d="m -501.43987,1397.0359 9.47174,0"
|
|
||||||
id="path18780"
|
|
||||||
sodipodi:nodetypes="cc"
|
|
||||||
inkscape:transform-center-y="-2.6596956e-05" />
|
|
||||||
<path
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
sodipodi:nodetypes="cc"
|
|
||||||
id="path18782"
|
|
||||||
d="m -494.5044,1380.2922 6.64243,6.9384"
|
|
||||||
style="opacity:0.5;color:#000000;fill:none;stroke:#ffffff;stroke-width:7.08212566;stroke-linecap:round;stroke-opacity:1;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
|
||||||
inkscape:transform-center-x="3.3098902"
|
|
||||||
inkscape:transform-center-y="-3.3099302" />
|
|
||||||
</g>
|
</g>
|
||||||
<use
|
<use
|
||||||
style="display:inline"
|
|
||||||
x="0"
|
x="0"
|
||||||
y="0"
|
y="0"
|
||||||
xlink:href="#g10450-5"
|
xlink:href="#g10450-5-3"
|
||||||
id="use4981"
|
id="use13294"
|
||||||
transform="matrix(0.70710678,0.70710678,-0.70710678,0.70710678,36,-4.9705636)"
|
transform="matrix(0.70710678,0.70710679,-0.70710679,0.70710678,35.986458,-4.9737924)"
|
||||||
width="400"
|
width="96"
|
||||||
height="400" />
|
height="48" />
|
||||||
<use
|
<use
|
||||||
style="display:inline"
|
|
||||||
x="0"
|
x="0"
|
||||||
y="0"
|
y="0"
|
||||||
xlink:href="#use4981"
|
xlink:href="#use13294"
|
||||||
id="use4983"
|
id="use13314"
|
||||||
transform="matrix(0.70710678,0.70710678,-0.70710678,0.70710678,43.032478,-21.909695)"
|
transform="matrix(0.70710678,0.70710679,-0.70710679,0.70710678,43.036943,-21.933639)"
|
||||||
width="400"
|
width="96"
|
||||||
height="400" />
|
height="48" />
|
||||||
<use
|
<use
|
||||||
style="display:inline"
|
|
||||||
x="0"
|
x="0"
|
||||||
y="0"
|
y="0"
|
||||||
xlink:href="#use4983"
|
xlink:href="#use13314"
|
||||||
id="use4985"
|
id="use13334"
|
||||||
transform="matrix(0.70710678,0.70710678,-0.70710678,0.70710678,50.081986,-38.904617)"
|
transform="matrix(0.70710678,0.70710679,-0.70710679,0.70710678,50.085328,-38.904987)"
|
||||||
width="400"
|
width="96"
|
||||||
height="400" />
|
height="48" />
|
||||||
<use
|
<use
|
||||||
style="display:inline"
|
|
||||||
x="0"
|
x="0"
|
||||||
y="0"
|
y="0"
|
||||||
xlink:href="#use4985"
|
xlink:href="#use13334"
|
||||||
id="use4987"
|
id="use13354"
|
||||||
transform="matrix(0.70710678,0.70710678,-0.70710678,0.70710678,-38.919996,-31.872139)"
|
transform="matrix(0.70710678,0.70710679,-0.70710679,0.70710678,-38.894841,-31.888724)"
|
||||||
width="400"
|
width="96"
|
||||||
height="400" />
|
height="48" />
|
||||||
<use
|
<use
|
||||||
style="display:inline"
|
|
||||||
x="0"
|
x="0"
|
||||||
y="0"
|
y="0"
|
||||||
xlink:href="#use4987"
|
xlink:href="#use13354"
|
||||||
id="use4989"
|
id="use13374"
|
||||||
transform="matrix(0.70710678,0.70710678,-0.70710678,0.70710678,52.986628,2.0890543)"
|
transform="matrix(0.70710678,0.70710679,-0.70710679,0.70710678,52.971072,2.0670843)"
|
||||||
width="400"
|
width="96"
|
||||||
height="400" />
|
height="48" />
|
||||||
<use
|
<use
|
||||||
style="display:inline"
|
|
||||||
x="0"
|
x="0"
|
||||||
y="0"
|
y="0"
|
||||||
xlink:href="#use4989"
|
xlink:href="#use13374"
|
||||||
id="use4991"
|
id="use13394"
|
||||||
transform="matrix(0.70710678,0.70710678,-0.70710678,0.70710678,60.013026,-14.912936)"
|
transform="matrix(0.70710678,0.70710679,-0.70710679,0.70710678,60.017834,-14.929741)"
|
||||||
width="400"
|
width="96"
|
||||||
height="400" />
|
height="48" />
|
||||||
<use
|
<use
|
||||||
style="display:inline"
|
|
||||||
x="0"
|
x="0"
|
||||||
y="0"
|
y="0"
|
||||||
xlink:href="#use4991"
|
xlink:href="#use13394"
|
||||||
id="use4993"
|
id="use13414"
|
||||||
transform="matrix(0.70710678,0.70710678,-0.70710678,0.70710678,67.022396,-31.859127)"
|
transform="matrix(0.86602541,0.50000001,-0.50000001,0.86602541,50.044124,-25.16226)"
|
||||||
width="400"
|
width="96"
|
||||||
height="400" />
|
height="48" />
|
||||||
</g>
|
</g>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 9.8 KiB After Width: | Height: | Size: 26 KiB |
@ -7,51 +7,127 @@
|
|||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
xmlns="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:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
width="65"
|
width="65"
|
||||||
height="22"
|
height="22"
|
||||||
id="svg3273"
|
id="svg2857"
|
||||||
version="1.1"
|
version="1.1"
|
||||||
inkscape:version="0.47 r22583"
|
inkscape:version="0.48.5 r10040"
|
||||||
sodipodi:docname="New document 14">
|
sodipodi:docname="toggle-off-us.svg">
|
||||||
<defs
|
<defs
|
||||||
id="defs3275">
|
id="defs2859">
|
||||||
<inkscape:perspective
|
<inkscape:perspective
|
||||||
sodipodi:type="inkscape:persp3d"
|
sodipodi:type="inkscape:persp3d"
|
||||||
inkscape:vp_x="0 : 526.18109 : 1"
|
inkscape:vp_x="0 : 526.18109 : 1"
|
||||||
inkscape:vp_y="0 : 1000 : 0"
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
inkscape:vp_z="744.09448 : 526.18109 : 1"
|
inkscape:vp_z="744.09448 : 526.18109 : 1"
|
||||||
inkscape:persp3d-origin="372.04724 : 350.78739 : 1"
|
inkscape:persp3d-origin="372.04724 : 350.78739 : 1"
|
||||||
id="perspective3281" />
|
id="perspective2865" />
|
||||||
<inkscape:perspective
|
<inkscape:perspective
|
||||||
id="perspective3261"
|
id="perspective2843"
|
||||||
inkscape:persp3d-origin="0.5 : 0.33333333 : 1"
|
inkscape:persp3d-origin="0.5 : 0.33333333 : 1"
|
||||||
inkscape:vp_z="1 : 0.5 : 1"
|
inkscape:vp_z="1 : 0.5 : 1"
|
||||||
inkscape:vp_y="0 : 1000 : 0"
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
inkscape:vp_x="0 : 0.5 : 1"
|
inkscape:vp_x="0 : 0.5 : 1"
|
||||||
sodipodi:type="inkscape:persp3d" />
|
sodipodi:type="inkscape:persp3d" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient76469-7-7-4"
|
||||||
|
id="linearGradient38024"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.0215462,0,0,1.0322581,717.22867,428.68472)"
|
||||||
|
x1="6"
|
||||||
|
y1="102.95528"
|
||||||
|
x2="6"
|
||||||
|
y2="84.505203" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
id="linearGradient76469-7-7-4">
|
||||||
|
<stop
|
||||||
|
style="stop-color:#2e3232;stop-opacity:1"
|
||||||
|
offset="0"
|
||||||
|
id="stop76471-7-1-5" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#3e4545;stop-opacity:1"
|
||||||
|
offset="1"
|
||||||
|
id="stop76473-9-0-0" />
|
||||||
|
</linearGradient>
|
||||||
|
<inkscape:path-effect
|
||||||
|
effect="spiro"
|
||||||
|
id="path-effect77541-4"
|
||||||
|
is_visible="true" />
|
||||||
|
<inkscape:path-effect
|
||||||
|
effect="spiro"
|
||||||
|
id="path-effect77541-4-0"
|
||||||
|
is_visible="true" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient37802-8"
|
||||||
|
id="linearGradient12311-3-1-0-5-4"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.5918367,0,0,0.85714285,-256.56122,59.071426)"
|
||||||
|
x1="610.13782"
|
||||||
|
y1="501.43866"
|
||||||
|
x2="610.13782"
|
||||||
|
y2="492.52756" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient37802-8"
|
||||||
|
inkscape:collect="always">
|
||||||
|
<stop
|
||||||
|
id="stop37804-1"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#2c2c2c;stop-opacity:1" />
|
||||||
|
<stop
|
||||||
|
id="stop37806-8"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#16191a;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<linearGradient
|
||||||
|
y2="492.52756"
|
||||||
|
x2="610.13782"
|
||||||
|
y1="501.43866"
|
||||||
|
x1="610.13782"
|
||||||
|
gradientTransform="matrix(1.5918367,0,0,0.85714285,-900.56122,-423.92857)"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
id="linearGradient13602"
|
||||||
|
xlink:href="#linearGradient37802-8"
|
||||||
|
inkscape:collect="always" />
|
||||||
</defs>
|
</defs>
|
||||||
<sodipodi:namedview
|
<sodipodi:namedview
|
||||||
id="base"
|
id="base"
|
||||||
pagecolor="#ffffff"
|
pagecolor="#000000"
|
||||||
bordercolor="#666666"
|
bordercolor="#666666"
|
||||||
borderopacity="1.0"
|
borderopacity="1.0"
|
||||||
inkscape:pageopacity="0.0"
|
inkscape:pageopacity="1"
|
||||||
inkscape:pageshadow="2"
|
inkscape:pageshadow="2"
|
||||||
inkscape:zoom="0.35"
|
inkscape:zoom="1"
|
||||||
inkscape:cx="32.000004"
|
inkscape:cx="-5.0602834"
|
||||||
inkscape:cy="10.999997"
|
inkscape:cy="16.473273"
|
||||||
inkscape:document-units="px"
|
inkscape:document-units="px"
|
||||||
inkscape:current-layer="layer1"
|
inkscape:current-layer="g37994"
|
||||||
showgrid="false"
|
showgrid="false"
|
||||||
inkscape:window-width="609"
|
inkscape:window-width="2560"
|
||||||
inkscape:window-height="501"
|
inkscape:window-height="1375"
|
||||||
inkscape:window-x="0"
|
inkscape:window-x="0"
|
||||||
inkscape:window-y="26"
|
inkscape:window-y="27"
|
||||||
inkscape:window-maximized="0" />
|
inkscape:window-maximized="1"
|
||||||
|
borderlayer="true"
|
||||||
|
inkscape:showpageshadow="false"
|
||||||
|
inkscape:snap-nodes="false"
|
||||||
|
inkscape:snap-bbox="true"
|
||||||
|
showborder="false">
|
||||||
|
<inkscape:grid
|
||||||
|
type="xygrid"
|
||||||
|
id="grid12954"
|
||||||
|
empspacing="5"
|
||||||
|
visible="true"
|
||||||
|
enabled="true"
|
||||||
|
snapvisiblegridlinesonly="true" />
|
||||||
|
</sodipodi:namedview>
|
||||||
<metadata
|
<metadata
|
||||||
id="metadata3278">
|
id="metadata2862">
|
||||||
<rdf:RDF>
|
<rdf:RDF>
|
||||||
<cc:Work
|
<cc:Work
|
||||||
rdf:about="">
|
rdf:about="">
|
||||||
@ -66,61 +142,68 @@
|
|||||||
inkscape:label="Layer 1"
|
inkscape:label="Layer 1"
|
||||||
inkscape:groupmode="layer"
|
inkscape:groupmode="layer"
|
||||||
id="layer1"
|
id="layer1"
|
||||||
transform="translate(-343,-521.36218)">
|
transform="translate(-444.64286,-781.36218)">
|
||||||
<g
|
<g
|
||||||
id="g17454"
|
transform="matrix(0.6526046,0,0,0.80554422,99.592644,-636.32172)"
|
||||||
transform="translate(-453,448.36218)"
|
id="g37994">
|
||||||
style="display:inline">
|
|
||||||
<rect
|
|
||||||
transform="scale(-1,1)"
|
|
||||||
ry="4"
|
|
||||||
rx="4"
|
|
||||||
y="74.5"
|
|
||||||
x="-859.5"
|
|
||||||
height="19"
|
|
||||||
width="63.000004"
|
|
||||||
id="rect17456"
|
|
||||||
style="color:#000000;fill:none;stroke:#2e3436;stroke-width:0.99999994;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" />
|
|
||||||
<rect
|
|
||||||
transform="scale(-1,1)"
|
|
||||||
ry="4"
|
|
||||||
rx="4"
|
|
||||||
y="74"
|
|
||||||
x="-828"
|
|
||||||
height="20"
|
|
||||||
width="31"
|
|
||||||
id="rect17458"
|
|
||||||
style="fill:#000000;fill-opacity:1;stroke:#5f5f5f;stroke-width:2;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline" />
|
|
||||||
<g
|
<g
|
||||||
transform="matrix(-1,0,0,1,1619.1239,-33.986291)"
|
id="g37996"
|
||||||
id="g17460"
|
transform="translate(-115,1277)">
|
||||||
style="display:inline">
|
<rect
|
||||||
<path
|
style="color:#000000;fill:none;stroke:#ffffff;stroke-width:1.37920964000000001;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;opacity:0.19591837"
|
||||||
style="fill:none;stroke:#5f5f5f;stroke-width:1px;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1"
|
id="rect13475"
|
||||||
d="m 803.6322,115.48629 0,4.29495"
|
width="98"
|
||||||
id="path17462"
|
height="25"
|
||||||
inkscape:connector-curvature="0" />
|
x="644.5"
|
||||||
<path
|
y="484.61118"
|
||||||
style="fill:none;stroke:#5f5f5f;stroke-width:1px;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1;display:inline"
|
rx="4.7429576"
|
||||||
d="m 806.62805,115.48629 0,4.29495"
|
ry="3.8424656" />
|
||||||
id="path17464"
|
<rect
|
||||||
inkscape:connector-curvature="0" />
|
ry="3.8424656"
|
||||||
<path
|
rx="4.7429576"
|
||||||
style="fill:none;stroke:#5f5f5f;stroke-width:1px;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1;display:inline"
|
y="483.5"
|
||||||
d="m 809.6239,115.48629 0,4.29495"
|
x="644.5"
|
||||||
id="path17466"
|
height="25"
|
||||||
inkscape:connector-curvature="0" />
|
width="98"
|
||||||
|
id="rect38000"
|
||||||
|
style="color:#000000;fill:url(#linearGradient12311-3-1-0-5-4);fill-opacity:1;fill-rule:nonzero;stroke:#16191a;stroke-width:1.37920942;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:new" />
|
||||||
|
</g>
|
||||||
|
<g
|
||||||
|
transform="translate(-49.946213,-1.890275)"
|
||||||
|
id="g38002">
|
||||||
|
<g
|
||||||
|
transform="translate(-115,1247)"
|
||||||
|
style="display:inline"
|
||||||
|
id="g38004">
|
||||||
|
<rect
|
||||||
|
ry="3.7972314"
|
||||||
|
rx="4.6871223"
|
||||||
|
y="515.5"
|
||||||
|
x="694.53046"
|
||||||
|
height="25"
|
||||||
|
width="45.969578"
|
||||||
|
id="rect38006"
|
||||||
|
style="color:#000000;fill:url(#linearGradient38024);fill-opacity:1;fill-rule:nonzero;stroke:#1f2020;stroke-width:1.37920964;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" />
|
||||||
|
<path
|
||||||
|
sodipodi:nodetypes="cc"
|
||||||
|
style="opacity:0.1;color:#000000;fill:none;stroke:#ffffff;stroke-width:1.37920964px;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
||||||
|
d="m 699.09675,516.7365 36.86904,0"
|
||||||
|
id="path38016"
|
||||||
|
inkscape:path-effect="#path-effect77541-4"
|
||||||
|
inkscape:original-d="m 699.09675,516.7365 36.86904,0"
|
||||||
|
inkscape:connector-curvature="0" />
|
||||||
|
</g>
|
||||||
</g>
|
</g>
|
||||||
<path
|
<path
|
||||||
sodipodi:type="arc"
|
sodipodi:type="arc"
|
||||||
style="color:#000000;fill:none;stroke:#ffffff;stroke-width:1.96875012;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
style="color:#000000;fill:none;stroke:#ffffff;stroke-width:2.15627193;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:new"
|
||||||
id="path18722"
|
id="path13479"
|
||||||
sodipodi:cx="47.6875"
|
sodipodi:cx="16.4375"
|
||||||
sodipodi:cy="11.5625"
|
sodipodi:cy="10.8125"
|
||||||
sodipodi:rx="3.9375"
|
sodipodi:rx="4.3125"
|
||||||
sodipodi:ry="3.9375"
|
sodipodi:ry="4.3125"
|
||||||
d="m 51.625,11.5625 c 0,2.174621 -1.762879,3.9375 -3.9375,3.9375 -2.174621,0 -3.9375,-1.762879 -3.9375,-3.9375 0,-2.1746212 1.762879,-3.9375 3.9375,-3.9375 2.174621,0 3.9375,1.7628788 3.9375,3.9375 z"
|
d="m 20.75,10.8125 a 4.3125,4.3125 0 1 1 -8.625,0 4.3125,4.3125 0 1 1 8.625,0 z"
|
||||||
transform="matrix(1.0158729,0,0,1.0158729,795.55556,72.25399)" />
|
transform="matrix(1.4212691,0,0,1.1514287,577.38488,1761.1138)" />
|
||||||
</g>
|
</g>
|
||||||
</g>
|
</g>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 4.7 KiB After Width: | Height: | Size: 7.5 KiB |
@ -7,51 +7,171 @@
|
|||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
xmlns="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:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
width="65"
|
width="65"
|
||||||
height="22"
|
height="22"
|
||||||
id="svg3012"
|
id="svg2857"
|
||||||
version="1.1"
|
version="1.1"
|
||||||
inkscape:version="0.47 r22583"
|
inkscape:version="0.48.5 r10040"
|
||||||
sodipodi:docname="New document 6">
|
sodipodi:docname="toggle-on-intl.svg">
|
||||||
<defs
|
<defs
|
||||||
id="defs3014">
|
id="defs2859">
|
||||||
<inkscape:perspective
|
<inkscape:perspective
|
||||||
sodipodi:type="inkscape:persp3d"
|
sodipodi:type="inkscape:persp3d"
|
||||||
inkscape:vp_x="0 : 526.18109 : 1"
|
inkscape:vp_x="0 : 526.18109 : 1"
|
||||||
inkscape:vp_y="0 : 1000 : 0"
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
inkscape:vp_z="744.09448 : 526.18109 : 1"
|
inkscape:vp_z="744.09448 : 526.18109 : 1"
|
||||||
inkscape:persp3d-origin="372.04724 : 350.78739 : 1"
|
inkscape:persp3d-origin="372.04724 : 350.78739 : 1"
|
||||||
id="perspective3020" />
|
id="perspective2865" />
|
||||||
<inkscape:perspective
|
<inkscape:perspective
|
||||||
id="perspective2997"
|
id="perspective2843"
|
||||||
inkscape:persp3d-origin="0.5 : 0.33333333 : 1"
|
inkscape:persp3d-origin="0.5 : 0.33333333 : 1"
|
||||||
inkscape:vp_z="1 : 0.5 : 1"
|
inkscape:vp_z="1 : 0.5 : 1"
|
||||||
inkscape:vp_y="0 : 1000 : 0"
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
inkscape:vp_x="0 : 0.5 : 1"
|
inkscape:vp_x="0 : 0.5 : 1"
|
||||||
sodipodi:type="inkscape:persp3d" />
|
sodipodi:type="inkscape:persp3d" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient76469-7-7-4"
|
||||||
|
id="linearGradient38024"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.0215462,0,0,1.0322581,717.22867,428.68472)"
|
||||||
|
x1="6"
|
||||||
|
y1="102.95528"
|
||||||
|
x2="6"
|
||||||
|
y2="84.505203" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
id="linearGradient76469-7-7-4">
|
||||||
|
<stop
|
||||||
|
style="stop-color:#2e3232;stop-opacity:1"
|
||||||
|
offset="0"
|
||||||
|
id="stop76471-7-1-5" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#3e4545;stop-opacity:1"
|
||||||
|
offset="1"
|
||||||
|
id="stop76473-9-0-0" />
|
||||||
|
</linearGradient>
|
||||||
|
<inkscape:path-effect
|
||||||
|
effect="spiro"
|
||||||
|
id="path-effect77541-4"
|
||||||
|
is_visible="true" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient37802"
|
||||||
|
id="linearGradient12311-3-1-0-5"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.5918367,0,0,0.85714285,-256.56122,59.071426)"
|
||||||
|
x1="610.13782"
|
||||||
|
y1="501.43866"
|
||||||
|
x2="610.13782"
|
||||||
|
y2="492.52756" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient37802"
|
||||||
|
inkscape:collect="always">
|
||||||
|
<stop
|
||||||
|
id="stop37804"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#2c2c2c;stop-opacity:1" />
|
||||||
|
<stop
|
||||||
|
id="stop37806"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#16191a;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient76469-7-7-4-3"
|
||||||
|
id="linearGradient77680"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1,0,0,1.0322581,717.71949,428.68472)"
|
||||||
|
x1="6"
|
||||||
|
y1="102.95528"
|
||||||
|
x2="6"
|
||||||
|
y2="84.505203" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
id="linearGradient76469-7-7-4-3">
|
||||||
|
<stop
|
||||||
|
style="stop-color:#2e3232;stop-opacity:1"
|
||||||
|
offset="0"
|
||||||
|
id="stop76471-7-1-5-7" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#3e4545;stop-opacity:1"
|
||||||
|
offset="1"
|
||||||
|
id="stop76473-9-0-0-9" />
|
||||||
|
</linearGradient>
|
||||||
|
<inkscape:path-effect
|
||||||
|
effect="spiro"
|
||||||
|
id="path-effect77541-4-0"
|
||||||
|
is_visible="true" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient37802-8"
|
||||||
|
id="linearGradient12311-3-1-0-5-4"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.5918367,0,0,0.85714285,-256.56122,59.071426)"
|
||||||
|
x1="610.13782"
|
||||||
|
y1="501.43866"
|
||||||
|
x2="610.13782"
|
||||||
|
y2="492.52756" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient37802-8"
|
||||||
|
inkscape:collect="always">
|
||||||
|
<stop
|
||||||
|
id="stop37804-1"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#2c2c2c;stop-opacity:1" />
|
||||||
|
<stop
|
||||||
|
id="stop37806-8"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#16191a;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<linearGradient
|
||||||
|
y2="492.52756"
|
||||||
|
x2="610.13782"
|
||||||
|
y1="501.43866"
|
||||||
|
x1="610.13782"
|
||||||
|
gradientTransform="matrix(1.5918367,0,0,0.85714285,-900.56122,-423.92857)"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
id="linearGradient13602"
|
||||||
|
xlink:href="#linearGradient37802-8"
|
||||||
|
inkscape:collect="always" />
|
||||||
</defs>
|
</defs>
|
||||||
<sodipodi:namedview
|
<sodipodi:namedview
|
||||||
id="base"
|
id="base"
|
||||||
pagecolor="#ffffff"
|
pagecolor="#000000"
|
||||||
bordercolor="#666666"
|
bordercolor="#666666"
|
||||||
borderopacity="1.0"
|
borderopacity="1.0"
|
||||||
inkscape:pageopacity="0.0"
|
inkscape:pageopacity="1"
|
||||||
inkscape:pageshadow="2"
|
inkscape:pageshadow="2"
|
||||||
inkscape:zoom="0.35"
|
inkscape:zoom="1"
|
||||||
inkscape:cx="32.000004"
|
inkscape:cx="16.760995"
|
||||||
inkscape:cy="10.999997"
|
inkscape:cy="21.955673"
|
||||||
inkscape:document-units="px"
|
inkscape:document-units="px"
|
||||||
inkscape:current-layer="layer1"
|
inkscape:current-layer="g37994"
|
||||||
showgrid="false"
|
showgrid="false"
|
||||||
inkscape:window-width="609"
|
inkscape:window-width="2560"
|
||||||
inkscape:window-height="501"
|
inkscape:window-height="1375"
|
||||||
inkscape:window-x="0"
|
inkscape:window-x="0"
|
||||||
inkscape:window-y="26"
|
inkscape:window-y="27"
|
||||||
inkscape:window-maximized="0" />
|
inkscape:window-maximized="1"
|
||||||
|
borderlayer="true"
|
||||||
|
inkscape:showpageshadow="false"
|
||||||
|
inkscape:snap-nodes="false"
|
||||||
|
inkscape:snap-bbox="true"
|
||||||
|
showborder="false">
|
||||||
|
<inkscape:grid
|
||||||
|
type="xygrid"
|
||||||
|
id="grid12954"
|
||||||
|
empspacing="5"
|
||||||
|
visible="true"
|
||||||
|
enabled="true"
|
||||||
|
snapvisiblegridlinesonly="true" />
|
||||||
|
</sodipodi:namedview>
|
||||||
<metadata
|
<metadata
|
||||||
id="metadata3017">
|
id="metadata2862">
|
||||||
<rdf:RDF>
|
<rdf:RDF>
|
||||||
<cc:Work
|
<cc:Work
|
||||||
rdf:about="">
|
rdf:about="">
|
||||||
@ -66,73 +186,70 @@
|
|||||||
inkscape:label="Layer 1"
|
inkscape:label="Layer 1"
|
||||||
inkscape:groupmode="layer"
|
inkscape:groupmode="layer"
|
||||||
id="layer1"
|
id="layer1"
|
||||||
transform="translate(-343,-521.36218)">
|
transform="translate(-444.64286,-781.36218)">
|
||||||
<g
|
<g
|
||||||
id="g17454"
|
transform="matrix(0.6526046,0,0,0.80554422,99.592644,-636.32172)"
|
||||||
transform="translate(-453,448.36218)"
|
id="g37994">
|
||||||
style="display:inline">
|
|
||||||
<rect
|
|
||||||
transform="scale(-1,1)"
|
|
||||||
ry="4"
|
|
||||||
rx="4"
|
|
||||||
y="74.5"
|
|
||||||
x="-859.5"
|
|
||||||
height="19"
|
|
||||||
width="63.000004"
|
|
||||||
id="rect17456"
|
|
||||||
style="color:#000000;fill:none;stroke:#2e3436;stroke-width:0.99999994;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" />
|
|
||||||
<rect
|
|
||||||
transform="scale(-1,1)"
|
|
||||||
ry="4"
|
|
||||||
rx="4"
|
|
||||||
y="74"
|
|
||||||
x="-828"
|
|
||||||
height="20"
|
|
||||||
width="31"
|
|
||||||
id="rect17458"
|
|
||||||
style="fill:#000000;fill-opacity:1;stroke:#5f5f5f;stroke-width:2;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline" />
|
|
||||||
<g
|
<g
|
||||||
transform="matrix(-1,0,0,1,1619.1239,-33.986291)"
|
id="g37996"
|
||||||
id="g17460"
|
transform="translate(-115,1277)">
|
||||||
style="display:inline">
|
<rect
|
||||||
<path
|
style="color:#000000;fill:none;stroke:#ffffff;stroke-width:1.37920964000000001;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;opacity:0.19591837"
|
||||||
style="fill:none;stroke:#5f5f5f;stroke-width:1px;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1"
|
id="rect13475"
|
||||||
d="m 803.6322,115.48629 0,4.29495"
|
width="98"
|
||||||
id="path17462"
|
height="25"
|
||||||
inkscape:connector-curvature="0" />
|
x="644.5"
|
||||||
<path
|
y="484.61118"
|
||||||
style="fill:none;stroke:#5f5f5f;stroke-width:1px;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1;display:inline"
|
rx="4.7429576"
|
||||||
d="m 806.62805,115.48629 0,4.29495"
|
ry="3.8424656" />
|
||||||
id="path17464"
|
<rect
|
||||||
inkscape:connector-curvature="0" />
|
ry="3.8424656"
|
||||||
<path
|
rx="4.7429576"
|
||||||
style="fill:none;stroke:#5f5f5f;stroke-width:1px;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1;display:inline"
|
y="483.5"
|
||||||
d="m 809.6239,115.48629 0,4.29495"
|
x="644.5"
|
||||||
id="path17466"
|
height="25"
|
||||||
inkscape:connector-curvature="0" />
|
width="98"
|
||||||
|
id="rect38000"
|
||||||
|
style="color:#000000;fill:url(#linearGradient12311-3-1-0-5-4);fill-opacity:1;fill-rule:nonzero;stroke:#16191a;stroke-width:1.37920942;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:new" />
|
||||||
</g>
|
</g>
|
||||||
<g
|
<g
|
||||||
style="font-size:8.95877075px;font-style:normal;font-variant:normal;font-weight:bold;font-stretch:normal;text-indent:0;text-align:start;text-decoration:none;line-height:125%;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;block-progression:tb;writing-mode:lr-tb;text-anchor:start;color:#000000;fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1px;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;font-family:Cantarell;-inkscape-font-specification:Cantarell Bold"
|
transform="translate(-49.946213,-1.890275)"
|
||||||
id="text17468"
|
id="g38002">
|
||||||
transform="translate(0.34375,0)">
|
<g
|
||||||
<path
|
transform="translate(-115,1247)"
|
||||||
d="m 837.28518,80.750726 c 0.63282,6e-6 1.19566,0.123947 1.68852,0.371824 0.49284,0.247888 0.8807,0.609505 1.16359,1.084851 0.28287,0.472439 0.42431,1.022155 0.42431,1.649149 0,0.635748 -0.13853,1.200045 -0.41556,1.692892 -0.27706,0.489934 -0.66638,0.870507 -1.16797,1.141719 -0.5016,0.271213 -1.07756,0.406819 -1.72789,0.406819 -0.42869,0 -0.83551,-0.06562 -1.22045,-0.196848 -0.38495,-0.134148 -0.73053,-0.32808 -1.03674,-0.581795 -0.30329,-0.256631 -0.54534,-0.589085 -0.72615,-0.997363 -0.17789,-0.408276 -0.26684,-0.869045 -0.26683,-1.382311 -10e-6,-0.638658 0.13997,-1.200039 0.41994,-1.684144 0.27996,-0.487011 0.66782,-0.858835 1.16359,-1.115472 0.49576,-0.259541 1.06297,-0.389315 1.70164,-0.389321 m 0.57305,1.089225 c -0.20123,-0.05249 -0.40683,-0.07873 -0.61679,-0.07874 -0.20998,5e-6 -0.41412,0.02625 -0.61242,0.07874 -0.19831,0.04958 -0.38933,0.129779 -0.57305,0.240592 -0.18081,0.107907 -0.33974,0.242055 -0.47681,0.402445 -0.13706,0.160399 -0.24642,0.358705 -0.32808,0.594918 -0.0816,0.233306 -0.12248,0.491395 -0.12248,0.774269 0,0.67366 0.20851,1.214627 0.62554,1.622903 0.41702,0.408278 0.93758,0.612416 1.56166,0.612416 0.25954,0 0.51034,-0.04229 0.7524,-0.126858 0.24496,-0.08457 0.47097,-0.20997 0.67803,-0.376198 0.20705,-0.166226 0.37328,-0.392236 0.49868,-0.678032 0.12539,-0.285792 0.18809,-0.610956 0.1881,-0.975492 -10e-6,-0.297455 -0.0437,-0.568668 -0.13123,-0.813638 -0.0875,-0.247878 -0.20415,-0.453475 -0.34995,-0.61679 -0.14291,-0.163307 -0.31059,-0.301829 -0.50306,-0.415568 -0.18956,-0.11373 -0.38641,-0.195385 -0.59054,-0.244967"
|
style="display:inline"
|
||||||
style="line-height:125%;fill:#ffffff;fill-opacity:1;marker:none;font-family:Cantarell;-inkscape-font-specification:Cantarell Bold"
|
id="g38004">
|
||||||
id="path18599"
|
<rect
|
||||||
inkscape:connector-curvature="0" />
|
ry="3.7972314"
|
||||||
<path
|
rx="4.6871223"
|
||||||
d="m 843.5362,81.831203 0,1.17917 2.94834,0 0,1.014861 -2.94834,0 0,3.00713 -1.10673,0 0,-6.216022 4.31754,0 0,1.014861 -3.21081,0"
|
y="515.5"
|
||||||
style="line-height:125%;fill:#ffffff;fill-opacity:1;marker:none;font-family:Cantarell;-inkscape-font-specification:Cantarell Bold"
|
x="694.53046"
|
||||||
id="path18601"
|
height="25"
|
||||||
inkscape:connector-curvature="0"
|
width="45.969578"
|
||||||
sodipodi:nodetypes="ccccccccccc" />
|
id="rect38006"
|
||||||
<path
|
style="color:#000000;fill:url(#linearGradient38024);fill-opacity:1;fill-rule:nonzero;stroke:#1f2020;stroke-width:1.37920964;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" />
|
||||||
d="m 849.71285,81.831203 0,1.17917 2.94834,0 0,1.014861 -2.94834,0 0,3.00713 -1.10672,0 0,-6.216022 4.31753,0 0,1.014861 -3.21081,0"
|
<path
|
||||||
style="line-height:125%;fill:#ffffff;fill-opacity:1;marker:none;font-family:Cantarell;-inkscape-font-specification:Cantarell Bold"
|
sodipodi:nodetypes="cc"
|
||||||
id="path18603"
|
style="opacity:0.1;color:#000000;fill:none;stroke:#ffffff;stroke-width:1.37920964px;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
||||||
inkscape:connector-curvature="0"
|
d="m 699.09675,516.7365 36.86904,0"
|
||||||
sodipodi:nodetypes="ccccccccccc" />
|
id="path38016"
|
||||||
|
inkscape:path-effect="#path-effect77541-4"
|
||||||
|
inkscape:original-d="m 699.09675,516.7365 36.86904,0"
|
||||||
|
inkscape:connector-curvature="0" />
|
||||||
|
</g>
|
||||||
</g>
|
</g>
|
||||||
|
<text
|
||||||
|
xml:space="preserve"
|
||||||
|
style="font-size:13.79166794px;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;font-family:Cantarell;-inkscape-font-specification:Cantarell Bold"
|
||||||
|
x="520.29974"
|
||||||
|
y="1997.0011"
|
||||||
|
id="text75614"
|
||||||
|
sodipodi:linespacing="125%"
|
||||||
|
transform="scale(1.1236771,0.88993537)"><tspan
|
||||||
|
sodipodi:role="line"
|
||||||
|
id="tspan75616"
|
||||||
|
x="520.29974"
|
||||||
|
y="1997.0011">OFF</tspan></text>
|
||||||
</g>
|
</g>
|
||||||
</g>
|
</g>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 7.2 KiB After Width: | Height: | Size: 8.8 KiB |
@ -7,51 +7,113 @@
|
|||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
xmlns="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:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
width="65"
|
width="65"
|
||||||
height="22"
|
height="22"
|
||||||
id="svg3199"
|
id="svg2857"
|
||||||
version="1.1"
|
version="1.1"
|
||||||
inkscape:version="0.48.1 r9760"
|
inkscape:version="0.48.5 r10040"
|
||||||
sodipodi:docname="toggle-on-intl.svg">
|
sodipodi:docname="toggle-on-intl.svg">
|
||||||
<defs
|
<defs
|
||||||
id="defs3201">
|
id="defs2859">
|
||||||
<inkscape:perspective
|
<inkscape:perspective
|
||||||
sodipodi:type="inkscape:persp3d"
|
sodipodi:type="inkscape:persp3d"
|
||||||
inkscape:vp_x="0 : 526.18109 : 1"
|
inkscape:vp_x="0 : 526.18109 : 1"
|
||||||
inkscape:vp_y="0 : 1000 : 0"
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
inkscape:vp_z="744.09448 : 526.18109 : 1"
|
inkscape:vp_z="744.09448 : 526.18109 : 1"
|
||||||
inkscape:persp3d-origin="372.04724 : 350.78739 : 1"
|
inkscape:persp3d-origin="372.04724 : 350.78739 : 1"
|
||||||
id="perspective3207" />
|
id="perspective2865" />
|
||||||
<inkscape:perspective
|
<inkscape:perspective
|
||||||
id="perspective3187"
|
id="perspective2843"
|
||||||
inkscape:persp3d-origin="0.5 : 0.33333333 : 1"
|
inkscape:persp3d-origin="0.5 : 0.33333333 : 1"
|
||||||
inkscape:vp_z="1 : 0.5 : 1"
|
inkscape:vp_z="1 : 0.5 : 1"
|
||||||
inkscape:vp_y="0 : 1000 : 0"
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
inkscape:vp_x="0 : 0.5 : 1"
|
inkscape:vp_x="0 : 0.5 : 1"
|
||||||
sodipodi:type="inkscape:persp3d" />
|
sodipodi:type="inkscape:persp3d" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient77461"
|
||||||
|
id="linearGradient77551"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.3066667,0,0,1,-841.64667,-483)"
|
||||||
|
x1="1164.7644"
|
||||||
|
y1="962.93695"
|
||||||
|
x2="1164.7644"
|
||||||
|
y2="970.51404" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient77461"
|
||||||
|
inkscape:collect="always">
|
||||||
|
<stop
|
||||||
|
id="stop77463"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#182f4c;stop-opacity:1" />
|
||||||
|
<stop
|
||||||
|
id="stop77465"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#204a87;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient76469-7-7-4"
|
||||||
|
id="linearGradient38024"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.0215462,0,0,1.0322581,717.22867,428.68472)"
|
||||||
|
x1="6"
|
||||||
|
y1="102.95528"
|
||||||
|
x2="6"
|
||||||
|
y2="84.505203" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
id="linearGradient76469-7-7-4">
|
||||||
|
<stop
|
||||||
|
style="stop-color:#2e3232;stop-opacity:1"
|
||||||
|
offset="0"
|
||||||
|
id="stop76471-7-1-5" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#3e4545;stop-opacity:1"
|
||||||
|
offset="1"
|
||||||
|
id="stop76473-9-0-0" />
|
||||||
|
</linearGradient>
|
||||||
|
<inkscape:path-effect
|
||||||
|
effect="spiro"
|
||||||
|
id="path-effect77541-4"
|
||||||
|
is_visible="true" />
|
||||||
</defs>
|
</defs>
|
||||||
<sodipodi:namedview
|
<sodipodi:namedview
|
||||||
id="base"
|
id="base"
|
||||||
pagecolor="#ffffff"
|
pagecolor="#000000"
|
||||||
bordercolor="#666666"
|
bordercolor="#666666"
|
||||||
borderopacity="1.0"
|
borderopacity="1.0"
|
||||||
inkscape:pageopacity="0.0"
|
inkscape:pageopacity="1"
|
||||||
inkscape:pageshadow="2"
|
inkscape:pageshadow="2"
|
||||||
inkscape:zoom="1"
|
inkscape:zoom="32"
|
||||||
inkscape:cx="49.147112"
|
inkscape:cx="17.255148"
|
||||||
inkscape:cy="17.532036"
|
inkscape:cy="8.9252639"
|
||||||
inkscape:document-units="px"
|
inkscape:document-units="px"
|
||||||
inkscape:current-layer="layer1"
|
inkscape:current-layer="g37994"
|
||||||
showgrid="false"
|
showgrid="true"
|
||||||
inkscape:window-width="1412"
|
inkscape:window-width="2560"
|
||||||
inkscape:window-height="1067"
|
inkscape:window-height="1375"
|
||||||
inkscape:window-x="0"
|
inkscape:window-x="0"
|
||||||
inkscape:window-y="26"
|
inkscape:window-y="27"
|
||||||
inkscape:window-maximized="0" />
|
inkscape:window-maximized="1"
|
||||||
|
borderlayer="true"
|
||||||
|
inkscape:showpageshadow="false"
|
||||||
|
inkscape:snap-nodes="false"
|
||||||
|
inkscape:snap-bbox="true"
|
||||||
|
showborder="false">
|
||||||
|
<inkscape:grid
|
||||||
|
type="xygrid"
|
||||||
|
id="grid12954"
|
||||||
|
empspacing="5"
|
||||||
|
visible="true"
|
||||||
|
enabled="true"
|
||||||
|
snapvisiblegridlinesonly="true" />
|
||||||
|
</sodipodi:namedview>
|
||||||
<metadata
|
<metadata
|
||||||
id="metadata3204">
|
id="metadata2862">
|
||||||
<rdf:RDF>
|
<rdf:RDF>
|
||||||
<cc:Work
|
<cc:Work
|
||||||
rdf:about="">
|
rdf:about="">
|
||||||
@ -66,57 +128,65 @@
|
|||||||
inkscape:label="Layer 1"
|
inkscape:label="Layer 1"
|
||||||
inkscape:groupmode="layer"
|
inkscape:groupmode="layer"
|
||||||
id="layer1"
|
id="layer1"
|
||||||
transform="translate(-342.5,-521.36218)">
|
transform="translate(-444.64286,-781.36218)">
|
||||||
<g
|
<g
|
||||||
style="display:inline"
|
transform="matrix(0.6526046,0,0,0.80554422,99.592644,-636.32172)"
|
||||||
transform="translate(-453.5,448.36218)"
|
id="g37994">
|
||||||
id="g16453">
|
|
||||||
<rect
|
|
||||||
style="color:#000000;fill:#4a90d9;fill-opacity:1;fill-rule:nonzero;stroke:#3465a4;stroke-width:0.99999994000000003;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
|
||||||
id="rect16256-9-4"
|
|
||||||
width="63.000004"
|
|
||||||
height="19"
|
|
||||||
x="-859.5"
|
|
||||||
y="74.5"
|
|
||||||
rx="4"
|
|
||||||
ry="4"
|
|
||||||
transform="scale(-1,1)" />
|
|
||||||
<rect
|
|
||||||
style="fill:#000000;fill-opacity:1;stroke:#5f5f5f;stroke-width:2;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
|
|
||||||
id="rect16258-5-4"
|
|
||||||
width="31"
|
|
||||||
height="20"
|
|
||||||
x="-860"
|
|
||||||
y="74"
|
|
||||||
rx="4"
|
|
||||||
ry="4"
|
|
||||||
transform="scale(-1,1)" />
|
|
||||||
<g
|
<g
|
||||||
style="display:inline"
|
id="g37996"
|
||||||
id="g16298-3-6"
|
transform="translate(-115,1277)">
|
||||||
transform="matrix(-1,0,0,1,1651.1322,-33.986291)">
|
<rect
|
||||||
<path
|
style="color:#000000;fill:none;stroke:#ffffff;stroke-width:1.37920964000000001;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;opacity:0.19591837"
|
||||||
inkscape:connector-curvature="0"
|
id="rect13475"
|
||||||
id="path16265-3-5"
|
width="98"
|
||||||
d="m 803.6322,115.48629 0,4.29495"
|
height="25"
|
||||||
style="fill:none;stroke:#5f5f5f;stroke-width:1px;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1" />
|
x="644.5"
|
||||||
<path
|
y="484.61118"
|
||||||
inkscape:connector-curvature="0"
|
rx="4.7429576"
|
||||||
id="path16265-0-2-0"
|
ry="3.8424656" />
|
||||||
d="m 806.62805,115.48629 0,4.29495"
|
<rect
|
||||||
style="fill:none;stroke:#5f5f5f;stroke-width:1px;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1;display:inline" />
|
ry="3.8424656"
|
||||||
<path
|
rx="4.7429576"
|
||||||
inkscape:connector-curvature="0"
|
y="483.5"
|
||||||
id="path16265-8-7-1"
|
x="644.5"
|
||||||
d="m 809.6239,115.48629 0,4.29495"
|
height="25"
|
||||||
style="fill:none;stroke:#5f5f5f;stroke-width:1px;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1;display:inline" />
|
width="98"
|
||||||
|
id="rect38000"
|
||||||
|
style="color:#000000;fill:url(#linearGradient77551);fill-opacity:1;fill-rule:nonzero;stroke:#182f4c;stroke-width:1.37920964;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" />
|
||||||
</g>
|
</g>
|
||||||
<path
|
<g
|
||||||
style="color:#000000;fill:#eeeeec;fill-opacity:1;fill-rule:nonzero;stroke:#ffffff;stroke-width:2;stroke-linecap:square;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
transform="translate(2.0625,-2)"
|
||||||
d="m 16,27.9375 0,10.125"
|
id="g38002">
|
||||||
id="path19232"
|
<g
|
||||||
inkscape:connector-curvature="0"
|
transform="translate(-115,1247)"
|
||||||
transform="translate(796,51.00002)" />
|
style="display:inline"
|
||||||
|
id="g38004">
|
||||||
|
<rect
|
||||||
|
ry="3.7972314"
|
||||||
|
rx="4.6871223"
|
||||||
|
y="515.5"
|
||||||
|
x="694.53046"
|
||||||
|
height="25"
|
||||||
|
width="45.969578"
|
||||||
|
id="rect38006"
|
||||||
|
style="color:#000000;fill:url(#linearGradient38024);fill-opacity:1;fill-rule:nonzero;stroke:#1f2020;stroke-width:1.37920964;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" />
|
||||||
|
<path
|
||||||
|
sodipodi:nodetypes="cc"
|
||||||
|
style="opacity:0.1;color:#000000;fill:none;stroke:#ffffff;stroke-width:1.37920964px;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
||||||
|
d="m 699.09675,516.7365 36.86904,0"
|
||||||
|
id="path38016"
|
||||||
|
inkscape:path-effect="#path-effect77541-4"
|
||||||
|
inkscape:original-d="m 699.09675,516.7365 36.86904,0"
|
||||||
|
inkscape:connector-curvature="0" />
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
<rect
|
||||||
|
style="color:#000000;fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.99999994;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:new"
|
||||||
|
id="rect13678"
|
||||||
|
width="3.0646207"
|
||||||
|
height="12.414008"
|
||||||
|
x="554.77728"
|
||||||
|
y="1767.3566" />
|
||||||
</g>
|
</g>
|
||||||
</g>
|
</g>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 4.5 KiB After Width: | Height: | Size: 6.8 KiB |
@ -7,13 +7,14 @@
|
|||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
xmlns="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:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
width="65"
|
width="65"
|
||||||
height="22"
|
height="22"
|
||||||
id="svg2857"
|
id="svg2857"
|
||||||
version="1.1"
|
version="1.1"
|
||||||
inkscape:version="0.48.1 r9760"
|
inkscape:version="0.48.5 r10040"
|
||||||
sodipodi:docname="toggle-on-us.svg">
|
sodipodi:docname="toggle-on-us.svg">
|
||||||
<defs
|
<defs
|
||||||
id="defs2859">
|
id="defs2859">
|
||||||
@ -31,27 +32,86 @@
|
|||||||
inkscape:vp_y="0 : 1000 : 0"
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
inkscape:vp_x="0 : 0.5 : 1"
|
inkscape:vp_x="0 : 0.5 : 1"
|
||||||
sodipodi:type="inkscape:persp3d" />
|
sodipodi:type="inkscape:persp3d" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient77461"
|
||||||
|
id="linearGradient77551"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.3066667,0,0,1,-841.64667,-483)"
|
||||||
|
x1="1164.7644"
|
||||||
|
y1="962.93695"
|
||||||
|
x2="1164.7644"
|
||||||
|
y2="970.51404" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient77461"
|
||||||
|
inkscape:collect="always">
|
||||||
|
<stop
|
||||||
|
id="stop77463"
|
||||||
|
offset="0"
|
||||||
|
style="stop-color:#182f4c;stop-opacity:1" />
|
||||||
|
<stop
|
||||||
|
id="stop77465"
|
||||||
|
offset="1"
|
||||||
|
style="stop-color:#204a87;stop-opacity:1" />
|
||||||
|
</linearGradient>
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient76469-7-7-4"
|
||||||
|
id="linearGradient38024"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.0215462,0,0,1.0322581,717.22867,428.68472)"
|
||||||
|
x1="6"
|
||||||
|
y1="102.95528"
|
||||||
|
x2="6"
|
||||||
|
y2="84.505203" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
id="linearGradient76469-7-7-4">
|
||||||
|
<stop
|
||||||
|
style="stop-color:#2e3232;stop-opacity:1"
|
||||||
|
offset="0"
|
||||||
|
id="stop76471-7-1-5" />
|
||||||
|
<stop
|
||||||
|
style="stop-color:#3e4545;stop-opacity:1"
|
||||||
|
offset="1"
|
||||||
|
id="stop76473-9-0-0" />
|
||||||
|
</linearGradient>
|
||||||
|
<inkscape:path-effect
|
||||||
|
effect="spiro"
|
||||||
|
id="path-effect77541-4"
|
||||||
|
is_visible="true" />
|
||||||
</defs>
|
</defs>
|
||||||
<sodipodi:namedview
|
<sodipodi:namedview
|
||||||
id="base"
|
id="base"
|
||||||
pagecolor="#ffffff"
|
pagecolor="#000000"
|
||||||
bordercolor="#666666"
|
bordercolor="#666666"
|
||||||
borderopacity="1.0"
|
borderopacity="1.0"
|
||||||
inkscape:pageopacity="0.0"
|
inkscape:pageopacity="1"
|
||||||
inkscape:pageshadow="2"
|
inkscape:pageshadow="2"
|
||||||
inkscape:zoom="1"
|
inkscape:zoom="1"
|
||||||
inkscape:cx="19.689855"
|
inkscape:cx="33.380898"
|
||||||
inkscape:cy="2.0517979"
|
inkscape:cy="6.9658271"
|
||||||
inkscape:document-units="px"
|
inkscape:document-units="px"
|
||||||
inkscape:current-layer="layer1"
|
inkscape:current-layer="g37994"
|
||||||
showgrid="false"
|
showgrid="false"
|
||||||
inkscape:window-width="941"
|
inkscape:window-width="2560"
|
||||||
inkscape:window-height="751"
|
inkscape:window-height="1375"
|
||||||
inkscape:window-x="2577"
|
inkscape:window-x="0"
|
||||||
inkscape:window-y="206"
|
inkscape:window-y="27"
|
||||||
inkscape:window-maximized="0"
|
inkscape:window-maximized="1"
|
||||||
borderlayer="true"
|
borderlayer="true"
|
||||||
inkscape:showpageshadow="false" />
|
inkscape:showpageshadow="false"
|
||||||
|
inkscape:snap-nodes="false"
|
||||||
|
inkscape:snap-bbox="true"
|
||||||
|
showborder="false">
|
||||||
|
<inkscape:grid
|
||||||
|
type="xygrid"
|
||||||
|
id="grid12954"
|
||||||
|
empspacing="5"
|
||||||
|
visible="true"
|
||||||
|
enabled="true"
|
||||||
|
snapvisiblegridlinesonly="true" />
|
||||||
|
</sodipodi:namedview>
|
||||||
<metadata
|
<metadata
|
||||||
id="metadata2862">
|
id="metadata2862">
|
||||||
<rdf:RDF>
|
<rdf:RDF>
|
||||||
@ -70,61 +130,68 @@
|
|||||||
id="layer1"
|
id="layer1"
|
||||||
transform="translate(-444.64286,-781.36218)">
|
transform="translate(-444.64286,-781.36218)">
|
||||||
<g
|
<g
|
||||||
style="display:inline"
|
transform="matrix(0.6526046,0,0,0.80554422,99.592644,-636.32172)"
|
||||||
transform="translate(-351.35714,708.36218)"
|
id="g37994">
|
||||||
id="g16453">
|
|
||||||
<rect
|
|
||||||
style="color:#000000;fill:#4a90d9;fill-opacity:1;fill-rule:nonzero;stroke:#3465a4;stroke-width:0.99999994000000003;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
|
||||||
id="rect16256-9-4"
|
|
||||||
width="63.000004"
|
|
||||||
height="19"
|
|
||||||
x="-859.5"
|
|
||||||
y="74.5"
|
|
||||||
rx="4"
|
|
||||||
ry="4"
|
|
||||||
transform="scale(-1,1)" />
|
|
||||||
<rect
|
|
||||||
style="fill:#000000;fill-opacity:1;stroke:#5f5f5f;stroke-width:2;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;display:inline"
|
|
||||||
id="rect16258-5-4"
|
|
||||||
width="31"
|
|
||||||
height="20"
|
|
||||||
x="-860"
|
|
||||||
y="74"
|
|
||||||
rx="4"
|
|
||||||
ry="4"
|
|
||||||
transform="scale(-1,1)" />
|
|
||||||
<g
|
<g
|
||||||
style="display:inline"
|
id="g37996"
|
||||||
id="g16298-3-6"
|
transform="translate(-115,1277)">
|
||||||
transform="matrix(-1,0,0,1,1651.1322,-33.986291)">
|
<rect
|
||||||
<path
|
style="color:#000000;fill:none;stroke:#ffffff;stroke-width:1.37920964000000001;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;opacity:0.19591837"
|
||||||
inkscape:connector-curvature="0"
|
id="rect13475"
|
||||||
id="path16265-3-5"
|
width="98"
|
||||||
d="m 803.6322,115.48629 0,4.29495"
|
height="25"
|
||||||
style="fill:none;stroke:#5f5f5f;stroke-width:1px;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1" />
|
x="644.5"
|
||||||
<path
|
y="484.61118"
|
||||||
inkscape:connector-curvature="0"
|
rx="4.7429576"
|
||||||
id="path16265-0-2-0"
|
ry="3.8424656" />
|
||||||
d="m 806.62805,115.48629 0,4.29495"
|
<rect
|
||||||
style="fill:none;stroke:#5f5f5f;stroke-width:1px;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1;display:inline" />
|
ry="3.8424656"
|
||||||
<path
|
rx="4.7429576"
|
||||||
inkscape:connector-curvature="0"
|
y="483.5"
|
||||||
id="path16265-8-7-1"
|
x="644.5"
|
||||||
d="m 809.6239,115.48629 0,4.29495"
|
height="25"
|
||||||
style="fill:none;stroke:#5f5f5f;stroke-width:1px;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1;display:inline" />
|
width="98"
|
||||||
|
id="rect38000"
|
||||||
|
style="color:#000000;fill:url(#linearGradient77551);fill-opacity:1;fill-rule:nonzero;stroke:#182f4c;stroke-width:1.37920964;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" />
|
||||||
</g>
|
</g>
|
||||||
<g
|
<g
|
||||||
style="font-size:8.95877075px;font-style:normal;font-variant:normal;font-weight:bold;font-stretch:normal;text-indent:0;text-align:start;text-decoration:none;line-height:125%;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;block-progression:tb;writing-mode:lr-tb;text-anchor:start;color:#000000;fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1px;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;font-family:Cantarell;-inkscape-font-specification:Cantarell Bold"
|
transform="translate(2.0625,-2)"
|
||||||
id="text42229-3-0">
|
id="g38002">
|
||||||
<path
|
<g
|
||||||
d="m 808.01473,80.573953 c 0.63283,6e-6 1.19567,0.123947 1.68852,0.371824 0.49284,0.247888 0.88071,0.609505 1.16359,1.084851 0.28287,0.472439 0.42431,1.022155 0.42432,1.649149 -10e-6,0.635748 -0.13853,1.200045 -0.41557,1.692892 -0.27705,0.489934 -0.66637,0.870506 -1.16796,1.141719 -0.50161,0.271212 -1.07757,0.406819 -1.72789,0.406819 -0.4287,0 -0.83552,-0.06562 -1.22046,-0.196848 -0.38495,-0.134148 -0.73053,-0.32808 -1.03673,-0.581795 -0.3033,-0.256631 -0.54535,-0.589085 -0.72615,-0.997363 -0.1779,-0.408276 -0.26684,-0.869045 -0.26684,-1.382311 0,-0.638658 0.13998,-1.200039 0.41994,-1.684144 0.27996,-0.487011 0.66782,-0.858835 1.16359,-1.115472 0.49576,-0.259541 1.06298,-0.389315 1.70164,-0.389321 m 0.57305,1.089225 c -0.20123,-0.05249 -0.40682,-0.07873 -0.61679,-0.07874 -0.20998,5e-6 -0.41411,0.02625 -0.61242,0.07874 -0.19831,0.04958 -0.38932,0.129779 -0.57304,0.240592 -0.18081,0.107907 -0.33975,0.242055 -0.47681,0.402445 -0.13707,0.160399 -0.24643,0.358705 -0.32808,0.594918 -0.0817,0.233305 -0.12249,0.491395 -0.12249,0.774269 0,0.67366 0.20851,1.214627 0.62554,1.622902 0.41703,0.408279 0.93758,0.612417 1.56166,0.612416 0.25955,10e-7 0.51035,-0.04228 0.7524,-0.126857 0.24496,-0.08457 0.47097,-0.20997 0.67803,-0.376199 0.20705,-0.166225 0.37328,-0.392236 0.49868,-0.678031 0.1254,-0.285792 0.1881,-0.610956 0.1881,-0.975492 0,-0.297455 -0.0437,-0.568668 -0.13123,-0.813638 -0.0875,-0.247878 -0.20414,-0.453475 -0.34995,-0.61679 -0.1429,-0.163307 -0.31059,-0.301829 -0.50306,-0.415568 -0.18956,-0.11373 -0.38641,-0.195385 -0.59054,-0.244967"
|
transform="translate(-115,1247)"
|
||||||
style="line-height:125%;fill:#ffffff;fill-opacity:1;marker:none;font-family:Cantarell;-inkscape-font-specification:Cantarell Bold"
|
style="display:inline"
|
||||||
id="path18606" />
|
id="g38004">
|
||||||
<path
|
<rect
|
||||||
d="m 813.15903,80.639569 1.21608,0 3.4689,4.776844 0,-4.776844 1.10235,0 0,6.216022 -1.22921,0 -3.45577,-4.785594 0,4.785594 -1.10235,0 0,-6.216022"
|
ry="3.7972314"
|
||||||
style="line-height:125%;fill:#ffffff;fill-opacity:1;marker:none;font-family:Cantarell;-inkscape-font-specification:Cantarell Bold"
|
rx="4.6871223"
|
||||||
id="path18608" />
|
y="515.5"
|
||||||
|
x="694.53046"
|
||||||
|
height="25"
|
||||||
|
width="45.969578"
|
||||||
|
id="rect38006"
|
||||||
|
style="color:#000000;fill:url(#linearGradient38024);fill-opacity:1;fill-rule:nonzero;stroke:#1f2020;stroke-width:1.37920964;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" />
|
||||||
|
<path
|
||||||
|
sodipodi:nodetypes="cc"
|
||||||
|
style="opacity:0.1;color:#000000;fill:none;stroke:#ffffff;stroke-width:1.37920964px;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
||||||
|
d="m 699.09675,516.7365 36.86904,0"
|
||||||
|
id="path38016"
|
||||||
|
inkscape:path-effect="#path-effect77541-4"
|
||||||
|
inkscape:original-d="m 699.09675,516.7365 36.86904,0"
|
||||||
|
inkscape:connector-curvature="0" />
|
||||||
|
</g>
|
||||||
</g>
|
</g>
|
||||||
|
<text
|
||||||
|
transform="scale(1.1000946,0.90901274)"
|
||||||
|
sodipodi:linespacing="125%"
|
||||||
|
id="text38018"
|
||||||
|
y="1955.5205"
|
||||||
|
x="495.94223"
|
||||||
|
style="font-size:13.29953671px;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;font-family:Cantarell;-inkscape-font-specification:Cantarell Bold"
|
||||||
|
xml:space="preserve"><tspan
|
||||||
|
y="1955.5205"
|
||||||
|
x="495.94223"
|
||||||
|
id="tspan38020"
|
||||||
|
sodipodi:role="line">ON</tspan></text>
|
||||||
</g>
|
</g>
|
||||||
</g>
|
</g>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 6.8 KiB After Width: | Height: | Size: 7.0 KiB |
@ -59,14 +59,10 @@ const Application = new Lang.Class({
|
|||||||
|
|
||||||
_extensionAvailable: function(uuid) {
|
_extensionAvailable: function(uuid) {
|
||||||
let extension = ExtensionUtils.extensions[uuid];
|
let extension = ExtensionUtils.extensions[uuid];
|
||||||
let checkVersion = !this._settings.get_boolean('disable-extension-version-validation');
|
|
||||||
|
|
||||||
if (!extension)
|
if (!extension)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (checkVersion && ExtensionUtils.isOutOfDate(extension))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if (!extension.dir.get_child('prefs.js').query_exists(null))
|
if (!extension.dir.get_child('prefs.js').query_exists(null))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
@ -285,6 +281,10 @@ const ExtensionRow = new Lang.Class({
|
|||||||
function() {
|
function() {
|
||||||
this._switch.state = this._isEnabled();
|
this._switch.state = this._isEnabled();
|
||||||
}));
|
}));
|
||||||
|
this._settings.connect('changed::disable-extension-version-validation',
|
||||||
|
Lang.bind(this, function() {
|
||||||
|
this._switch.sensitive = this._canEnable();
|
||||||
|
}));
|
||||||
|
|
||||||
this._buildUI();
|
this._buildUI();
|
||||||
},
|
},
|
||||||
@ -323,6 +323,7 @@ const ExtensionRow = new Lang.Class({
|
|||||||
this.prefsButton = button;
|
this.prefsButton = button;
|
||||||
|
|
||||||
this._switch = new Gtk.Switch({ valign: Gtk.Align.CENTER,
|
this._switch = new Gtk.Switch({ valign: Gtk.Align.CENTER,
|
||||||
|
sensitive: this._canEnable(),
|
||||||
state: this._isEnabled() });
|
state: this._isEnabled() });
|
||||||
this._switch.connect('notify::active', Lang.bind(this,
|
this._switch.connect('notify::active', Lang.bind(this,
|
||||||
function() {
|
function() {
|
||||||
@ -335,6 +336,13 @@ const ExtensionRow = new Lang.Class({
|
|||||||
hbox.add(this._switch);
|
hbox.add(this._switch);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_canEnable: function() {
|
||||||
|
let extension = ExtensionUtils.extensions[this.uuid];
|
||||||
|
let checkVersion = !this._settings.get_boolean('disable-extension-version-validation');
|
||||||
|
|
||||||
|
return !(checkVersion && ExtensionUtils.isOutOfDate(extension));
|
||||||
|
},
|
||||||
|
|
||||||
_isEnabled: function() {
|
_isEnabled: function() {
|
||||||
let extensions = this._settings.get_strv('enabled-extensions');
|
let extensions = this._settings.get_strv('enabled-extensions');
|
||||||
return extensions.indexOf(this.uuid) != -1;
|
return extensions.indexOf(this.uuid) != -1;
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
||||||
|
|
||||||
const Clutter = imports.gi.Clutter;
|
const Clutter = imports.gi.Clutter;
|
||||||
|
const Gio = imports.gi.Gio;
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
const Signals = imports.signals;
|
const Signals = imports.signals;
|
||||||
const St = imports.gi.St;
|
const St = imports.gi.St;
|
||||||
@ -126,7 +127,7 @@ const AuthPrompt = new Lang.Class({
|
|||||||
|
|
||||||
this._initButtons();
|
this._initButtons();
|
||||||
|
|
||||||
let spinnerIcon = global.datadir + '/theme/process-working.svg';
|
let spinnerIcon = Gio.File.new_for_uri('resource:///org/gnome/shell/theme/process-working.svg');
|
||||||
this._spinner = new Animation.AnimatedIcon(spinnerIcon, DEFAULT_BUTTON_WELL_ICON_SIZE);
|
this._spinner = new Animation.AnimatedIcon(spinnerIcon, DEFAULT_BUTTON_WELL_ICON_SIZE);
|
||||||
this._spinner.actor.opacity = 0;
|
this._spinner.actor.opacity = 0;
|
||||||
this._spinner.actor.show();
|
this._spinner.actor.show();
|
||||||
@ -134,8 +135,7 @@ const AuthPrompt = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_onDestroy: function() {
|
_onDestroy: function() {
|
||||||
this._userVerifier.clear();
|
this._userVerifier.destroy();
|
||||||
this._userVerifier.disconnectAll();
|
|
||||||
this._userVerifier = null;
|
this._userVerifier = null;
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -419,11 +419,13 @@ const AuthPrompt = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
setUser: function(user) {
|
setUser: function(user) {
|
||||||
|
let oldChild = this._userWell.get_child();
|
||||||
|
if (oldChild)
|
||||||
|
oldChild.destroy();
|
||||||
|
|
||||||
if (user) {
|
if (user) {
|
||||||
let userWidget = new UserWidget.UserWidget(user);
|
let userWidget = new UserWidget.UserWidget(user);
|
||||||
this._userWell.set_child(userWidget.actor);
|
this._userWell.set_child(userWidget.actor);
|
||||||
} else {
|
|
||||||
this._userWell.set_child(null);
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -64,6 +64,8 @@ const UserListItem = new Lang.Class({
|
|||||||
reactive: true,
|
reactive: true,
|
||||||
x_align: St.Align.START,
|
x_align: St.Align.START,
|
||||||
x_fill: true });
|
x_fill: true });
|
||||||
|
this.actor.connect('destroy',
|
||||||
|
Lang.bind(this, this._onDestroy));
|
||||||
|
|
||||||
this._userWidget = new UserWidget.UserWidget(this.user);
|
this._userWidget = new UserWidget.UserWidget(this.user);
|
||||||
layout.add(this._userWidget.actor);
|
layout.add(this._userWidget.actor);
|
||||||
@ -87,6 +89,10 @@ const UserListItem = new Lang.Class({
|
|||||||
this.actor.remove_style_pseudo_class('logged-in');
|
this.actor.remove_style_pseudo_class('logged-in');
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_onDestroy: function() {
|
||||||
|
this._user.disconnect(this._userChangedId);
|
||||||
|
},
|
||||||
|
|
||||||
_onClicked: function() {
|
_onClicked: function() {
|
||||||
this.emit('activate');
|
this.emit('activate');
|
||||||
},
|
},
|
||||||
@ -373,13 +379,12 @@ const LoginDialog = new Lang.Class({
|
|||||||
if (GLib.getenv('GDM_GREETER_TEST') != '1') {
|
if (GLib.getenv('GDM_GREETER_TEST') != '1') {
|
||||||
this._greeter = gdmClient.get_greeter_sync(null);
|
this._greeter = gdmClient.get_greeter_sync(null);
|
||||||
|
|
||||||
this._greeter.connect('default-session-name-changed',
|
this._defaultSessionChangedId = this._greeter.connect('default-session-name-changed',
|
||||||
Lang.bind(this, this._onDefaultSessionChanged));
|
Lang.bind(this, this._onDefaultSessionChanged));
|
||||||
|
this._sessionOpenedId = this._greeter.connect('session-opened',
|
||||||
this._greeter.connect('session-opened',
|
Lang.bind(this, this._onSessionOpened));
|
||||||
Lang.bind(this, this._onSessionOpened));
|
this._timedLoginRequestedId = this._greeter.connect('timed-login-requested',
|
||||||
this._greeter.connect('timed-login-requested',
|
Lang.bind(this, this._onTimedLoginRequested));
|
||||||
Lang.bind(this, this._onTimedLoginRequested));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
this._settings = new Gio.Settings({ schema_id: GdmUtil.LOGIN_SCREEN_SCHEMA });
|
this._settings = new Gio.Settings({ schema_id: GdmUtil.LOGIN_SCREEN_SCHEMA });
|
||||||
@ -394,8 +399,8 @@ const LoginDialog = new Lang.Class({
|
|||||||
Lang.bind(this, this._updateLogo));
|
Lang.bind(this, this._updateLogo));
|
||||||
|
|
||||||
this._textureCache = St.TextureCache.get_default();
|
this._textureCache = St.TextureCache.get_default();
|
||||||
this._textureCache.connect('texture-file-changed',
|
this._updateLogoTextureId = this._textureCache.connect('texture-file-changed',
|
||||||
Lang.bind(this, this._updateLogoTexture));
|
Lang.bind(this, this._updateLogoTexture));
|
||||||
|
|
||||||
this._userSelectionBox = new St.BoxLayout({ style_class: 'login-dialog-user-selection-box',
|
this._userSelectionBox = new St.BoxLayout({ style_class: 'login-dialog-user-selection-box',
|
||||||
x_align: Clutter.ActorAlign.CENTER,
|
x_align: Clutter.ActorAlign.CENTER,
|
||||||
@ -476,8 +481,8 @@ const LoginDialog = new Lang.Class({
|
|||||||
// If the user list is enabled, it should take key focus; make sure the
|
// If the user list is enabled, it should take key focus; make sure the
|
||||||
// screen shield is initialized first to prevent it from stealing the
|
// screen shield is initialized first to prevent it from stealing the
|
||||||
// focus later
|
// focus later
|
||||||
Main.layoutManager.connect('startup-complete',
|
this._startupCompleteId = Main.layoutManager.connect('startup-complete',
|
||||||
Lang.bind(this, this._updateDisableUserList));
|
Lang.bind(this, this._updateDisableUserList));
|
||||||
},
|
},
|
||||||
|
|
||||||
_ensureUserListLoaded: function() {
|
_ensureUserListLoaded: function() {
|
||||||
@ -532,24 +537,24 @@ const LoginDialog = new Lang.Class({
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_updateLogoTexture: function(cache, uri) {
|
_updateLogoTexture: function(cache, file) {
|
||||||
if (this._logoFileUri != uri)
|
if (this._logoFile && !this._logoFile.equal(file))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
this._logoBin.destroy_all_children();
|
this._logoBin.destroy_all_children();
|
||||||
if (this._logoFileUri) {
|
if (this._logoFile) {
|
||||||
let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor;
|
let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor;
|
||||||
this._logoBin.add_child(this._textureCache.load_uri_async(this._logoFileUri,
|
this._logoBin.add_child(this._textureCache.load_file_async(this._logoFile,
|
||||||
-1, _LOGO_ICON_HEIGHT,
|
-1, _LOGO_ICON_HEIGHT,
|
||||||
scaleFactor));
|
scaleFactor));
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_updateLogo: function() {
|
_updateLogo: function() {
|
||||||
let path = this._settings.get_string(GdmUtil.LOGO_KEY);
|
let path = this._settings.get_string(GdmUtil.LOGO_KEY);
|
||||||
|
|
||||||
this._logoFileUri = path ? Gio.file_new_for_path(path).get_uri() : null;
|
this._logoFile = path ? Gio.file_new_for_path(path) : null;
|
||||||
this._updateLogoTexture(this._textureCache, this._logoFileUri);
|
this._updateLogoTexture(this._textureCache, this._logoFile);
|
||||||
},
|
},
|
||||||
|
|
||||||
_onPrompted: function() {
|
_onPrompted: function() {
|
||||||
@ -665,10 +670,12 @@ const LoginDialog = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_gotGreeterSessionProxy: function(proxy) {
|
_gotGreeterSessionProxy: function(proxy) {
|
||||||
proxy.connect('g-properties-changed', Lang.bind(this, function() {
|
this._greeterSessionProxy = proxy;
|
||||||
if (proxy.Active)
|
this._greeterSessionProxyChangedId =
|
||||||
this._loginScreenSessionActivated();
|
proxy.connect('g-properties-changed', Lang.bind(this, function() {
|
||||||
}));
|
if (proxy.Active)
|
||||||
|
this._loginScreenSessionActivated();
|
||||||
|
}));
|
||||||
},
|
},
|
||||||
|
|
||||||
_startSession: function(serviceName) {
|
_startSession: function(serviceName) {
|
||||||
@ -890,6 +897,30 @@ const LoginDialog = new Lang.Class({
|
|||||||
this._userManager.disconnect(this._userManagerLoadedId);
|
this._userManager.disconnect(this._userManagerLoadedId);
|
||||||
this._userManagerLoadedId = 0;
|
this._userManagerLoadedId = 0;
|
||||||
}
|
}
|
||||||
|
if (this._userAddedId) {
|
||||||
|
this._userManager.disconnect(this._userAddedId);
|
||||||
|
this._userAddedId = 0;
|
||||||
|
}
|
||||||
|
if (this._userRemovedId) {
|
||||||
|
this._userManager.disconnect(this._userRemovedId);
|
||||||
|
this._userRemovedId = 0;
|
||||||
|
}
|
||||||
|
this._textureCache.disconnect(this._updateLogoTextureId);
|
||||||
|
Main.layoutManager.disconnect(this._startupCompleteId);
|
||||||
|
if (this._settings) {
|
||||||
|
this._settings.run_dispose();
|
||||||
|
this._settings = null;
|
||||||
|
}
|
||||||
|
if (this._greeter) {
|
||||||
|
this._greeter.disconnect(this._defaultSessionChangedId);
|
||||||
|
this._greeter.disconnect(this._sessionOpenedId);
|
||||||
|
this._greeter.disconnect(this._timedLoginRequestedId);
|
||||||
|
this._greeter = null;
|
||||||
|
}
|
||||||
|
if (this._greeterSessionProxy) {
|
||||||
|
this._greeterSessionProxy.disconnect(this._greeterSessionProxyChangedId);
|
||||||
|
this._greeterSessionProxy = null;
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_loadUserList: function() {
|
_loadUserList: function() {
|
||||||
@ -904,15 +935,15 @@ const LoginDialog = new Lang.Class({
|
|||||||
this._userList.addUser(users[i]);
|
this._userList.addUser(users[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
this._userManager.connect('user-added',
|
this._userAddedId = this._userManager.connect('user-added',
|
||||||
Lang.bind(this, function(userManager, user) {
|
Lang.bind(this, function(userManager, user) {
|
||||||
this._userList.addUser(user);
|
this._userList.addUser(user);
|
||||||
}));
|
}));
|
||||||
|
|
||||||
this._userManager.connect('user-removed',
|
this._userRemovedId = this._userManager.connect('user-removed',
|
||||||
Lang.bind(this, function(userManager, user) {
|
Lang.bind(this, function(userManager, user) {
|
||||||
this._userList.removeUser(user);
|
this._userList.removeUser(user);
|
||||||
}));
|
}));
|
||||||
|
|
||||||
return GLib.SOURCE_REMOVE;
|
return GLib.SOURCE_REMOVE;
|
||||||
},
|
},
|
||||||
|
@ -142,10 +142,10 @@ const ShellUserVerifier = new Lang.Class({
|
|||||||
// after a user has been picked.
|
// after a user has been picked.
|
||||||
this._checkForSmartcard();
|
this._checkForSmartcard();
|
||||||
|
|
||||||
this._smartcardManager.connect('smartcard-inserted',
|
this._smartcardInsertedId = this._smartcardManager.connect('smartcard-inserted',
|
||||||
Lang.bind(this, this._checkForSmartcard));
|
Lang.bind(this, this._checkForSmartcard));
|
||||||
this._smartcardManager.connect('smartcard-removed',
|
this._smartcardRemovedId = this._smartcardManager.connect('smartcard-removed',
|
||||||
Lang.bind(this, this._checkForSmartcard));
|
Lang.bind(this, this._checkForSmartcard));
|
||||||
|
|
||||||
this._messageQueue = [];
|
this._messageQueue = [];
|
||||||
this._messageQueueTimeoutId = 0;
|
this._messageQueueTimeoutId = 0;
|
||||||
@ -159,8 +159,8 @@ const ShellUserVerifier = new Lang.Class({
|
|||||||
if (this._oVirtCredentialsManager.hasToken())
|
if (this._oVirtCredentialsManager.hasToken())
|
||||||
this._oVirtUserAuthenticated(this._oVirtCredentialsManager.getToken());
|
this._oVirtUserAuthenticated(this._oVirtCredentialsManager.getToken());
|
||||||
|
|
||||||
this._oVirtCredentialsManager.connect('user-authenticated',
|
this._oVirtUserAuthenticatedId = this._oVirtCredentialsManager.connect('user-authenticated',
|
||||||
Lang.bind(this, this._oVirtUserAuthenticated));
|
Lang.bind(this, this._oVirtUserAuthenticated));
|
||||||
},
|
},
|
||||||
|
|
||||||
begin: function(userName, hold) {
|
begin: function(userName, hold) {
|
||||||
@ -191,20 +191,37 @@ const ShellUserVerifier = new Lang.Class({
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_clearUserVerifier: function() {
|
||||||
|
if (this._userVerifier) {
|
||||||
|
this._userVerifier.run_dispose();
|
||||||
|
this._userVerifier = null;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
clear: function() {
|
clear: function() {
|
||||||
if (this._cancellable) {
|
if (this._cancellable) {
|
||||||
this._cancellable.cancel();
|
this._cancellable.cancel();
|
||||||
this._cancellable = null;
|
this._cancellable = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this._userVerifier) {
|
this._clearUserVerifier();
|
||||||
this._userVerifier.run_dispose();
|
|
||||||
this._userVerifier = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._clearMessageQueue();
|
this._clearMessageQueue();
|
||||||
},
|
},
|
||||||
|
|
||||||
|
destroy: function() {
|
||||||
|
this.clear();
|
||||||
|
|
||||||
|
this._settings.run_dispose();
|
||||||
|
this._settings = null;
|
||||||
|
|
||||||
|
this._smartcardManager.disconnect(this._smartcardInsertedId);
|
||||||
|
this._smartcardManager.disconnect(this._smartcardRemovedId);
|
||||||
|
this._smartcardManager = null;
|
||||||
|
|
||||||
|
this._oVirtCredentialsManager.disconnect(this._oVirtUserAuthenticatedId);
|
||||||
|
this._oVirtCredentialsManager = null;
|
||||||
|
},
|
||||||
|
|
||||||
answerQuery: function(serviceName, answer) {
|
answerQuery: function(serviceName, answer) {
|
||||||
if (!this.hasPendingMessages) {
|
if (!this.hasPendingMessages) {
|
||||||
this._userVerifier.call_answer_query(serviceName, answer, this._cancellable, null);
|
this._userVerifier.call_answer_query(serviceName, answer, this._cancellable, null);
|
||||||
@ -283,9 +300,10 @@ const ShellUserVerifier = new Lang.Class({
|
|||||||
|
|
||||||
this._fprintManager.GetDefaultDeviceRemote(Gio.DBusCallFlags.NONE, this._cancellable, Lang.bind(this,
|
this._fprintManager.GetDefaultDeviceRemote(Gio.DBusCallFlags.NONE, this._cancellable, Lang.bind(this,
|
||||||
function(device, error) {
|
function(device, error) {
|
||||||
if (!error && device)
|
if (!error && device) {
|
||||||
this._haveFingerprintReader = true;
|
this._haveFingerprintReader = true;
|
||||||
this._updateDefaultService();
|
this._updateDefaultService();
|
||||||
|
}
|
||||||
}));
|
}));
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -326,6 +344,7 @@ const ShellUserVerifier = new Lang.Class({
|
|||||||
|
|
||||||
_reauthenticationChannelOpened: function(client, result) {
|
_reauthenticationChannelOpened: function(client, result) {
|
||||||
try {
|
try {
|
||||||
|
this._clearUserVerifier();
|
||||||
this._userVerifier = client.open_reauthentication_channel_finish(result);
|
this._userVerifier = client.open_reauthentication_channel_finish(result);
|
||||||
} catch(e if e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.CANCELLED)) {
|
} catch(e if e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.CANCELLED)) {
|
||||||
return;
|
return;
|
||||||
@ -349,6 +368,7 @@ const ShellUserVerifier = new Lang.Class({
|
|||||||
|
|
||||||
_userVerifierGot: function(client, result) {
|
_userVerifierGot: function(client, result) {
|
||||||
try {
|
try {
|
||||||
|
this._clearUserVerifier();
|
||||||
this._userVerifier = client.get_user_verifier_finish(result);
|
this._userVerifier = client.get_user_verifier_finish(result);
|
||||||
} catch(e if e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.CANCELLED)) {
|
} catch(e if e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.CANCELLED)) {
|
||||||
return;
|
return;
|
||||||
|
@ -16,7 +16,9 @@
|
|||||||
<file>misc/fileUtils.js</file>
|
<file>misc/fileUtils.js</file>
|
||||||
<file>misc/gnomeSession.js</file>
|
<file>misc/gnomeSession.js</file>
|
||||||
<file>misc/history.js</file>
|
<file>misc/history.js</file>
|
||||||
|
<file>misc/ibusManager.js</file>
|
||||||
<file>misc/jsParse.js</file>
|
<file>misc/jsParse.js</file>
|
||||||
|
<file>misc/keyboardManager.js</file>
|
||||||
<file>misc/loginManager.js</file>
|
<file>misc/loginManager.js</file>
|
||||||
<file>misc/modemManager.js</file>
|
<file>misc/modemManager.js</file>
|
||||||
<file>misc/objectManager.js</file>
|
<file>misc/objectManager.js</file>
|
||||||
|
180
js/misc/ibusManager.js
Normal file
@ -0,0 +1,180 @@
|
|||||||
|
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
||||||
|
|
||||||
|
const Gio = imports.gi.Gio;
|
||||||
|
const Lang = imports.lang;
|
||||||
|
const Signals = imports.signals;
|
||||||
|
|
||||||
|
try {
|
||||||
|
var IBus = imports.gi.IBus;
|
||||||
|
if (!('new_async' in IBus.Bus))
|
||||||
|
throw "IBus version is too old";
|
||||||
|
const IBusCandidatePopup = imports.ui.ibusCandidatePopup;
|
||||||
|
} catch (e) {
|
||||||
|
var IBus = null;
|
||||||
|
log(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
let _ibusManager = null;
|
||||||
|
|
||||||
|
function getIBusManager() {
|
||||||
|
if (_ibusManager == null)
|
||||||
|
_ibusManager = new IBusManager();
|
||||||
|
return _ibusManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
const IBusManager = new Lang.Class({
|
||||||
|
Name: 'IBusManager',
|
||||||
|
|
||||||
|
// This is the longest we'll keep the keyboard frozen until an input
|
||||||
|
// source is active.
|
||||||
|
_MAX_INPUT_SOURCE_ACTIVATION_TIME: 4000, // ms
|
||||||
|
|
||||||
|
_init: function() {
|
||||||
|
if (!IBus)
|
||||||
|
return;
|
||||||
|
|
||||||
|
IBus.init();
|
||||||
|
|
||||||
|
this._candidatePopup = new IBusCandidatePopup.CandidatePopup();
|
||||||
|
|
||||||
|
this._panelService = null;
|
||||||
|
this._engines = {};
|
||||||
|
this._ready = false;
|
||||||
|
this._registerPropertiesId = 0;
|
||||||
|
this._currentEngineName = null;
|
||||||
|
|
||||||
|
this._ibus = IBus.Bus.new_async();
|
||||||
|
this._ibus.connect('connected', Lang.bind(this, this._onConnected));
|
||||||
|
this._ibus.connect('disconnected', Lang.bind(this, this._clear));
|
||||||
|
// Need to set this to get 'global-engine-changed' emitions
|
||||||
|
this._ibus.set_watch_ibus_signal(true);
|
||||||
|
this._ibus.connect('global-engine-changed', Lang.bind(this, this._engineChanged));
|
||||||
|
|
||||||
|
this._spawn();
|
||||||
|
},
|
||||||
|
|
||||||
|
_spawn: function() {
|
||||||
|
try {
|
||||||
|
Gio.Subprocess.new(['ibus-daemon', '--xim', '--panel', 'disable'],
|
||||||
|
Gio.SubprocessFlags.NONE);
|
||||||
|
} catch(e) {
|
||||||
|
log('Failed to launch ibus-daemon: ' + e.message);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
_clear: function() {
|
||||||
|
if (this._panelService)
|
||||||
|
this._panelService.destroy();
|
||||||
|
|
||||||
|
this._panelService = null;
|
||||||
|
this._candidatePopup.setPanelService(null);
|
||||||
|
this._engines = {};
|
||||||
|
this._ready = false;
|
||||||
|
this._registerPropertiesId = 0;
|
||||||
|
this._currentEngineName = null;
|
||||||
|
|
||||||
|
this.emit('ready', false);
|
||||||
|
|
||||||
|
this._spawn();
|
||||||
|
},
|
||||||
|
|
||||||
|
_onConnected: function() {
|
||||||
|
this._ibus.list_engines_async(-1, null, Lang.bind(this, this._initEngines));
|
||||||
|
this._ibus.request_name_async(IBus.SERVICE_PANEL,
|
||||||
|
IBus.BusNameFlag.REPLACE_EXISTING,
|
||||||
|
-1, null,
|
||||||
|
Lang.bind(this, this._initPanelService));
|
||||||
|
},
|
||||||
|
|
||||||
|
_initEngines: function(ibus, result) {
|
||||||
|
let enginesList = this._ibus.list_engines_async_finish(result);
|
||||||
|
if (enginesList) {
|
||||||
|
for (let i = 0; i < enginesList.length; ++i) {
|
||||||
|
let name = enginesList[i].get_name();
|
||||||
|
this._engines[name] = enginesList[i];
|
||||||
|
}
|
||||||
|
this._updateReadiness();
|
||||||
|
} else {
|
||||||
|
this._clear();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
_initPanelService: function(ibus, result) {
|
||||||
|
let success = this._ibus.request_name_async_finish(result);
|
||||||
|
if (success) {
|
||||||
|
this._panelService = new IBus.PanelService({ connection: this._ibus.get_connection(),
|
||||||
|
object_path: IBus.PATH_PANEL });
|
||||||
|
this._candidatePopup.setPanelService(this._panelService);
|
||||||
|
this._panelService.connect('update-property', Lang.bind(this, this._updateProperty));
|
||||||
|
// If an engine is already active we need to get its properties
|
||||||
|
this._ibus.get_global_engine_async(-1, null, Lang.bind(this, function(i, result) {
|
||||||
|
let engine;
|
||||||
|
try {
|
||||||
|
engine = this._ibus.get_global_engine_async_finish(result);
|
||||||
|
if (!engine)
|
||||||
|
return;
|
||||||
|
} catch(e) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
this._engineChanged(this._ibus, engine.get_name());
|
||||||
|
}));
|
||||||
|
this._updateReadiness();
|
||||||
|
} else {
|
||||||
|
this._clear();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
_updateReadiness: function() {
|
||||||
|
this._ready = (Object.keys(this._engines).length > 0 &&
|
||||||
|
this._panelService != null);
|
||||||
|
this.emit('ready', this._ready);
|
||||||
|
},
|
||||||
|
|
||||||
|
_engineChanged: function(bus, engineName) {
|
||||||
|
if (!this._ready)
|
||||||
|
return;
|
||||||
|
|
||||||
|
this._currentEngineName = engineName;
|
||||||
|
|
||||||
|
if (this._registerPropertiesId != 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
this._registerPropertiesId =
|
||||||
|
this._panelService.connect('register-properties', Lang.bind(this, function(p, props) {
|
||||||
|
if (!props.get(0))
|
||||||
|
return;
|
||||||
|
|
||||||
|
this._panelService.disconnect(this._registerPropertiesId);
|
||||||
|
this._registerPropertiesId = 0;
|
||||||
|
|
||||||
|
this.emit('properties-registered', this._currentEngineName, props);
|
||||||
|
}));
|
||||||
|
},
|
||||||
|
|
||||||
|
_updateProperty: function(panel, prop) {
|
||||||
|
this.emit('property-updated', this._currentEngineName, prop);
|
||||||
|
},
|
||||||
|
|
||||||
|
activateProperty: function(key, state) {
|
||||||
|
this._panelService.property_activate(key, state);
|
||||||
|
},
|
||||||
|
|
||||||
|
getEngineDesc: function(id) {
|
||||||
|
if (!IBus || !this._ready)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
return this._engines[id];
|
||||||
|
},
|
||||||
|
|
||||||
|
setEngine: function(id, callback) {
|
||||||
|
if (!IBus || !this._ready || id == this._currentEngineName) {
|
||||||
|
if (callback)
|
||||||
|
callback();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
this._ibus.set_global_engine_async(id, this._MAX_INPUT_SOURCE_ACTIVATION_TIME,
|
||||||
|
null, callback);
|
||||||
|
},
|
||||||
|
});
|
||||||
|
Signals.addSignalMethods(IBusManager.prototype);
|
153
js/misc/keyboardManager.js
Normal file
@ -0,0 +1,153 @@
|
|||||||
|
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
||||||
|
|
||||||
|
const GLib = imports.gi.GLib;
|
||||||
|
const GnomeDesktop = imports.gi.GnomeDesktop;
|
||||||
|
const Lang = imports.lang;
|
||||||
|
const Meta = imports.gi.Meta;
|
||||||
|
|
||||||
|
const Main = imports.ui.main;
|
||||||
|
|
||||||
|
const DEFAULT_LOCALE = 'en_US';
|
||||||
|
const DEFAULT_LAYOUT = 'us';
|
||||||
|
const DEFAULT_VARIANT = '';
|
||||||
|
|
||||||
|
let _xkbInfo = null;
|
||||||
|
|
||||||
|
function getXkbInfo() {
|
||||||
|
if (_xkbInfo == null)
|
||||||
|
_xkbInfo = new GnomeDesktop.XkbInfo();
|
||||||
|
return _xkbInfo;
|
||||||
|
}
|
||||||
|
|
||||||
|
let _keyboardManager = null;
|
||||||
|
|
||||||
|
function getKeyboardManager() {
|
||||||
|
if (_keyboardManager == null)
|
||||||
|
_keyboardManager = new KeyboardManager();
|
||||||
|
return _keyboardManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
function releaseKeyboard() {
|
||||||
|
if (Main.modalCount > 0)
|
||||||
|
global.display.unfreeze_keyboard(global.get_current_time());
|
||||||
|
else
|
||||||
|
global.display.ungrab_keyboard(global.get_current_time());
|
||||||
|
}
|
||||||
|
|
||||||
|
function holdKeyboard() {
|
||||||
|
global.display.freeze_keyboard(global.get_current_time());
|
||||||
|
}
|
||||||
|
|
||||||
|
const KeyboardManager = new Lang.Class({
|
||||||
|
Name: 'KeyboardManager',
|
||||||
|
|
||||||
|
// The XKB protocol doesn't allow for more that 4 layouts in a
|
||||||
|
// keymap. Wayland doesn't impose this limit and libxkbcommon can
|
||||||
|
// handle up to 32 layouts but since we need to support X clients
|
||||||
|
// even as a Wayland compositor, we can't bump this.
|
||||||
|
MAX_LAYOUTS_PER_GROUP: 4,
|
||||||
|
|
||||||
|
_init: function() {
|
||||||
|
this._xkbInfo = getXkbInfo();
|
||||||
|
this._current = null;
|
||||||
|
this._localeLayoutInfo = this._getLocaleLayout();
|
||||||
|
this._layoutInfos = {};
|
||||||
|
},
|
||||||
|
|
||||||
|
_applyLayoutGroup: function(group) {
|
||||||
|
let options = this._buildOptionsString();
|
||||||
|
let [layouts, variants] = this._buildGroupStrings(group);
|
||||||
|
Meta.get_backend().set_keymap(layouts, variants, options);
|
||||||
|
},
|
||||||
|
|
||||||
|
_applyLayoutGroupIndex: function(idx) {
|
||||||
|
Meta.get_backend().lock_layout_group(idx);
|
||||||
|
},
|
||||||
|
|
||||||
|
apply: function(id) {
|
||||||
|
let info = this._layoutInfos[id];
|
||||||
|
if (!info)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (this._current && this._current.group == info.group) {
|
||||||
|
if (this._current.groupIndex != info.groupIndex)
|
||||||
|
this._applyLayoutGroupIndex(info.groupIndex);
|
||||||
|
} else {
|
||||||
|
this._applyLayoutGroup(info.group);
|
||||||
|
this._applyLayoutGroupIndex(info.groupIndex);
|
||||||
|
}
|
||||||
|
|
||||||
|
this._current = info;
|
||||||
|
},
|
||||||
|
|
||||||
|
reapply: function() {
|
||||||
|
if (!this._current)
|
||||||
|
return;
|
||||||
|
|
||||||
|
this._applyLayoutGroup(this._current.group);
|
||||||
|
this._applyLayoutGroupIndex(this._current.groupIndex);
|
||||||
|
},
|
||||||
|
|
||||||
|
setUserLayouts: function(ids) {
|
||||||
|
this._current = null;
|
||||||
|
this._layoutInfos = {};
|
||||||
|
|
||||||
|
for (let i = 0; i < ids.length; ++i) {
|
||||||
|
let [found, , , _layout, _variant] = this._xkbInfo.get_layout_info(ids[i]);
|
||||||
|
if (found)
|
||||||
|
this._layoutInfos[ids[i]] = { id: ids[i], layout: _layout, variant: _variant };
|
||||||
|
}
|
||||||
|
|
||||||
|
let i = 0;
|
||||||
|
let group = [];
|
||||||
|
for (let id in this._layoutInfos) {
|
||||||
|
// We need to leave one slot on each group free so that we
|
||||||
|
// can add a layout containing the symbols for the
|
||||||
|
// language used in UI strings to ensure that toolkits can
|
||||||
|
// handle mnemonics like Alt+Ф even if the user is
|
||||||
|
// actually typing in a different layout.
|
||||||
|
let groupIndex = i % (this.MAX_LAYOUTS_PER_GROUP - 1);
|
||||||
|
if (groupIndex == 0)
|
||||||
|
group = [];
|
||||||
|
|
||||||
|
let info = this._layoutInfos[id];
|
||||||
|
group[groupIndex] = info;
|
||||||
|
info.group = group;
|
||||||
|
info.groupIndex = groupIndex;
|
||||||
|
|
||||||
|
i += 1;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
_getLocaleLayout: function() {
|
||||||
|
let locale = GLib.get_language_names()[0];
|
||||||
|
if (locale.indexOf('_') == -1)
|
||||||
|
locale = DEFAULT_LOCALE;
|
||||||
|
|
||||||
|
let [found, , id] = GnomeDesktop.get_input_source_from_locale(locale);
|
||||||
|
if (!found)
|
||||||
|
[, , id] = GnomeDesktop.get_input_source_from_locale(DEFAULT_LOCALE);
|
||||||
|
|
||||||
|
let [found, , , _layout, _variant] = this._xkbInfo.get_layout_info(id);
|
||||||
|
if (found)
|
||||||
|
return { layout: _layout, variant: _variant };
|
||||||
|
else
|
||||||
|
return { layout: DEFAULT_LAYOUT, variant: DEFAULT_VARIANT };
|
||||||
|
},
|
||||||
|
|
||||||
|
_buildGroupStrings: function(_group) {
|
||||||
|
let group = _group.concat(this._localeLayoutInfo);
|
||||||
|
let layouts = group.map(function(g) { return g.layout; }).join(',');
|
||||||
|
let variants = group.map(function(g) { return g.variant; }).join(',');
|
||||||
|
return [layouts, variants];
|
||||||
|
},
|
||||||
|
|
||||||
|
setKeyboardOptions: function(options) {
|
||||||
|
this._xkbOptions = options;
|
||||||
|
},
|
||||||
|
|
||||||
|
_buildOptionsString: function() {
|
||||||
|
let options = this._xkbOptions.join(',');
|
||||||
|
return options;
|
||||||
|
}
|
||||||
|
});
|
@ -58,6 +58,14 @@ const AppSwitcherPopup = new Lang.Class({
|
|||||||
this._currentWindow = -1;
|
this._currentWindow = -1;
|
||||||
|
|
||||||
this.thumbnailsVisible = false;
|
this.thumbnailsVisible = false;
|
||||||
|
|
||||||
|
let apps = Shell.AppSystem.get_default().get_running ();
|
||||||
|
|
||||||
|
if (apps.length == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
this._switcherList = new AppSwitcher(apps, this);
|
||||||
|
this._items = this._switcherList.icons;
|
||||||
},
|
},
|
||||||
|
|
||||||
_allocate: function (actor, box, flags) {
|
_allocate: function (actor, box, flags) {
|
||||||
@ -99,20 +107,6 @@ const AppSwitcherPopup = new Lang.Class({
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_createSwitcher: function() {
|
|
||||||
let apps = Shell.AppSystem.get_default().get_running ();
|
|
||||||
|
|
||||||
if (apps.length == 0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
this._switcherList = new AppSwitcher(apps, this);
|
|
||||||
this._items = this._switcherList.icons;
|
|
||||||
if (this._items.length == 0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
},
|
|
||||||
|
|
||||||
_initialSelection: function(backward, binding) {
|
_initialSelection: function(backward, binding) {
|
||||||
if (binding == 'switch-group') {
|
if (binding == 'switch-group') {
|
||||||
if (backward) {
|
if (backward) {
|
||||||
@ -365,9 +359,18 @@ const WindowSwitcherPopup = new Lang.Class({
|
|||||||
Name: 'WindowSwitcherPopup',
|
Name: 'WindowSwitcherPopup',
|
||||||
Extends: SwitcherPopup.SwitcherPopup,
|
Extends: SwitcherPopup.SwitcherPopup,
|
||||||
|
|
||||||
_init: function(items) {
|
_init: function() {
|
||||||
this.parent(items);
|
this.parent();
|
||||||
this._settings = new Gio.Settings({ schema_id: 'org.gnome.shell.window-switcher' });
|
this._settings = new Gio.Settings({ schema_id: 'org.gnome.shell.window-switcher' });
|
||||||
|
|
||||||
|
let windows = this._getWindowList();
|
||||||
|
|
||||||
|
if (windows.length == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
let mode = this._settings.get_enum('app-icon-mode');
|
||||||
|
this._switcherList = new WindowList(windows, mode);
|
||||||
|
this._items = this._switcherList.icons;
|
||||||
},
|
},
|
||||||
|
|
||||||
_getWindowList: function() {
|
_getWindowList: function() {
|
||||||
@ -375,31 +378,6 @@ const WindowSwitcherPopup = new Lang.Class({
|
|||||||
return global.display.get_tab_list(Meta.TabList.NORMAL, workspace);
|
return global.display.get_tab_list(Meta.TabList.NORMAL, workspace);
|
||||||
},
|
},
|
||||||
|
|
||||||
_createSwitcher: function() {
|
|
||||||
let windows = this._getWindowList();
|
|
||||||
|
|
||||||
if (windows.length == 0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
let mode = this._settings.get_enum('app-icon-mode');
|
|
||||||
this._switcherList = new WindowList(windows, mode);
|
|
||||||
this._items = this._switcherList.icons;
|
|
||||||
|
|
||||||
if (this._items.length == 0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
},
|
|
||||||
|
|
||||||
_initialSelection: function(backward, binding) {
|
|
||||||
if (binding == 'switch-windows-backward' || backward)
|
|
||||||
this._select(this._items.length - 1);
|
|
||||||
else if (this._items.length == 1)
|
|
||||||
this._select(0);
|
|
||||||
else
|
|
||||||
this._select(1);
|
|
||||||
},
|
|
||||||
|
|
||||||
_keyPressHandler: function(keysym, action) {
|
_keyPressHandler: function(keysym, action) {
|
||||||
if (action == Meta.KeyBindingAction.SWITCH_WINDOWS) {
|
if (action == Meta.KeyBindingAction.SWITCH_WINDOWS) {
|
||||||
this._select(this._next());
|
this._select(this._next());
|
||||||
|
@ -12,7 +12,7 @@ const ANIMATED_ICON_UPDATE_TIMEOUT = 100;
|
|||||||
const Animation = new Lang.Class({
|
const Animation = new Lang.Class({
|
||||||
Name: 'Animation',
|
Name: 'Animation',
|
||||||
|
|
||||||
_init: function(filename, width, height, speed) {
|
_init: function(file, width, height, speed) {
|
||||||
this.actor = new St.Bin();
|
this.actor = new St.Bin();
|
||||||
this.actor.connect('destroy', Lang.bind(this, this._onDestroy));
|
this.actor.connect('destroy', Lang.bind(this, this._onDestroy));
|
||||||
this._speed = speed;
|
this._speed = speed;
|
||||||
@ -23,7 +23,7 @@ const Animation = new Lang.Class({
|
|||||||
this._frame = 0;
|
this._frame = 0;
|
||||||
|
|
||||||
let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor;
|
let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor;
|
||||||
this._animations = St.TextureCache.get_default().load_sliced_image (filename, width, height, scaleFactor,
|
this._animations = St.TextureCache.get_default().load_sliced_image (file, width, height, scaleFactor,
|
||||||
Lang.bind(this, this._animationsLoaded));
|
Lang.bind(this, this._animationsLoaded));
|
||||||
this.actor.set_child(this._animations);
|
this.actor.set_child(this._animations);
|
||||||
},
|
},
|
||||||
@ -82,7 +82,7 @@ const AnimatedIcon = new Lang.Class({
|
|||||||
Name: 'AnimatedIcon',
|
Name: 'AnimatedIcon',
|
||||||
Extends: Animation,
|
Extends: Animation,
|
||||||
|
|
||||||
_init: function(filename, size) {
|
_init: function(file, size) {
|
||||||
this.parent(filename, size, size, ANIMATED_ICON_UPDATE_TIMEOUT);
|
this.parent(file, size, size, ANIMATED_ICON_UPDATE_TIMEOUT);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -379,9 +379,7 @@ const AllView = new Lang.Class({
|
|||||||
this.actor.add_actor(this._scrollView);
|
this.actor.add_actor(this._scrollView);
|
||||||
|
|
||||||
this._scrollView.set_policy(Gtk.PolicyType.NEVER,
|
this._scrollView.set_policy(Gtk.PolicyType.NEVER,
|
||||||
Gtk.PolicyType.AUTOMATIC);
|
Gtk.PolicyType.EXTERNAL);
|
||||||
// we are only using ScrollView for the fade effect, hide scrollbars
|
|
||||||
this._scrollView.vscroll.hide();
|
|
||||||
this._adjustment = this._scrollView.vscroll.adjustment;
|
this._adjustment = this._scrollView.vscroll.adjustment;
|
||||||
|
|
||||||
this._pageIndicators = new PageIndicators();
|
this._pageIndicators = new PageIndicators();
|
||||||
@ -1267,6 +1265,7 @@ const FolderIcon = new Lang.Class({
|
|||||||
addAppId(appInfo.get_id());
|
addAppId(appInfo.get_id());
|
||||||
});
|
});
|
||||||
|
|
||||||
|
this.actor.visible = this.view.getAllItems().length > 0;
|
||||||
this.view.loadGrid();
|
this.view.loadGrid();
|
||||||
this.emit('apps-changed');
|
this.emit('apps-changed');
|
||||||
},
|
},
|
||||||
@ -1518,13 +1517,33 @@ const AppIcon = new Lang.Class({
|
|||||||
this.id = app.get_id();
|
this.id = app.get_id();
|
||||||
this.name = app.get_name();
|
this.name = app.get_name();
|
||||||
|
|
||||||
this.actor = new St.Button({ style_class: 'app-well-app',
|
// We need to make it track_hover so dash item can connect to
|
||||||
|
// the hover signal of the actor in _hookupLabel to call
|
||||||
|
// shouldShowTooltip when hovered.
|
||||||
|
this.actor = new St.Widget({ layout_manager: new Clutter.BinLayout(),
|
||||||
reactive: true,
|
reactive: true,
|
||||||
button_mask: St.ButtonMask.ONE | St.ButtonMask.TWO,
|
track_hover: true });
|
||||||
can_focus: true,
|
|
||||||
x_fill: true,
|
this._dot = new St.Widget({ style_class: 'app-well-app-running-dot',
|
||||||
y_fill: true });
|
layout_manager: new Clutter.BinLayout(),
|
||||||
|
x_expand: true, y_expand: true,
|
||||||
|
x_align: Clutter.ActorAlign.CENTER,
|
||||||
|
y_align: Clutter.ActorAlign.END });
|
||||||
|
|
||||||
|
this._dot.hide();
|
||||||
|
|
||||||
|
this._button = new St.Button({ style_class: 'app-well-app',
|
||||||
|
reactive: true,
|
||||||
|
button_mask: St.ButtonMask.ONE | St.ButtonMask.TWO,
|
||||||
|
can_focus: true,
|
||||||
|
x_fill: true,
|
||||||
|
y_fill: true });
|
||||||
|
|
||||||
|
this.actor.add_actor(this._button);
|
||||||
|
this.actor.add_actor(this._dot);
|
||||||
|
|
||||||
this.actor._delegate = this;
|
this.actor._delegate = this;
|
||||||
|
this._button._delegate = this;
|
||||||
|
|
||||||
if (!iconParams)
|
if (!iconParams)
|
||||||
iconParams = {};
|
iconParams = {};
|
||||||
@ -1532,20 +1551,20 @@ const AppIcon = new Lang.Class({
|
|||||||
iconParams['createIcon'] = Lang.bind(this, this._createIcon);
|
iconParams['createIcon'] = Lang.bind(this, this._createIcon);
|
||||||
iconParams['setSizeManually'] = true;
|
iconParams['setSizeManually'] = true;
|
||||||
this.icon = new IconGrid.BaseIcon(app.get_name(), iconParams);
|
this.icon = new IconGrid.BaseIcon(app.get_name(), iconParams);
|
||||||
this.actor.set_child(this.icon.actor);
|
this._button.set_child(this.icon.actor);
|
||||||
|
|
||||||
this.actor.label_actor = this.icon.label;
|
this.actor.label_actor = this.icon.label;
|
||||||
|
|
||||||
this.actor.connect('leave-event', Lang.bind(this, this._onLeaveEvent));
|
this._button.connect('leave-event', Lang.bind(this, this._onLeaveEvent));
|
||||||
this.actor.connect('button-press-event', Lang.bind(this, this._onButtonPress));
|
this._button.connect('button-press-event', Lang.bind(this, this._onButtonPress));
|
||||||
this.actor.connect('touch-event', Lang.bind(this, this._onTouchEvent));
|
this._button.connect('touch-event', Lang.bind(this, this._onTouchEvent));
|
||||||
this.actor.connect('clicked', Lang.bind(this, this._onClicked));
|
this._button.connect('clicked', Lang.bind(this, this._onClicked));
|
||||||
this.actor.connect('popup-menu', Lang.bind(this, this._onKeyboardPopupMenu));
|
this._button.connect('popup-menu', Lang.bind(this, this._onKeyboardPopupMenu));
|
||||||
|
|
||||||
this._menu = null;
|
this._menu = null;
|
||||||
this._menuManager = new PopupMenu.PopupMenuManager(this);
|
this._menuManager = new PopupMenu.PopupMenuManager(this);
|
||||||
|
|
||||||
this._draggable = DND.makeDraggable(this.actor);
|
this._draggable = DND.makeDraggable(this._button);
|
||||||
this._draggable.connect('drag-begin', Lang.bind(this,
|
this._draggable.connect('drag-begin', Lang.bind(this,
|
||||||
function () {
|
function () {
|
||||||
this._removeMenuTimeout();
|
this._removeMenuTimeout();
|
||||||
@ -1563,10 +1582,23 @@ const AppIcon = new Lang.Class({
|
|||||||
this.actor.connect('destroy', Lang.bind(this, this._onDestroy));
|
this.actor.connect('destroy', Lang.bind(this, this._onDestroy));
|
||||||
|
|
||||||
this._menuTimeoutId = 0;
|
this._menuTimeoutId = 0;
|
||||||
this._stateChangedId = this.app.connect('notify::state',
|
this._stateChangedId = this.app.connect('notify::state', Lang.bind(this,
|
||||||
Lang.bind(this,
|
function () {
|
||||||
this._onStateChanged));
|
this._updateRunningStyle();
|
||||||
this._onStateChanged();
|
}));
|
||||||
|
this._updateRunningStyle();
|
||||||
|
},
|
||||||
|
|
||||||
|
// Needed for containers that want to track focus of the widget
|
||||||
|
// for i.e. scroll the container when navigating through items
|
||||||
|
getFocusReceiver: function () {
|
||||||
|
return this._button;
|
||||||
|
},
|
||||||
|
|
||||||
|
// Needed for containers that want to change style of the widget
|
||||||
|
// for i.e. set as selected when searching in shell
|
||||||
|
getStyleReceiver: function () {
|
||||||
|
return this._button;
|
||||||
},
|
},
|
||||||
|
|
||||||
_onDestroy: function() {
|
_onDestroy: function() {
|
||||||
@ -1587,11 +1619,14 @@ const AppIcon = new Lang.Class({
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_onStateChanged: function() {
|
_updateRunningStyle: function() {
|
||||||
if (this.app.state != Shell.AppState.STOPPED)
|
if (this.app.state != Shell.AppState.STOPPED) {
|
||||||
this.actor.add_style_class_name('running');
|
this._button.add_style_class_name('running');
|
||||||
else
|
this._dot.show();
|
||||||
this.actor.remove_style_class_name('running');
|
} else {
|
||||||
|
this._button.remove_style_class_name('running');
|
||||||
|
this._dot.hide();
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_setPopupTimeout: function() {
|
_setPopupTimeout: function() {
|
||||||
@ -1606,7 +1641,7 @@ const AppIcon = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_onLeaveEvent: function(actor, event) {
|
_onLeaveEvent: function(actor, event) {
|
||||||
this.actor.fake_release();
|
this._button.fake_release();
|
||||||
this._removeMenuTimeout();
|
this._removeMenuTimeout();
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -1644,7 +1679,7 @@ const AppIcon = new Lang.Class({
|
|||||||
|
|
||||||
popupMenu: function() {
|
popupMenu: function() {
|
||||||
this._removeMenuTimeout();
|
this._removeMenuTimeout();
|
||||||
this.actor.fake_release();
|
this._button.fake_release();
|
||||||
this._draggable.fakeRelease();
|
this._draggable.fakeRelease();
|
||||||
|
|
||||||
if (!this._menu) {
|
if (!this._menu) {
|
||||||
@ -1663,7 +1698,7 @@ const AppIcon = new Lang.Class({
|
|||||||
|
|
||||||
this.emit('menu-state-changed', true);
|
this.emit('menu-state-changed', true);
|
||||||
|
|
||||||
this.actor.set_hover(true);
|
this._button.set_hover(true);
|
||||||
this._menu.popup();
|
this._menu.popup();
|
||||||
this._menuManager.ignoreRelease();
|
this._menuManager.ignoreRelease();
|
||||||
this.emit('sync-tooltip');
|
this.emit('sync-tooltip');
|
||||||
@ -1680,14 +1715,15 @@ const AppIcon = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_onMenuPoppedDown: function() {
|
_onMenuPoppedDown: function() {
|
||||||
this.actor.sync_hover();
|
this._button.sync_hover();
|
||||||
this.emit('menu-state-changed', false);
|
this.emit('menu-state-changed', false);
|
||||||
},
|
},
|
||||||
|
|
||||||
activate: function (button) {
|
activate: function (button) {
|
||||||
let event = Clutter.get_current_event();
|
let event = Clutter.get_current_event();
|
||||||
let modifiers = event ? event.get_state() : 0;
|
let modifiers = event ? event.get_state() : 0;
|
||||||
let openNewWindow = modifiers & Clutter.ModifierType.CONTROL_MASK &&
|
let openNewWindow = this.app.can_open_new_window () &&
|
||||||
|
modifiers & Clutter.ModifierType.CONTROL_MASK &&
|
||||||
this.app.state == Shell.AppState.RUNNING ||
|
this.app.state == Shell.AppState.RUNNING ||
|
||||||
button && button == 2;
|
button && button == 2;
|
||||||
|
|
||||||
|
@ -14,6 +14,11 @@ const RENAMED_DESKTOP_IDS = {
|
|||||||
'gcalctool.desktop': 'gnome-calculator.desktop',
|
'gcalctool.desktop': 'gnome-calculator.desktop',
|
||||||
'gedit.desktop': 'org.gnome.gedit.desktop',
|
'gedit.desktop': 'org.gnome.gedit.desktop',
|
||||||
'glchess.desktop': 'gnome-chess.desktop',
|
'glchess.desktop': 'gnome-chess.desktop',
|
||||||
|
'glines.desktop': 'five-or-more.desktop',
|
||||||
|
'gnect.desktop': 'four-in-a-row.desktop',
|
||||||
|
'gnibbles.desktop': 'gnome-nibbles.desktop',
|
||||||
|
'gnobots2.desktop': 'gnome-robots.desktop',
|
||||||
|
'gnome-boxes.desktop': 'org.gnome.Boxes.desktop',
|
||||||
'gnome-clocks.desktop': 'org.gnome.clocks.desktop',
|
'gnome-clocks.desktop': 'org.gnome.clocks.desktop',
|
||||||
'gnome-contacts.desktop': 'org.gnome.Contacts.desktop',
|
'gnome-contacts.desktop': 'org.gnome.Contacts.desktop',
|
||||||
'gnome-documents.desktop': 'org.gnome.Documents.desktop',
|
'gnome-documents.desktop': 'org.gnome.Documents.desktop',
|
||||||
@ -23,6 +28,9 @@ const RENAMED_DESKTOP_IDS = {
|
|||||||
'gnome-software.desktop': 'org.gnome.Software.desktop',
|
'gnome-software.desktop': 'org.gnome.Software.desktop',
|
||||||
'gnome-weather.desktop': 'org.gnome.Weather.Application.desktop',
|
'gnome-weather.desktop': 'org.gnome.Weather.Application.desktop',
|
||||||
'gnomine.desktop': 'gnome-mines.desktop',
|
'gnomine.desktop': 'gnome-mines.desktop',
|
||||||
|
'gnotravex.desktop': 'gnome-tetravex.desktop',
|
||||||
|
'gnotski.desktop': 'gnome-klotski.desktop',
|
||||||
|
'gtali.desktop': 'tali.desktop',
|
||||||
'nautilus.desktop': 'org.gnome.Nautilus.desktop',
|
'nautilus.desktop': 'org.gnome.Nautilus.desktop',
|
||||||
'polari.desktop': 'org.gnome.Polari.desktop',
|
'polari.desktop': 'org.gnome.Polari.desktop',
|
||||||
'totem.desktop': 'org.gnome.Totem.desktop',
|
'totem.desktop': 'org.gnome.Totem.desktop',
|
||||||
|
@ -106,6 +106,8 @@ const Main = imports.ui.main;
|
|||||||
const Params = imports.misc.params;
|
const Params = imports.misc.params;
|
||||||
const Tweener = imports.ui.tweener;
|
const Tweener = imports.ui.tweener;
|
||||||
|
|
||||||
|
const DEFAULT_BACKGROUND_COLOR = Clutter.Color.from_pixel(0x2e3436ff);
|
||||||
|
|
||||||
const BACKGROUND_SCHEMA = 'org.gnome.desktop.background';
|
const BACKGROUND_SCHEMA = 'org.gnome.desktop.background';
|
||||||
const PRIMARY_COLOR_KEY = 'primary-color';
|
const PRIMARY_COLOR_KEY = 'primary-color';
|
||||||
const SECONDARY_COLOR_KEY = 'secondary-color';
|
const SECONDARY_COLOR_KEY = 'secondary-color';
|
||||||
@ -125,6 +127,16 @@ const ANIMATION_MIN_WAKEUP_INTERVAL = 1.0;
|
|||||||
|
|
||||||
let _backgroundCache = null;
|
let _backgroundCache = null;
|
||||||
|
|
||||||
|
function _fileEqual0(file1, file2) {
|
||||||
|
if (file1 == file2)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
if (!file1 || !file2)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
return file1.equal(file2);
|
||||||
|
}
|
||||||
|
|
||||||
const BackgroundCache = new Lang.Class({
|
const BackgroundCache = new Lang.Class({
|
||||||
Name: 'BackgroundCache',
|
Name: 'BackgroundCache',
|
||||||
|
|
||||||
@ -134,25 +146,25 @@ const BackgroundCache = new Lang.Class({
|
|||||||
this._backgroundSources = {};
|
this._backgroundSources = {};
|
||||||
},
|
},
|
||||||
|
|
||||||
monitorFile: function(filename) {
|
monitorFile: function(file) {
|
||||||
if (this._fileMonitors[filename])
|
let key = file.hash();
|
||||||
|
if (this._fileMonitors[key])
|
||||||
return;
|
return;
|
||||||
|
|
||||||
let file = Gio.File.new_for_path(filename);
|
|
||||||
let monitor = file.monitor(Gio.FileMonitorFlags.NONE, null);
|
let monitor = file.monitor(Gio.FileMonitorFlags.NONE, null);
|
||||||
monitor.connect('changed',
|
monitor.connect('changed',
|
||||||
Lang.bind(this, function() {
|
Lang.bind(this, function() {
|
||||||
this.emit('file-changed', filename);
|
this.emit('file-changed', file);
|
||||||
}));
|
}));
|
||||||
|
|
||||||
this._fileMonitors[filename] = monitor;
|
this._fileMonitors[key] = monitor;
|
||||||
},
|
},
|
||||||
|
|
||||||
getAnimation: function(params) {
|
getAnimation: function(params) {
|
||||||
params = Params.parse(params, { filename: null,
|
params = Params.parse(params, { file: null,
|
||||||
onLoaded: null });
|
onLoaded: null });
|
||||||
|
|
||||||
if (this._animationFilename == params.filename) {
|
if (_fileEqual0(this._animationFile, params.file)) {
|
||||||
if (params.onLoaded) {
|
if (params.onLoaded) {
|
||||||
let id = GLib.idle_add(GLib.PRIORITY_DEFAULT, Lang.bind(this, function() {
|
let id = GLib.idle_add(GLib.PRIORITY_DEFAULT, Lang.bind(this, function() {
|
||||||
params.onLoaded(this._animation);
|
params.onLoaded(this._animation);
|
||||||
@ -160,12 +172,13 @@ const BackgroundCache = new Lang.Class({
|
|||||||
}));
|
}));
|
||||||
GLib.Source.set_name_by_id(id, '[gnome-shell] params.onLoaded');
|
GLib.Source.set_name_by_id(id, '[gnome-shell] params.onLoaded');
|
||||||
}
|
}
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
let animation = new Animation({ filename: params.filename });
|
let animation = new Animation({ file: params.file });
|
||||||
|
|
||||||
animation.load(Lang.bind(this, function() {
|
animation.load(Lang.bind(this, function() {
|
||||||
this._animationFilename = params.filename;
|
this._animationFile = params.file;
|
||||||
this._animation = animation;
|
this._animation = animation;
|
||||||
|
|
||||||
if (params.onLoaded) {
|
if (params.onLoaded) {
|
||||||
@ -218,14 +231,14 @@ const Background = new Lang.Class({
|
|||||||
params = Params.parse(params, { monitorIndex: 0,
|
params = Params.parse(params, { monitorIndex: 0,
|
||||||
layoutManager: Main.layoutManager,
|
layoutManager: Main.layoutManager,
|
||||||
settings: null,
|
settings: null,
|
||||||
filename: null,
|
file: null,
|
||||||
style: null });
|
style: null });
|
||||||
|
|
||||||
this.background = new Meta.Background({ meta_screen: global.screen });
|
this.background = new Meta.Background({ meta_screen: global.screen });
|
||||||
this.background._delegate = this;
|
this.background._delegate = this;
|
||||||
|
|
||||||
this._settings = params.settings;
|
this._settings = params.settings;
|
||||||
this._filename = params.filename;
|
this._file = params.file;
|
||||||
this._style = params.style;
|
this._style = params.style;
|
||||||
this._monitorIndex = params.monitorIndex;
|
this._monitorIndex = params.monitorIndex;
|
||||||
this._layoutManager = params.layoutManager;
|
this._layoutManager = params.layoutManager;
|
||||||
@ -242,11 +255,7 @@ const Background = new Lang.Class({
|
|||||||
|
|
||||||
destroy: function() {
|
destroy: function() {
|
||||||
this._cancellable.cancel();
|
this._cancellable.cancel();
|
||||||
|
this._removeAnimationTimeout();
|
||||||
if (this._updateAnimationTimeoutId) {
|
|
||||||
GLib.source_remove (this._updateAnimationTimeoutId);
|
|
||||||
this._updateAnimationTimeoutId = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
let i;
|
let i;
|
||||||
let keys = Object.keys(this._fileWatches);
|
let keys = Object.keys(this._fileWatches);
|
||||||
@ -260,6 +269,13 @@ const Background = new Lang.Class({
|
|||||||
this._settingsChangedSignalId = 0;
|
this._settingsChangedSignalId = 0;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
updateResolution: function() {
|
||||||
|
if (this._animation) {
|
||||||
|
this._removeAnimationTimeout();
|
||||||
|
this._updateAnimation();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
_setLoaded: function() {
|
_setLoaded: function() {
|
||||||
if (this.isLoaded)
|
if (this.isLoaded)
|
||||||
return;
|
return;
|
||||||
@ -289,18 +305,28 @@ const Background = new Lang.Class({
|
|||||||
this.background.set_gradient(shadingType, color, secondColor);
|
this.background.set_gradient(shadingType, color, secondColor);
|
||||||
},
|
},
|
||||||
|
|
||||||
_watchFile: function(filename) {
|
_watchFile: function(file) {
|
||||||
if (this._fileWatches[filename])
|
let key = file.hash();
|
||||||
|
if (this._fileWatches[key])
|
||||||
return;
|
return;
|
||||||
|
|
||||||
this._cache.monitorFile(filename);
|
this._cache.monitorFile(file);
|
||||||
let signalId = this._cache.connect('file-changed',
|
let signalId = this._cache.connect('file-changed',
|
||||||
Lang.bind(this, function(cache, changedFile) {
|
Lang.bind(this, function(cache, changedFile) {
|
||||||
if (changedFile == filename) {
|
if (changedFile.equal(file)) {
|
||||||
|
let imageCache = Meta.BackgroundImageCache.get_default();
|
||||||
|
imageCache.purge(changedFile);
|
||||||
this.emit('changed');
|
this.emit('changed');
|
||||||
}
|
}
|
||||||
}));
|
}));
|
||||||
this._fileWatches[filename] = signalId;
|
this._fileWatches[key] = signalId;
|
||||||
|
},
|
||||||
|
|
||||||
|
_removeAnimationTimeout: function() {
|
||||||
|
if (this._updateAnimationTimeoutId) {
|
||||||
|
GLib.source_remove(this._updateAnimationTimeoutId);
|
||||||
|
this._updateAnimationTimeoutId = 0;
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_updateAnimation: function() {
|
_updateAnimation: function() {
|
||||||
@ -316,9 +342,9 @@ const Background = new Lang.Class({
|
|||||||
this._animation.transitionProgress,
|
this._animation.transitionProgress,
|
||||||
this._style);
|
this._style);
|
||||||
} else if (files.length > 0) {
|
} else if (files.length > 0) {
|
||||||
this.background.set_filename(files[0], this._style);
|
this.background.set_file(files[0], this._style);
|
||||||
} else {
|
} else {
|
||||||
this.background.set_filename(null, this._style);
|
this.background.set_file(null, this._style);
|
||||||
}
|
}
|
||||||
this._queueUpdateAnimation();
|
this._queueUpdateAnimation();
|
||||||
});
|
});
|
||||||
@ -375,28 +401,28 @@ const Background = new Lang.Class({
|
|||||||
GLib.Source.set_name_by_id(this._updateAnimationTimeoutId, '[gnome-shell] this._updateAnimation');
|
GLib.Source.set_name_by_id(this._updateAnimationTimeoutId, '[gnome-shell] this._updateAnimation');
|
||||||
},
|
},
|
||||||
|
|
||||||
_loadAnimation: function(filename) {
|
_loadAnimation: function(file) {
|
||||||
this._cache.getAnimation({ filename: filename,
|
this._cache.getAnimation({ file: file,
|
||||||
onLoaded: Lang.bind(this, function(animation) {
|
onLoaded: Lang.bind(this, function(animation) {
|
||||||
this._animation = animation;
|
this._animation = animation;
|
||||||
|
|
||||||
if (!this._animation || this._cancellable.is_cancelled()) {
|
if (!this._animation || this._cancellable.is_cancelled()) {
|
||||||
this._setLoaded();
|
this._setLoaded();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
this._updateAnimation();
|
this._updateAnimation();
|
||||||
this._watchFile(filename);
|
this._watchFile(file);
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
_loadImage: function(filename) {
|
_loadImage: function(file) {
|
||||||
this.background.set_filename(filename, this._style);
|
this.background.set_file(file, this._style);
|
||||||
this._watchFile(filename);
|
this._watchFile(file);
|
||||||
|
|
||||||
let cache = Meta.BackgroundImageCache.get_default();
|
let cache = Meta.BackgroundImageCache.get_default();
|
||||||
let image = cache.load(filename);
|
let image = cache.load(file);
|
||||||
if (image.is_loaded())
|
if (image.is_loaded())
|
||||||
this._setLoaded();
|
this._setLoaded();
|
||||||
else {
|
else {
|
||||||
@ -408,11 +434,11 @@ const Background = new Lang.Class({
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_loadFile: function(filename) {
|
_loadFile: function(file) {
|
||||||
if (filename.endsWith('.xml'))
|
if (file.get_basename().endsWith('.xml'))
|
||||||
this._loadAnimation(filename);
|
this._loadAnimation(file);
|
||||||
else
|
else
|
||||||
this._loadImage(filename);
|
this._loadImage(file);
|
||||||
},
|
},
|
||||||
|
|
||||||
_load: function () {
|
_load: function () {
|
||||||
@ -420,12 +446,12 @@ const Background = new Lang.Class({
|
|||||||
|
|
||||||
this._loadPattern();
|
this._loadPattern();
|
||||||
|
|
||||||
if (!this._filename) {
|
if (!this._file) {
|
||||||
this._setLoaded();
|
this._setLoaded();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
this._loadFile(this._filename);
|
this._loadFile(this._file);
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
Signals.addSignalMethods(Background.prototype);
|
Signals.addSignalMethods(Background.prototype);
|
||||||
@ -436,11 +462,12 @@ const SystemBackground = new Lang.Class({
|
|||||||
Name: 'SystemBackground',
|
Name: 'SystemBackground',
|
||||||
|
|
||||||
_init: function() {
|
_init: function() {
|
||||||
let filename = global.datadir + '/theme/noise-texture.png';
|
let file = Gio.File.new_for_uri('resource:///org/gnome/shell/theme/noise-texture.png');
|
||||||
|
|
||||||
if (_systemBackground == null) {
|
if (_systemBackground == null) {
|
||||||
_systemBackground = new Meta.Background({ meta_screen: global.screen });
|
_systemBackground = new Meta.Background({ meta_screen: global.screen });
|
||||||
_systemBackground.set_filename(filename, GDesktopEnums.BackgroundStyle.WALLPAPER);
|
_systemBackground.set_color(DEFAULT_BACKGROUND_COLOR);
|
||||||
|
_systemBackground.set_file(file, GDesktopEnums.BackgroundStyle.WALLPAPER);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.actor = new Meta.BackgroundActor({ meta_screen: global.screen,
|
this.actor = new Meta.BackgroundActor({ meta_screen: global.screen,
|
||||||
@ -448,7 +475,7 @@ const SystemBackground = new Lang.Class({
|
|||||||
background: _systemBackground });
|
background: _systemBackground });
|
||||||
|
|
||||||
let cache = Meta.BackgroundImageCache.get_default();
|
let cache = Meta.BackgroundImageCache.get_default();
|
||||||
let image = cache.load(filename);
|
let image = cache.load(file);
|
||||||
if (image.is_loaded()) {
|
if (image.is_loaded()) {
|
||||||
image = null;
|
image = null;
|
||||||
let id = GLib.idle_add(GLib.PRIORITY_DEFAULT, Lang.bind(this, function() {
|
let id = GLib.idle_add(GLib.PRIORITY_DEFAULT, Lang.bind(this, function() {
|
||||||
@ -477,23 +504,37 @@ const BackgroundSource = new Lang.Class({
|
|||||||
this._overrideImage = GLib.getenv('SHELL_BACKGROUND_IMAGE');
|
this._overrideImage = GLib.getenv('SHELL_BACKGROUND_IMAGE');
|
||||||
this._settings = new Gio.Settings({ schema_id: settingsSchema });
|
this._settings = new Gio.Settings({ schema_id: settingsSchema });
|
||||||
this._backgrounds = [];
|
this._backgrounds = [];
|
||||||
|
|
||||||
|
this._monitorsChangedId = global.screen.connect('monitors-changed',
|
||||||
|
Lang.bind(this, this._onMonitorsChanged));
|
||||||
|
},
|
||||||
|
|
||||||
|
_onMonitorsChanged: function() {
|
||||||
|
for (let monitorIndex in this._backgrounds) {
|
||||||
|
let background = this._backgrounds[monitorIndex];
|
||||||
|
|
||||||
|
if (monitorIndex < this._layoutManager.monitors.length) {
|
||||||
|
background.updateResolution();
|
||||||
|
} else {
|
||||||
|
background.disconnect(background._changedId);
|
||||||
|
background.destroy();
|
||||||
|
delete this._backgrounds[monitorIndex];
|
||||||
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
getBackground: function(monitorIndex) {
|
getBackground: function(monitorIndex) {
|
||||||
let filename = null;
|
let file = null;
|
||||||
let style;
|
let style;
|
||||||
|
|
||||||
if (this._overrideImage != null) {
|
if (this._overrideImage != null) {
|
||||||
filename = this._overrideImage;
|
file = Gio.File.new_for_path(this._overrideImage);
|
||||||
style = GDesktopEnums.BackgroundStyle.ZOOM; // Hardcode
|
style = GDesktopEnums.BackgroundStyle.ZOOM; // Hardcode
|
||||||
} else {
|
} else {
|
||||||
style = this._settings.get_enum(BACKGROUND_STYLE_KEY);
|
style = this._settings.get_enum(BACKGROUND_STYLE_KEY);
|
||||||
if (style != GDesktopEnums.BackgroundStyle.NONE) {
|
if (style != GDesktopEnums.BackgroundStyle.NONE) {
|
||||||
let uri = this._settings.get_string(PICTURE_URI_KEY);
|
let uri = this._settings.get_string(PICTURE_URI_KEY);
|
||||||
if (GLib.uri_parse_scheme(uri) != null)
|
file = Gio.File.new_for_commandline_arg(uri);
|
||||||
filename = Gio.File.new_for_uri(uri).get_path();
|
|
||||||
else
|
|
||||||
filename = uri;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -501,7 +542,7 @@ const BackgroundSource = new Lang.Class({
|
|||||||
// they can have variants that depend on the aspect ratio and
|
// they can have variants that depend on the aspect ratio and
|
||||||
// size of the monitor; for other backgrounds we can use the
|
// size of the monitor; for other backgrounds we can use the
|
||||||
// same background object for all monitors.
|
// same background object for all monitors.
|
||||||
if (filename == null || !filename.endsWith('.xml'))
|
if (file == null || !file.get_basename().endsWith('.xml'))
|
||||||
monitorIndex = 0;
|
monitorIndex = 0;
|
||||||
|
|
||||||
if (!(monitorIndex in this._backgrounds)) {
|
if (!(monitorIndex in this._backgrounds)) {
|
||||||
@ -509,12 +550,12 @@ const BackgroundSource = new Lang.Class({
|
|||||||
monitorIndex: monitorIndex,
|
monitorIndex: monitorIndex,
|
||||||
layoutManager: this._layoutManager,
|
layoutManager: this._layoutManager,
|
||||||
settings: this._settings,
|
settings: this._settings,
|
||||||
filename: filename,
|
file: file,
|
||||||
style: style
|
style: style
|
||||||
});
|
});
|
||||||
|
|
||||||
let changedId = background.connect('changed', Lang.bind(this, function() {
|
background._changedId = background.connect('changed', Lang.bind(this, function() {
|
||||||
background.disconnect(changedId);
|
background.disconnect(background._changedId);
|
||||||
background.destroy();
|
background.destroy();
|
||||||
delete this._backgrounds[monitorIndex];
|
delete this._backgrounds[monitorIndex];
|
||||||
}));
|
}));
|
||||||
@ -526,8 +567,13 @@ const BackgroundSource = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
destroy: function() {
|
destroy: function() {
|
||||||
for (let monitorIndex in this._backgrounds)
|
global.screen.disconnect(this._monitorsChangedId);
|
||||||
this._backgrounds[monitorIndex].destroy();
|
|
||||||
|
for (let monitorIndex in this._backgrounds) {
|
||||||
|
let background = this._backgrounds[monitorIndex];
|
||||||
|
background.disconnect(background._changedId);
|
||||||
|
background.destroy();
|
||||||
|
}
|
||||||
|
|
||||||
this._backgrounds = null;
|
this._backgrounds = null;
|
||||||
}
|
}
|
||||||
@ -537,9 +583,9 @@ const Animation = new Lang.Class({
|
|||||||
Name: 'Animation',
|
Name: 'Animation',
|
||||||
|
|
||||||
_init: function(params) {
|
_init: function(params) {
|
||||||
params = Params.parse(params, { filename: null });
|
params = Params.parse(params, { file: null });
|
||||||
|
|
||||||
this.filename = params.filename;
|
this.file = params.file;
|
||||||
this.keyFrameFiles = [];
|
this.keyFrameFiles = [];
|
||||||
this.transitionProgress = 0.0;
|
this.transitionProgress = 0.0;
|
||||||
this.transitionDuration = 0.0;
|
this.transitionDuration = 0.0;
|
||||||
@ -547,9 +593,7 @@ const Animation = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
load: function(callback) {
|
load: function(callback) {
|
||||||
let file = Gio.File.new_for_path(this.filename);
|
this._show = new GnomeDesktop.BGSlideShow({ filename: this.file.get_path() });
|
||||||
|
|
||||||
this._show = new GnomeDesktop.BGSlideShow({ filename: this.filename });
|
|
||||||
|
|
||||||
this._show.load_async(null,
|
this._show.load_async(null,
|
||||||
Lang.bind(this,
|
Lang.bind(this,
|
||||||
@ -569,16 +613,16 @@ const Animation = new Lang.Class({
|
|||||||
if (this._show.get_num_slides() < 1)
|
if (this._show.get_num_slides() < 1)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
let [progress, duration, isFixed, file1, file2] = this._show.get_current_slide(monitor.width, monitor.height);
|
let [progress, duration, isFixed, filename1, filename2] = this._show.get_current_slide(monitor.width, monitor.height);
|
||||||
|
|
||||||
this.transitionDuration = duration;
|
this.transitionDuration = duration;
|
||||||
this.transitionProgress = progress;
|
this.transitionProgress = progress;
|
||||||
|
|
||||||
if (file1)
|
if (filename1)
|
||||||
this.keyFrameFiles.push(file1);
|
this.keyFrameFiles.push(Gio.File.new_for_path(filename1));
|
||||||
|
|
||||||
if (file2)
|
if (filename2)
|
||||||
this.keyFrameFiles.push(file2);
|
this.keyFrameFiles.push(Gio.File.new_for_path(filename2));
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
Signals.addSignalMethods(Animation.prototype);
|
Signals.addSignalMethods(Animation.prototype);
|
||||||
@ -701,7 +745,7 @@ const BackgroundManager = new Lang.Class({
|
|||||||
background.disconnect(changeSignalId);
|
background.disconnect(changeSignalId);
|
||||||
|
|
||||||
if (backgroundActor.loadedSignalId)
|
if (backgroundActor.loadedSignalId)
|
||||||
backgroundActor.background._delegate.disconnect(backgroundActor.loadedSignalId);
|
background.disconnect(backgroundActor.loadedSignalId);
|
||||||
}));
|
}));
|
||||||
|
|
||||||
return backgroundActor;
|
return backgroundActor;
|
||||||
|
@ -13,9 +13,11 @@ const Shell = imports.gi.Shell;
|
|||||||
|
|
||||||
const MSECS_IN_DAY = 24 * 60 * 60 * 1000;
|
const MSECS_IN_DAY = 24 * 60 * 60 * 1000;
|
||||||
const SHOW_WEEKDATE_KEY = 'show-weekdate';
|
const SHOW_WEEKDATE_KEY = 'show-weekdate';
|
||||||
|
const ELLIPSIS_CHAR = '\u2026';
|
||||||
|
|
||||||
// alias to prevent xgettext from picking up strings translated in GTK+
|
// alias to prevent xgettext from picking up strings translated in GTK+
|
||||||
const gtk30_ = Gettext_gtk30.gettext;
|
const gtk30_ = Gettext_gtk30.gettext;
|
||||||
|
const NC_ = function(context, str) { return str; };
|
||||||
|
|
||||||
// in org.gnome.desktop.interface
|
// in org.gnome.desktop.interface
|
||||||
const CLOCK_FORMAT_KEY = 'clock-format';
|
const CLOCK_FORMAT_KEY = 'clock-format';
|
||||||
@ -32,12 +34,10 @@ function _sameDay(dateA, dateB) {
|
|||||||
return _sameMonth(dateA, dateB) && (dateA.getDate() == dateB.getDate());
|
return _sameMonth(dateA, dateB) && (dateA.getDate() == dateB.getDate());
|
||||||
}
|
}
|
||||||
|
|
||||||
/* TODO: maybe needs config - right now we assume that Saturday and
|
|
||||||
* Sunday are non-work days (not true in e.g. Israel, it's Sunday and
|
|
||||||
* Monday there)
|
|
||||||
*/
|
|
||||||
function _isWorkDay(date) {
|
function _isWorkDay(date) {
|
||||||
return date.getDay() != 0 && date.getDay() != 6;
|
/* Translators: Enter 0-6 (Sunday-Saturday) for non-work days. Examples: "0" (Sunday) "6" (Saturday) "06" (Sunday and Saturday). */
|
||||||
|
let days = C_('calendar-no-work', "06");
|
||||||
|
return days.indexOf(date.getDay().toString()) == -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
function _getBeginningOfDay(date) {
|
function _getBeginningOfDay(date) {
|
||||||
@ -58,19 +58,21 @@ function _getEndOfDay(date) {
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
function _formatEventTime(event, clockFormat) {
|
function _formatEventTime(event, clockFormat, periodBegin, periodEnd) {
|
||||||
let ret;
|
let ret;
|
||||||
if (event.allDay) {
|
let allDay = (event.allDay || (event.date <= periodBegin && event.end >= periodEnd));
|
||||||
|
if (allDay) {
|
||||||
/* Translators: Shown in calendar event list for all day events
|
/* Translators: Shown in calendar event list for all day events
|
||||||
* Keep it short, best if you can use less then 10 characters
|
* Keep it short, best if you can use less then 10 characters
|
||||||
*/
|
*/
|
||||||
ret = C_("event list time", "All Day");
|
ret = C_("event list time", "All Day");
|
||||||
} else {
|
} else {
|
||||||
|
let date = event.date >= periodBegin ? event.date : event.end;
|
||||||
switch (clockFormat) {
|
switch (clockFormat) {
|
||||||
case '24h':
|
case '24h':
|
||||||
/* Translators: Shown in calendar event list, if 24h format,
|
/* Translators: Shown in calendar event list, if 24h format,
|
||||||
\u2236 is a ratio character, similar to : */
|
\u2236 is a ratio character, similar to : */
|
||||||
ret = event.date.toLocaleFormat(C_("event list time", "%H\u2236%M"));
|
ret = date.toLocaleFormat(C_("event list time", "%H\u2236%M"));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@ -79,7 +81,7 @@ function _formatEventTime(event, clockFormat) {
|
|||||||
/* Translators: Shown in calendar event list, if 12h format,
|
/* Translators: Shown in calendar event list, if 12h format,
|
||||||
\u2236 is a ratio character, similar to : and \u2009 is
|
\u2236 is a ratio character, similar to : and \u2009 is
|
||||||
a thin space */
|
a thin space */
|
||||||
ret = event.date.toLocaleFormat(C_("event list time", "%l\u2236%M\u2009%p"));
|
ret = date.toLocaleFormat(C_("event list time", "%l\u2236%M\u2009%p"));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -361,6 +363,12 @@ const DBusEventSource = new Lang.Class({
|
|||||||
result.push(event);
|
result.push(event);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
result.sort(function(event1, event2) {
|
||||||
|
// sort events by end time on ending day
|
||||||
|
let d1 = event1.date < begin && event1.end <= end ? event1.end : event1.date;
|
||||||
|
let d2 = event2.date < begin && event2.end <= end ? event2.end : event2.date;
|
||||||
|
return d1.getTime() - d2.getTime();
|
||||||
|
});
|
||||||
return result;
|
return result;
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -721,12 +729,16 @@ const EventsList = new Lang.Class({
|
|||||||
this._eventSource.connect('changed', Lang.bind(this, this._update));
|
this._eventSource.connect('changed', Lang.bind(this, this._update));
|
||||||
},
|
},
|
||||||
|
|
||||||
_addEvent: function(event, index, includeDayName) {
|
_addEvent: function(event, index, includeDayName, periodBegin, periodEnd) {
|
||||||
let dayString;
|
let dayString;
|
||||||
if (includeDayName)
|
if (includeDayName) {
|
||||||
dayString = _getEventDayAbbreviation(event.date.getDay());
|
if (event.date >= periodBegin)
|
||||||
else
|
dayString = _getEventDayAbbreviation(event.date.getDay());
|
||||||
|
else /* show event end day if it began earlier */
|
||||||
|
dayString = _getEventDayAbbreviation(event.end.getDay());
|
||||||
|
} else {
|
||||||
dayString = '';
|
dayString = '';
|
||||||
|
}
|
||||||
|
|
||||||
let dayLabel = new St.Label({ style_class: 'events-day-dayname',
|
let dayLabel = new St.Label({ style_class: 'events-day-dayname',
|
||||||
text: dayString,
|
text: dayString,
|
||||||
@ -739,16 +751,30 @@ const EventsList = new Lang.Class({
|
|||||||
|
|
||||||
let layout = this.actor.layout_manager;
|
let layout = this.actor.layout_manager;
|
||||||
layout.attach(dayLabel, rtl ? 2 : 0, index, 1, 1);
|
layout.attach(dayLabel, rtl ? 2 : 0, index, 1, 1);
|
||||||
|
|
||||||
let clockFormat = this._desktopSettings.get_string(CLOCK_FORMAT_KEY);
|
let clockFormat = this._desktopSettings.get_string(CLOCK_FORMAT_KEY);
|
||||||
let timeString = _formatEventTime(event, clockFormat);
|
let timeString = _formatEventTime(event, clockFormat, periodBegin, periodEnd);
|
||||||
let timeLabel = new St.Label({ style_class: 'events-day-time',
|
let timeLabel = new St.Label({ style_class: 'events-day-time',
|
||||||
text: timeString,
|
text: timeString,
|
||||||
y_align: Clutter.ActorAlign.START });
|
y_align: Clutter.ActorAlign.START });
|
||||||
timeLabel.clutter_text.line_wrap = false;
|
timeLabel.clutter_text.line_wrap = false;
|
||||||
timeLabel.clutter_text.ellipsize = false;
|
timeLabel.clutter_text.ellipsize = false;
|
||||||
|
|
||||||
layout.attach(timeLabel, 1, index, 1, 1);
|
let preEllipsisLabel = new St.Label({ style_class: 'events-day-time-ellipses',
|
||||||
|
text: ELLIPSIS_CHAR,
|
||||||
|
y_align: Clutter.ActorAlign.START });
|
||||||
|
let postEllipsisLabel = new St.Label({ style_class: 'events-day-time-ellipses',
|
||||||
|
text: ELLIPSIS_CHAR,
|
||||||
|
y_align: Clutter.ActorAlign.START });
|
||||||
|
if (event.allDay || event.date >= periodBegin)
|
||||||
|
preEllipsisLabel.opacity = 0;
|
||||||
|
if (event.allDay || event.end <= periodEnd)
|
||||||
|
postEllipsisLabel.opacity = 0;
|
||||||
|
|
||||||
|
let timeLabelBoxLayout = new St.BoxLayout();
|
||||||
|
timeLabelBoxLayout.add(preEllipsisLabel);
|
||||||
|
timeLabelBoxLayout.add(timeLabel);
|
||||||
|
timeLabelBoxLayout.add(postEllipsisLabel);
|
||||||
|
layout.attach(timeLabelBoxLayout, 1, index, 1, 1);
|
||||||
|
|
||||||
let titleLabel = new St.Label({ style_class: 'events-day-task',
|
let titleLabel = new St.Label({ style_class: 'events-day-task',
|
||||||
text: event.summary,
|
text: event.summary,
|
||||||
@ -759,8 +785,8 @@ const EventsList = new Lang.Class({
|
|||||||
layout.attach(titleLabel, rtl ? 0 : 2, index, 1, 1);
|
layout.attach(titleLabel, rtl ? 0 : 2, index, 1, 1);
|
||||||
},
|
},
|
||||||
|
|
||||||
_addPeriod: function(header, index, begin, end, includeDayName, showNothingScheduled) {
|
_addPeriod: function(header, index, periodBegin, periodEnd, includeDayName, showNothingScheduled) {
|
||||||
let events = this._eventSource.getEvents(begin, end);
|
let events = this._eventSource.getEvents(periodBegin, periodEnd);
|
||||||
|
|
||||||
if (events.length == 0 && !showNothingScheduled)
|
if (events.length == 0 && !showNothingScheduled)
|
||||||
return index;
|
return index;
|
||||||
@ -771,15 +797,14 @@ const EventsList = new Lang.Class({
|
|||||||
index++;
|
index++;
|
||||||
|
|
||||||
for (let n = 0; n < events.length; n++) {
|
for (let n = 0; n < events.length; n++) {
|
||||||
this._addEvent(events[n], index, includeDayName);
|
this._addEvent(events[n], index, includeDayName, periodBegin, periodEnd);
|
||||||
index++;
|
index++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (events.length == 0 && showNothingScheduled) {
|
if (events.length == 0 && showNothingScheduled) {
|
||||||
let now = new Date();
|
|
||||||
/* Translators: Text to show if there are no events */
|
/* Translators: Text to show if there are no events */
|
||||||
let nothingEvent = new CalendarEvent(now, now, _("Nothing Scheduled"), true);
|
let nothingEvent = new CalendarEvent(periodBegin, periodBegin, _("Nothing Scheduled"), true);
|
||||||
this._addEvent(nothingEvent, index, false);
|
this._addEvent(nothingEvent, index, false, periodBegin, periodEnd);
|
||||||
index++;
|
index++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -792,14 +817,17 @@ const EventsList = new Lang.Class({
|
|||||||
let dayBegin = _getBeginningOfDay(day);
|
let dayBegin = _getBeginningOfDay(day);
|
||||||
let dayEnd = _getEndOfDay(day);
|
let dayEnd = _getEndOfDay(day);
|
||||||
|
|
||||||
let dayString;
|
let dayFormat;
|
||||||
let now = new Date();
|
let now = new Date();
|
||||||
if (_sameYear(day, now))
|
if (_sameYear(day, now))
|
||||||
/* Translators: Shown on calendar heading when selected day occurs on current year */
|
/* Translators: Shown on calendar heading when selected day occurs on current year */
|
||||||
dayString = day.toLocaleFormat(C_("calendar heading", "%A, %B %d"));
|
dayFormat = Shell.util_translate_time_string(NC_("calendar heading",
|
||||||
|
"%A, %B %d"));
|
||||||
else
|
else
|
||||||
/* Translators: Shown on calendar heading when selected day occurs on different year */
|
/* Translators: Shown on calendar heading when selected day occurs on different year */
|
||||||
dayString = day.toLocaleFormat(C_("calendar heading", "%A, %B %d, %Y"));
|
dayFormat = Shell.util_translate_time_string(NC_("calendar heading",
|
||||||
|
"%A, %B %d, %Y"));
|
||||||
|
let dayString = day.toLocaleFormat(dayFormat);
|
||||||
this._addPeriod(dayString, 0, dayBegin, dayEnd, false, true);
|
this._addPeriod(dayString, 0, dayBegin, dayEnd, false, true);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -84,6 +84,7 @@ const KeyringDialog = new Lang.Class({
|
|||||||
let table = new St.Widget({ style_class: 'keyring-dialog-control-table',
|
let table = new St.Widget({ style_class: 'keyring-dialog-control-table',
|
||||||
layout_manager: layout });
|
layout_manager: layout });
|
||||||
layout.hookup_style(table);
|
layout.hookup_style(table);
|
||||||
|
let rtl = table.get_text_direction() == Clutter.TextDirection.RTL;
|
||||||
let row = 0;
|
let row = 0;
|
||||||
|
|
||||||
if (this.prompt.password_visible) {
|
if (this.prompt.password_visible) {
|
||||||
@ -92,7 +93,6 @@ const KeyringDialog = new Lang.Class({
|
|||||||
y_align: Clutter.ActorAlign.CENTER });
|
y_align: Clutter.ActorAlign.CENTER });
|
||||||
label.set_text(_("Password:"));
|
label.set_text(_("Password:"));
|
||||||
label.clutter_text.ellipsize = Pango.EllipsizeMode.NONE;
|
label.clutter_text.ellipsize = Pango.EllipsizeMode.NONE;
|
||||||
layout.attach(label, 0, row, 1, 1);
|
|
||||||
this._passwordEntry = new St.Entry({ style_class: 'prompt-dialog-password-entry',
|
this._passwordEntry = new St.Entry({ style_class: 'prompt-dialog-password-entry',
|
||||||
text: '',
|
text: '',
|
||||||
can_focus: true,
|
can_focus: true,
|
||||||
@ -100,7 +100,14 @@ const KeyringDialog = new Lang.Class({
|
|||||||
this._passwordEntry.clutter_text.set_password_char('\u25cf'); // ● U+25CF BLACK CIRCLE
|
this._passwordEntry.clutter_text.set_password_char('\u25cf'); // ● U+25CF BLACK CIRCLE
|
||||||
ShellEntry.addContextMenu(this._passwordEntry, { isPassword: true });
|
ShellEntry.addContextMenu(this._passwordEntry, { isPassword: true });
|
||||||
this._passwordEntry.clutter_text.connect('activate', Lang.bind(this, this._onPasswordActivate));
|
this._passwordEntry.clutter_text.connect('activate', Lang.bind(this, this._onPasswordActivate));
|
||||||
layout.attach(this._passwordEntry, 1, row, 1, 1);
|
|
||||||
|
if (rtl) {
|
||||||
|
layout.attach(this._passwordEntry, 0, row, 1, 1);
|
||||||
|
layout.attach(label, 1, row, 1, 1);
|
||||||
|
} else {
|
||||||
|
layout.attach(label, 0, row, 1, 1);
|
||||||
|
layout.attach(this._passwordEntry, 1, row, 1, 1);
|
||||||
|
}
|
||||||
row++;
|
row++;
|
||||||
} else {
|
} else {
|
||||||
this._passwordEntry = null;
|
this._passwordEntry = null;
|
||||||
@ -111,7 +118,6 @@ const KeyringDialog = new Lang.Class({
|
|||||||
x_align: Clutter.ActorAlign.START,
|
x_align: Clutter.ActorAlign.START,
|
||||||
y_align: Clutter.ActorAlign.CENTER }));
|
y_align: Clutter.ActorAlign.CENTER }));
|
||||||
label.set_text(_("Type again:"));
|
label.set_text(_("Type again:"));
|
||||||
layout.attach(label, 0, row, 1, 1);
|
|
||||||
this._confirmEntry = new St.Entry({ style_class: 'prompt-dialog-password-entry',
|
this._confirmEntry = new St.Entry({ style_class: 'prompt-dialog-password-entry',
|
||||||
text: '',
|
text: '',
|
||||||
can_focus: true,
|
can_focus: true,
|
||||||
@ -119,7 +125,13 @@ const KeyringDialog = new Lang.Class({
|
|||||||
this._confirmEntry.clutter_text.set_password_char('\u25cf'); // ● U+25CF BLACK CIRCLE
|
this._confirmEntry.clutter_text.set_password_char('\u25cf'); // ● U+25CF BLACK CIRCLE
|
||||||
ShellEntry.addContextMenu(this._confirmEntry, { isPassword: true });
|
ShellEntry.addContextMenu(this._confirmEntry, { isPassword: true });
|
||||||
this._confirmEntry.clutter_text.connect('activate', Lang.bind(this, this._onConfirmActivate));
|
this._confirmEntry.clutter_text.connect('activate', Lang.bind(this, this._onConfirmActivate));
|
||||||
layout.attach(this._confirmEntry, 1, row, 1, 1);
|
if (rtl) {
|
||||||
|
layout.attach(this._confirmEntry, 0, row, 1, 1);
|
||||||
|
layout.attach(label, 1, row, 1, 1);
|
||||||
|
} else {
|
||||||
|
layout.attach(label, 0, row, 1, 1);
|
||||||
|
layout.attach(this._confirmEntry, 1, row, 1, 1);
|
||||||
|
}
|
||||||
row++;
|
row++;
|
||||||
} else {
|
} else {
|
||||||
this._confirmEntry = null;
|
this._confirmEntry = null;
|
||||||
@ -132,7 +144,7 @@ const KeyringDialog = new Lang.Class({
|
|||||||
let choice = new CheckBox.CheckBox();
|
let choice = new CheckBox.CheckBox();
|
||||||
this.prompt.bind_property('choice-label', choice.getLabelActor(), 'text', GObject.BindingFlags.SYNC_CREATE);
|
this.prompt.bind_property('choice-label', choice.getLabelActor(), 'text', GObject.BindingFlags.SYNC_CREATE);
|
||||||
this.prompt.bind_property('choice-chosen', choice.actor, 'checked', GObject.BindingFlags.SYNC_CREATE | GObject.BindingFlags.BIDIRECTIONAL);
|
this.prompt.bind_property('choice-chosen', choice.actor, 'checked', GObject.BindingFlags.SYNC_CREATE | GObject.BindingFlags.BIDIRECTIONAL);
|
||||||
layout.attach(choice.actor, 1, row, 1, 1);
|
layout.attach(choice.actor, rtl ? 0 : 1, row, 1, 1);
|
||||||
row++;
|
row++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -140,7 +152,7 @@ const KeyringDialog = new Lang.Class({
|
|||||||
x_align: Clutter.ActorAlign.START });
|
x_align: Clutter.ActorAlign.START });
|
||||||
warning.clutter_text.ellipsize = Pango.EllipsizeMode.NONE;
|
warning.clutter_text.ellipsize = Pango.EllipsizeMode.NONE;
|
||||||
warning.clutter_text.line_wrap = true;
|
warning.clutter_text.line_wrap = true;
|
||||||
layout.attach(warning, 1, row, 1, 1);
|
layout.attach(warning, rtl ? 0 : 1, row, 1, 1);
|
||||||
this.prompt.bind_property('warning-visible', warning, 'visible', GObject.BindingFlags.SYNC_CREATE);
|
this.prompt.bind_property('warning-visible', warning, 'visible', GObject.BindingFlags.SYNC_CREATE);
|
||||||
this.prompt.bind_property('warning', warning, 'text', GObject.BindingFlags.SYNC_CREATE);
|
this.prompt.bind_property('warning', warning, 'text', GObject.BindingFlags.SYNC_CREATE);
|
||||||
|
|
||||||
|
@ -380,6 +380,12 @@ const VPNRequestHandler = new Lang.Class({
|
|||||||
argv.push('-i');
|
argv.push('-i');
|
||||||
if (flags & NMClient.SecretAgentGetSecretsFlags.REQUEST_NEW)
|
if (flags & NMClient.SecretAgentGetSecretsFlags.REQUEST_NEW)
|
||||||
argv.push('-r');
|
argv.push('-r');
|
||||||
|
if (authHelper.supportsHints) {
|
||||||
|
for (let i = 0; i < hints.length; i++) {
|
||||||
|
argv.push('-t');
|
||||||
|
argv.push(hints[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
this._newStylePlugin = authHelper.externalUIMode;
|
this._newStylePlugin = authHelper.externalUIMode;
|
||||||
|
|
||||||
@ -598,7 +604,9 @@ const NetworkAgent = new Lang.Class({
|
|||||||
Name: 'NetworkAgent',
|
Name: 'NetworkAgent',
|
||||||
|
|
||||||
_init: function() {
|
_init: function() {
|
||||||
this._native = new Shell.NetworkAgent({ identifier: 'org.gnome.Shell.NetworkAgent' });
|
this._native = new Shell.NetworkAgent({ identifier: 'org.gnome.Shell.NetworkAgent',
|
||||||
|
capabilities: NMClient.SecretAgentCapabilities.VPN_HINTS
|
||||||
|
});
|
||||||
|
|
||||||
this._dialogs = { };
|
this._dialogs = { };
|
||||||
this._vpnRequests = { };
|
this._vpnRequests = { };
|
||||||
@ -698,16 +706,23 @@ const NetworkAgent = new Lang.Class({
|
|||||||
let service = keyfile.get_string('VPN Connection', 'service');
|
let service = keyfile.get_string('VPN Connection', 'service');
|
||||||
let binary = keyfile.get_string('GNOME', 'auth-dialog');
|
let binary = keyfile.get_string('GNOME', 'auth-dialog');
|
||||||
let externalUIMode = false;
|
let externalUIMode = false;
|
||||||
|
let hints = false;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
externalUIMode = keyfile.get_boolean('GNOME', 'supports-external-ui-mode');
|
externalUIMode = keyfile.get_boolean('GNOME', 'supports-external-ui-mode');
|
||||||
} catch(e) { } // ignore errors if key does not exist
|
} catch(e) { } // ignore errors if key does not exist
|
||||||
|
|
||||||
|
try {
|
||||||
|
hints = keyfile.get_boolean('GNOME', 'supports-hints');
|
||||||
|
} catch(e) { } // ignore errors if key does not exist
|
||||||
|
|
||||||
let path = binary;
|
let path = binary;
|
||||||
if (!GLib.path_is_absolute(path)) {
|
if (!GLib.path_is_absolute(path)) {
|
||||||
path = GLib.build_filenamev([Config.LIBEXECDIR, path]);
|
path = GLib.build_filenamev([Config.LIBEXECDIR, path]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (GLib.file_test(path, GLib.FileTest.IS_EXECUTABLE))
|
if (GLib.file_test(path, GLib.FileTest.IS_EXECUTABLE))
|
||||||
this._vpnBinaries[service] = { fileName: path, externalUIMode: externalUIMode };
|
this._vpnBinaries[service] = { fileName: path, externalUIMode: externalUIMode, supportsHints: hints };
|
||||||
else
|
else
|
||||||
throw new Error('VPN plugin at %s is not executable'.format(path));
|
throw new Error('VPN plugin at %s is not executable'.format(path));
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
|
@ -36,6 +36,8 @@ const NotificationDirection = {
|
|||||||
RECEIVED: 'chat-received'
|
RECEIVED: 'chat-received'
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const N_ = function(s) { return s; };
|
||||||
|
|
||||||
function makeMessageFromTpMessage(tpMessage, direction) {
|
function makeMessageFromTpMessage(tpMessage, direction) {
|
||||||
let [text, flags] = tpMessage.to_text();
|
let [text, flags] = tpMessage.to_text();
|
||||||
|
|
||||||
@ -950,70 +952,70 @@ const ChatNotification = new Lang.Class({
|
|||||||
// Show only the time if date is on today
|
// Show only the time if date is on today
|
||||||
if(daysAgo < 1){
|
if(daysAgo < 1){
|
||||||
/* Translators: Time in 24h format */
|
/* Translators: Time in 24h format */
|
||||||
format = _("%H\u2236%M");
|
format = N_("%H\u2236%M");
|
||||||
}
|
}
|
||||||
// Show the word "Yesterday" and time if date is on yesterday
|
// Show the word "Yesterday" and time if date is on yesterday
|
||||||
else if(daysAgo <2){
|
else if(daysAgo <2){
|
||||||
/* Translators: this is the word "Yesterday" followed by a
|
/* Translators: this is the word "Yesterday" followed by a
|
||||||
time string in 24h format. i.e. "Yesterday, 14:30" */
|
time string in 24h format. i.e. "Yesterday, 14:30" */
|
||||||
// xgettext:no-c-format
|
// xgettext:no-c-format
|
||||||
format = _("Yesterday, %H\u2236%M");
|
format = N_("Yesterday, %H\u2236%M");
|
||||||
}
|
}
|
||||||
// Show a week day and time if date is in the last week
|
// Show a week day and time if date is in the last week
|
||||||
else if (daysAgo < 7) {
|
else if (daysAgo < 7) {
|
||||||
/* Translators: this is the week day name followed by a time
|
/* Translators: this is the week day name followed by a time
|
||||||
string in 24h format. i.e. "Monday, 14:30" */
|
string in 24h format. i.e. "Monday, 14:30" */
|
||||||
// xgettext:no-c-format
|
// xgettext:no-c-format
|
||||||
format = _("%A, %H\u2236%M");
|
format = N_("%A, %H\u2236%M");
|
||||||
|
|
||||||
} else if (date.getYear() == now.getYear()) {
|
} else if (date.getYear() == now.getYear()) {
|
||||||
/* Translators: this is the month name and day number
|
/* Translators: this is the month name and day number
|
||||||
followed by a time string in 24h format.
|
followed by a time string in 24h format.
|
||||||
i.e. "May 25, 14:30" */
|
i.e. "May 25, 14:30" */
|
||||||
// xgettext:no-c-format
|
// xgettext:no-c-format
|
||||||
format = _("%B %d, %H\u2236%M");
|
format = N_("%B %d, %H\u2236%M");
|
||||||
} else {
|
} else {
|
||||||
/* Translators: this is the month name, day number, year
|
/* Translators: this is the month name, day number, year
|
||||||
number followed by a time string in 24h format.
|
number followed by a time string in 24h format.
|
||||||
i.e. "May 25 2012, 14:30" */
|
i.e. "May 25 2012, 14:30" */
|
||||||
// xgettext:no-c-format
|
// xgettext:no-c-format
|
||||||
format = _("%B %d %Y, %H\u2236%M");
|
format = N_("%B %d %Y, %H\u2236%M");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// Show only the time if date is on today
|
// Show only the time if date is on today
|
||||||
if(daysAgo < 1){
|
if(daysAgo < 1){
|
||||||
/* Translators: Time in 24h format */
|
/* Translators: Time in 24h format */
|
||||||
format = _("%l\u2236%M %p");
|
format = N_("%l\u2236%M %p");
|
||||||
}
|
}
|
||||||
// Show the word "Yesterday" and time if date is on yesterday
|
// Show the word "Yesterday" and time if date is on yesterday
|
||||||
else if(daysAgo <2){
|
else if(daysAgo <2){
|
||||||
/* Translators: this is the word "Yesterday" followed by a
|
/* Translators: this is the word "Yesterday" followed by a
|
||||||
time string in 12h format. i.e. "Yesterday, 2:30 pm" */
|
time string in 12h format. i.e. "Yesterday, 2:30 pm" */
|
||||||
// xgettext:no-c-format
|
// xgettext:no-c-format
|
||||||
format = _("Yesterday, %l\u2236%M %p");
|
format = N_("Yesterday, %l\u2236%M %p");
|
||||||
}
|
}
|
||||||
// Show a week day and time if date is in the last week
|
// Show a week day and time if date is in the last week
|
||||||
else if (daysAgo < 7) {
|
else if (daysAgo < 7) {
|
||||||
/* Translators: this is the week day name followed by a time
|
/* Translators: this is the week day name followed by a time
|
||||||
string in 12h format. i.e. "Monday, 2:30 pm" */
|
string in 12h format. i.e. "Monday, 2:30 pm" */
|
||||||
// xgettext:no-c-format
|
// xgettext:no-c-format
|
||||||
format = _("%A, %l\u2236%M %p");
|
format = N_("%A, %l\u2236%M %p");
|
||||||
|
|
||||||
} else if (date.getYear() == now.getYear()) {
|
} else if (date.getYear() == now.getYear()) {
|
||||||
/* Translators: this is the month name and day number
|
/* Translators: this is the month name and day number
|
||||||
followed by a time string in 12h format.
|
followed by a time string in 12h format.
|
||||||
i.e. "May 25, 2:30 pm" */
|
i.e. "May 25, 2:30 pm" */
|
||||||
// xgettext:no-c-format
|
// xgettext:no-c-format
|
||||||
format = _("%B %d, %l\u2236%M %p");
|
format = N_("%B %d, %l\u2236%M %p");
|
||||||
} else {
|
} else {
|
||||||
/* Translators: this is the month name, day number, year
|
/* Translators: this is the month name, day number, year
|
||||||
number followed by a time string in 12h format.
|
number followed by a time string in 12h format.
|
||||||
i.e. "May 25 2012, 2:30 pm"*/
|
i.e. "May 25 2012, 2:30 pm"*/
|
||||||
// xgettext:no-c-format
|
// xgettext:no-c-format
|
||||||
format = _("%B %d %Y, %l\u2236%M %p");
|
format = N_("%B %d %Y, %l\u2236%M %p");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return date.toLocaleFormat(format);
|
return date.toLocaleFormat(Shell.util_translate_time_string(format));
|
||||||
},
|
},
|
||||||
|
|
||||||
appendTimestamp: function() {
|
appendTimestamp: function() {
|
||||||
@ -1264,9 +1266,8 @@ const SubscriptionRequestNotification = new Lang.Class({
|
|||||||
let file = contact.get_avatar_file();
|
let file = contact.get_avatar_file();
|
||||||
|
|
||||||
if (file) {
|
if (file) {
|
||||||
let uri = file.get_uri();
|
|
||||||
let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor;
|
let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor;
|
||||||
iconBox.child = textureCache.load_uri_async(uri, iconBox._size, iconBox._size, scaleFactor);
|
iconBox.child = textureCache.load_file_async(file, iconBox._size, iconBox._size, scaleFactor);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
iconBox.child = new St.Icon({ icon_name: 'avatar-default',
|
iconBox.child = new St.Icon({ icon_name: 'avatar-default',
|
||||||
|
@ -140,20 +140,10 @@ const CtrlAltTabPopup = new Lang.Class({
|
|||||||
Name: 'CtrlAltTabPopup',
|
Name: 'CtrlAltTabPopup',
|
||||||
Extends: SwitcherPopup.SwitcherPopup,
|
Extends: SwitcherPopup.SwitcherPopup,
|
||||||
|
|
||||||
_createSwitcher: function() {
|
_init: function(items) {
|
||||||
this._switcherList = new CtrlAltTabSwitcher(this._items);
|
this.parent(items);
|
||||||
return true;
|
|
||||||
},
|
|
||||||
|
|
||||||
_initialSelection: function(backward, binding) {
|
this._switcherList = new CtrlAltTabSwitcher(this._items);
|
||||||
if (binding == 'switch-panels') {
|
|
||||||
if (backward)
|
|
||||||
this._selectedIndex = this._items.length - 1;
|
|
||||||
} else if (binding == 'switch-panels-backward') {
|
|
||||||
if (!backward)
|
|
||||||
this._selectedIndex = this._items.length - 1;
|
|
||||||
}
|
|
||||||
this._select(this._selectedIndex);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_keyPressHandler: function(keysym, action) {
|
_keyPressHandler: function(keysym, action) {
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
const GLib = imports.gi.GLib;
|
const GLib = imports.gi.GLib;
|
||||||
const Gio = imports.gi.Gio;
|
const Gio = imports.gi.Gio;
|
||||||
const GnomeDesktop = imports.gi.GnomeDesktop;
|
const GnomeDesktop = imports.gi.GnomeDesktop;
|
||||||
|
const GObject = imports.gi.GObject;
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
const Mainloop = imports.mainloop;
|
const Mainloop = imports.mainloop;
|
||||||
const Cairo = imports.cairo;
|
const Cairo = imports.cairo;
|
||||||
@ -18,6 +19,8 @@ const PanelMenu = imports.ui.panelMenu;
|
|||||||
const PopupMenu = imports.ui.popupMenu;
|
const PopupMenu = imports.ui.popupMenu;
|
||||||
const Calendar = imports.ui.calendar;
|
const Calendar = imports.ui.calendar;
|
||||||
|
|
||||||
|
const N_ = function(s) { return s; };
|
||||||
|
|
||||||
function _onVertSepRepaint(area) {
|
function _onVertSepRepaint(area) {
|
||||||
let cr = area.get_context();
|
let cr = area.get_context();
|
||||||
let themeNode = area.get_theme_node();
|
let themeNode = area.get_theme_node();
|
||||||
@ -124,14 +127,19 @@ const DateMenuButton = new Lang.Class({
|
|||||||
if (isOpen) {
|
if (isOpen) {
|
||||||
let now = new Date();
|
let now = new Date();
|
||||||
this._calendar.setDate(now);
|
this._calendar.setDate(now);
|
||||||
|
|
||||||
|
/* Translators: This is the date format to use when the calendar popup is
|
||||||
|
* shown - it is shown just below the time in the shell (e.g. "Tue 9:29 AM").
|
||||||
|
*/
|
||||||
|
let dateFormat = Shell.util_translate_time_string (N_("%A %B %e, %Y"));
|
||||||
|
this._date.set_label(now.toLocaleFormat(dateFormat));
|
||||||
}
|
}
|
||||||
}));
|
}));
|
||||||
|
|
||||||
// Done with hbox for calendar and event list
|
// Done with hbox for calendar and event list
|
||||||
|
|
||||||
this._clock = new GnomeDesktop.WallClock();
|
this._clock = new GnomeDesktop.WallClock();
|
||||||
this._clock.connect('notify::clock', Lang.bind(this, this._updateClockAndDate));
|
this._clock.bind_property('clock', this._clockDisplay, 'text', GObject.BindingFlags.SYNC_CREATE);
|
||||||
this._updateClockAndDate();
|
|
||||||
|
|
||||||
Main.sessionMode.connect('updated', Lang.bind(this, this._sessionUpdated));
|
Main.sessionMode.connect('updated', Lang.bind(this, this._sessionUpdated));
|
||||||
this._sessionUpdated();
|
this._sessionUpdated();
|
||||||
@ -141,7 +149,7 @@ const DateMenuButton = new Lang.Class({
|
|||||||
let now = new Date();
|
let now = new Date();
|
||||||
return now.getYear() == date.getYear() &&
|
return now.getYear() == date.getYear() &&
|
||||||
now.getMonth() == date.getMonth() &&
|
now.getMonth() == date.getMonth() &&
|
||||||
now.getDay() == date.getDay();
|
now.getDate() == date.getDate();
|
||||||
},
|
},
|
||||||
|
|
||||||
_appInstalledChanged: function() {
|
_appInstalledChanged: function() {
|
||||||
@ -167,6 +175,10 @@ const DateMenuButton = new Lang.Class({
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_getEventSource: function() {
|
||||||
|
return new Calendar.DBusEventSource();
|
||||||
|
},
|
||||||
|
|
||||||
_setEventSource: function(eventSource) {
|
_setEventSource: function(eventSource) {
|
||||||
if (this._eventSource)
|
if (this._eventSource)
|
||||||
this._eventSource.destroy();
|
this._eventSource.destroy();
|
||||||
@ -184,7 +196,7 @@ const DateMenuButton = new Lang.Class({
|
|||||||
let eventSource;
|
let eventSource;
|
||||||
let showEvents = Main.sessionMode.showCalendarEvents;
|
let showEvents = Main.sessionMode.showCalendarEvents;
|
||||||
if (showEvents) {
|
if (showEvents) {
|
||||||
eventSource = new Calendar.DBusEventSource();
|
eventSource = this._getEventSource();
|
||||||
} else {
|
} else {
|
||||||
eventSource = new Calendar.EmptyEventSource();
|
eventSource = new Calendar.EmptyEventSource();
|
||||||
}
|
}
|
||||||
@ -196,16 +208,6 @@ const DateMenuButton = new Lang.Class({
|
|||||||
this._dateAndTimeSeparator.actor.visible = Main.sessionMode.allowSettings;
|
this._dateAndTimeSeparator.actor.visible = Main.sessionMode.allowSettings;
|
||||||
},
|
},
|
||||||
|
|
||||||
_updateClockAndDate: function() {
|
|
||||||
this._clockDisplay.set_text(this._clock.clock);
|
|
||||||
/* Translators: This is the date format to use when the calendar popup is
|
|
||||||
* shown - it is shown just below the time in the shell (e.g. "Tue 9:29 AM").
|
|
||||||
*/
|
|
||||||
let dateFormat = _("%A %B %e, %Y");
|
|
||||||
let displayDate = new Date();
|
|
||||||
this._date.set_label(displayDate.toLocaleFormat(dateFormat));
|
|
||||||
},
|
|
||||||
|
|
||||||
_getCalendarApp: function() {
|
_getCalendarApp: function() {
|
||||||
if (this._calendarApp !== undefined)
|
if (this._calendarApp !== undefined)
|
||||||
return this._calendarApp;
|
return this._calendarApp;
|
||||||
|
@ -38,8 +38,6 @@ const UserWidget = imports.ui.userWidget;
|
|||||||
|
|
||||||
let _endSessionDialog = null;
|
let _endSessionDialog = null;
|
||||||
|
|
||||||
const TRIGGER_OFFLINE_UPDATE = '/usr/libexec/pk-trigger-offline-update';
|
|
||||||
|
|
||||||
const _ITEM_ICON_SIZE = 48;
|
const _ITEM_ICON_SIZE = 48;
|
||||||
const _DIALOG_ICON_SIZE = 48;
|
const _DIALOG_ICON_SIZE = 48;
|
||||||
|
|
||||||
@ -134,11 +132,18 @@ const restartInstallDialogContent = {
|
|||||||
showOtherSessions: true,
|
showOtherSessions: true,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const DialogType = {
|
||||||
|
LOGOUT: 0 /* GSM_SHELL_END_SESSION_DIALOG_TYPE_LOGOUT */,
|
||||||
|
SHUTDOWN: 1 /* GSM_SHELL_END_SESSION_DIALOG_TYPE_SHUTDOWN */,
|
||||||
|
RESTART: 2 /* GSM_SHELL_END_SESSION_DIALOG_TYPE_RESTART */,
|
||||||
|
UPDATE_RESTART: 3
|
||||||
|
};
|
||||||
|
|
||||||
const DialogContent = {
|
const DialogContent = {
|
||||||
0 /* GSM_SHELL_END_SESSION_DIALOG_TYPE_LOGOUT */: logoutDialogContent,
|
0 /* DialogType.LOGOUT */: logoutDialogContent,
|
||||||
1 /* GSM_SHELL_END_SESSION_DIALOG_TYPE_SHUTDOWN */: shutdownDialogContent,
|
1 /* DialogType.SHUTDOWN */: shutdownDialogContent,
|
||||||
2 /* GSM_SHELL_END_SESSION_DIALOG_TYPE_RESTART */: restartDialogContent,
|
2 /* DialogType.RESTART */: restartDialogContent,
|
||||||
3: restartInstallDialogContent
|
3 /* DialogType.UPDATE_RESTART */: restartInstallDialogContent
|
||||||
};
|
};
|
||||||
|
|
||||||
const MAX_USERS_IN_SESSION_DIALOG = 5;
|
const MAX_USERS_IN_SESSION_DIALOG = 5;
|
||||||
@ -155,6 +160,19 @@ const LogindSessionIface = '<node> \
|
|||||||
|
|
||||||
const LogindSession = Gio.DBusProxy.makeProxyWrapper(LogindSessionIface);
|
const LogindSession = Gio.DBusProxy.makeProxyWrapper(LogindSessionIface);
|
||||||
|
|
||||||
|
const PkOfflineIface = '<node> \
|
||||||
|
<interface name="org.freedesktop.PackageKit.Offline"> \
|
||||||
|
<property name="UpdatePrepared" type="b" access="read"/> \
|
||||||
|
<property name="TriggerAction" type="s" access="read"/> \
|
||||||
|
<method name="Trigger"> \
|
||||||
|
<arg type="s" name="action" direction="in"/> \
|
||||||
|
</method> \
|
||||||
|
<method name="Cancel"/> \
|
||||||
|
</interface> \
|
||||||
|
</node>';
|
||||||
|
|
||||||
|
const PkOfflineProxy = Gio.DBusProxy.makeProxyWrapper(PkOfflineIface);
|
||||||
|
|
||||||
const UPowerIface = '<node> \
|
const UPowerIface = '<node> \
|
||||||
<interface name="org.freedesktop.UPower"> \
|
<interface name="org.freedesktop.UPower"> \
|
||||||
<property name="OnBattery" type="b" access="read"/> \
|
<property name="OnBattery" type="b" access="read"/> \
|
||||||
@ -245,9 +263,14 @@ const EndSessionDialog = new Lang.Class({
|
|||||||
this._loginManager = LoginManager.getLoginManager();
|
this._loginManager = LoginManager.getLoginManager();
|
||||||
this._userManager = AccountsService.UserManager.get_default();
|
this._userManager = AccountsService.UserManager.get_default();
|
||||||
this._user = this._userManager.get_user(GLib.get_user_name());
|
this._user = this._userManager.get_user(GLib.get_user_name());
|
||||||
this._updatesFile = Gio.File.new_for_path('/system-update');
|
|
||||||
this._preparedUpdateFile = Gio.File.new_for_path('/var/lib/PackageKit/prepared-update');
|
|
||||||
|
|
||||||
|
this._pkOfflineProxy = new PkOfflineProxy(Gio.DBus.system,
|
||||||
|
'org.freedesktop.PackageKit',
|
||||||
|
'/org/freedesktop/PackageKit',
|
||||||
|
Lang.bind(this, function(proxy, error) {
|
||||||
|
if (error)
|
||||||
|
log(error.message);
|
||||||
|
}));
|
||||||
this._powerProxy = new UPowerProxy(Gio.DBus.system,
|
this._powerProxy = new UPowerProxy(Gio.DBus.system,
|
||||||
'org.freedesktop.UPower',
|
'org.freedesktop.UPower',
|
||||||
'/org/freedesktop/UPower',
|
'/org/freedesktop/UPower',
|
||||||
@ -499,31 +522,29 @@ const EndSessionDialog = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_triggerOfflineUpdateReboot: function(callback) {
|
_triggerOfflineUpdateReboot: function(callback) {
|
||||||
this._pkexecSpawn([TRIGGER_OFFLINE_UPDATE, 'reboot'], callback);
|
this._pkOfflineProxy.TriggerRemote('reboot',
|
||||||
|
function (result, error) {
|
||||||
|
if (error)
|
||||||
|
log(error.message);
|
||||||
|
|
||||||
|
callback();
|
||||||
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
_triggerOfflineUpdateShutdown: function(callback) {
|
_triggerOfflineUpdateShutdown: function(callback) {
|
||||||
this._pkexecSpawn([TRIGGER_OFFLINE_UPDATE, 'power-off'], callback);
|
this._pkOfflineProxy.TriggerRemote('power-off',
|
||||||
|
function (result, error) {
|
||||||
|
if (error)
|
||||||
|
log(error.message);
|
||||||
|
|
||||||
|
callback();
|
||||||
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
_triggerOfflineUpdateCancel: function(callback) {
|
_triggerOfflineUpdateCancel: function(callback) {
|
||||||
this._pkexecSpawn([TRIGGER_OFFLINE_UPDATE, '--cancel'], callback);
|
this._pkOfflineProxy.CancelRemote(function (result, error) {
|
||||||
},
|
if (error)
|
||||||
|
log(error.message);
|
||||||
_pkexecSpawn: function(argv, callback) {
|
|
||||||
let ret, pid;
|
|
||||||
try {
|
|
||||||
[ret, pid] = GLib.spawn_async(null, ['pkexec'].concat(argv), null,
|
|
||||||
GLib.SpawnFlags.DO_NOT_REAP_CHILD | GLib.SpawnFlags.SEARCH_PATH,
|
|
||||||
null);
|
|
||||||
} catch (e) {
|
|
||||||
log('Error spawning "pkexec %s": %s'.format(argv.join(' '), e.toString()));
|
|
||||||
callback();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
GLib.child_watch_add(GLib.PRIORITY_DEFAULT, pid, function(pid, status) {
|
|
||||||
GLib.spawn_close_pid(pid);
|
|
||||||
|
|
||||||
callback();
|
callback();
|
||||||
});
|
});
|
||||||
@ -677,8 +698,9 @@ const EndSessionDialog = new Lang.Class({
|
|||||||
this._totalSecondsToStayOpen = totalSecondsToStayOpen;
|
this._totalSecondsToStayOpen = totalSecondsToStayOpen;
|
||||||
this._type = type;
|
this._type = type;
|
||||||
|
|
||||||
if (this._type == 2 && this._updatesFile.query_exists(null))
|
if (this._type == DialogType.RESTART &&
|
||||||
this._type = 3;
|
this._pkOfflineProxy.TriggerAction == 'reboot')
|
||||||
|
this._type = DialogType.UPDATE_RESTART;
|
||||||
|
|
||||||
this._applications = [];
|
this._applications = [];
|
||||||
this._applicationList.destroy_all_children();
|
this._applicationList.destroy_all_children();
|
||||||
@ -705,19 +727,19 @@ const EndSessionDialog = new Lang.Class({
|
|||||||
if (dialogContent.showOtherSessions)
|
if (dialogContent.showOtherSessions)
|
||||||
this._loadSessions();
|
this._loadSessions();
|
||||||
|
|
||||||
let preparedUpdate = this._preparedUpdateFile.query_exists(null);
|
let updateAlreadyTriggered = this._pkOfflineProxy.TriggerAction == 'power-off' || this._pkOfflineProxy.TriggerAction == 'reboot';
|
||||||
let updateAlreadyTriggered = this._updatesFile.query_exists(null);
|
let updatePrepared = this._pkOfflineProxy.UpdatePrepared;
|
||||||
let updatesAllowed = this._updatesPermission && this._updatesPermission.allowed;
|
let updatesAllowed = this._updatesPermission && this._updatesPermission.allowed;
|
||||||
|
|
||||||
_setCheckBoxLabel(this._checkBox, dialogContent.checkBoxText);
|
_setCheckBoxLabel(this._checkBox, dialogContent.checkBoxText);
|
||||||
this._checkBox.actor.visible = (dialogContent.checkBoxText && preparedUpdate && updatesAllowed);
|
this._checkBox.actor.visible = (dialogContent.checkBoxText && updatePrepared && updatesAllowed);
|
||||||
this._checkBox.actor.checked = (preparedUpdate && updateAlreadyTriggered);
|
this._checkBox.actor.checked = (updatePrepared && updateAlreadyTriggered);
|
||||||
|
|
||||||
// We show the warning either together with the checkbox, or when
|
// We show the warning either together with the checkbox, or when
|
||||||
// updates have already been triggered, but the user doesn't have
|
// updates have already been triggered, but the user doesn't have
|
||||||
// enough permissions to cancel them.
|
// enough permissions to cancel them.
|
||||||
this._batteryWarning.visible = (dialogContent.showBatteryWarning &&
|
this._batteryWarning.visible = (dialogContent.showBatteryWarning &&
|
||||||
(this._checkBox.actor.visible || preparedUpdate && updateAlreadyTriggered && !updatesAllowed));
|
(this._checkBox.actor.visible || updatePrepared && updateAlreadyTriggered && !updatesAllowed));
|
||||||
|
|
||||||
this._updateButtons();
|
this._updateButtons();
|
||||||
|
|
||||||
|
@ -74,7 +74,7 @@ function disableExtension(uuid) {
|
|||||||
|
|
||||||
if (extension.stylesheet) {
|
if (extension.stylesheet) {
|
||||||
let theme = St.ThemeContext.get_for_stage(global.stage).get_theme();
|
let theme = St.ThemeContext.get_for_stage(global.stage).get_theme();
|
||||||
theme.unload_stylesheet(extension.stylesheet.get_path());
|
theme.unload_stylesheet(extension.stylesheet);
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
@ -118,7 +118,7 @@ function enableExtension(uuid) {
|
|||||||
let stylesheetFile = extension.dir.get_child(stylesheetNames[i]);
|
let stylesheetFile = extension.dir.get_child(stylesheetNames[i]);
|
||||||
if (stylesheetFile.query_exists(null)) {
|
if (stylesheetFile.query_exists(null)) {
|
||||||
let theme = St.ThemeContext.get_for_stage(global.stage).get_theme();
|
let theme = St.ThemeContext.get_for_stage(global.stage).get_theme();
|
||||||
theme.load_stylesheet(stylesheetFile.get_path());
|
theme.load_stylesheet(stylesheetFile);
|
||||||
extension.stylesheet = stylesheetFile;
|
extension.stylesheet = stylesheetFile;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -271,10 +271,17 @@ function onEnabledExtensionsChanged() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function _onVersionValidationChanged() {
|
function _onVersionValidationChanged() {
|
||||||
|
// we want to reload all extensions, but only enable
|
||||||
|
// extensions when allowed by the sessionMode, so
|
||||||
|
// temporarily disable them all
|
||||||
|
enabledExtensions = [];
|
||||||
|
for (let uuid in ExtensionUtils.extensions)
|
||||||
|
reloadExtension(ExtensionUtils.extensions[uuid]);
|
||||||
|
enabledExtensions = getEnabledExtensions();
|
||||||
|
|
||||||
if (Main.sessionMode.allowExtensions) {
|
if (Main.sessionMode.allowExtensions) {
|
||||||
enabledExtensions.forEach(function(uuid) {
|
enabledExtensions.forEach(function(uuid) {
|
||||||
if (ExtensionUtils.extensions[uuid])
|
enableExtension(uuid);
|
||||||
reloadExtension(ExtensionUtils.extensions[uuid]);
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -20,6 +20,7 @@ const EXTRA_SPACE_ANIMATION_TIME = 0.25;
|
|||||||
const ANIMATION_TIME_IN = 0.350;
|
const ANIMATION_TIME_IN = 0.350;
|
||||||
const ANIMATION_TIME_OUT = 1/2 * ANIMATION_TIME_IN;
|
const ANIMATION_TIME_OUT = 1/2 * ANIMATION_TIME_IN;
|
||||||
const ANIMATION_MAX_DELAY_FOR_ITEM = 2/3 * ANIMATION_TIME_IN;
|
const ANIMATION_MAX_DELAY_FOR_ITEM = 2/3 * ANIMATION_TIME_IN;
|
||||||
|
const ANIMATION_BASE_DELAY_FOR_ITEM = 1/4 * ANIMATION_MAX_DELAY_FOR_ITEM;
|
||||||
const ANIMATION_MAX_DELAY_OUT_FOR_ITEM = 2/3 * ANIMATION_TIME_OUT;
|
const ANIMATION_MAX_DELAY_OUT_FOR_ITEM = 2/3 * ANIMATION_TIME_OUT;
|
||||||
const ANIMATION_FADE_IN_TIME_FOR_ITEM = 1/4 * ANIMATION_TIME_IN;
|
const ANIMATION_FADE_IN_TIME_FOR_ITEM = 1/4 * ANIMATION_TIME_IN;
|
||||||
|
|
||||||
@ -277,20 +278,6 @@ const IconGrid = new Lang.Class({
|
|||||||
this._grid.connect('get-preferred-width', Lang.bind(this, this._getPreferredWidth));
|
this._grid.connect('get-preferred-width', Lang.bind(this, this._getPreferredWidth));
|
||||||
this._grid.connect('get-preferred-height', Lang.bind(this, this._getPreferredHeight));
|
this._grid.connect('get-preferred-height', Lang.bind(this, this._getPreferredHeight));
|
||||||
this._grid.connect('allocate', Lang.bind(this, this._allocate));
|
this._grid.connect('allocate', Lang.bind(this, this._allocate));
|
||||||
this._grid.connect('actor-added', Lang.bind(this, this._childAdded));
|
|
||||||
this._grid.connect('actor-removed', Lang.bind(this, this._childRemoved));
|
|
||||||
},
|
|
||||||
|
|
||||||
_keyFocusIn: function(actor) {
|
|
||||||
this.emit('key-focus-in', actor);
|
|
||||||
},
|
|
||||||
|
|
||||||
_childAdded: function(grid, child) {
|
|
||||||
child._iconGridKeyFocusInId = child.connect('key-focus-in', Lang.bind(this, this._keyFocusIn));
|
|
||||||
},
|
|
||||||
|
|
||||||
_childRemoved: function(grid, child) {
|
|
||||||
child.disconnect(child._iconGridKeyFocusInId);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_getPreferredWidth: function (grid, forHeight, alloc) {
|
_getPreferredWidth: function (grid, forHeight, alloc) {
|
||||||
@ -429,34 +416,30 @@ const IconGrid = new Lang.Class({
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// For few items the animation can be slow, so use a smaller
|
||||||
|
// delay when there are less than 4 items
|
||||||
|
// (ANIMATION_BASE_DELAY_FOR_ITEM = 1/4 *
|
||||||
|
// ANIMATION_MAX_DELAY_FOR_ITEM)
|
||||||
|
let maxDelay = Math.min(ANIMATION_BASE_DELAY_FOR_ITEM * actors.length,
|
||||||
|
ANIMATION_MAX_DELAY_FOR_ITEM);
|
||||||
|
|
||||||
for (let index = 0; index < actors.length; index++) {
|
for (let index = 0; index < actors.length; index++) {
|
||||||
let actor = actors[index];
|
let actor = actors[index];
|
||||||
actor.opacity = 0;
|
|
||||||
actor.reactive = false;
|
actor.reactive = false;
|
||||||
|
actor.set_scale(0, 0);
|
||||||
|
actor.set_pivot_point(0.5, 0.5);
|
||||||
|
|
||||||
let delay = index / actors.length * ANIMATION_MAX_DELAY_FOR_ITEM;
|
let delay = index / actors.length * maxDelay;
|
||||||
let [originalX, originalY] = actor.get_transformed_position();
|
|
||||||
let [originalWidth, originalHeight,,] = this._getAllocatedChildSizeAndSpacing(actor);
|
|
||||||
|
|
||||||
let actorClone = new Clutter.Clone({ source: actor });
|
|
||||||
Main.uiGroup.add_actor(actorClone);
|
|
||||||
|
|
||||||
actorClone.set_position(originalX, originalY);
|
|
||||||
actorClone.set_scale(0, 0);
|
|
||||||
actorClone.set_pivot_point(0.5, 0.5);
|
|
||||||
actorClone.set_size(originalWidth, originalHeight);
|
|
||||||
|
|
||||||
let bounceUpTime = ANIMATION_TIME_IN / 4;
|
let bounceUpTime = ANIMATION_TIME_IN / 4;
|
||||||
// Defeat onComplete anonymous function closure
|
|
||||||
let isLastItem = index == actors.length - 1;
|
let isLastItem = index == actors.length - 1;
|
||||||
Tweener.addTween(actorClone,
|
Tweener.addTween(actor,
|
||||||
{ time: bounceUpTime,
|
{ time: bounceUpTime,
|
||||||
transition: 'easeInOutQuad',
|
transition: 'easeInOutQuad',
|
||||||
delay: delay,
|
delay: delay,
|
||||||
scale_x: ANIMATION_BOUNCE_ICON_SCALE,
|
scale_x: ANIMATION_BOUNCE_ICON_SCALE,
|
||||||
scale_y: ANIMATION_BOUNCE_ICON_SCALE,
|
scale_y: ANIMATION_BOUNCE_ICON_SCALE,
|
||||||
onComplete: Lang.bind(this, function() {
|
onComplete: Lang.bind(this, function() {
|
||||||
Tweener.addTween(actorClone,
|
Tweener.addTween(actor,
|
||||||
{ time: ANIMATION_TIME_IN - bounceUpTime,
|
{ time: ANIMATION_TIME_IN - bounceUpTime,
|
||||||
transition: 'easeInOutQuad',
|
transition: 'easeInOutQuad',
|
||||||
scale_x: 1,
|
scale_x: 1,
|
||||||
@ -464,10 +447,7 @@ const IconGrid = new Lang.Class({
|
|||||||
onComplete: Lang.bind(this, function() {
|
onComplete: Lang.bind(this, function() {
|
||||||
if (isLastItem)
|
if (isLastItem)
|
||||||
this._animationDone();
|
this._animationDone();
|
||||||
|
|
||||||
actor.opacity = 255;
|
|
||||||
actor.reactive = true;
|
actor.reactive = true;
|
||||||
actorClone.destroy();
|
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
})
|
})
|
||||||
@ -521,11 +501,10 @@ const IconGrid = new Lang.Class({
|
|||||||
let scaleY = sourceScaledHeight / height;
|
let scaleY = sourceScaledHeight / height;
|
||||||
let [adjustedSourcePositionX, adjustedSourcePositionY] = [sourceCenterX - sourceScaledWidth / 2, sourceCenterY - sourceScaledHeight / 2];
|
let [adjustedSourcePositionX, adjustedSourcePositionY] = [sourceCenterX - sourceScaledWidth / 2, sourceCenterY - sourceScaledHeight / 2];
|
||||||
|
|
||||||
// Defeat onComplete anonymous function closure
|
|
||||||
let isLastItem = index == actors.length - 1;
|
|
||||||
|
|
||||||
let movementParams, fadeParams;
|
let movementParams, fadeParams;
|
||||||
if (animationDirection == AnimationDirection.IN) {
|
if (animationDirection == AnimationDirection.IN) {
|
||||||
|
let isLastItem = actor._distance == minDist;
|
||||||
|
|
||||||
actorClone.opacity = 0;
|
actorClone.opacity = 0;
|
||||||
actorClone.set_scale(scaleX, scaleY);
|
actorClone.set_scale(scaleX, scaleY);
|
||||||
|
|
||||||
@ -553,6 +532,8 @@ const IconGrid = new Lang.Class({
|
|||||||
delay: delay,
|
delay: delay,
|
||||||
opacity: 255 };
|
opacity: 255 };
|
||||||
} else {
|
} else {
|
||||||
|
let isLastItem = actor._distance == maxDist;
|
||||||
|
|
||||||
let [startX, startY] = actor._transformedPosition;
|
let [startX, startY] = actor._transformedPosition;
|
||||||
actorClone.set_position(startX, startY);
|
actorClone.set_position(startX, startY);
|
||||||
|
|
||||||
@ -569,6 +550,7 @@ const IconGrid = new Lang.Class({
|
|||||||
this._animationDone();
|
this._animationDone();
|
||||||
this._restoreItemsOpacity();
|
this._restoreItemsOpacity();
|
||||||
}
|
}
|
||||||
|
actor.reactive = true;
|
||||||
actorClone.destroy();
|
actorClone.destroy();
|
||||||
})};
|
})};
|
||||||
fadeParams = { time: ANIMATION_FADE_IN_TIME_FOR_ITEM,
|
fadeParams = { time: ANIMATION_FADE_IN_TIME_FOR_ITEM,
|
||||||
@ -686,6 +668,10 @@ const IconGrid = new Lang.Class({
|
|||||||
this._grid.destroy_all_children();
|
this._grid.destroy_all_children();
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_keyFocusIn: function(actor) {
|
||||||
|
this.emit('key-focus-in', actor._associatedItem);
|
||||||
|
},
|
||||||
|
|
||||||
addItem: function(item, index) {
|
addItem: function(item, index) {
|
||||||
if (!item.icon instanceof BaseIcon)
|
if (!item.icon instanceof BaseIcon)
|
||||||
throw new Error('Only items with a BaseIcon icon property can be added to IconGrid');
|
throw new Error('Only items with a BaseIcon icon property can be added to IconGrid');
|
||||||
@ -695,9 +681,26 @@ const IconGrid = new Lang.Class({
|
|||||||
this._grid.insert_child_at_index(item.actor, index);
|
this._grid.insert_child_at_index(item.actor, index);
|
||||||
else
|
else
|
||||||
this._grid.add_actor(item.actor);
|
this._grid.add_actor(item.actor);
|
||||||
|
|
||||||
|
// Maybe the item actor acts as a container, so ask the item if
|
||||||
|
// it has a specific actor to track focus
|
||||||
|
let focusReceiver = item.actor;
|
||||||
|
if (item.getFocusReceiver)
|
||||||
|
focusReceiver = item.getFocusReceiver();
|
||||||
|
|
||||||
|
focusReceiver._associatedItem = item.actor;
|
||||||
|
focusReceiver._iconGridKeyFocusInId = focusReceiver.connect('key-focus-in', Lang.bind(this, this._keyFocusIn));
|
||||||
},
|
},
|
||||||
|
|
||||||
removeItem: function(item) {
|
removeItem: function(item) {
|
||||||
|
let focusReceiver = item.actor;
|
||||||
|
if (item.getFocusReceiver)
|
||||||
|
focusReceiver = item.getFocusReceiver();
|
||||||
|
|
||||||
|
|
||||||
|
focusReceiver._associatedItem = null;
|
||||||
|
focusReceiver.disconnect(focusReceiver._iconGridKeyFocusInId);
|
||||||
|
|
||||||
this._grid.remove_child(item.actor);
|
this._grid.remove_child(item.actor);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -75,6 +75,7 @@ const Key = new Lang.Class({
|
|||||||
_init : function(key) {
|
_init : function(key) {
|
||||||
this._key = key;
|
this._key = key;
|
||||||
this.actor = this._makeKey(key, GLib.markup_escape_text(key.label, -1));
|
this.actor = this._makeKey(key, GLib.markup_escape_text(key.label, -1));
|
||||||
|
this.actor.connect('destroy', Lang.bind(this, this._onDestroy));
|
||||||
|
|
||||||
this._extended_keys = this._key.get_extended_keys();
|
this._extended_keys = this._key.get_extended_keys();
|
||||||
this._extended_keyboard = null;
|
this._extended_keyboard = null;
|
||||||
@ -97,6 +98,13 @@ const Key = new Lang.Class({
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_onDestroy: function() {
|
||||||
|
if (this._boxPointer) {
|
||||||
|
this._boxPointer.actor.destroy();
|
||||||
|
this._boxPointer = null;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
_makeKey: function (key, label) {
|
_makeKey: function (key, label) {
|
||||||
let button = new St.Button ({ label: label,
|
let button = new St.Button ({ label: label,
|
||||||
style_class: 'keyboard-key' });
|
style_class: 'keyboard-key' });
|
||||||
@ -179,14 +187,7 @@ const Keyboard = new Lang.Class({
|
|||||||
this._watchNameId = Gio.bus_watch_name(Gio.BusType.SESSION, CURSOR_BUS_NAME, 0,
|
this._watchNameId = Gio.bus_watch_name(Gio.BusType.SESSION, CURSOR_BUS_NAME, 0,
|
||||||
Lang.bind(this, this._sync),
|
Lang.bind(this, this._sync),
|
||||||
Lang.bind(this, this._sync));
|
Lang.bind(this, this._sync));
|
||||||
this._daemonProxy = new CaribouDaemonProxy(Gio.DBus.session, CARIBOU_BUS_NAME,
|
this._daemonProxy = null;
|
||||||
CARIBOU_OBJECT_PATH,
|
|
||||||
Lang.bind(this, function(proxy, error) {
|
|
||||||
if (error) {
|
|
||||||
log(error.message);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}));
|
|
||||||
this._cursorProxy = new CursorManagerProxy(Gio.DBus.session, CURSOR_BUS_NAME,
|
this._cursorProxy = new CursorManagerProxy(Gio.DBus.session, CURSOR_BUS_NAME,
|
||||||
CURSOR_OBJECT_PATH,
|
CURSOR_OBJECT_PATH,
|
||||||
Lang.bind(this, function(proxy, error) {
|
Lang.bind(this, function(proxy, error) {
|
||||||
@ -248,15 +249,28 @@ const Keyboard = new Lang.Class({
|
|||||||
this.actor = null;
|
this.actor = null;
|
||||||
|
|
||||||
this._destroySource();
|
this._destroySource();
|
||||||
this._daemonProxy.QuitRemote(function (result, error) {
|
if (this._daemonProxy) {
|
||||||
if (error) {
|
this._daemonProxy.QuitRemote(function (result, error) {
|
||||||
log(error.message);
|
if (error) {
|
||||||
return;
|
log(error.message);
|
||||||
}
|
return;
|
||||||
});
|
}
|
||||||
|
});
|
||||||
|
this._daemonProxy = null;
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_setupKeyboard: function() {
|
_setupKeyboard: function() {
|
||||||
|
if (!this._daemonProxy) {
|
||||||
|
this._daemonProxy = new CaribouDaemonProxy(Gio.DBus.session, CARIBOU_BUS_NAME,
|
||||||
|
CARIBOU_OBJECT_PATH,
|
||||||
|
Lang.bind(this, function(proxy, error) {
|
||||||
|
if (error) {
|
||||||
|
log(error.message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}));
|
||||||
|
}
|
||||||
this._daemonProxy.RunRemote(function (result, error) {
|
this._daemonProxy.RunRemote(function (result, error) {
|
||||||
if (error) {
|
if (error) {
|
||||||
log(error.message);
|
log(error.message);
|
||||||
@ -602,7 +616,7 @@ const Keyboard = new Lang.Class({
|
|||||||
|
|
||||||
_moveTemporarily: function () {
|
_moveTemporarily: function () {
|
||||||
let currentWindow = global.screen.get_display().focus_window;
|
let currentWindow = global.screen.get_display().focus_window;
|
||||||
let rect = currentWindow.get_outer_rect();
|
let rect = currentWindow.get_frame_rect();
|
||||||
|
|
||||||
let newX = rect.x;
|
let newX = rect.x;
|
||||||
let newY = 3 * this.actor.height / 2;
|
let newY = 3 * this.actor.height / 2;
|
||||||
|
@ -20,7 +20,6 @@ const Tweener = imports.ui.tweener;
|
|||||||
const STARTUP_ANIMATION_TIME = 0.5;
|
const STARTUP_ANIMATION_TIME = 0.5;
|
||||||
const KEYBOARD_ANIMATION_TIME = 0.15;
|
const KEYBOARD_ANIMATION_TIME = 0.15;
|
||||||
const BACKGROUND_FADE_ANIMATION_TIME = 1.0;
|
const BACKGROUND_FADE_ANIMATION_TIME = 1.0;
|
||||||
const DEFAULT_BACKGROUND_COLOR = Clutter.Color.from_pixel(0x2e3436ff);
|
|
||||||
|
|
||||||
// The message tray takes this much pressure
|
// The message tray takes this much pressure
|
||||||
// in the pressure barrier at once to release it.
|
// in the pressure barrier at once to release it.
|
||||||
@ -160,10 +159,10 @@ const LayoutManager = new Lang.Class({
|
|||||||
this._isPopupWindowVisible = false;
|
this._isPopupWindowVisible = false;
|
||||||
this._startingUp = true;
|
this._startingUp = true;
|
||||||
|
|
||||||
// Normally, the stage is always covered so Clutter doesn't need to clear
|
// We don't want to paint the stage background color because either
|
||||||
// it; however it becomes visible during the startup animation
|
// the SystemBackground we create or the MetaBackgroundActor inside
|
||||||
// See the comment below for a longer explanation
|
// global.window_group covers the entirety of the screen.
|
||||||
global.stage.background_color = DEFAULT_BACKGROUND_COLOR;
|
global.stage.no_clear_hint = true;
|
||||||
|
|
||||||
// Set up stage hierarchy to group all UI actors under one container.
|
// Set up stage hierarchy to group all UI actors under one container.
|
||||||
this.uiGroup = new Shell.GenericContainer({ name: 'uiGroup' });
|
this.uiGroup = new Shell.GenericContainer({ name: 'uiGroup' });
|
||||||
@ -230,6 +229,10 @@ const LayoutManager = new Lang.Class({
|
|||||||
global.stage.remove_actor(global.top_window_group);
|
global.stage.remove_actor(global.top_window_group);
|
||||||
this.uiGroup.add_actor(global.top_window_group);
|
this.uiGroup.add_actor(global.top_window_group);
|
||||||
|
|
||||||
|
let feedbackGroup = Meta.get_feedback_group_for_screen(global.screen);
|
||||||
|
global.stage.remove_actor(feedbackGroup);
|
||||||
|
this.uiGroup.add_actor(feedbackGroup);
|
||||||
|
|
||||||
this._backgroundGroup = new Meta.BackgroundGroup();
|
this._backgroundGroup = new Meta.BackgroundGroup();
|
||||||
global.window_group.add_child(this._backgroundGroup);
|
global.window_group.add_child(this._backgroundGroup);
|
||||||
this._backgroundGroup.lower_bottom();
|
this._backgroundGroup.lower_bottom();
|
||||||
@ -259,7 +262,6 @@ const LayoutManager = new Lang.Class({
|
|||||||
|
|
||||||
this._inOverview = true;
|
this._inOverview = true;
|
||||||
this._updateVisibility();
|
this._updateVisibility();
|
||||||
this._updateRegions();
|
|
||||||
},
|
},
|
||||||
|
|
||||||
hideOverview: function() {
|
hideOverview: function() {
|
||||||
@ -267,7 +269,6 @@ const LayoutManager = new Lang.Class({
|
|||||||
|
|
||||||
this._inOverview = false;
|
this._inOverview = false;
|
||||||
this._updateVisibility();
|
this._updateVisibility();
|
||||||
this._queueUpdateRegions();
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_sessionUpdated: function() {
|
_sessionUpdated: function() {
|
||||||
@ -421,10 +422,7 @@ const LayoutManager = new Lang.Class({
|
|||||||
this.panelBox.set_position(this.primaryMonitor.x, this.primaryMonitor.y);
|
this.panelBox.set_position(this.primaryMonitor.x, this.primaryMonitor.y);
|
||||||
this.panelBox.set_size(this.primaryMonitor.width, -1);
|
this.panelBox.set_size(this.primaryMonitor.width, -1);
|
||||||
|
|
||||||
if (this.keyboardIndex < 0)
|
this.keyboardIndex = this.primaryIndex;
|
||||||
this.keyboardIndex = this.primaryIndex;
|
|
||||||
else
|
|
||||||
this._updateKeyboardBox();
|
|
||||||
|
|
||||||
this.trayBox.set_position(this.bottomMonitor.x,
|
this.trayBox.set_position(this.bottomMonitor.x,
|
||||||
this.bottomMonitor.y + this.bottomMonitor.height);
|
this.bottomMonitor.y + this.bottomMonitor.height);
|
||||||
@ -589,10 +587,6 @@ const LayoutManager = new Lang.Class({
|
|||||||
//
|
//
|
||||||
// When starting a normal user session, we want to grow it out of the middle
|
// When starting a normal user session, we want to grow it out of the middle
|
||||||
// of the screen.
|
// of the screen.
|
||||||
//
|
|
||||||
// Usually, we don't want to paint the stage background color because the
|
|
||||||
// MetaBackgroundActor inside global.window_group covers the entirety of the
|
|
||||||
// screen. So, we set no_clear_hint at the end of the animation.
|
|
||||||
|
|
||||||
_prepareStartupAnimation: function() {
|
_prepareStartupAnimation: function() {
|
||||||
// During the initial transition, add a simple actor to block all events,
|
// During the initial transition, add a simple actor to block all events,
|
||||||
@ -673,10 +667,6 @@ const LayoutManager = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_startupAnimationComplete: function() {
|
_startupAnimationComplete: function() {
|
||||||
// At this point, the UI group is covering everything, so
|
|
||||||
// we no longer need to clear the stage
|
|
||||||
global.stage.no_clear_hint = true;
|
|
||||||
|
|
||||||
this._coverPane.destroy();
|
this._coverPane.destroy();
|
||||||
this._coverPane = null;
|
this._coverPane = null;
|
||||||
|
|
||||||
@ -915,9 +905,6 @@ const LayoutManager = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_queueUpdateRegions: function() {
|
_queueUpdateRegions: function() {
|
||||||
if (Main.sessionMode.isGreeter)
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (this._startingUp)
|
if (this._startingUp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@ -951,13 +938,16 @@ const LayoutManager = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_updateRegions: function() {
|
_updateRegions: function() {
|
||||||
let rects = [], struts = [], i;
|
|
||||||
|
|
||||||
if (this._updateRegionIdle) {
|
if (this._updateRegionIdle) {
|
||||||
Meta.later_remove(this._updateRegionIdle);
|
Meta.later_remove(this._updateRegionIdle);
|
||||||
delete this._updateRegionIdle;
|
delete this._updateRegionIdle;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// No need to update when we have a modal.
|
||||||
|
if (Main.modalCount > 0)
|
||||||
|
return GLib.SOURCE_REMOVE;
|
||||||
|
|
||||||
|
let rects = [], struts = [], i;
|
||||||
let isPopupMenuVisible = global.top_window_group.get_children().some(isPopupMetaWindow);
|
let isPopupMenuVisible = global.top_window_group.get_children().some(isPopupMetaWindow);
|
||||||
let wantsInputRegion = !isPopupMenuVisible;
|
let wantsInputRegion = !isPopupMenuVisible;
|
||||||
|
|
||||||
@ -1043,7 +1033,13 @@ const LayoutManager = new Lang.Class({
|
|||||||
}
|
}
|
||||||
|
|
||||||
return GLib.SOURCE_REMOVE;
|
return GLib.SOURCE_REMOVE;
|
||||||
}
|
},
|
||||||
|
|
||||||
|
modalEnded: function() {
|
||||||
|
// We don't update the stage input region while in a modal,
|
||||||
|
// so queue an update now.
|
||||||
|
this._queueUpdateRegions();
|
||||||
|
},
|
||||||
});
|
});
|
||||||
Signals.addSignalMethods(LayoutManager.prototype);
|
Signals.addSignalMethods(LayoutManager.prototype);
|
||||||
|
|
||||||
|
@ -1198,12 +1198,7 @@ const ZoomRegion = new Lang.Class({
|
|||||||
|
|
||||||
// Add a background for when the magnified uiGroup is scrolled
|
// Add a background for when the magnified uiGroup is scrolled
|
||||||
// out of view (don't want to see desktop showing through).
|
// out of view (don't want to see desktop showing through).
|
||||||
this._background = new Clutter.Actor({ background_color: Main.DEFAULT_BACKGROUND_COLOR,
|
this._background = (new Background.SystemBackground()).actor;
|
||||||
layout_manager: new Clutter.BinLayout(),
|
|
||||||
width: global.screen_width,
|
|
||||||
height: global.screen_height });
|
|
||||||
let noiseTexture = (new Background.SystemBackground()).actor;
|
|
||||||
this._background.add_actor(noiseTexture);
|
|
||||||
mainGroup.add_actor(this._background);
|
mainGroup.add_actor(this._background);
|
||||||
|
|
||||||
// Clone the group that contains all of UI on the screen. This is the
|
// Clone the group that contains all of UI on the screen. This is the
|
||||||
|
@ -40,8 +40,6 @@ const Magnifier = imports.ui.magnifier;
|
|||||||
const XdndHandler = imports.ui.xdndHandler;
|
const XdndHandler = imports.ui.xdndHandler;
|
||||||
const Util = imports.misc.util;
|
const Util = imports.misc.util;
|
||||||
|
|
||||||
const DEFAULT_BACKGROUND_COLOR = Clutter.Color.from_pixel(0x2e3436ff);
|
|
||||||
|
|
||||||
const A11Y_SCHEMA = 'org.gnome.desktop.a11y.keyboard';
|
const A11Y_SCHEMA = 'org.gnome.desktop.a11y.keyboard';
|
||||||
const STICKY_KEYS_ENABLE = 'stickykeys-enable';
|
const STICKY_KEYS_ENABLE = 'stickykeys-enable';
|
||||||
const GNOMESHELL_STARTED_MESSAGE_ID = 'f3ea493c22934e26811cd62abe8e203a';
|
const GNOMESHELL_STARTED_MESSAGE_ID = 'f3ea493c22934e26811cd62abe8e203a';
|
||||||
@ -131,6 +129,9 @@ function _initializeUI() {
|
|||||||
Shell.WindowTracker.get_default();
|
Shell.WindowTracker.get_default();
|
||||||
Shell.AppUsage.get_default();
|
Shell.AppUsage.get_default();
|
||||||
|
|
||||||
|
let resource = Gio.Resource.load(global.datadir + '/gnome-shell-theme.gresource');
|
||||||
|
resource._register();
|
||||||
|
|
||||||
_loadDefaultStylesheet();
|
_loadDefaultStylesheet();
|
||||||
|
|
||||||
// Setup the stage hierarchy early
|
// Setup the stage hierarchy early
|
||||||
@ -204,32 +205,46 @@ function _initializeUI() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
layoutManager.connect('startup-complete', function() {
|
layoutManager.connect('startup-complete', function() {
|
||||||
if (keybindingMode == Shell.KeyBindingMode.NONE) {
|
if (keybindingMode == Shell.KeyBindingMode.NONE) {
|
||||||
keybindingMode = Shell.KeyBindingMode.NORMAL;
|
keybindingMode = Shell.KeyBindingMode.NORMAL;
|
||||||
}
|
}
|
||||||
if (screenShield) {
|
if (screenShield) {
|
||||||
screenShield.lockIfWasLocked();
|
screenShield.lockIfWasLocked();
|
||||||
}
|
}
|
||||||
if (LoginManager.haveSystemd() &&
|
if (LoginManager.haveSystemd() &&
|
||||||
sessionMode.currentMode != 'gdm' &&
|
sessionMode.currentMode != 'gdm' &&
|
||||||
sessionMode.currentMode != 'initial-setup') {
|
sessionMode.currentMode != 'initial-setup') {
|
||||||
// Do not import globally to not depend
|
// Do not import globally to not depend
|
||||||
// on systemd on non-systemd systems.
|
// on systemd on non-systemd systems.
|
||||||
let GSystem = imports.gi.GSystem;
|
let GSystem = imports.gi.GSystem;
|
||||||
GSystem.log_structured_print('GNOME Shell started at ' + _startDate,
|
GSystem.log_structured_print('GNOME Shell started at ' + _startDate,
|
||||||
['MESSAGE_ID=' + GNOMESHELL_STARTED_MESSAGE_ID]);
|
['MESSAGE_ID=' + GNOMESHELL_STARTED_MESSAGE_ID]);
|
||||||
} else {
|
} else {
|
||||||
log('GNOME Shell started at ' + _startDate);
|
log('GNOME Shell started at ' + _startDate);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function _getDefaultStylesheet() {
|
||||||
|
let stylesheet;
|
||||||
|
|
||||||
|
stylesheet = Gio.File.new_for_uri('resource:///org/gnome/shell/theme/' + sessionMode.stylesheetName);
|
||||||
|
if (stylesheet.query_exists(null))
|
||||||
|
return stylesheet;
|
||||||
|
|
||||||
|
stylesheet = Gio.File.new_for_path(global.datadir + '/theme/' + sessionMode.stylesheetName);
|
||||||
|
if (stylesheet.query_exists(null))
|
||||||
|
return stylesheet;
|
||||||
|
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
function _loadDefaultStylesheet() {
|
function _loadDefaultStylesheet() {
|
||||||
if (!sessionMode.isPrimary)
|
if (!sessionMode.isPrimary)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
let stylesheet = global.datadir + '/theme/' + sessionMode.stylesheetName;
|
let stylesheet = _getDefaultStylesheet();
|
||||||
if (_defaultCssStylesheet == stylesheet)
|
if (_defaultCssStylesheet && _defaultCssStylesheet.equal(stylesheet))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
_defaultCssStylesheet = stylesheet;
|
_defaultCssStylesheet = stylesheet;
|
||||||
@ -256,7 +271,7 @@ function getThemeStylesheet() {
|
|||||||
* Set the theme CSS file that the shell will load
|
* Set the theme CSS file that the shell will load
|
||||||
*/
|
*/
|
||||||
function setThemeStylesheet(cssStylesheet) {
|
function setThemeStylesheet(cssStylesheet) {
|
||||||
_cssStylesheet = cssStylesheet;
|
_cssStylesheet = Gio.File.new_for_path(cssStylesheet);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -454,6 +469,7 @@ function popModal(actor, timestamp) {
|
|||||||
if (modalCount > 0)
|
if (modalCount > 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
layoutManager.modalEnded();
|
||||||
global.end_modal(timestamp);
|
global.end_modal(timestamp);
|
||||||
Meta.enable_unredirect_for_screen(global.screen);
|
Meta.enable_unredirect_for_screen(global.screen);
|
||||||
keybindingMode = Shell.KeyBindingMode.NORMAL;
|
keybindingMode = Shell.KeyBindingMode.NORMAL;
|
||||||
|
@ -27,6 +27,7 @@ const PopupMenu = imports.ui.popupMenu;
|
|||||||
const Params = imports.misc.params;
|
const Params = imports.misc.params;
|
||||||
const Tweener = imports.ui.tweener;
|
const Tweener = imports.ui.tweener;
|
||||||
const Util = imports.misc.util;
|
const Util = imports.misc.util;
|
||||||
|
const ViewSelector = imports.ui.viewSelector;
|
||||||
|
|
||||||
const SHELL_KEYBINDINGS_SCHEMA = 'org.gnome.shell.keybindings';
|
const SHELL_KEYBINDINGS_SCHEMA = 'org.gnome.shell.keybindings';
|
||||||
|
|
||||||
@ -1158,6 +1159,7 @@ const SourceActor = new Lang.Class({
|
|||||||
this.actor.connect('get-preferred-height', Lang.bind(this, this._getPreferredHeight));
|
this.actor.connect('get-preferred-height', Lang.bind(this, this._getPreferredHeight));
|
||||||
this.actor.connect('allocate', Lang.bind(this, this._allocate));
|
this.actor.connect('allocate', Lang.bind(this, this._allocate));
|
||||||
this.actor.connect('destroy', Lang.bind(this, function() {
|
this.actor.connect('destroy', Lang.bind(this, function() {
|
||||||
|
this._source.disconnect(this._iconUpdatedId);
|
||||||
this._actorDestroyed = true;
|
this._actorDestroyed = true;
|
||||||
}));
|
}));
|
||||||
this._actorDestroyed = false;
|
this._actorDestroyed = false;
|
||||||
@ -1169,7 +1171,7 @@ const SourceActor = new Lang.Class({
|
|||||||
|
|
||||||
this.actor.add_actor(this._iconBin);
|
this.actor.add_actor(this._iconBin);
|
||||||
|
|
||||||
this._source.connect('icon-updated', Lang.bind(this, this._updateIcon));
|
this._iconUpdatedId = this._source.connect('icon-updated', Lang.bind(this, this._updateIcon));
|
||||||
this._updateIcon();
|
this._updateIcon();
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -1227,8 +1229,12 @@ const SourceActorWithLabel = new Lang.Class({
|
|||||||
|
|
||||||
this.actor.add_actor(this._counterBin);
|
this.actor.add_actor(this._counterBin);
|
||||||
|
|
||||||
this._source.connect('count-updated', Lang.bind(this, this._updateCount));
|
this._countUpdatedId = this._source.connect('count-updated', Lang.bind(this, this._updateCount));
|
||||||
this._updateCount();
|
this._updateCount();
|
||||||
|
|
||||||
|
this.actor.connect('destroy', function() {
|
||||||
|
this._source.disconnect(this._countUpdatedId);
|
||||||
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
_allocate: function(actor, box, flags) {
|
_allocate: function(actor, box, flags) {
|
||||||
@ -1811,6 +1817,13 @@ const MessageTray = new Lang.Class({
|
|||||||
y_expand: true });
|
y_expand: true });
|
||||||
this.actor.add_actor(this._summary);
|
this.actor.add_actor(this._summary);
|
||||||
|
|
||||||
|
this._focusTrap = new ViewSelector.FocusTrap({ can_focus: true });
|
||||||
|
this._focusTrap.connect('key-focus-in', Lang.bind(this,
|
||||||
|
function() {
|
||||||
|
this._messageTrayMenuButton.actor.grab_key_focus();
|
||||||
|
}));
|
||||||
|
this._summary.add_actor(this._focusTrap);
|
||||||
|
|
||||||
this._summaryMotionId = 0;
|
this._summaryMotionId = 0;
|
||||||
|
|
||||||
this._summaryBoxPointer = new BoxPointer.BoxPointer(St.Side.BOTTOM,
|
this._summaryBoxPointer = new BoxPointer.BoxPointer(St.Side.BOTTOM,
|
||||||
@ -1935,6 +1948,9 @@ const MessageTray = new Lang.Class({
|
|||||||
this._messageTrayMenuButton = new MessageTrayMenuButton(this);
|
this._messageTrayMenuButton = new MessageTrayMenuButton(this);
|
||||||
this.actor.add_actor(this._messageTrayMenuButton.actor);
|
this.actor.add_actor(this._messageTrayMenuButton.actor);
|
||||||
|
|
||||||
|
this._messageTrayMenuButton.actor.connect('key-press-event',
|
||||||
|
Lang.bind(this, this._onTrayButtonKeyPress));
|
||||||
|
|
||||||
let gesture = new EdgeDragAction.EdgeDragAction(St.Side.BOTTOM);
|
let gesture = new EdgeDragAction.EdgeDragAction(St.Side.BOTTOM);
|
||||||
gesture.connect('activated', Lang.bind(this, this.toggle));
|
gesture.connect('activated', Lang.bind(this, this.toggle));
|
||||||
global.stage.add_action(gesture);
|
global.stage.add_action(gesture);
|
||||||
@ -2030,6 +2046,16 @@ const MessageTray = new Lang.Class({
|
|||||||
return GLib.SOURCE_REMOVE;
|
return GLib.SOURCE_REMOVE;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_onTrayButtonKeyPress: function(actor, event) {
|
||||||
|
if (event.get_key_symbol() == Clutter.ISO_Left_Tab) {
|
||||||
|
this._focusTrap.can_focus = false;
|
||||||
|
this._summary.navigate_focus(null, Gtk.DirectionType.TAB_BACKWARD, false);
|
||||||
|
this._focusTrap.can_focus = true;
|
||||||
|
return Clutter.EVENT_STOP;
|
||||||
|
}
|
||||||
|
return Clutter.EVENT_PROPAGATE;
|
||||||
|
},
|
||||||
|
|
||||||
_onNotificationKeyRelease: function(actor, event) {
|
_onNotificationKeyRelease: function(actor, event) {
|
||||||
if (event.get_key_symbol() == Clutter.KEY_Escape && event.get_state() == 0) {
|
if (event.get_key_symbol() == Clutter.KEY_Escape && event.get_state() == 0) {
|
||||||
this._expireNotification();
|
this._expireNotification();
|
||||||
@ -2406,8 +2432,22 @@ const MessageTray = new Lang.Class({
|
|||||||
if (shouldShowNotification && nextNotification) {
|
if (shouldShowNotification && nextNotification) {
|
||||||
let limited = this._busy || Main.layoutManager.bottomMonitor.inFullscreen;
|
let limited = this._busy || Main.layoutManager.bottomMonitor.inFullscreen;
|
||||||
let showNextNotification = (!limited || nextNotification.forFeedback || nextNotification.urgency == Urgency.CRITICAL);
|
let showNextNotification = (!limited || nextNotification.forFeedback || nextNotification.urgency == Urgency.CRITICAL);
|
||||||
if (showNextNotification)
|
if (showNextNotification) {
|
||||||
this._showNotification();
|
let len = this._notificationQueue.length;
|
||||||
|
if (len > 1) {
|
||||||
|
this._notificationQueue.length = 0;
|
||||||
|
let source = new SystemNotificationSource();
|
||||||
|
this.add(source);
|
||||||
|
let notification = new Notification(source, ngettext("%d new message", "%d new messages", len).format(len));
|
||||||
|
notification.setTransient(true);
|
||||||
|
notification.connect('clicked', Lang.bind(this, function() {
|
||||||
|
this.openTray();
|
||||||
|
}));
|
||||||
|
source.notify(notification);
|
||||||
|
} else {
|
||||||
|
this._showNotification();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else if (this._notificationState == State.SHOWN) {
|
} else if (this._notificationState == State.SHOWN) {
|
||||||
let expired = (this._userActiveWhileNotificationShown &&
|
let expired = (this._userActiveWhileNotificationShown &&
|
||||||
|
@ -194,7 +194,7 @@ const ModalDialog = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
placeSpinner: function(layoutInfo) {
|
placeSpinner: function(layoutInfo) {
|
||||||
let spinnerIcon = global.datadir + '/theme/process-working.svg';
|
let spinnerIcon = Gio.File.new_for_uri('resource:///org/gnome/shell/theme/process-working.svg');
|
||||||
this._workSpinner = new Animation.AnimatedIcon(spinnerIcon, WORK_SPINNER_ICON_SIZE);
|
this._workSpinner = new Animation.AnimatedIcon(spinnerIcon, WORK_SPINNER_ICON_SIZE);
|
||||||
this._workSpinner.actor.opacity = 0;
|
this._workSpinner.actor.opacity = 0;
|
||||||
this._workSpinner.actor.show();
|
this._workSpinner.actor.show();
|
||||||
|
@ -435,17 +435,17 @@ const Overview = new Lang.Class({
|
|||||||
this._inDrag = false;
|
this._inDrag = false;
|
||||||
},
|
},
|
||||||
|
|
||||||
beginWindowDrag: function(clone) {
|
beginWindowDrag: function(window) {
|
||||||
this.emit('window-drag-begin', clone);
|
this.emit('window-drag-begin', window);
|
||||||
this._inDrag = true;
|
this._inDrag = true;
|
||||||
},
|
},
|
||||||
|
|
||||||
cancelledWindowDrag: function(clone) {
|
cancelledWindowDrag: function(window) {
|
||||||
this.emit('window-drag-cancelled', clone);
|
this.emit('window-drag-cancelled', window);
|
||||||
},
|
},
|
||||||
|
|
||||||
endWindowDrag: function(clone) {
|
endWindowDrag: function(window) {
|
||||||
this.emit('window-drag-end', clone);
|
this.emit('window-drag-end', window);
|
||||||
this._inDrag = false;
|
this._inDrag = false;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -64,7 +64,8 @@ const SlideLayout = new Lang.Class({
|
|||||||
// flags only determine what to do if the allocated box is bigger
|
// flags only determine what to do if the allocated box is bigger
|
||||||
// than the actor's box.
|
// than the actor's box.
|
||||||
let realDirection = getRtlSlideDirection(this._direction, child);
|
let realDirection = getRtlSlideDirection(this._direction, child);
|
||||||
let alignX = (realDirection == SlideDirection.LEFT) ? (availWidth - natWidth) : 0;
|
let alignX = (realDirection == SlideDirection.LEFT) ? (availWidth - natWidth)
|
||||||
|
: (availWidth - natWidth * this._slideX);
|
||||||
|
|
||||||
let actorBox = new Clutter.ActorBox();
|
let actorBox = new Clutter.ActorBox();
|
||||||
actorBox.x1 = box.x1 + alignX + this._translationX;
|
actorBox.x1 = box.x1 + alignX + this._translationX;
|
||||||
|
@ -189,11 +189,8 @@ const AppMenuButton = new Lang.Class({
|
|||||||
this.actor.bind_property("reactive", this.actor, "can-focus", 0);
|
this.actor.bind_property("reactive", this.actor, "can-focus", 0);
|
||||||
this.actor.reactive = false;
|
this.actor.reactive = false;
|
||||||
|
|
||||||
this._container = new Shell.GenericContainer();
|
this._container = St.BoxLayout({ style_class: 'panel-status-menu-box' });
|
||||||
bin.set_child(this._container);
|
bin.set_child(this._container);
|
||||||
this._container.connect('get-preferred-width', Lang.bind(this, this._getContentPreferredWidth));
|
|
||||||
this._container.connect('get-preferred-height', Lang.bind(this, this._getContentPreferredHeight));
|
|
||||||
this._container.connect('allocate', Lang.bind(this, this._contentAllocate));
|
|
||||||
|
|
||||||
let textureCache = St.TextureCache.get_default();
|
let textureCache = St.TextureCache.get_default();
|
||||||
textureCache.connect('icon-theme-changed',
|
textureCache.connect('icon-theme-changed',
|
||||||
@ -206,14 +203,11 @@ const AppMenuButton = new Lang.Class({
|
|||||||
Lang.bind(this, this._updateIconBoxClip));
|
Lang.bind(this, this._updateIconBoxClip));
|
||||||
this._container.add_actor(this._iconBox);
|
this._container.add_actor(this._iconBox);
|
||||||
|
|
||||||
this._hbox = new St.BoxLayout({ style_class: 'panel-status-menu-box' });
|
|
||||||
this._container.add_actor(this._hbox);
|
|
||||||
|
|
||||||
this._label = new TextShadower();
|
this._label = new TextShadower();
|
||||||
this._label.actor.y_align = Clutter.ActorAlign.CENTER;
|
this._label.actor.y_align = Clutter.ActorAlign.CENTER;
|
||||||
this._hbox.add_actor(this._label.actor);
|
this._container.add_actor(this._label.actor);
|
||||||
this._arrow = PopupMenu.arrowIcon(St.Side.BOTTOM);
|
this._arrow = PopupMenu.arrowIcon(St.Side.BOTTOM);
|
||||||
this._hbox.add_actor(this._arrow);
|
this._container.add_actor(this._arrow);
|
||||||
|
|
||||||
this._iconBottomClip = 0;
|
this._iconBottomClip = 0;
|
||||||
|
|
||||||
@ -273,11 +267,11 @@ const AppMenuButton = new Lang.Class({
|
|||||||
_onStyleChanged: function(actor) {
|
_onStyleChanged: function(actor) {
|
||||||
let node = actor.get_theme_node();
|
let node = actor.get_theme_node();
|
||||||
let [success, icon] = node.lookup_url('spinner-image', false);
|
let [success, icon] = node.lookup_url('spinner-image', false);
|
||||||
if (!success || this._spinnerIcon == icon)
|
if (!success || (this._spinnerIcon && this._spinnerIcon.equal(icon)))
|
||||||
return;
|
return;
|
||||||
this._spinnerIcon = icon;
|
this._spinnerIcon = icon;
|
||||||
this._spinner = new Animation.AnimatedIcon(this._spinnerIcon, PANEL_ICON_SIZE);
|
this._spinner = new Animation.AnimatedIcon(this._spinnerIcon, PANEL_ICON_SIZE);
|
||||||
this._hbox.add_actor(this._spinner.actor);
|
this._container.add_actor(this._spinner.actor);
|
||||||
this._spinner.actor.hide();
|
this._spinner.actor.hide();
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -291,7 +285,7 @@ const AppMenuButton = new Lang.Class({
|
|||||||
if (!this._targetApp)
|
if (!this._targetApp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
let icon = this._targetApp.get_faded_icon(2 * PANEL_ICON_SIZE, this._iconBox.text_direction);
|
let icon = this._targetApp.create_icon_texture(2 * PANEL_ICON_SIZE);
|
||||||
this._iconBox.set_child(icon);
|
this._iconBox.set_child(icon);
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -344,64 +338,6 @@ const AppMenuButton = new Lang.Class({
|
|||||||
this._spinner.actor.show();
|
this._spinner.actor.show();
|
||||||
},
|
},
|
||||||
|
|
||||||
_getContentPreferredWidth: function(actor, forHeight, alloc) {
|
|
||||||
let [minSize, naturalSize] = this._iconBox.get_preferred_width(forHeight);
|
|
||||||
alloc.min_size = minSize;
|
|
||||||
alloc.natural_size = naturalSize;
|
|
||||||
[minSize, naturalSize] = this._hbox.get_preferred_width(forHeight);
|
|
||||||
alloc.min_size = alloc.min_size + Math.max(0, minSize - Math.floor(alloc.min_size / 2));
|
|
||||||
alloc.natural_size = alloc.natural_size + Math.max(0, naturalSize - Math.floor(alloc.natural_size / 2));
|
|
||||||
},
|
|
||||||
|
|
||||||
_getContentPreferredHeight: function(actor, forWidth, alloc) {
|
|
||||||
let [minSize, naturalSize] = this._iconBox.get_preferred_height(forWidth);
|
|
||||||
alloc.min_size = minSize;
|
|
||||||
alloc.natural_size = naturalSize;
|
|
||||||
[minSize, naturalSize] = this._hbox.get_preferred_height(forWidth);
|
|
||||||
if (minSize > alloc.min_size)
|
|
||||||
alloc.min_size = minSize;
|
|
||||||
if (naturalSize > alloc.natural_size)
|
|
||||||
alloc.natural_size = naturalSize;
|
|
||||||
},
|
|
||||||
|
|
||||||
_contentAllocate: function(actor, box, flags) {
|
|
||||||
let allocWidth = box.x2 - box.x1;
|
|
||||||
let allocHeight = box.y2 - box.y1;
|
|
||||||
let childBox = new Clutter.ActorBox();
|
|
||||||
|
|
||||||
let [minWidth, minHeight, naturalWidth, naturalHeight] = this._iconBox.get_preferred_size();
|
|
||||||
|
|
||||||
let direction = this.actor.get_text_direction();
|
|
||||||
|
|
||||||
let yPadding = Math.floor(Math.max(0, allocHeight - naturalHeight) / 2);
|
|
||||||
childBox.y1 = yPadding;
|
|
||||||
childBox.y2 = childBox.y1 + Math.min(naturalHeight, allocHeight);
|
|
||||||
if (direction == Clutter.TextDirection.LTR) {
|
|
||||||
childBox.x1 = 0;
|
|
||||||
childBox.x2 = childBox.x1 + Math.min(naturalWidth, allocWidth);
|
|
||||||
} else {
|
|
||||||
childBox.x1 = Math.max(0, allocWidth - naturalWidth);
|
|
||||||
childBox.x2 = allocWidth;
|
|
||||||
}
|
|
||||||
this._iconBox.allocate(childBox, flags);
|
|
||||||
|
|
||||||
let iconWidth = childBox.x2 - childBox.x1;
|
|
||||||
|
|
||||||
[minWidth, naturalWidth] = this._hbox.get_preferred_width(-1);
|
|
||||||
|
|
||||||
childBox.y1 = 0;
|
|
||||||
childBox.y2 = allocHeight;
|
|
||||||
|
|
||||||
if (direction == Clutter.TextDirection.LTR) {
|
|
||||||
childBox.x1 = Math.floor(iconWidth / 2);
|
|
||||||
childBox.x2 = Math.min(childBox.x1 + naturalWidth, allocWidth);
|
|
||||||
} else {
|
|
||||||
childBox.x2 = allocWidth - Math.floor(iconWidth / 2);
|
|
||||||
childBox.x1 = Math.max(0, childBox.x2 - naturalWidth);
|
|
||||||
}
|
|
||||||
this._hbox.allocate(childBox, flags);
|
|
||||||
},
|
|
||||||
|
|
||||||
_onAppStateChanged: function(appSys, app) {
|
_onAppStateChanged: function(appSys, app) {
|
||||||
let state = app.state;
|
let state = app.state;
|
||||||
if (state != Shell.AppState.STARTING) {
|
if (state != Shell.AppState.STARTING) {
|
||||||
@ -814,7 +750,7 @@ const AggregateMenu = new Lang.Class({
|
|||||||
this.menu.actor.add_style_class_name('aggregate-menu');
|
this.menu.actor.add_style_class_name('aggregate-menu');
|
||||||
|
|
||||||
this._indicators = new St.BoxLayout({ style_class: 'panel-status-indicators-box' });
|
this._indicators = new St.BoxLayout({ style_class: 'panel-status-indicators-box' });
|
||||||
this.actor.add_child(this._indicators);
|
this.actor.add_actor(this._indicators);
|
||||||
|
|
||||||
if (Config.HAVE_NETWORKMANAGER) {
|
if (Config.HAVE_NETWORKMANAGER) {
|
||||||
this._network = new imports.ui.status.network.NMApplet();
|
this._network = new imports.ui.status.network.NMApplet();
|
||||||
@ -1019,7 +955,7 @@ const Panel = new Lang.Class({
|
|||||||
if (!dragWindow)
|
if (!dragWindow)
|
||||||
return Clutter.EVENT_PROPAGATE;
|
return Clutter.EVENT_PROPAGATE;
|
||||||
|
|
||||||
let rect = dragWindow.get_outer_rect();
|
let rect = dragWindow.get_frame_rect();
|
||||||
let [stageX, stageY] = event.get_coords();
|
let [stageX, stageY] = event.get_coords();
|
||||||
|
|
||||||
let allowDrag = dragWindow.maximized_vertically &&
|
let allowDrag = dragWindow.maximized_vertically &&
|
||||||
@ -1100,7 +1036,7 @@ const Panel = new Lang.Class({
|
|||||||
continue;
|
continue;
|
||||||
if (indicator.menu)
|
if (indicator.menu)
|
||||||
indicator.menu.close();
|
indicator.menu.close();
|
||||||
indicator.container.hide();
|
indicator.actor.hide();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -1132,21 +1068,14 @@ const Panel = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_addToPanelBox: function(role, indicator, position, box) {
|
_addToPanelBox: function(role, indicator, position, box) {
|
||||||
let container = indicator.container;
|
indicator.actor.show();
|
||||||
container.show();
|
box.insert_child_at_index(indicator.actor, position);
|
||||||
|
|
||||||
let parent = container.get_parent();
|
|
||||||
if (parent)
|
|
||||||
parent.remove_actor(container);
|
|
||||||
|
|
||||||
box.insert_child_at_index(container, position);
|
|
||||||
if (indicator.menu)
|
if (indicator.menu)
|
||||||
this.menuManager.addMenu(indicator.menu);
|
this.menuManager.addMenu(indicator.menu);
|
||||||
this.statusArea[role] = indicator;
|
this.statusArea[role] = indicator;
|
||||||
let destroyId = indicator.connect('destroy', Lang.bind(this, function(emitter) {
|
let destroyId = indicator.connect('destroy', Lang.bind(this, function(emitter) {
|
||||||
delete this.statusArea[role];
|
delete this.statusArea[role];
|
||||||
emitter.disconnect(destroyId);
|
emitter.disconnect(destroyId);
|
||||||
container.destroy();
|
|
||||||
}));
|
}));
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -13,92 +13,16 @@ const Main = imports.ui.main;
|
|||||||
const Params = imports.misc.params;
|
const Params = imports.misc.params;
|
||||||
const PopupMenu = imports.ui.popupMenu;
|
const PopupMenu = imports.ui.popupMenu;
|
||||||
|
|
||||||
const ButtonBox = new Lang.Class({
|
|
||||||
Name: 'ButtonBox',
|
|
||||||
|
|
||||||
_init: function(params) {
|
|
||||||
params = Params.parse(params, { style_class: 'panel-button' }, true);
|
|
||||||
this.actor = new Shell.GenericContainer(params);
|
|
||||||
this.actor._delegate = this;
|
|
||||||
|
|
||||||
this.container = new St.Bin({ y_fill: true,
|
|
||||||
x_fill: true,
|
|
||||||
child: this.actor });
|
|
||||||
|
|
||||||
this.actor.connect('get-preferred-width', Lang.bind(this, this._getPreferredWidth));
|
|
||||||
this.actor.connect('get-preferred-height', Lang.bind(this, this._getPreferredHeight));
|
|
||||||
this.actor.connect('allocate', Lang.bind(this, this._allocate));
|
|
||||||
|
|
||||||
this.actor.connect('style-changed', Lang.bind(this, this._onStyleChanged));
|
|
||||||
this._minHPadding = this._natHPadding = 0.0;
|
|
||||||
},
|
|
||||||
|
|
||||||
_onStyleChanged: function(actor) {
|
|
||||||
let themeNode = actor.get_theme_node();
|
|
||||||
|
|
||||||
this._minHPadding = themeNode.get_length('-minimum-hpadding');
|
|
||||||
this._natHPadding = themeNode.get_length('-natural-hpadding');
|
|
||||||
},
|
|
||||||
|
|
||||||
_getPreferredWidth: function(actor, forHeight, alloc) {
|
|
||||||
let child = actor.get_first_child();
|
|
||||||
|
|
||||||
if (child) {
|
|
||||||
[alloc.min_size, alloc.natural_size] = child.get_preferred_width(-1);
|
|
||||||
} else {
|
|
||||||
alloc.min_size = alloc.natural_size = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
alloc.min_size += 2 * this._minHPadding;
|
|
||||||
alloc.natural_size += 2 * this._natHPadding;
|
|
||||||
},
|
|
||||||
|
|
||||||
_getPreferredHeight: function(actor, forWidth, alloc) {
|
|
||||||
let child = actor.get_first_child();
|
|
||||||
|
|
||||||
if (child) {
|
|
||||||
[alloc.min_size, alloc.natural_size] = child.get_preferred_height(-1);
|
|
||||||
} else {
|
|
||||||
alloc.min_size = alloc.natural_size = 0;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_allocate: function(actor, box, flags) {
|
|
||||||
let child = actor.get_first_child();
|
|
||||||
if (!child)
|
|
||||||
return;
|
|
||||||
|
|
||||||
let [minWidth, natWidth] = child.get_preferred_width(-1);
|
|
||||||
|
|
||||||
let availWidth = box.x2 - box.x1;
|
|
||||||
let availHeight = box.y2 - box.y1;
|
|
||||||
|
|
||||||
let childBox = new Clutter.ActorBox();
|
|
||||||
if (natWidth + 2 * this._natHPadding <= availWidth) {
|
|
||||||
childBox.x1 = this._natHPadding;
|
|
||||||
childBox.x2 = availWidth - this._natHPadding;
|
|
||||||
} else {
|
|
||||||
childBox.x1 = this._minHPadding;
|
|
||||||
childBox.x2 = availWidth - this._minHPadding;
|
|
||||||
}
|
|
||||||
|
|
||||||
childBox.y1 = 0;
|
|
||||||
childBox.y2 = availHeight;
|
|
||||||
|
|
||||||
child.allocate(childBox, flags);
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
const Button = new Lang.Class({
|
const Button = new Lang.Class({
|
||||||
Name: 'PanelMenuButton',
|
Name: 'PanelMenuButton',
|
||||||
Extends: ButtonBox,
|
|
||||||
|
|
||||||
_init: function(menuAlignment, nameText, dontCreateMenu) {
|
_init: function(menuAlignment, nameText, dontCreateMenu) {
|
||||||
this.parent({ reactive: true,
|
this.actor = new St.Bin({ style_class: 'panel-button',
|
||||||
can_focus: true,
|
reactive: true,
|
||||||
track_hover: true,
|
can_focus: true,
|
||||||
accessible_name: nameText ? nameText : "",
|
track_hover: true,
|
||||||
accessible_role: Atk.Role.MENU });
|
accessible_name: nameText ? nameText : "",
|
||||||
|
accessible_role: Atk.Role.MENU });
|
||||||
|
|
||||||
this.actor.connect('event', Lang.bind(this, this._onEvent));
|
this.actor.connect('event', Lang.bind(this, this._onEvent));
|
||||||
this.actor.connect('notify::visible', Lang.bind(this, this._onVisibilityChanged));
|
this.actor.connect('notify::visible', Lang.bind(this, this._onVisibilityChanged));
|
||||||
@ -177,8 +101,6 @@ const Button = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
destroy: function() {
|
destroy: function() {
|
||||||
this.actor._delegate = null;
|
|
||||||
|
|
||||||
if (this.menu)
|
if (this.menu)
|
||||||
this.menu.destroy();
|
this.menu.destroy();
|
||||||
this.actor.destroy();
|
this.actor.destroy();
|
||||||
|
@ -918,14 +918,14 @@ const PopupSubMenu = new Lang.Class({
|
|||||||
if (animate && needsScrollbar)
|
if (animate && needsScrollbar)
|
||||||
animate = false;
|
animate = false;
|
||||||
|
|
||||||
|
let targetAngle = this.actor.text_direction == Clutter.TextDirection.RTL ? -90 : 90;
|
||||||
|
|
||||||
if (animate) {
|
if (animate) {
|
||||||
let [minHeight, naturalHeight] = this.actor.get_preferred_height(-1);
|
let [minHeight, naturalHeight] = this.actor.get_preferred_height(-1);
|
||||||
this.actor.height = 0;
|
this.actor.height = 0;
|
||||||
this.actor._arrowRotation = this._arrow.rotation_angle_z;
|
this.actor._arrowRotation = this._arrow.rotation_angle_z;
|
||||||
let angle = this.actor._arrowRotation;
|
|
||||||
// animate to the first multiple of 90 greater than current angle
|
|
||||||
Tweener.addTween(this.actor,
|
Tweener.addTween(this.actor,
|
||||||
{ _arrowRotation: angle - angle % 90 + 90,
|
{ _arrowRotation: targetAngle,
|
||||||
height: naturalHeight,
|
height: naturalHeight,
|
||||||
time: 0.25,
|
time: 0.25,
|
||||||
onUpdateScope: this,
|
onUpdateScope: this,
|
||||||
@ -938,7 +938,7 @@ const PopupSubMenu = new Lang.Class({
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
this._arrow.rotation_angle_z = this.actor._arrowRotation + 90;
|
this._arrow.rotation_angle_z = targetAngle;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -957,10 +957,8 @@ const PopupSubMenu = new Lang.Class({
|
|||||||
|
|
||||||
if (animate) {
|
if (animate) {
|
||||||
this.actor._arrowRotation = this._arrow.rotation_angle_z;
|
this.actor._arrowRotation = this._arrow.rotation_angle_z;
|
||||||
let angle = this.actor._arrowRotation;
|
|
||||||
// animate to the first multiple of 90 less than current angle
|
|
||||||
Tweener.addTween(this.actor,
|
Tweener.addTween(this.actor,
|
||||||
{ _arrowRotation: (angle - 1) - (angle - 1) % 90,
|
{ _arrowRotation: 0,
|
||||||
height: 0,
|
height: 0,
|
||||||
time: 0.25,
|
time: 0.25,
|
||||||
onUpdateScope: this,
|
onUpdateScope: this,
|
||||||
@ -974,7 +972,7 @@ const PopupSubMenu = new Lang.Class({
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
this._arrow.rotation_angle_z = this.actor._arrowRotation - 90;
|
this._arrow.rotation_angle_z = 0;
|
||||||
this.actor.hide();
|
this.actor.hide();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@ -1052,8 +1050,6 @@ const PopupSubMenuMenuItem = new Lang.Class({
|
|||||||
this._triangleBin = new St.Widget({ y_expand: true,
|
this._triangleBin = new St.Widget({ y_expand: true,
|
||||||
y_align: Clutter.ActorAlign.CENTER });
|
y_align: Clutter.ActorAlign.CENTER });
|
||||||
this._triangleBin.add_child(this._triangle);
|
this._triangleBin.add_child(this._triangle);
|
||||||
if (this._triangleBin.get_text_direction() == Clutter.TextDirection.RTL)
|
|
||||||
this._triangleBin.set_scale(-1.0, 1.0);
|
|
||||||
|
|
||||||
this.actor.add_child(this._triangleBin);
|
this.actor.add_child(this._triangleBin);
|
||||||
this.actor.add_accessible_state (Atk.StateType.EXPANDABLE);
|
this.actor.add_accessible_state (Atk.StateType.EXPANDABLE);
|
||||||
|
@ -85,7 +85,8 @@ const Clock = new Lang.Class({
|
|||||||
let date = new Date();
|
let date = new Date();
|
||||||
/* Translators: This is a time format for a date in
|
/* Translators: This is a time format for a date in
|
||||||
long format */
|
long format */
|
||||||
this._date.text = date.toLocaleFormat(_("%A, %B %d"));
|
let dateFormat = Shell.util_translate_time_string(N_("%A, %B %d"));
|
||||||
|
this._date.text = date.toLocaleFormat(dateFormat);
|
||||||
},
|
},
|
||||||
|
|
||||||
destroy: function() {
|
destroy: function() {
|
||||||
@ -669,7 +670,9 @@ const ScreenShield = new Lang.Class({
|
|||||||
if (this._lockScreenState != MessageTray.State.SHOWN)
|
if (this._lockScreenState != MessageTray.State.SHOWN)
|
||||||
return Clutter.EVENT_PROPAGATE;
|
return Clutter.EVENT_PROPAGATE;
|
||||||
|
|
||||||
let isEnter = (symbol == Clutter.KEY_Return || symbol == Clutter.KEY_KP_Enter);
|
let isEnter = (symbol == Clutter.KEY_Return ||
|
||||||
|
symbol == Clutter.KEY_KP_Enter ||
|
||||||
|
symbol == Clutter.KEY_ISO_Enter);
|
||||||
if (!isEnter && !(GLib.unichar_isprint(unichar) || symbol == Clutter.KEY_Escape))
|
if (!isEnter && !(GLib.unichar_isprint(unichar) || symbol == Clutter.KEY_Escape))
|
||||||
return Clutter.EVENT_PROPAGATE;
|
return Clutter.EVENT_PROPAGATE;
|
||||||
|
|
||||||
@ -919,6 +922,11 @@ const ScreenShield = new Lang.Class({
|
|||||||
|
|
||||||
this._lockScreenState = MessageTray.State.HIDDEN;
|
this._lockScreenState = MessageTray.State.HIDDEN;
|
||||||
this._lockScreenGroup.hide();
|
this._lockScreenGroup.hide();
|
||||||
|
|
||||||
|
if (this._dialog) {
|
||||||
|
this._dialog.actor.grab_key_focus();
|
||||||
|
this._dialog.actor.navigate_focus(null, Gtk.DirectionType.TAB_FORWARD, false);
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_hideLockScreen: function(animate, velocity) {
|
_hideLockScreen: function(animate, velocity) {
|
||||||
@ -1327,6 +1335,8 @@ const ScreenShield = new Lang.Class({
|
|||||||
|
|
||||||
// If the previous shell crashed, and gnome-session restarted us, then re-lock
|
// If the previous shell crashed, and gnome-session restarted us, then re-lock
|
||||||
lockIfWasLocked: function() {
|
lockIfWasLocked: function() {
|
||||||
|
if (!this._settings.get_boolean(LOCK_ENABLED_KEY))
|
||||||
|
return;
|
||||||
let wasLocked = global.get_runtime_state('b', LOCKED_STATE_STR);
|
let wasLocked = global.get_runtime_state('b', LOCKED_STATE_STR);
|
||||||
if (wasLocked === null)
|
if (wasLocked === null)
|
||||||
return;
|
return;
|
||||||
|
@ -43,6 +43,8 @@ const ScreencastService = new Lang.Class({
|
|||||||
|
|
||||||
this._recorders = new Map();
|
this._recorders = new Map();
|
||||||
|
|
||||||
|
this._lockdownSettings = new Gio.Settings({ schema_id: 'org.gnome.desktop.lockdown' });
|
||||||
|
|
||||||
Main.sessionMode.connect('updated', Lang.bind(this, this._sessionUpdated));
|
Main.sessionMode.connect('updated', Lang.bind(this, this._sessionUpdated));
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -68,8 +70,8 @@ const ScreencastService = new Lang.Class({
|
|||||||
if (Main.sessionMode.allowScreencast)
|
if (Main.sessionMode.allowScreencast)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
this._recorders.clear();
|
for (let sender of this._recorders.keys())
|
||||||
this.emit('updated');
|
this._stopRecordingForSender(sender);
|
||||||
},
|
},
|
||||||
|
|
||||||
_onNameVanished: function(connection, name) {
|
_onNameVanished: function(connection, name) {
|
||||||
@ -103,7 +105,8 @@ const ScreencastService = new Lang.Class({
|
|||||||
|
|
||||||
ScreencastAsync: function(params, invocation) {
|
ScreencastAsync: function(params, invocation) {
|
||||||
let returnValue = [false, ''];
|
let returnValue = [false, ''];
|
||||||
if (!Main.sessionMode.allowScreencast) {
|
if (!Main.sessionMode.allowScreencast ||
|
||||||
|
this._lockdownSettings.get_boolean('disable-save-to-disk')) {
|
||||||
invocation.return_value(GLib.Variant.new('(bs)', returnValue));
|
invocation.return_value(GLib.Variant.new('(bs)', returnValue));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -117,6 +120,8 @@ const ScreencastService = new Lang.Class({
|
|||||||
this._applyOptionalParameters(recorder, options);
|
this._applyOptionalParameters(recorder, options);
|
||||||
let [success, fileName] = recorder.record();
|
let [success, fileName] = recorder.record();
|
||||||
returnValue = [success, fileName ? fileName : ''];
|
returnValue = [success, fileName ? fileName : ''];
|
||||||
|
if (!success)
|
||||||
|
this._stopRecordingForSender(sender);
|
||||||
}
|
}
|
||||||
|
|
||||||
invocation.return_value(GLib.Variant.new('(bs)', returnValue));
|
invocation.return_value(GLib.Variant.new('(bs)', returnValue));
|
||||||
@ -124,7 +129,8 @@ const ScreencastService = new Lang.Class({
|
|||||||
|
|
||||||
ScreencastAreaAsync: function(params, invocation) {
|
ScreencastAreaAsync: function(params, invocation) {
|
||||||
let returnValue = [false, ''];
|
let returnValue = [false, ''];
|
||||||
if (!Main.sessionMode.allowScreencast) {
|
if (!Main.sessionMode.allowScreencast ||
|
||||||
|
this._lockdownSettings.get_boolean('disable-save-to-disk')) {
|
||||||
invocation.return_value(GLib.Variant.new('(bs)', returnValue));
|
invocation.return_value(GLib.Variant.new('(bs)', returnValue));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -150,6 +156,8 @@ const ScreencastService = new Lang.Class({
|
|||||||
this._applyOptionalParameters(recorder, options);
|
this._applyOptionalParameters(recorder, options);
|
||||||
let [success, fileName] = recorder.record();
|
let [success, fileName] = recorder.record();
|
||||||
returnValue = [success, fileName ? fileName : ''];
|
returnValue = [success, fileName ? fileName : ''];
|
||||||
|
if (!success)
|
||||||
|
this._stopRecordingForSender(sender);
|
||||||
}
|
}
|
||||||
|
|
||||||
invocation.return_value(GLib.Variant.new('(bs)', returnValue));
|
invocation.return_value(GLib.Variant.new('(bs)', returnValue));
|
||||||
|
@ -65,9 +65,44 @@ const ScreenshotService = new Lang.Class({
|
|||||||
this._dbusImpl = Gio.DBusExportedObject.wrapJSObject(ScreenshotIface, this);
|
this._dbusImpl = Gio.DBusExportedObject.wrapJSObject(ScreenshotIface, this);
|
||||||
this._dbusImpl.export(Gio.DBus.session, '/org/gnome/Shell/Screenshot');
|
this._dbusImpl.export(Gio.DBus.session, '/org/gnome/Shell/Screenshot');
|
||||||
|
|
||||||
|
this._screenShooter = new Map();
|
||||||
|
|
||||||
|
this._lockdownSettings = new Gio.Settings({ schema_id: 'org.gnome.desktop.lockdown' });
|
||||||
|
|
||||||
Gio.DBus.session.own_name('org.gnome.Shell.Screenshot', Gio.BusNameOwnerFlags.REPLACE, null, null);
|
Gio.DBus.session.own_name('org.gnome.Shell.Screenshot', Gio.BusNameOwnerFlags.REPLACE, null, null);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_createScreenshot: function(invocation) {
|
||||||
|
let sender = invocation.get_sender();
|
||||||
|
if (this._screenShooter.has(sender) ||
|
||||||
|
this._lockdownSettings.get_boolean('disable-save-to-disk')) {
|
||||||
|
invocation.return_value(GLib.Variant.new('(bs)', [false, '']));
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
let shooter = new Shell.Screenshot();
|
||||||
|
shooter._watchNameId =
|
||||||
|
Gio.bus_watch_name(Gio.BusType.SESSION, sender, 0, null,
|
||||||
|
Lang.bind(this, this._onNameVanished));
|
||||||
|
|
||||||
|
this._screenShooter.set(sender, shooter);
|
||||||
|
|
||||||
|
return shooter;
|
||||||
|
},
|
||||||
|
|
||||||
|
_onNameVanished: function(connection, name) {
|
||||||
|
this._removeShooterForSender(name);
|
||||||
|
},
|
||||||
|
|
||||||
|
_removeShooterForSender: function(sender) {
|
||||||
|
let shooter = this._screenShooter.get(sender);
|
||||||
|
if (!shooter)
|
||||||
|
return;
|
||||||
|
|
||||||
|
Gio.bus_unwatch_name(shooter._watchNameId);
|
||||||
|
this._screenShooter.delete(sender);
|
||||||
|
},
|
||||||
|
|
||||||
_checkArea: function(x, y, width, height) {
|
_checkArea: function(x, y, width, height) {
|
||||||
return x >= 0 && y >= 0 &&
|
return x >= 0 && y >= 0 &&
|
||||||
width > 0 && height > 0 &&
|
width > 0 && height > 0 &&
|
||||||
@ -76,9 +111,15 @@ const ScreenshotService = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_onScreenshotComplete: function(obj, result, area, filenameUsed, flash, invocation) {
|
_onScreenshotComplete: function(obj, result, area, filenameUsed, flash, invocation) {
|
||||||
if (flash && result) {
|
if (result) {
|
||||||
let flashspot = new Flashspot(area);
|
if (flash) {
|
||||||
flashspot.fire();
|
let flashspot = new Flashspot(area);
|
||||||
|
flashspot.fire(Lang.bind(this, function() {
|
||||||
|
this._removeShooterForSender(invocation.get_sender());
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
this._removeShooterForSender(invocation.get_sender());
|
||||||
}
|
}
|
||||||
|
|
||||||
let retval = GLib.Variant.new('(bs)', [result, filenameUsed]);
|
let retval = GLib.Variant.new('(bs)', [result, filenameUsed]);
|
||||||
@ -112,7 +153,9 @@ const ScreenshotService = new Lang.Class({
|
|||||||
"Invalid params");
|
"Invalid params");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
let screenshot = new Shell.Screenshot();
|
let screenshot = this._createScreenshot(invocation);
|
||||||
|
if (!screenshot)
|
||||||
|
return;
|
||||||
screenshot.screenshot_area (x, y, width, height, filename,
|
screenshot.screenshot_area (x, y, width, height, filename,
|
||||||
Lang.bind(this, this._onScreenshotComplete,
|
Lang.bind(this, this._onScreenshotComplete,
|
||||||
flash, invocation));
|
flash, invocation));
|
||||||
@ -120,7 +163,9 @@ const ScreenshotService = new Lang.Class({
|
|||||||
|
|
||||||
ScreenshotWindowAsync : function (params, invocation) {
|
ScreenshotWindowAsync : function (params, invocation) {
|
||||||
let [include_frame, include_cursor, flash, filename] = params;
|
let [include_frame, include_cursor, flash, filename] = params;
|
||||||
let screenshot = new Shell.Screenshot();
|
let screenshot = this._createScreenshot(invocation);
|
||||||
|
if (!screenshot)
|
||||||
|
return;
|
||||||
screenshot.screenshot_window (include_frame, include_cursor, filename,
|
screenshot.screenshot_window (include_frame, include_cursor, filename,
|
||||||
Lang.bind(this, this._onScreenshotComplete,
|
Lang.bind(this, this._onScreenshotComplete,
|
||||||
flash, invocation));
|
flash, invocation));
|
||||||
@ -128,7 +173,9 @@ const ScreenshotService = new Lang.Class({
|
|||||||
|
|
||||||
ScreenshotAsync : function (params, invocation) {
|
ScreenshotAsync : function (params, invocation) {
|
||||||
let [include_cursor, flash, filename] = params;
|
let [include_cursor, flash, filename] = params;
|
||||||
let screenshot = new Shell.Screenshot();
|
let screenshot = this._createScreenshot(invocation);
|
||||||
|
if (!screenshot)
|
||||||
|
return;
|
||||||
screenshot.screenshot(include_cursor, filename,
|
screenshot.screenshot(include_cursor, filename,
|
||||||
Lang.bind(this, this._onScreenshotComplete,
|
Lang.bind(this, this._onScreenshotComplete,
|
||||||
flash, invocation));
|
flash, invocation));
|
||||||
@ -302,7 +349,7 @@ const Flashspot = new Lang.Class({
|
|||||||
this.actor.set_position(area.x, area.y);
|
this.actor.set_position(area.x, area.y);
|
||||||
},
|
},
|
||||||
|
|
||||||
fire: function() {
|
fire: function(doneCallback) {
|
||||||
this.actor.show();
|
this.actor.show();
|
||||||
this.actor.opacity = 255;
|
this.actor.opacity = 255;
|
||||||
Tweener.addTween(this.actor,
|
Tweener.addTween(this.actor,
|
||||||
@ -310,6 +357,8 @@ const Flashspot = new Lang.Class({
|
|||||||
time: FLASHSPOT_ANIMATION_OUT_TIME,
|
time: FLASHSPOT_ANIMATION_OUT_TIME,
|
||||||
transition: 'easeOutQuad',
|
transition: 'easeOutQuad',
|
||||||
onComplete: Lang.bind(this, function() {
|
onComplete: Lang.bind(this, function() {
|
||||||
|
if (doneCallback)
|
||||||
|
doneCallback();
|
||||||
this.destroy();
|
this.destroy();
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
|
311
js/ui/search.js
@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
const Clutter = imports.gi.Clutter;
|
const Clutter = imports.gi.Clutter;
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
|
const GLib = imports.gi.GLib;
|
||||||
const Gio = imports.gi.Gio;
|
const Gio = imports.gi.Gio;
|
||||||
const Gtk = imports.gi.Gtk;
|
const Gtk = imports.gi.Gtk;
|
||||||
const Meta = imports.gi.Meta;
|
const Meta = imports.gi.Meta;
|
||||||
@ -24,108 +25,6 @@ const SEARCH_PROVIDERS_SCHEMA = 'org.gnome.desktop.search-providers';
|
|||||||
const MAX_LIST_SEARCH_RESULTS_ROWS = 3;
|
const MAX_LIST_SEARCH_RESULTS_ROWS = 3;
|
||||||
const MAX_GRID_SEARCH_RESULTS_ROWS = 1;
|
const MAX_GRID_SEARCH_RESULTS_ROWS = 1;
|
||||||
|
|
||||||
const SearchSystem = new Lang.Class({
|
|
||||||
Name: 'SearchSystem',
|
|
||||||
|
|
||||||
_init: function() {
|
|
||||||
this._providers = [];
|
|
||||||
|
|
||||||
this._registerProvider(new AppDisplay.AppSearchProvider());
|
|
||||||
|
|
||||||
this._searchSettings = new Gio.Settings({ schema_id: SEARCH_PROVIDERS_SCHEMA });
|
|
||||||
this._searchSettings.connect('changed::enabled', Lang.bind(this, this._reloadRemoteProviders));
|
|
||||||
this._searchSettings.connect('changed::disabled', Lang.bind(this, this._reloadRemoteProviders));
|
|
||||||
this._searchSettings.connect('changed::disable-external', Lang.bind(this, this._reloadRemoteProviders));
|
|
||||||
this._searchSettings.connect('changed::sort-order', Lang.bind(this, this._reloadRemoteProviders));
|
|
||||||
|
|
||||||
this._reloadRemoteProviders();
|
|
||||||
|
|
||||||
this._cancellable = new Gio.Cancellable();
|
|
||||||
},
|
|
||||||
|
|
||||||
addProvider: function(provider) {
|
|
||||||
this._providers.push(provider);
|
|
||||||
this.emit('providers-changed');
|
|
||||||
},
|
|
||||||
|
|
||||||
_reloadRemoteProviders: function() {
|
|
||||||
let remoteProviders = this._providers.filter(function(provider) {
|
|
||||||
return provider.isRemoteProvider;
|
|
||||||
});
|
|
||||||
remoteProviders.forEach(Lang.bind(this, function(provider) {
|
|
||||||
this._unregisterProvider(provider);
|
|
||||||
}));
|
|
||||||
|
|
||||||
RemoteSearch.loadRemoteSearchProviders(Lang.bind(this, function(providers) {
|
|
||||||
providers.forEach(Lang.bind(this, this._registerProvider));
|
|
||||||
}));
|
|
||||||
|
|
||||||
this.emit('providers-changed');
|
|
||||||
},
|
|
||||||
|
|
||||||
_registerProvider: function (provider) {
|
|
||||||
this._providers.push(provider);
|
|
||||||
},
|
|
||||||
|
|
||||||
_unregisterProvider: function (provider) {
|
|
||||||
let index = this._providers.indexOf(provider);
|
|
||||||
this._providers.splice(index, 1);
|
|
||||||
|
|
||||||
if (provider.display)
|
|
||||||
provider.display.destroy();
|
|
||||||
},
|
|
||||||
|
|
||||||
getProviders: function() {
|
|
||||||
return this._providers;
|
|
||||||
},
|
|
||||||
|
|
||||||
getTerms: function() {
|
|
||||||
return this._terms;
|
|
||||||
},
|
|
||||||
|
|
||||||
reset: function() {
|
|
||||||
this._terms = [];
|
|
||||||
this._results = {};
|
|
||||||
},
|
|
||||||
|
|
||||||
_gotResults: function(results, provider) {
|
|
||||||
this._results[provider.id] = results;
|
|
||||||
this.emit('search-updated', provider, results);
|
|
||||||
},
|
|
||||||
|
|
||||||
setTerms: function(terms) {
|
|
||||||
this._cancellable.cancel();
|
|
||||||
this._cancellable.reset();
|
|
||||||
|
|
||||||
let previousResults = this._results;
|
|
||||||
let previousTerms = this._terms;
|
|
||||||
this.reset();
|
|
||||||
|
|
||||||
if (!terms)
|
|
||||||
return;
|
|
||||||
|
|
||||||
let searchString = terms.join(' ');
|
|
||||||
let previousSearchString = previousTerms.join(' ');
|
|
||||||
if (searchString == previousSearchString)
|
|
||||||
return;
|
|
||||||
|
|
||||||
let isSubSearch = false;
|
|
||||||
if (previousTerms.length > 0)
|
|
||||||
isSubSearch = searchString.indexOf(previousSearchString) == 0;
|
|
||||||
|
|
||||||
this._terms = terms;
|
|
||||||
|
|
||||||
this._providers.forEach(Lang.bind(this, function(provider) {
|
|
||||||
let previousProviderResults = previousResults[provider.id];
|
|
||||||
if (isSubSearch && previousProviderResults)
|
|
||||||
provider.getSubsearchResultSet(previousProviderResults, terms, Lang.bind(this, this._gotResults, provider), this._cancellable);
|
|
||||||
else
|
|
||||||
provider.getInitialResultSet(terms, Lang.bind(this, this._gotResults, provider), this._cancellable);
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
Signals.addSignalMethods(SearchSystem.prototype);
|
|
||||||
|
|
||||||
const MaxWidthBin = new Lang.Class({
|
const MaxWidthBin = new Lang.Class({
|
||||||
Name: 'MaxWidthBin',
|
Name: 'MaxWidthBin',
|
||||||
Extends: St.Bin,
|
Extends: St.Bin,
|
||||||
@ -335,9 +234,10 @@ const SearchResultsBase = new Lang.Class({
|
|||||||
let hasMoreResults = results.length < providerResults.length;
|
let hasMoreResults = results.length < providerResults.length;
|
||||||
|
|
||||||
this._ensureResultActors(results, Lang.bind(this, function(successful) {
|
this._ensureResultActors(results, Lang.bind(this, function(successful) {
|
||||||
this._clearResultDisplay();
|
if (!successful) {
|
||||||
if (!successful)
|
this._clearResultDisplay();
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// To avoid CSS transitions causing flickering when
|
// To avoid CSS transitions causing flickering when
|
||||||
// the first search result stays the same, we hide the
|
// the first search result stays the same, we hide the
|
||||||
@ -497,16 +397,136 @@ const SearchResults = new Lang.Class({
|
|||||||
this._statusText = new St.Label({ style_class: 'search-statustext' });
|
this._statusText = new St.Label({ style_class: 'search-statustext' });
|
||||||
this._statusBin = new St.Bin({ x_align: St.Align.MIDDLE,
|
this._statusBin = new St.Bin({ x_align: St.Align.MIDDLE,
|
||||||
y_align: St.Align.MIDDLE });
|
y_align: St.Align.MIDDLE });
|
||||||
this._content.add(this._statusBin, { expand: true });
|
this.actor.add(this._statusBin, { expand: true });
|
||||||
this._statusBin.add_actor(this._statusText);
|
this._statusBin.add_actor(this._statusText);
|
||||||
|
|
||||||
this._highlightDefault = false;
|
this._highlightDefault = false;
|
||||||
this._defaultResult = null;
|
this._defaultResult = null;
|
||||||
|
this._startingSearch = false;
|
||||||
|
|
||||||
this._searchSystem = new SearchSystem();
|
this._terms = [];
|
||||||
this._searchSystem.connect('search-updated', Lang.bind(this, this._updateResults));
|
this._results = {};
|
||||||
this._searchSystem.connect('providers-changed', Lang.bind(this, this._updateProviderDisplays));
|
|
||||||
this._updateProviderDisplays();
|
this._providers = [];
|
||||||
|
|
||||||
|
this._searchSettings = new Gio.Settings({ schema_id: SEARCH_PROVIDERS_SCHEMA });
|
||||||
|
this._searchSettings.connect('changed::disabled', Lang.bind(this, this._reloadRemoteProviders));
|
||||||
|
this._searchSettings.connect('changed::disable-external', Lang.bind(this, this._reloadRemoteProviders));
|
||||||
|
this._searchSettings.connect('changed::sort-order', Lang.bind(this, this._reloadRemoteProviders));
|
||||||
|
|
||||||
|
this._searchTimeoutId = 0;
|
||||||
|
this._cancellable = new Gio.Cancellable();
|
||||||
|
|
||||||
|
this._registerProvider(new AppDisplay.AppSearchProvider());
|
||||||
|
this._reloadRemoteProviders();
|
||||||
|
},
|
||||||
|
|
||||||
|
_reloadRemoteProviders: function() {
|
||||||
|
let remoteProviders = this._providers.filter(function(provider) {
|
||||||
|
return provider.isRemoteProvider;
|
||||||
|
});
|
||||||
|
remoteProviders.forEach(Lang.bind(this, function(provider) {
|
||||||
|
this._unregisterProvider(provider);
|
||||||
|
}));
|
||||||
|
|
||||||
|
RemoteSearch.loadRemoteSearchProviders(Lang.bind(this, function(providers) {
|
||||||
|
providers.forEach(Lang.bind(this, this._registerProvider));
|
||||||
|
}));
|
||||||
|
},
|
||||||
|
|
||||||
|
_registerProvider: function (provider) {
|
||||||
|
this._providers.push(provider);
|
||||||
|
this._ensureProviderDisplay(provider);
|
||||||
|
},
|
||||||
|
|
||||||
|
_unregisterProvider: function (provider) {
|
||||||
|
let index = this._providers.indexOf(provider);
|
||||||
|
this._providers.splice(index, 1);
|
||||||
|
|
||||||
|
if (provider.display)
|
||||||
|
provider.display.destroy();
|
||||||
|
},
|
||||||
|
|
||||||
|
_gotResults: function(results, provider) {
|
||||||
|
this._results[provider.id] = results;
|
||||||
|
this._updateResults(provider, results);
|
||||||
|
},
|
||||||
|
|
||||||
|
_clearSearchTimeout: function() {
|
||||||
|
if (this._searchTimeoutId > 0) {
|
||||||
|
GLib.source_remove(this._searchTimeoutId);
|
||||||
|
this._searchTimeoutId = 0;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
_reset: function() {
|
||||||
|
this._terms = [];
|
||||||
|
this._results = {};
|
||||||
|
this._clearDisplay();
|
||||||
|
this._clearSearchTimeout();
|
||||||
|
this._defaultResult = null;
|
||||||
|
this._startingSearch = false;
|
||||||
|
|
||||||
|
this._updateSearchProgress();
|
||||||
|
},
|
||||||
|
|
||||||
|
_doSearch: function() {
|
||||||
|
this._startingSearch = false;
|
||||||
|
|
||||||
|
let previousResults = this._results;
|
||||||
|
this._results = {};
|
||||||
|
|
||||||
|
this._providers.forEach(Lang.bind(this, function(provider) {
|
||||||
|
provider.searchInProgress = true;
|
||||||
|
|
||||||
|
let previousProviderResults = previousResults[provider.id];
|
||||||
|
if (this._isSubSearch && previousProviderResults)
|
||||||
|
provider.getSubsearchResultSet(previousProviderResults, this._terms, Lang.bind(this, this._gotResults, provider), this._cancellable);
|
||||||
|
else
|
||||||
|
provider.getInitialResultSet(this._terms, Lang.bind(this, this._gotResults, provider), this._cancellable);
|
||||||
|
}));
|
||||||
|
|
||||||
|
this._updateSearchProgress();
|
||||||
|
|
||||||
|
this._clearSearchTimeout();
|
||||||
|
},
|
||||||
|
|
||||||
|
_onSearchTimeout: function() {
|
||||||
|
this._searchTimeoutId = 0;
|
||||||
|
this._doSearch();
|
||||||
|
return GLib.SOURCE_REMOVE;
|
||||||
|
},
|
||||||
|
|
||||||
|
setTerms: function(terms) {
|
||||||
|
// Check for the case of making a duplicate previous search before
|
||||||
|
// setting state of the current search or cancelling the search.
|
||||||
|
// This will prevent incorrect state being as a result of a duplicate
|
||||||
|
// search while the previous search is still active.
|
||||||
|
let searchString = terms.join(' ');
|
||||||
|
let previousSearchString = this._terms.join(' ');
|
||||||
|
if (searchString == previousSearchString)
|
||||||
|
return;
|
||||||
|
|
||||||
|
this._startingSearch = true;
|
||||||
|
|
||||||
|
this._cancellable.cancel();
|
||||||
|
this._cancellable.reset();
|
||||||
|
|
||||||
|
if (terms.length == 0) {
|
||||||
|
this._reset();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
let isSubSearch = false;
|
||||||
|
if (this._terms.length > 0)
|
||||||
|
isSubSearch = searchString.indexOf(previousSearchString) == 0;
|
||||||
|
|
||||||
|
this._terms = terms;
|
||||||
|
this._isSubSearch = isSubSearch;
|
||||||
|
this._updateSearchProgress();
|
||||||
|
|
||||||
|
if (this._searchTimeoutId == 0)
|
||||||
|
this._searchTimeoutId = GLib.timeout_add(GLib.PRIORITY_DEFAULT, 150, Lang.bind(this, this._onSearchTimeout));
|
||||||
},
|
},
|
||||||
|
|
||||||
_onPan: function(action) {
|
_onPan: function(action) {
|
||||||
@ -528,44 +548,24 @@ const SearchResults = new Lang.Class({
|
|||||||
if (provider.appInfo)
|
if (provider.appInfo)
|
||||||
providerDisplay = new ListSearchResults(provider);
|
providerDisplay = new ListSearchResults(provider);
|
||||||
else
|
else
|
||||||
providerDisplay = new GridSearchResults(provider, this._content);
|
providerDisplay = new GridSearchResults(provider, this.actor);
|
||||||
|
|
||||||
providerDisplay.connect('key-focus-in', Lang.bind(this, this._keyFocusIn));
|
providerDisplay.connect('key-focus-in', Lang.bind(this, this._keyFocusIn));
|
||||||
|
providerDisplay.actor.hide();
|
||||||
this._content.add(providerDisplay.actor);
|
this._content.add(providerDisplay.actor);
|
||||||
provider.display = providerDisplay;
|
provider.display = providerDisplay;
|
||||||
},
|
},
|
||||||
|
|
||||||
_updateProviderDisplays: function() {
|
|
||||||
this._searchSystem.getProviders().forEach(Lang.bind(this, this._ensureProviderDisplay));
|
|
||||||
},
|
|
||||||
|
|
||||||
_clearDisplay: function() {
|
_clearDisplay: function() {
|
||||||
this._searchSystem.getProviders().forEach(function(provider) {
|
this._providers.forEach(function(provider) {
|
||||||
provider.display.clear();
|
provider.display.clear();
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
reset: function() {
|
|
||||||
this._searchSystem.reset();
|
|
||||||
this._statusBin.hide();
|
|
||||||
this._clearDisplay();
|
|
||||||
this._defaultResult = null;
|
|
||||||
},
|
|
||||||
|
|
||||||
startingSearch: function() {
|
|
||||||
this.reset();
|
|
||||||
this._statusText.set_text(_("Searching…"));
|
|
||||||
this._statusBin.show();
|
|
||||||
},
|
|
||||||
|
|
||||||
setTerms: function(terms) {
|
|
||||||
this._searchSystem.setTerms(terms);
|
|
||||||
},
|
|
||||||
|
|
||||||
_maybeSetInitialSelection: function() {
|
_maybeSetInitialSelection: function() {
|
||||||
let newDefaultResult = null;
|
let newDefaultResult = null;
|
||||||
|
|
||||||
let providers = this._searchSystem.getProviders();
|
let providers = this._providers;
|
||||||
for (let i = 0; i < providers.length; i++) {
|
for (let i = 0; i < providers.length; i++) {
|
||||||
let provider = providers[i];
|
let provider = providers[i];
|
||||||
let display = provider.display;
|
let display = provider.display;
|
||||||
@ -588,31 +588,50 @@ const SearchResults = new Lang.Class({
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_updateStatusText: function () {
|
get searchInProgress() {
|
||||||
let haveResults = this._searchSystem.getProviders().some(function(provider) {
|
if (this._startingSearch)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
return this._providers.some(function(provider) {
|
||||||
|
return provider.searchInProgress;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
_updateSearchProgress: function () {
|
||||||
|
let haveResults = this._providers.some(function(provider) {
|
||||||
let display = provider.display;
|
let display = provider.display;
|
||||||
return (display.getFirstResult() != null);
|
return (display.getFirstResult() != null);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
this._scrollView.visible = haveResults;
|
||||||
|
this._statusBin.visible = !haveResults;
|
||||||
|
|
||||||
if (!haveResults) {
|
if (!haveResults) {
|
||||||
this._statusText.set_text(_("No results."));
|
if (this.searchInProgress) {
|
||||||
this._statusBin.show();
|
this._statusText.set_text(_("Searching…"));
|
||||||
} else {
|
} else {
|
||||||
this._statusBin.hide();
|
this._statusText.set_text(_("No results."));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_updateResults: function(searchSystem, provider, results) {
|
_updateResults: function(provider, results) {
|
||||||
let terms = searchSystem.getTerms();
|
let terms = this._terms;
|
||||||
let display = provider.display;
|
let display = provider.display;
|
||||||
|
|
||||||
display.updateSearch(results, terms, Lang.bind(this, function() {
|
display.updateSearch(results, terms, Lang.bind(this, function() {
|
||||||
|
provider.searchInProgress = false;
|
||||||
|
|
||||||
this._maybeSetInitialSelection();
|
this._maybeSetInitialSelection();
|
||||||
this._updateStatusText();
|
this._updateSearchProgress();
|
||||||
}));
|
}));
|
||||||
},
|
},
|
||||||
|
|
||||||
activateDefault: function() {
|
activateDefault: function() {
|
||||||
|
// If we have a search queued up, force the search now.
|
||||||
|
if (this._searchTimeoutId > 0)
|
||||||
|
this._doSearch();
|
||||||
|
|
||||||
if (this._defaultResult)
|
if (this._defaultResult)
|
||||||
this._defaultResult.activate();
|
this._defaultResult.activate();
|
||||||
},
|
},
|
||||||
@ -640,11 +659,15 @@ const SearchResults = new Lang.Class({
|
|||||||
if (!result)
|
if (!result)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
let styleReceiver = result.actor;
|
||||||
|
if (result.getStyleReceiver)
|
||||||
|
styleReceiver = result.getStyleReceiver();
|
||||||
|
|
||||||
if (selected) {
|
if (selected) {
|
||||||
result.actor.add_style_pseudo_class('selected');
|
styleReceiver.add_style_pseudo_class('selected');
|
||||||
Util.ensureActorVisibleInScrollView(this._scrollView, result.actor);
|
Util.ensureActorVisibleInScrollView(this._scrollView, result.actor);
|
||||||
} else {
|
} else {
|
||||||
result.actor.remove_style_pseudo_class('selected');
|
styleReceiver.remove_style_pseudo_class('selected');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -17,8 +17,6 @@ const EntryMenu = new Lang.Class({
|
|||||||
_init: function(entry) {
|
_init: function(entry) {
|
||||||
this.parent(entry, 0, St.Side.TOP);
|
this.parent(entry, 0, St.Side.TOP);
|
||||||
|
|
||||||
this.actor.add_style_class_name('entry-context-menu');
|
|
||||||
|
|
||||||
this._entry = entry;
|
this._entry = entry;
|
||||||
this._clipboard = St.Clipboard.get_default();
|
this._clipboard = St.Clipboard.get_default();
|
||||||
|
|
||||||
|
@ -2,8 +2,6 @@
|
|||||||
|
|
||||||
const Clutter = imports.gi.Clutter;
|
const Clutter = imports.gi.Clutter;
|
||||||
const Gio = imports.gi.Gio;
|
const Gio = imports.gi.Gio;
|
||||||
const GLib = imports.gi.GLib;
|
|
||||||
const GnomeDesktop = imports.gi.GnomeDesktop;
|
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
const Meta = imports.gi.Meta;
|
const Meta = imports.gi.Meta;
|
||||||
const Shell = imports.gi.Shell;
|
const Shell = imports.gi.Shell;
|
||||||
@ -11,16 +9,9 @@ const Signals = imports.signals;
|
|||||||
const St = imports.gi.St;
|
const St = imports.gi.St;
|
||||||
const Gettext = imports.gettext;
|
const Gettext = imports.gettext;
|
||||||
|
|
||||||
try {
|
const IBus = imports.misc.ibusManager.IBus;
|
||||||
var IBus = imports.gi.IBus;
|
const IBusManager = imports.misc.ibusManager;
|
||||||
if (!('new_async' in IBus.Bus))
|
const KeyboardManager = imports.misc.keyboardManager;
|
||||||
throw "IBus version is too old";
|
|
||||||
const IBusCandidatePopup = imports.ui.ibusCandidatePopup;
|
|
||||||
} catch (e) {
|
|
||||||
var IBus = null;
|
|
||||||
log(e);
|
|
||||||
}
|
|
||||||
|
|
||||||
const Main = imports.ui.main;
|
const Main = imports.ui.main;
|
||||||
const PopupMenu = imports.ui.popupMenu;
|
const PopupMenu = imports.ui.popupMenu;
|
||||||
const PanelMenu = imports.ui.panelMenu;
|
const PanelMenu = imports.ui.panelMenu;
|
||||||
@ -28,173 +19,12 @@ const SwitcherPopup = imports.ui.switcherPopup;
|
|||||||
const Util = imports.misc.util;
|
const Util = imports.misc.util;
|
||||||
|
|
||||||
const DESKTOP_INPUT_SOURCES_SCHEMA = 'org.gnome.desktop.input-sources';
|
const DESKTOP_INPUT_SOURCES_SCHEMA = 'org.gnome.desktop.input-sources';
|
||||||
const KEY_CURRENT_INPUT_SOURCE = 'current';
|
|
||||||
const KEY_INPUT_SOURCES = 'sources';
|
const KEY_INPUT_SOURCES = 'sources';
|
||||||
|
const KEY_KEYBOARD_OPTIONS = 'xkb-options';
|
||||||
|
|
||||||
const INPUT_SOURCE_TYPE_XKB = 'xkb';
|
const INPUT_SOURCE_TYPE_XKB = 'xkb';
|
||||||
const INPUT_SOURCE_TYPE_IBUS = 'ibus';
|
const INPUT_SOURCE_TYPE_IBUS = 'ibus';
|
||||||
|
|
||||||
// This is the longest we'll keep the keyboard frozen until an input
|
|
||||||
// source is active.
|
|
||||||
const MAX_INPUT_SOURCE_ACTIVATION_TIME = 4000; // ms
|
|
||||||
|
|
||||||
const BUS_NAME = 'org.gnome.SettingsDaemon.Keyboard';
|
|
||||||
const OBJECT_PATH = '/org/gnome/SettingsDaemon/Keyboard';
|
|
||||||
|
|
||||||
const KeyboardManagerInterface = '<node> \
|
|
||||||
<interface name="org.gnome.SettingsDaemon.Keyboard"> \
|
|
||||||
<method name="SetInputSource"> \
|
|
||||||
<arg type="u" direction="in" /> \
|
|
||||||
</method> \
|
|
||||||
</interface> \
|
|
||||||
</node>';
|
|
||||||
|
|
||||||
const KeyboardManagerProxy = Gio.DBusProxy.makeProxyWrapper(KeyboardManagerInterface);
|
|
||||||
|
|
||||||
function releaseKeyboard() {
|
|
||||||
if (Main.modalCount > 0)
|
|
||||||
global.display.unfreeze_keyboard(global.get_current_time());
|
|
||||||
else
|
|
||||||
global.display.ungrab_keyboard(global.get_current_time());
|
|
||||||
}
|
|
||||||
|
|
||||||
function holdKeyboard() {
|
|
||||||
global.freeze_keyboard(global.get_current_time());
|
|
||||||
}
|
|
||||||
|
|
||||||
const IBusManager = new Lang.Class({
|
|
||||||
Name: 'IBusManager',
|
|
||||||
|
|
||||||
_init: function(readyCallback) {
|
|
||||||
if (!IBus)
|
|
||||||
return;
|
|
||||||
|
|
||||||
IBus.init();
|
|
||||||
|
|
||||||
this._readyCallback = readyCallback;
|
|
||||||
this._candidatePopup = new IBusCandidatePopup.CandidatePopup();
|
|
||||||
|
|
||||||
this._panelService = null;
|
|
||||||
this._engines = {};
|
|
||||||
this._ready = false;
|
|
||||||
this._registerPropertiesId = 0;
|
|
||||||
this._currentEngineName = null;
|
|
||||||
|
|
||||||
this._ibus = IBus.Bus.new_async();
|
|
||||||
this._ibus.connect('connected', Lang.bind(this, this._onConnected));
|
|
||||||
this._ibus.connect('disconnected', Lang.bind(this, this._clear));
|
|
||||||
// Need to set this to get 'global-engine-changed' emitions
|
|
||||||
this._ibus.set_watch_ibus_signal(true);
|
|
||||||
this._ibus.connect('global-engine-changed', Lang.bind(this, this._engineChanged));
|
|
||||||
},
|
|
||||||
|
|
||||||
_clear: function() {
|
|
||||||
if (this._panelService)
|
|
||||||
this._panelService.destroy();
|
|
||||||
|
|
||||||
this._panelService = null;
|
|
||||||
this._candidatePopup.setPanelService(null);
|
|
||||||
this._engines = {};
|
|
||||||
this._ready = false;
|
|
||||||
this._registerPropertiesId = 0;
|
|
||||||
this._currentEngineName = null;
|
|
||||||
|
|
||||||
if (this._readyCallback)
|
|
||||||
this._readyCallback(false);
|
|
||||||
},
|
|
||||||
|
|
||||||
_onConnected: function() {
|
|
||||||
this._ibus.list_engines_async(-1, null, Lang.bind(this, this._initEngines));
|
|
||||||
this._ibus.request_name_async(IBus.SERVICE_PANEL,
|
|
||||||
IBus.BusNameFlag.REPLACE_EXISTING,
|
|
||||||
-1, null,
|
|
||||||
Lang.bind(this, this._initPanelService));
|
|
||||||
},
|
|
||||||
|
|
||||||
_initEngines: function(ibus, result) {
|
|
||||||
let enginesList = this._ibus.list_engines_async_finish(result);
|
|
||||||
if (enginesList) {
|
|
||||||
for (let i = 0; i < enginesList.length; ++i) {
|
|
||||||
let name = enginesList[i].get_name();
|
|
||||||
this._engines[name] = enginesList[i];
|
|
||||||
}
|
|
||||||
this._updateReadiness();
|
|
||||||
} else {
|
|
||||||
this._clear();
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_initPanelService: function(ibus, result) {
|
|
||||||
let success = this._ibus.request_name_async_finish(result);
|
|
||||||
if (success) {
|
|
||||||
this._panelService = new IBus.PanelService({ connection: this._ibus.get_connection(),
|
|
||||||
object_path: IBus.PATH_PANEL });
|
|
||||||
this._candidatePopup.setPanelService(this._panelService);
|
|
||||||
this._panelService.connect('update-property', Lang.bind(this, this._updateProperty));
|
|
||||||
// If an engine is already active we need to get its properties
|
|
||||||
this._ibus.get_global_engine_async(-1, null, Lang.bind(this, function(i, result) {
|
|
||||||
let engine;
|
|
||||||
try {
|
|
||||||
engine = this._ibus.get_global_engine_async_finish(result);
|
|
||||||
if (!engine)
|
|
||||||
return;
|
|
||||||
} catch(e) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
this._engineChanged(this._ibus, engine.get_name());
|
|
||||||
}));
|
|
||||||
this._updateReadiness();
|
|
||||||
} else {
|
|
||||||
this._clear();
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_updateReadiness: function() {
|
|
||||||
this._ready = (Object.keys(this._engines).length > 0 &&
|
|
||||||
this._panelService != null);
|
|
||||||
|
|
||||||
if (this._readyCallback)
|
|
||||||
this._readyCallback(this._ready);
|
|
||||||
},
|
|
||||||
|
|
||||||
_engineChanged: function(bus, engineName) {
|
|
||||||
if (!this._ready)
|
|
||||||
return;
|
|
||||||
|
|
||||||
this._currentEngineName = engineName;
|
|
||||||
|
|
||||||
if (this._registerPropertiesId != 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
this._registerPropertiesId =
|
|
||||||
this._panelService.connect('register-properties', Lang.bind(this, function(p, props) {
|
|
||||||
if (!props.get(0))
|
|
||||||
return;
|
|
||||||
|
|
||||||
this._panelService.disconnect(this._registerPropertiesId);
|
|
||||||
this._registerPropertiesId = 0;
|
|
||||||
|
|
||||||
this.emit('properties-registered', this._currentEngineName, props);
|
|
||||||
}));
|
|
||||||
},
|
|
||||||
|
|
||||||
_updateProperty: function(panel, prop) {
|
|
||||||
this.emit('property-updated', this._currentEngineName, prop);
|
|
||||||
},
|
|
||||||
|
|
||||||
activateProperty: function(key, state) {
|
|
||||||
this._panelService.property_activate(key, state);
|
|
||||||
},
|
|
||||||
|
|
||||||
getEngineDesc: function(id) {
|
|
||||||
if (!IBus || !this._ready)
|
|
||||||
return null;
|
|
||||||
|
|
||||||
return this._engines[id];
|
|
||||||
}
|
|
||||||
});
|
|
||||||
Signals.addSignalMethods(IBusManager.prototype);
|
|
||||||
|
|
||||||
const LayoutMenuItem = new Lang.Class({
|
const LayoutMenuItem = new Lang.Class({
|
||||||
Name: 'LayoutMenuItem',
|
Name: 'LayoutMenuItem',
|
||||||
Extends: PopupMenu.PopupBaseMenuItem,
|
Extends: PopupMenu.PopupBaseMenuItem,
|
||||||
@ -220,16 +50,9 @@ const InputSource = new Lang.Class({
|
|||||||
this._shortName = shortName;
|
this._shortName = shortName;
|
||||||
this.index = index;
|
this.index = index;
|
||||||
|
|
||||||
this._menuItem = new LayoutMenuItem(this.displayName, this._shortName);
|
|
||||||
this._menuItem.connect('activate', Lang.bind(this, this.activate));
|
|
||||||
this._indicatorLabel = new St.Label({ text: this._shortName });
|
|
||||||
|
|
||||||
this.properties = null;
|
this.properties = null;
|
||||||
},
|
|
||||||
|
|
||||||
destroy: function() {
|
this.xkbId = this._getXkbId();
|
||||||
this._menuItem.destroy();
|
|
||||||
this._indicatorLabel.destroy();
|
|
||||||
},
|
},
|
||||||
|
|
||||||
get shortName() {
|
get shortName() {
|
||||||
@ -238,21 +61,23 @@ const InputSource = new Lang.Class({
|
|||||||
|
|
||||||
set shortName(v) {
|
set shortName(v) {
|
||||||
this._shortName = v;
|
this._shortName = v;
|
||||||
this._menuItem.indicator.set_text(v);
|
this.emit('changed');
|
||||||
this._indicatorLabel.set_text(v);
|
|
||||||
},
|
|
||||||
|
|
||||||
get menuItem() {
|
|
||||||
return this._menuItem;
|
|
||||||
},
|
|
||||||
|
|
||||||
get indicatorLabel() {
|
|
||||||
return this._indicatorLabel;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
activate: function() {
|
activate: function() {
|
||||||
this.emit('activate');
|
this.emit('activate');
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_getXkbId: function() {
|
||||||
|
let engineDesc = IBusManager.getIBusManager().getEngineDesc(this.id);
|
||||||
|
if (!engineDesc)
|
||||||
|
return this.id;
|
||||||
|
|
||||||
|
if (engineDesc.variant && engineDesc.variant.length > 0)
|
||||||
|
return engineDesc.layout + '+' + engineDesc.variant;
|
||||||
|
else
|
||||||
|
return engineDesc.layout;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
Signals.addSignalMethods(InputSource.prototype);
|
Signals.addSignalMethods(InputSource.prototype);
|
||||||
|
|
||||||
@ -265,22 +90,8 @@ const InputSourcePopup = new Lang.Class({
|
|||||||
|
|
||||||
this._action = action;
|
this._action = action;
|
||||||
this._actionBackward = actionBackward;
|
this._actionBackward = actionBackward;
|
||||||
},
|
|
||||||
|
|
||||||
_createSwitcher: function() {
|
|
||||||
this._switcherList = new InputSourceSwitcher(this._items);
|
this._switcherList = new InputSourceSwitcher(this._items);
|
||||||
return true;
|
|
||||||
},
|
|
||||||
|
|
||||||
_initialSelection: function(backward, binding) {
|
|
||||||
if (binding == 'switch-input-source') {
|
|
||||||
if (backward)
|
|
||||||
this._selectedIndex = this._items.length - 1;
|
|
||||||
} else if (binding == 'switch-input-source-backward') {
|
|
||||||
if (!backward)
|
|
||||||
this._selectedIndex = this._items.length - 1;
|
|
||||||
}
|
|
||||||
this._select(this._selectedIndex);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_keyPressHandler: function(keysym, action) {
|
_keyPressHandler: function(keysym, action) {
|
||||||
@ -331,25 +142,10 @@ const InputSourceSwitcher = new Lang.Class({
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
const InputSourceIndicator = new Lang.Class({
|
const InputSourceManager = new Lang.Class({
|
||||||
Name: 'InputSourceIndicator',
|
Name: 'InputSourceManager',
|
||||||
Extends: PanelMenu.Button,
|
|
||||||
|
|
||||||
_init: function() {
|
_init: function() {
|
||||||
this.parent(0.0, _("Keyboard"));
|
|
||||||
|
|
||||||
this._container = new Shell.GenericContainer();
|
|
||||||
this._container.connect('get-preferred-width', Lang.bind(this, this._containerGetPreferredWidth));
|
|
||||||
this._container.connect('get-preferred-height', Lang.bind(this, this._containerGetPreferredHeight));
|
|
||||||
this._container.connect('allocate', Lang.bind(this, this._containerAllocate));
|
|
||||||
|
|
||||||
this._hbox = new St.BoxLayout({ style_class: 'panel-status-menu-box' });
|
|
||||||
this._hbox.add_child(this._container);
|
|
||||||
this._hbox.add_child(PopupMenu.arrowIcon(St.Side.BOTTOM));
|
|
||||||
|
|
||||||
this.actor.add_child(this._hbox);
|
|
||||||
this.actor.add_style_class_name('panel-status-button');
|
|
||||||
|
|
||||||
// All valid input sources currently in the gsettings
|
// All valid input sources currently in the gsettings
|
||||||
// KEY_INPUT_SOURCES list indexed by their index there
|
// KEY_INPUT_SOURCES list indexed by their index there
|
||||||
this._inputSources = {};
|
this._inputSources = {};
|
||||||
@ -376,38 +172,20 @@ const InputSourceIndicator = new Lang.Class({
|
|||||||
Shell.KeyBindingMode.ALL,
|
Shell.KeyBindingMode.ALL,
|
||||||
Lang.bind(this, this._switchInputSource));
|
Lang.bind(this, this._switchInputSource));
|
||||||
this._settings = new Gio.Settings({ schema_id: DESKTOP_INPUT_SOURCES_SCHEMA });
|
this._settings = new Gio.Settings({ schema_id: DESKTOP_INPUT_SOURCES_SCHEMA });
|
||||||
this._settings.connect('changed::' + KEY_CURRENT_INPUT_SOURCE, Lang.bind(this, this._currentInputSourceChanged));
|
|
||||||
this._settings.connect('changed::' + KEY_INPUT_SOURCES, Lang.bind(this, this._inputSourcesChanged));
|
this._settings.connect('changed::' + KEY_INPUT_SOURCES, Lang.bind(this, this._inputSourcesChanged));
|
||||||
|
this._settings.connect('changed::' + KEY_KEYBOARD_OPTIONS, Lang.bind(this, this._keyboardOptionsChanged));
|
||||||
|
|
||||||
this._xkbInfo = new GnomeDesktop.XkbInfo();
|
this._xkbInfo = KeyboardManager.getXkbInfo();
|
||||||
|
this._keyboardManager = KeyboardManager.getKeyboardManager();
|
||||||
this._propSeparator = new PopupMenu.PopupSeparatorMenuItem();
|
|
||||||
this.menu.addMenuItem(this._propSeparator);
|
|
||||||
this._propSection = new PopupMenu.PopupMenuSection();
|
|
||||||
this.menu.addMenuItem(this._propSection);
|
|
||||||
this._propSection.actor.hide();
|
|
||||||
|
|
||||||
this._ibusReady = false;
|
this._ibusReady = false;
|
||||||
this._ibusManager = new IBusManager(Lang.bind(this, this._ibusReadyCallback));
|
this._ibusManager = IBusManager.getIBusManager();
|
||||||
|
this._ibusManager.connect('ready', Lang.bind(this, this._ibusReadyCallback));
|
||||||
this._ibusManager.connect('properties-registered', Lang.bind(this, this._ibusPropertiesRegistered));
|
this._ibusManager.connect('properties-registered', Lang.bind(this, this._ibusPropertiesRegistered));
|
||||||
this._ibusManager.connect('property-updated', Lang.bind(this, this._ibusPropertyUpdated));
|
this._ibusManager.connect('property-updated', Lang.bind(this, this._ibusPropertyUpdated));
|
||||||
this._inputSourcesChanged();
|
|
||||||
|
|
||||||
this._keyboardManager = new KeyboardManagerProxy(Gio.DBus.session, BUS_NAME, OBJECT_PATH,
|
|
||||||
function(proxy, error) {
|
|
||||||
if (error)
|
|
||||||
log(error.message);
|
|
||||||
});
|
|
||||||
this._keyboardManager.g_default_timeout = MAX_INPUT_SOURCE_ACTIVATION_TIME;
|
|
||||||
|
|
||||||
global.display.connect('modifiers-accelerator-activated', Lang.bind(this, this._modifiersSwitcher));
|
global.display.connect('modifiers-accelerator-activated', Lang.bind(this, this._modifiersSwitcher));
|
||||||
|
|
||||||
this.menu.addMenuItem(new PopupMenu.PopupSeparatorMenuItem());
|
|
||||||
this._showLayoutItem = this.menu.addAction(_("Show Keyboard Layout"), Lang.bind(this, this._showLayout));
|
|
||||||
|
|
||||||
Main.sessionMode.connect('updated', Lang.bind(this, this._sessionUpdated));
|
|
||||||
this._sessionUpdated();
|
|
||||||
|
|
||||||
this._sourcesPerWindow = false;
|
this._sourcesPerWindow = false;
|
||||||
this._focusWindowNotifyId = 0;
|
this._focusWindowNotifyId = 0;
|
||||||
this._overviewShowingId = 0;
|
this._overviewShowingId = 0;
|
||||||
@ -416,15 +194,12 @@ const InputSourceIndicator = new Lang.Class({
|
|||||||
this._sourcesPerWindowChanged();
|
this._sourcesPerWindowChanged();
|
||||||
},
|
},
|
||||||
|
|
||||||
_sessionUpdated: function() {
|
reload: function() {
|
||||||
// re-using "allowSettings" for the keyboard layout is a bit shady,
|
this._keyboardManager.setKeyboardOptions(this._settings.get_strv(KEY_KEYBOARD_OPTIONS));
|
||||||
// but at least for now it is used as "allow popping up windows
|
this._inputSourcesChanged();
|
||||||
// from shell menus"; we can always add a separate sessionMode
|
|
||||||
// option if need arises.
|
|
||||||
this._showLayoutItem.actor.visible = Main.sessionMode.allowSettings;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_ibusReadyCallback: function(ready) {
|
_ibusReadyCallback: function(im, ready) {
|
||||||
if (this._ibusReady == ready)
|
if (this._ibusReady == ready)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@ -436,7 +211,7 @@ const InputSourceIndicator = new Lang.Class({
|
|||||||
_modifiersSwitcher: function() {
|
_modifiersSwitcher: function() {
|
||||||
let sourceIndexes = Object.keys(this._inputSources);
|
let sourceIndexes = Object.keys(this._inputSources);
|
||||||
if (sourceIndexes.length == 0) {
|
if (sourceIndexes.length == 0) {
|
||||||
releaseKeyboard();
|
KeyboardManager.releaseKeyboard();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -471,42 +246,20 @@ const InputSourceIndicator = new Lang.Class({
|
|||||||
}
|
}
|
||||||
|
|
||||||
let popup = new InputSourcePopup(this._mruSources, this._keybindingAction, this._keybindingActionBackward);
|
let popup = new InputSourcePopup(this._mruSources, this._keybindingAction, this._keybindingActionBackward);
|
||||||
let modifiers = binding.get_modifiers();
|
|
||||||
if (!popup.show(binding.is_reversed(), binding.get_name(), binding.get_mask()))
|
if (!popup.show(binding.is_reversed(), binding.get_name(), binding.get_mask()))
|
||||||
popup.destroy();
|
popup.destroy();
|
||||||
},
|
},
|
||||||
|
|
||||||
_currentInputSourceChanged: function() {
|
_keyboardOptionsChanged: function() {
|
||||||
let nVisibleSources = Object.keys(this._inputSources).length;
|
this._keyboardManager.setKeyboardOptions(this._settings.get_strv(KEY_KEYBOARD_OPTIONS));
|
||||||
let newSourceIndex = this._settings.get_uint(KEY_CURRENT_INPUT_SOURCE);
|
this._keyboardManager.reapply();
|
||||||
let newSource = this._inputSources[newSourceIndex];
|
},
|
||||||
|
|
||||||
|
_currentInputSourceChanged: function(newSource) {
|
||||||
let oldSource;
|
let oldSource;
|
||||||
[oldSource, this._currentSource] = [this._currentSource, newSource];
|
[oldSource, this._currentSource] = [this._currentSource, newSource];
|
||||||
|
|
||||||
if (oldSource) {
|
this.emit('current-source-changed', oldSource);
|
||||||
oldSource.menuItem.setOrnament(PopupMenu.Ornament.NONE);
|
|
||||||
oldSource.indicatorLabel.hide();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!newSource || (nVisibleSources < 2 && !newSource.properties)) {
|
|
||||||
// This source index might be invalid if we weren't able
|
|
||||||
// to build a menu item for it, so we hide ourselves since
|
|
||||||
// we can't fix it here. *shrug*
|
|
||||||
|
|
||||||
// We also hide if we have only one visible source unless
|
|
||||||
// it's an IBus source with properties.
|
|
||||||
this.menu.close();
|
|
||||||
this.actor.hide();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this.actor.show();
|
|
||||||
|
|
||||||
newSource.menuItem.setOrnament(PopupMenu.Ornament.DOT);
|
|
||||||
newSource.indicatorLabel.show();
|
|
||||||
|
|
||||||
this._buildPropSection(newSource.properties);
|
|
||||||
|
|
||||||
for (let i = 1; i < this._mruSources.length; ++i)
|
for (let i = 1; i < this._mruSources.length; ++i)
|
||||||
if (this._mruSources[i] == newSource) {
|
if (this._mruSources[i] == newSource) {
|
||||||
@ -518,19 +271,34 @@ const InputSourceIndicator = new Lang.Class({
|
|||||||
this._changePerWindowSource();
|
this._changePerWindowSource();
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_activateInputSource: function(is) {
|
||||||
|
KeyboardManager.holdKeyboard();
|
||||||
|
this._keyboardManager.apply(is.xkbId);
|
||||||
|
|
||||||
|
// All the "xkb:..." IBus engines simply "echo" back symbols,
|
||||||
|
// despite their naming implying differently, so we always set
|
||||||
|
// one in order for XIM applications to work given that we set
|
||||||
|
// XMODIFIERS=@im=ibus in the first place so that they can
|
||||||
|
// work without restarting when/if the user adds an IBus input
|
||||||
|
// source.
|
||||||
|
let engine;
|
||||||
|
if (is.type == INPUT_SOURCE_TYPE_IBUS)
|
||||||
|
engine = is.id;
|
||||||
|
else
|
||||||
|
engine = 'xkb:us::eng';
|
||||||
|
|
||||||
|
this._ibusManager.setEngine(engine, KeyboardManager.releaseKeyboard);
|
||||||
|
this._currentInputSourceChanged(is);
|
||||||
|
},
|
||||||
|
|
||||||
_inputSourcesChanged: function() {
|
_inputSourcesChanged: function() {
|
||||||
let sources = this._settings.get_value(KEY_INPUT_SOURCES);
|
let sources = this._settings.get_value(KEY_INPUT_SOURCES);
|
||||||
let nSources = sources.n_children();
|
let nSources = sources.n_children();
|
||||||
|
|
||||||
for (let i in this._inputSources)
|
|
||||||
this._inputSources[i].destroy();
|
|
||||||
|
|
||||||
this._inputSources = {};
|
this._inputSources = {};
|
||||||
this._ibusSources = {};
|
this._ibusSources = {};
|
||||||
this._currentSource = null;
|
|
||||||
|
|
||||||
let inputSourcesByShortName = {};
|
|
||||||
|
|
||||||
|
let infosList = [];
|
||||||
for (let i = 0; i < nSources; i++) {
|
for (let i = 0; i < nSources; i++) {
|
||||||
let displayName;
|
let displayName;
|
||||||
let shortName;
|
let shortName;
|
||||||
@ -554,15 +322,25 @@ const InputSourceIndicator = new Lang.Class({
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!exists)
|
if (exists)
|
||||||
continue;
|
infosList.push({ type: type, id: id, displayName: displayName, shortName: shortName });
|
||||||
|
}
|
||||||
|
|
||||||
let is = new InputSource(type, id, displayName, shortName, i);
|
if (infosList.length == 0) {
|
||||||
|
let type = INPUT_SOURCE_TYPE_XKB;
|
||||||
|
let id = KeyboardManager.DEFAULT_LAYOUT;
|
||||||
|
let [ , displayName, shortName, , ] = this._xkbInfo.get_layout_info(id);
|
||||||
|
infosList.push({ type: type, id: id, displayName: displayName, shortName: shortName });
|
||||||
|
}
|
||||||
|
|
||||||
is.connect('activate', Lang.bind(this, function() {
|
let inputSourcesByShortName = {};
|
||||||
holdKeyboard();
|
for (let i = 0; i < infosList.length; i++) {
|
||||||
this._keyboardManager.SetInputSourceRemote(is.index, releaseKeyboard);
|
let is = new InputSource(infosList[i].type,
|
||||||
}));
|
infosList[i].id,
|
||||||
|
infosList[i].displayName,
|
||||||
|
infosList[i].shortName,
|
||||||
|
i);
|
||||||
|
is.connect('activate', Lang.bind(this, this._activateInputSource));
|
||||||
|
|
||||||
if (!(is.shortName in inputSourcesByShortName))
|
if (!(is.shortName in inputSourcesByShortName))
|
||||||
inputSourcesByShortName[is.shortName] = [];
|
inputSourcesByShortName[is.shortName] = [];
|
||||||
@ -574,24 +352,22 @@ const InputSourceIndicator = new Lang.Class({
|
|||||||
this._ibusSources[is.id] = is;
|
this._ibusSources[is.id] = is;
|
||||||
}
|
}
|
||||||
|
|
||||||
let menuIndex = 0;
|
|
||||||
for (let i in this._inputSources) {
|
for (let i in this._inputSources) {
|
||||||
let is = this._inputSources[i];
|
let is = this._inputSources[i];
|
||||||
if (inputSourcesByShortName[is.shortName].length > 1) {
|
if (inputSourcesByShortName[is.shortName].length > 1) {
|
||||||
let sub = inputSourcesByShortName[is.shortName].indexOf(is) + 1;
|
let sub = inputSourcesByShortName[is.shortName].indexOf(is) + 1;
|
||||||
is.shortName += String.fromCharCode(0x2080 + sub);
|
is.shortName += String.fromCharCode(0x2080 + sub);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.menu.addMenuItem(is.menuItem, menuIndex++);
|
|
||||||
|
|
||||||
is.indicatorLabel.hide();
|
|
||||||
this._container.add_actor(is.indicatorLabel);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.emit('sources-changed');
|
||||||
|
|
||||||
let sourcesList = [];
|
let sourcesList = [];
|
||||||
for (let i in this._inputSources)
|
for (let i in this._inputSources)
|
||||||
sourcesList.push(this._inputSources[i]);
|
sourcesList.push(this._inputSources[i]);
|
||||||
|
|
||||||
|
this._keyboardManager.setUserLayouts(sourcesList.map(function(x) { return x.xkbId; }));
|
||||||
|
|
||||||
let mruSources = [];
|
let mruSources = [];
|
||||||
for (let i = 0; i < this._mruSources.length; i++) {
|
for (let i = 0; i < this._mruSources.length; i++) {
|
||||||
for (let j = 0; j < sourcesList.length; j++)
|
for (let j = 0; j < sourcesList.length; j++)
|
||||||
@ -603,34 +379,8 @@ const InputSourceIndicator = new Lang.Class({
|
|||||||
}
|
}
|
||||||
this._mruSources = mruSources.concat(sourcesList);
|
this._mruSources = mruSources.concat(sourcesList);
|
||||||
|
|
||||||
this._currentInputSourceChanged();
|
if (this._mruSources.length > 0)
|
||||||
},
|
this._mruSources[0].activate();
|
||||||
|
|
||||||
_showLayout: function() {
|
|
||||||
Main.overview.hide();
|
|
||||||
|
|
||||||
let source = this._currentSource;
|
|
||||||
let xkbLayout = '';
|
|
||||||
let xkbVariant = '';
|
|
||||||
|
|
||||||
if (source.type == INPUT_SOURCE_TYPE_XKB) {
|
|
||||||
[, , , xkbLayout, xkbVariant] = this._xkbInfo.get_layout_info(source.id);
|
|
||||||
} else if (source.type == INPUT_SOURCE_TYPE_IBUS) {
|
|
||||||
let engineDesc = this._ibusManager.getEngineDesc(source.id);
|
|
||||||
if (engineDesc) {
|
|
||||||
xkbLayout = engineDesc.get_layout();
|
|
||||||
xkbVariant = '';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!xkbLayout || xkbLayout.length == 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
let description = xkbLayout;
|
|
||||||
if (xkbVariant.length > 0)
|
|
||||||
description = description + '\t' + xkbVariant;
|
|
||||||
|
|
||||||
Util.spawn(['gkbd-keyboard-display', '-l', description]);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_makeEngineShortName: function(engineDesc) {
|
_makeEngineShortName: function(engineDesc) {
|
||||||
@ -653,7 +403,7 @@ const InputSourceIndicator = new Lang.Class({
|
|||||||
source.properties = props;
|
source.properties = props;
|
||||||
|
|
||||||
if (source == this._currentSource)
|
if (source == this._currentSource)
|
||||||
this._currentInputSourceChanged();
|
this.emit('current-source-changed', null);
|
||||||
},
|
},
|
||||||
|
|
||||||
_ibusPropertyUpdated: function(im, engineName, prop) {
|
_ibusPropertyUpdated: function(im, engineName, prop) {
|
||||||
@ -663,7 +413,7 @@ const InputSourceIndicator = new Lang.Class({
|
|||||||
|
|
||||||
if (this._updateSubProperty(source.properties, prop) &&
|
if (this._updateSubProperty(source.properties, prop) &&
|
||||||
source == this._currentSource)
|
source == this._currentSource)
|
||||||
this._currentInputSourceChanged();
|
this.emit('current-source-changed', null);
|
||||||
},
|
},
|
||||||
|
|
||||||
_updateSubProperty: function(props, prop) {
|
_updateSubProperty: function(props, prop) {
|
||||||
@ -683,116 +433,6 @@ const InputSourceIndicator = new Lang.Class({
|
|||||||
return false;
|
return false;
|
||||||
},
|
},
|
||||||
|
|
||||||
_buildPropSection: function(properties) {
|
|
||||||
this._propSeparator.actor.hide();
|
|
||||||
this._propSection.actor.hide();
|
|
||||||
this._propSection.removeAll();
|
|
||||||
|
|
||||||
this._buildPropSubMenu(this._propSection, properties);
|
|
||||||
|
|
||||||
if (!this._propSection.isEmpty()) {
|
|
||||||
this._propSection.actor.show();
|
|
||||||
this._propSeparator.actor.show();
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_buildPropSubMenu: function(menu, props) {
|
|
||||||
if (!props)
|
|
||||||
return;
|
|
||||||
|
|
||||||
let radioGroup = [];
|
|
||||||
let p;
|
|
||||||
for (let i = 0; (p = props.get(i)) != null; ++i) {
|
|
||||||
let prop = p;
|
|
||||||
|
|
||||||
if (!prop.get_visible())
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (prop.get_key() == 'InputMode') {
|
|
||||||
let text;
|
|
||||||
if (prop.get_symbol)
|
|
||||||
text = prop.get_symbol().get_text();
|
|
||||||
else
|
|
||||||
text = prop.get_label().get_text();
|
|
||||||
|
|
||||||
if (text && text.length > 0 && text.length < 3)
|
|
||||||
this._currentSource.indicatorLabel.set_text(text);
|
|
||||||
}
|
|
||||||
|
|
||||||
let item;
|
|
||||||
switch (prop.get_prop_type()) {
|
|
||||||
case IBus.PropType.MENU:
|
|
||||||
item = new PopupMenu.PopupSubMenuMenuItem(prop.get_label().get_text());
|
|
||||||
this._buildPropSubMenu(item.menu, prop.get_sub_props());
|
|
||||||
break;
|
|
||||||
|
|
||||||
case IBus.PropType.RADIO:
|
|
||||||
item = new PopupMenu.PopupMenuItem(prop.get_label().get_text());
|
|
||||||
item.prop = prop;
|
|
||||||
radioGroup.push(item);
|
|
||||||
item.radioGroup = radioGroup;
|
|
||||||
item.setOrnament(prop.get_state() == IBus.PropState.CHECKED ?
|
|
||||||
PopupMenu.Ornament.DOT : PopupMenu.Ornament.NONE);
|
|
||||||
item.connect('activate', Lang.bind(this, function() {
|
|
||||||
if (item.prop.get_state() == IBus.PropState.CHECKED)
|
|
||||||
return;
|
|
||||||
|
|
||||||
let group = item.radioGroup;
|
|
||||||
for (let i = 0; i < group.length; ++i) {
|
|
||||||
if (group[i] == item) {
|
|
||||||
item.setOrnament(PopupMenu.Ornament.DOT);
|
|
||||||
item.prop.set_state(IBus.PropState.CHECKED);
|
|
||||||
this._ibusManager.activateProperty(item.prop.get_key(),
|
|
||||||
IBus.PropState.CHECKED);
|
|
||||||
} else {
|
|
||||||
group[i].setOrnament(PopupMenu.Ornament.NONE);
|
|
||||||
group[i].prop.set_state(IBus.PropState.UNCHECKED);
|
|
||||||
this._ibusManager.activateProperty(group[i].prop.get_key(),
|
|
||||||
IBus.PropState.UNCHECKED);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}));
|
|
||||||
break;
|
|
||||||
|
|
||||||
case IBus.PropType.TOGGLE:
|
|
||||||
item = new PopupMenu.PopupSwitchMenuItem(prop.get_label().get_text(), prop.get_state() == IBus.PropState.CHECKED);
|
|
||||||
item.prop = prop;
|
|
||||||
item.connect('toggled', Lang.bind(this, function() {
|
|
||||||
if (item.state) {
|
|
||||||
item.prop.set_state(IBus.PropState.CHECKED);
|
|
||||||
this._ibusManager.activateProperty(item.prop.get_key(),
|
|
||||||
IBus.PropState.CHECKED);
|
|
||||||
} else {
|
|
||||||
item.prop.set_state(IBus.PropState.UNCHECKED);
|
|
||||||
this._ibusManager.activateProperty(item.prop.get_key(),
|
|
||||||
IBus.PropState.UNCHECKED);
|
|
||||||
}
|
|
||||||
}));
|
|
||||||
break;
|
|
||||||
|
|
||||||
case IBus.PropType.NORMAL:
|
|
||||||
item = new PopupMenu.PopupMenuItem(prop.get_label().get_text());
|
|
||||||
item.prop = prop;
|
|
||||||
item.connect('activate', Lang.bind(this, function() {
|
|
||||||
this._ibusManager.activateProperty(item.prop.get_key(),
|
|
||||||
item.prop.get_state());
|
|
||||||
}));
|
|
||||||
break;
|
|
||||||
|
|
||||||
case IBus.PropType.SEPARATOR:
|
|
||||||
item = new PopupMenu.PopupSeparatorMenuItem();
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
log ('IBus property %s has invalid type %d'.format(prop.get_key(), type));
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
item.setSensitive(prop.get_sensitive());
|
|
||||||
menu.addMenuItem(item);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_getNewInputSource: function(current) {
|
_getNewInputSource: function(current) {
|
||||||
for (let i in this._inputSources) {
|
for (let i in this._inputSources) {
|
||||||
let is = this._inputSources[i];
|
let is = this._inputSources[i];
|
||||||
@ -869,15 +509,279 @@ const InputSourceIndicator = new Lang.Class({
|
|||||||
window._currentSource = this._currentSource;
|
window._currentSource = this._currentSource;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
get currentSource() {
|
||||||
|
return this._currentSource;
|
||||||
|
},
|
||||||
|
|
||||||
|
get inputSources() {
|
||||||
|
return this._inputSources;
|
||||||
|
},
|
||||||
|
});
|
||||||
|
Signals.addSignalMethods(InputSourceManager.prototype);
|
||||||
|
|
||||||
|
let _inputSourceManager = null;
|
||||||
|
|
||||||
|
function getInputSourceManager() {
|
||||||
|
if (_inputSourceManager == null)
|
||||||
|
_inputSourceManager = new InputSourceManager();
|
||||||
|
return _inputSourceManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
const InputSourceIndicator = new Lang.Class({
|
||||||
|
Name: 'InputSourceIndicator',
|
||||||
|
Extends: PanelMenu.Button,
|
||||||
|
|
||||||
|
_init: function() {
|
||||||
|
this.parent(0.0, _("Keyboard"));
|
||||||
|
|
||||||
|
this._menuItems = {};
|
||||||
|
this._indicatorLabels = {};
|
||||||
|
|
||||||
|
this._container = new Shell.GenericContainer();
|
||||||
|
this._container.connect('get-preferred-width', Lang.bind(this, this._containerGetPreferredWidth));
|
||||||
|
this._container.connect('get-preferred-height', Lang.bind(this, this._containerGetPreferredHeight));
|
||||||
|
this._container.connect('allocate', Lang.bind(this, this._containerAllocate));
|
||||||
|
|
||||||
|
this._hbox = new St.BoxLayout({ style_class: 'panel-status-menu-box' });
|
||||||
|
this._hbox.add_child(this._container);
|
||||||
|
this._hbox.add_child(PopupMenu.arrowIcon(St.Side.BOTTOM));
|
||||||
|
|
||||||
|
this.actor.add_child(this._hbox);
|
||||||
|
this.actor.add_style_class_name('panel-status-button');
|
||||||
|
|
||||||
|
this._propSeparator = new PopupMenu.PopupSeparatorMenuItem();
|
||||||
|
this.menu.addMenuItem(this._propSeparator);
|
||||||
|
this._propSection = new PopupMenu.PopupMenuSection();
|
||||||
|
this.menu.addMenuItem(this._propSection);
|
||||||
|
this._propSection.actor.hide();
|
||||||
|
|
||||||
|
this.menu.addMenuItem(new PopupMenu.PopupSeparatorMenuItem());
|
||||||
|
this._showLayoutItem = this.menu.addAction(_("Show Keyboard Layout"), Lang.bind(this, this._showLayout));
|
||||||
|
|
||||||
|
Main.sessionMode.connect('updated', Lang.bind(this, this._sessionUpdated));
|
||||||
|
this._sessionUpdated();
|
||||||
|
|
||||||
|
this._inputSourceManager = getInputSourceManager();
|
||||||
|
this._inputSourceManager.connect('sources-changed', Lang.bind(this, this._sourcesChanged));
|
||||||
|
this._inputSourceManager.connect('current-source-changed', Lang.bind(this, this._currentSourceChanged));
|
||||||
|
this._inputSourceManager.reload();
|
||||||
|
},
|
||||||
|
|
||||||
|
_sessionUpdated: function() {
|
||||||
|
// re-using "allowSettings" for the keyboard layout is a bit shady,
|
||||||
|
// but at least for now it is used as "allow popping up windows
|
||||||
|
// from shell menus"; we can always add a separate sessionMode
|
||||||
|
// option if need arises.
|
||||||
|
this._showLayoutItem.actor.visible = Main.sessionMode.allowSettings;
|
||||||
|
},
|
||||||
|
|
||||||
|
_sourcesChanged: function() {
|
||||||
|
for (let i in this._menuItems)
|
||||||
|
this._menuItems[i].destroy();
|
||||||
|
for (let i in this._indicatorLabels)
|
||||||
|
this._indicatorLabels[i].destroy();
|
||||||
|
|
||||||
|
let menuIndex = 0;
|
||||||
|
for (let i in this._inputSourceManager.inputSources) {
|
||||||
|
let is = this._inputSourceManager.inputSources[i];
|
||||||
|
|
||||||
|
let menuItem = new LayoutMenuItem(is.displayName, is.shortName);
|
||||||
|
menuItem.connect('activate', Lang.bind(is, is.activate));
|
||||||
|
let indicatorLabel = new St.Label({ text: is.shortName,
|
||||||
|
visible: false });
|
||||||
|
|
||||||
|
this._menuItems[i] = menuItem;
|
||||||
|
this._indicatorLabels[i] = indicatorLabel;
|
||||||
|
is.connect('changed', function() {
|
||||||
|
menuItem.indicator.set_text(is.shortName);
|
||||||
|
indicatorLabel.set_text(is.shorName);
|
||||||
|
});
|
||||||
|
|
||||||
|
this.menu.addMenuItem(menuItem, menuIndex++);
|
||||||
|
this._container.add_actor(indicatorLabel);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
_currentSourceChanged: function(manager, oldSource) {
|
||||||
|
let nVisibleSources = Object.keys(this._inputSourceManager.inputSources).length;
|
||||||
|
let newSource = this._inputSourceManager.currentSource;
|
||||||
|
|
||||||
|
if (oldSource) {
|
||||||
|
this._menuItems[oldSource.index].setOrnament(PopupMenu.Ornament.NONE);
|
||||||
|
this._indicatorLabels[oldSource.index].hide();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!newSource || (nVisibleSources < 2 && !newSource.properties)) {
|
||||||
|
// This source index might be invalid if we weren't able
|
||||||
|
// to build a menu item for it, so we hide ourselves since
|
||||||
|
// we can't fix it here. *shrug*
|
||||||
|
|
||||||
|
// We also hide if we have only one visible source unless
|
||||||
|
// it's an IBus source with properties.
|
||||||
|
this.menu.close();
|
||||||
|
this.actor.hide();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.actor.show();
|
||||||
|
|
||||||
|
this._buildPropSection(newSource.properties);
|
||||||
|
|
||||||
|
this._menuItems[newSource.index].setOrnament(PopupMenu.Ornament.DOT);
|
||||||
|
this._indicatorLabels[newSource.index].show();
|
||||||
|
},
|
||||||
|
|
||||||
|
_buildPropSection: function(properties) {
|
||||||
|
this._propSeparator.actor.hide();
|
||||||
|
this._propSection.actor.hide();
|
||||||
|
this._propSection.removeAll();
|
||||||
|
|
||||||
|
this._buildPropSubMenu(this._propSection, properties);
|
||||||
|
|
||||||
|
if (!this._propSection.isEmpty()) {
|
||||||
|
this._propSection.actor.show();
|
||||||
|
this._propSeparator.actor.show();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
_buildPropSubMenu: function(menu, props) {
|
||||||
|
if (!props)
|
||||||
|
return;
|
||||||
|
|
||||||
|
let ibusManager = IBusManager.getIBusManager();
|
||||||
|
let radioGroup = [];
|
||||||
|
let p;
|
||||||
|
for (let i = 0; (p = props.get(i)) != null; ++i) {
|
||||||
|
let prop = p;
|
||||||
|
|
||||||
|
if (!prop.get_visible())
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (prop.get_key() == 'InputMode') {
|
||||||
|
let text;
|
||||||
|
if (prop.get_symbol)
|
||||||
|
text = prop.get_symbol().get_text();
|
||||||
|
else
|
||||||
|
text = prop.get_label().get_text();
|
||||||
|
|
||||||
|
let currentSource = this._inputSourceManager.currentSource;
|
||||||
|
if (currentSource) {
|
||||||
|
let indicatorLabel = this._indicatorLabels[currentSource.index];
|
||||||
|
if (text && text.length > 0 && text.length < 3)
|
||||||
|
indicatorLabel.set_text(text);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
let item;
|
||||||
|
switch (prop.get_prop_type()) {
|
||||||
|
case IBus.PropType.MENU:
|
||||||
|
item = new PopupMenu.PopupSubMenuMenuItem(prop.get_label().get_text());
|
||||||
|
this._buildPropSubMenu(item.menu, prop.get_sub_props());
|
||||||
|
break;
|
||||||
|
|
||||||
|
case IBus.PropType.RADIO:
|
||||||
|
item = new PopupMenu.PopupMenuItem(prop.get_label().get_text());
|
||||||
|
item.prop = prop;
|
||||||
|
radioGroup.push(item);
|
||||||
|
item.radioGroup = radioGroup;
|
||||||
|
item.setOrnament(prop.get_state() == IBus.PropState.CHECKED ?
|
||||||
|
PopupMenu.Ornament.DOT : PopupMenu.Ornament.NONE);
|
||||||
|
item.connect('activate', Lang.bind(this, function() {
|
||||||
|
if (item.prop.get_state() == IBus.PropState.CHECKED)
|
||||||
|
return;
|
||||||
|
|
||||||
|
let group = item.radioGroup;
|
||||||
|
for (let i = 0; i < group.length; ++i) {
|
||||||
|
if (group[i] == item) {
|
||||||
|
item.setOrnament(PopupMenu.Ornament.DOT);
|
||||||
|
item.prop.set_state(IBus.PropState.CHECKED);
|
||||||
|
ibusManager.activateProperty(item.prop.get_key(),
|
||||||
|
IBus.PropState.CHECKED);
|
||||||
|
} else {
|
||||||
|
group[i].setOrnament(PopupMenu.Ornament.NONE);
|
||||||
|
group[i].prop.set_state(IBus.PropState.UNCHECKED);
|
||||||
|
ibusManager.activateProperty(group[i].prop.get_key(),
|
||||||
|
IBus.PropState.UNCHECKED);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case IBus.PropType.TOGGLE:
|
||||||
|
item = new PopupMenu.PopupSwitchMenuItem(prop.get_label().get_text(), prop.get_state() == IBus.PropState.CHECKED);
|
||||||
|
item.prop = prop;
|
||||||
|
item.connect('toggled', Lang.bind(this, function() {
|
||||||
|
if (item.state) {
|
||||||
|
item.prop.set_state(IBus.PropState.CHECKED);
|
||||||
|
ibusManager.activateProperty(item.prop.get_key(),
|
||||||
|
IBus.PropState.CHECKED);
|
||||||
|
} else {
|
||||||
|
item.prop.set_state(IBus.PropState.UNCHECKED);
|
||||||
|
ibusManager.activateProperty(item.prop.get_key(),
|
||||||
|
IBus.PropState.UNCHECKED);
|
||||||
|
}
|
||||||
|
}));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case IBus.PropType.NORMAL:
|
||||||
|
item = new PopupMenu.PopupMenuItem(prop.get_label().get_text());
|
||||||
|
item.prop = prop;
|
||||||
|
item.connect('activate', Lang.bind(this, function() {
|
||||||
|
ibusManager.activateProperty(item.prop.get_key(),
|
||||||
|
item.prop.get_state());
|
||||||
|
}));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case IBus.PropType.SEPARATOR:
|
||||||
|
item = new PopupMenu.PopupSeparatorMenuItem();
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
log ('IBus property %s has invalid type %d'.format(prop.get_key(), type));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
item.setSensitive(prop.get_sensitive());
|
||||||
|
menu.addMenuItem(item);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
_showLayout: function() {
|
||||||
|
Main.overview.hide();
|
||||||
|
|
||||||
|
let source = this._inputSourceManager.currentSource;
|
||||||
|
let xkbLayout = '';
|
||||||
|
let xkbVariant = '';
|
||||||
|
|
||||||
|
if (source.type == INPUT_SOURCE_TYPE_XKB) {
|
||||||
|
[, , , xkbLayout, xkbVariant] = KeyboardManager.getXkbInfo().get_layout_info(source.id);
|
||||||
|
} else if (source.type == INPUT_SOURCE_TYPE_IBUS) {
|
||||||
|
let engineDesc = IBusManager.getIBusManager().getEngineDesc(source.id);
|
||||||
|
if (engineDesc) {
|
||||||
|
xkbLayout = engineDesc.get_layout();
|
||||||
|
xkbVariant = engineDesc.get_layout_variant();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!xkbLayout || xkbLayout.length == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
let description = xkbLayout;
|
||||||
|
if (xkbVariant.length > 0)
|
||||||
|
description = description + '\t' + xkbVariant;
|
||||||
|
|
||||||
|
Util.spawn(['gkbd-keyboard-display', '-l', description]);
|
||||||
|
},
|
||||||
|
|
||||||
_containerGetPreferredWidth: function(container, for_height, alloc) {
|
_containerGetPreferredWidth: function(container, for_height, alloc) {
|
||||||
// Here, and in _containerGetPreferredHeight, we need to query
|
// Here, and in _containerGetPreferredHeight, we need to query
|
||||||
// for the height of all children, but we ignore the results
|
// for the height of all children, but we ignore the results
|
||||||
// for those we don't actually display.
|
// for those we don't actually display.
|
||||||
let max_min_width = 0, max_natural_width = 0;
|
let max_min_width = 0, max_natural_width = 0;
|
||||||
|
|
||||||
for (let i in this._inputSources) {
|
for (let i in this._inputSourceManager.inputSources) {
|
||||||
let is = this._inputSources[i];
|
let label = this._indicatorLabels[i];
|
||||||
let [min_width, natural_width] = is.indicatorLabel.get_preferred_width(for_height);
|
let [min_width, natural_width] = label.get_preferred_width(for_height);
|
||||||
max_min_width = Math.max(max_min_width, min_width);
|
max_min_width = Math.max(max_min_width, min_width);
|
||||||
max_natural_width = Math.max(max_natural_width, natural_width);
|
max_natural_width = Math.max(max_natural_width, natural_width);
|
||||||
}
|
}
|
||||||
@ -889,9 +793,9 @@ const InputSourceIndicator = new Lang.Class({
|
|||||||
_containerGetPreferredHeight: function(container, for_width, alloc) {
|
_containerGetPreferredHeight: function(container, for_width, alloc) {
|
||||||
let max_min_height = 0, max_natural_height = 0;
|
let max_min_height = 0, max_natural_height = 0;
|
||||||
|
|
||||||
for (let i in this._inputSources) {
|
for (let i in this._inputSourceManager.inputSources) {
|
||||||
let is = this._inputSources[i];
|
let label = this._indicatorLabels[i];
|
||||||
let [min_height, natural_height] = is.indicatorLabel.get_preferred_height(for_width);
|
let [min_height, natural_height] = label.get_preferred_height(for_width);
|
||||||
max_min_height = Math.max(max_min_height, min_height);
|
max_min_height = Math.max(max_min_height, min_height);
|
||||||
max_natural_height = Math.max(max_natural_height, natural_height);
|
max_natural_height = Math.max(max_natural_height, natural_height);
|
||||||
}
|
}
|
||||||
@ -907,9 +811,9 @@ const InputSourceIndicator = new Lang.Class({
|
|||||||
box.y2 -= box.y1;
|
box.y2 -= box.y1;
|
||||||
box.y1 = 0;
|
box.y1 = 0;
|
||||||
|
|
||||||
for (let i in this._inputSources) {
|
for (let i in this._inputSourceManager.inputSources) {
|
||||||
let is = this._inputSources[i];
|
let label = this._indicatorLabels[i];
|
||||||
is.indicatorLabel.allocate_align_fill(box, 0.5, 0.5, false, false, flags);
|
label.allocate_align_fill(box, 0.5, 0.5, false, false, flags);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -13,6 +13,15 @@ const LOCATION_SCHEMA = 'org.gnome.system.location';
|
|||||||
const MAX_ACCURACY_LEVEL = 'max-accuracy-level';
|
const MAX_ACCURACY_LEVEL = 'max-accuracy-level';
|
||||||
const ENABLED = 'enabled';
|
const ENABLED = 'enabled';
|
||||||
|
|
||||||
|
const GeoclueAccuracyLevel = {
|
||||||
|
NONE: 0,
|
||||||
|
COUNTRY: 1,
|
||||||
|
CITY: 4,
|
||||||
|
NEIGHBORHOOD: 5,
|
||||||
|
STREET: 6,
|
||||||
|
EXACT: 8
|
||||||
|
};
|
||||||
|
|
||||||
var GeoclueIface = '<node> \
|
var GeoclueIface = '<node> \
|
||||||
<interface name="org.freedesktop.GeoClue2.Manager"> \
|
<interface name="org.freedesktop.GeoClue2.Manager"> \
|
||||||
<property name="InUse" type="b" access="read"/> \
|
<property name="InUse" type="b" access="read"/> \
|
||||||
@ -61,6 +70,7 @@ const Indicator = new Lang.Class({
|
|||||||
|
|
||||||
this._item.status.text = _("Enabled");
|
this._item.status.text = _("Enabled");
|
||||||
this._onOffAction = this._item.menu.addAction(_("Disable"), Lang.bind(this, this._onOnOffAction));
|
this._onOffAction = this._item.menu.addAction(_("Disable"), Lang.bind(this, this._onOnOffAction));
|
||||||
|
this._item.menu.addSettingsAction(_("Privacy Settings"), 'gnome-privacy-panel.desktop');
|
||||||
|
|
||||||
this.menu.addMenuItem(this._item);
|
this.menu.addMenuItem(this._item);
|
||||||
|
|
||||||
@ -181,10 +191,14 @@ const Indicator = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_getMaxAccuracyLevel: function() {
|
_getMaxAccuracyLevel: function() {
|
||||||
if (this._settings.get_boolean(ENABLED))
|
if (this._settings.get_boolean(ENABLED)) {
|
||||||
return this._settings.get_enum(MAX_ACCURACY_LEVEL);
|
let level = this._settings.get_string(MAX_ACCURACY_LEVEL);
|
||||||
else
|
|
||||||
return 0;
|
return GeoclueAccuracyLevel[level.toUpperCase()] ||
|
||||||
|
GeoclueAccuracyLevel.NONE;
|
||||||
|
} else {
|
||||||
|
return GeoclueAccuracyLevel.NONE;
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_notifyMaxAccuracyLevel: function() {
|
_notifyMaxAccuracyLevel: function() {
|
||||||
|
@ -876,7 +876,8 @@ const NMWirelessDialog = new Lang.Class({
|
|||||||
x_align: Clutter.ActorAlign.CENTER,
|
x_align: Clutter.ActorAlign.CENTER,
|
||||||
y_align: Clutter.ActorAlign.CENTER });
|
y_align: Clutter.ActorAlign.CENTER });
|
||||||
|
|
||||||
this._noNetworksSpinner = new Animation.AnimatedIcon(global.datadir + '/theme/process-working.svg', 24, 24);
|
let file = Gio.File.new_for_uri('resource:///org/gnome/shell/theme/process-working.svg');
|
||||||
|
this._noNetworksSpinner = new Animation.AnimatedIcon(file, 24, 24);
|
||||||
this._noNetworksBox.add_actor(this._noNetworksSpinner.actor);
|
this._noNetworksBox.add_actor(this._noNetworksSpinner.actor);
|
||||||
this._noNetworksBox.add_actor(new St.Label({ style_class: 'no-networks-label',
|
this._noNetworksBox.add_actor(new St.Label({ style_class: 'no-networks-label',
|
||||||
text: _("No Networks") }));
|
text: _("No Networks") }));
|
||||||
|
@ -15,6 +15,7 @@ const RfkillManagerInterface = '<node> \
|
|||||||
<interface name="org.gnome.SettingsDaemon.Rfkill"> \
|
<interface name="org.gnome.SettingsDaemon.Rfkill"> \
|
||||||
<property name="AirplaneMode" type="b" access="readwrite" /> \
|
<property name="AirplaneMode" type="b" access="readwrite" /> \
|
||||||
<property name="HardwareAirplaneMode" type="b" access="read" /> \
|
<property name="HardwareAirplaneMode" type="b" access="read" /> \
|
||||||
|
<property name="ShouldShowAirplaneMode" type="b" access="read" /> \
|
||||||
</interface> \
|
</interface> \
|
||||||
</node>';
|
</node>';
|
||||||
|
|
||||||
@ -48,6 +49,10 @@ const RfkillManager = new Lang.Class({
|
|||||||
return this._proxy.HardwareAirplaneMode;
|
return this._proxy.HardwareAirplaneMode;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
get shouldShowAirplaneMode() {
|
||||||
|
return this._proxy.ShouldShowAirplaneMode;
|
||||||
|
},
|
||||||
|
|
||||||
_changed: function() {
|
_changed: function() {
|
||||||
this.emit('airplane-mode-changed');
|
this.emit('airplane-mode-changed');
|
||||||
}
|
}
|
||||||
@ -101,11 +106,10 @@ const Indicator = new Lang.Class({
|
|||||||
_sync: function() {
|
_sync: function() {
|
||||||
let airplaneMode = this._manager.airplaneMode;
|
let airplaneMode = this._manager.airplaneMode;
|
||||||
let hwAirplaneMode = this._manager.hwAirplaneMode;
|
let hwAirplaneMode = this._manager.hwAirplaneMode;
|
||||||
let changed = (airplaneMode != this._indicator.visible) ||
|
let showAirplaneMode = this._manager.shouldShowAirplaneMode;
|
||||||
(hwAirplaneMode != this._offItem.actor.visible);
|
|
||||||
|
|
||||||
this._indicator.visible = airplaneMode;
|
this._indicator.visible = (airplaneMode && showAirplaneMode);
|
||||||
this._item.actor.visible = airplaneMode;
|
this._item.actor.visible = (airplaneMode && showAirplaneMode);
|
||||||
this._offItem.setSensitive(!hwAirplaneMode);
|
this._offItem.setSensitive(!hwAirplaneMode);
|
||||||
|
|
||||||
if (hwAirplaneMode)
|
if (hwAirplaneMode)
|
||||||
|
@ -102,16 +102,17 @@ const SwitcherPopup = new Lang.Class({
|
|||||||
this._switcherList.actor.allocate(childBox, flags);
|
this._switcherList.actor.allocate(childBox, flags);
|
||||||
},
|
},
|
||||||
|
|
||||||
_createSwitcher: function() {
|
|
||||||
throw new Error('Not implemented');
|
|
||||||
},
|
|
||||||
|
|
||||||
_initialSelection: function(backward, binding) {
|
_initialSelection: function(backward, binding) {
|
||||||
throw new Error('Not implemented');
|
if (backward)
|
||||||
|
this._select(this._items.length - 1);
|
||||||
|
else if (this._items.length == 1)
|
||||||
|
this._select(0);
|
||||||
|
else
|
||||||
|
this._select(1);
|
||||||
},
|
},
|
||||||
|
|
||||||
show: function(backward, binding, mask) {
|
show: function(backward, binding, mask) {
|
||||||
if (!this._createSwitcher())
|
if (this._items.length == 0)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (!Main.pushModal(this.actor)) {
|
if (!Main.pushModal(this.actor)) {
|
||||||
@ -139,11 +140,6 @@ const SwitcherPopup = new Lang.Class({
|
|||||||
this.actor.show();
|
this.actor.show();
|
||||||
this.actor.get_allocation_box();
|
this.actor.get_allocation_box();
|
||||||
|
|
||||||
if (this._items.length > 1)
|
|
||||||
this._selectedIndex = 1;
|
|
||||||
else
|
|
||||||
this._selectedIndex = 0;
|
|
||||||
|
|
||||||
this._initialSelection(backward, binding);
|
this._initialSelection(backward, binding);
|
||||||
|
|
||||||
// There's a race condition; if the user released Alt before
|
// There's a race condition; if the user released Alt before
|
||||||
|
@ -28,11 +28,12 @@ const Avatar = new Lang.Class({
|
|||||||
styleClass: 'framed-user-icon' });
|
styleClass: 'framed-user-icon' });
|
||||||
this._iconSize = params.iconSize;
|
this._iconSize = params.iconSize;
|
||||||
|
|
||||||
|
let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor;
|
||||||
this.actor = new St.Bin({ style_class: params.styleClass,
|
this.actor = new St.Bin({ style_class: params.styleClass,
|
||||||
track_hover: params.reactive,
|
track_hover: params.reactive,
|
||||||
reactive: params.reactive,
|
reactive: params.reactive,
|
||||||
width: this._iconSize,
|
width: this._iconSize * scaleFactor,
|
||||||
height: this._iconSize });
|
height: this._iconSize * scaleFactor });
|
||||||
},
|
},
|
||||||
|
|
||||||
setSensitive: function(sensitive) {
|
setSensitive: function(sensitive) {
|
||||||
|
@ -125,7 +125,6 @@ const ViewSelector = new Lang.Class({
|
|||||||
this._activePage = null;
|
this._activePage = null;
|
||||||
|
|
||||||
this._searchActive = false;
|
this._searchActive = false;
|
||||||
this._searchTimeoutId = 0;
|
|
||||||
|
|
||||||
this._entry = searchEntry;
|
this._entry = searchEntry;
|
||||||
ShellEntry.addContextMenu(this._entry);
|
ShellEntry.addContextMenu(this._entry);
|
||||||
@ -144,12 +143,8 @@ const ViewSelector = new Lang.Class({
|
|||||||
|
|
||||||
this._entry.set_primary_icon(new St.Icon({ style_class: 'search-entry-icon',
|
this._entry.set_primary_icon(new St.Icon({ style_class: 'search-entry-icon',
|
||||||
icon_name: 'edit-find-symbolic' }));
|
icon_name: 'edit-find-symbolic' }));
|
||||||
if (this._entry.get_text_direction() == Clutter.TextDirection.RTL)
|
this._clearIcon = new St.Icon({ style_class: 'search-entry-icon',
|
||||||
this._clearIcon = new St.Icon({ style_class: 'search-entry-icon',
|
icon_name: 'edit-clear-symbolic' });
|
||||||
icon_name: 'edit-clear-symbolic-rtl' });
|
|
||||||
else
|
|
||||||
this._clearIcon = new St.Icon({ style_class: 'search-entry-icon',
|
|
||||||
icon_name: 'edit-clear-symbolic-ltr' });
|
|
||||||
|
|
||||||
this._iconClickedId = 0;
|
this._iconClickedId = 0;
|
||||||
this._capturedEventId = 0;
|
this._capturedEventId = 0;
|
||||||
@ -489,36 +484,23 @@ const ViewSelector = new Lang.Class({
|
|||||||
_onTextChanged: function (se, prop) {
|
_onTextChanged: function (se, prop) {
|
||||||
let terms = getTermsForSearchString(this._entry.get_text());
|
let terms = getTermsForSearchString(this._entry.get_text());
|
||||||
|
|
||||||
let searchPreviouslyActive = this._searchActive;
|
|
||||||
this._searchActive = (terms.length > 0);
|
this._searchActive = (terms.length > 0);
|
||||||
|
this._searchResults.setTerms(terms);
|
||||||
let startSearch = this._searchActive && !searchPreviouslyActive;
|
|
||||||
if (startSearch)
|
|
||||||
this._searchResults.startingSearch();
|
|
||||||
|
|
||||||
if (this._searchActive) {
|
if (this._searchActive) {
|
||||||
|
this._showPage(this._searchPage);
|
||||||
|
|
||||||
this._entry.set_secondary_icon(this._clearIcon);
|
this._entry.set_secondary_icon(this._clearIcon);
|
||||||
|
|
||||||
if (this._iconClickedId == 0)
|
if (this._iconClickedId == 0)
|
||||||
this._iconClickedId = this._entry.connect('secondary-icon-clicked',
|
this._iconClickedId = this._entry.connect('secondary-icon-clicked',
|
||||||
Lang.bind(this, this.reset));
|
Lang.bind(this, this.reset));
|
||||||
|
|
||||||
if (this._searchTimeoutId == 0) {
|
|
||||||
this._searchTimeoutId = Mainloop.timeout_add(150,
|
|
||||||
Lang.bind(this, this._doSearch));
|
|
||||||
GLib.Source.set_name_by_id(this._searchTimeoutId, '[gnome-shell] this._doSearch');
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
if (this._iconClickedId > 0) {
|
if (this._iconClickedId > 0) {
|
||||||
this._entry.disconnect(this._iconClickedId);
|
this._entry.disconnect(this._iconClickedId);
|
||||||
this._iconClickedId = 0;
|
this._iconClickedId = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this._searchTimeoutId > 0) {
|
|
||||||
Mainloop.source_remove(this._searchTimeoutId);
|
|
||||||
this._searchTimeoutId = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._entry.set_secondary_icon(null);
|
this._entry.set_secondary_icon(null);
|
||||||
this._searchCancelled();
|
this._searchCancelled();
|
||||||
}
|
}
|
||||||
@ -556,12 +538,6 @@ const ViewSelector = new Lang.Class({
|
|||||||
this._searchResults.navigateFocus(nextDirection);
|
this._searchResults.navigateFocus(nextDirection);
|
||||||
return Clutter.EVENT_STOP;
|
return Clutter.EVENT_STOP;
|
||||||
} else if (symbol == Clutter.Return || symbol == Clutter.KP_Enter) {
|
} else if (symbol == Clutter.Return || symbol == Clutter.KP_Enter) {
|
||||||
// We can't connect to 'activate' here because search providers
|
|
||||||
// might want to do something with the modifiers in activateDefault.
|
|
||||||
if (this._searchTimeoutId > 0) {
|
|
||||||
Mainloop.source_remove(this._searchTimeoutId);
|
|
||||||
this._doSearch();
|
|
||||||
}
|
|
||||||
this._searchResults.activateDefault();
|
this._searchResults.activateDefault();
|
||||||
return Clutter.EVENT_STOP;
|
return Clutter.EVENT_STOP;
|
||||||
}
|
}
|
||||||
@ -584,17 +560,6 @@ const ViewSelector = new Lang.Class({
|
|||||||
return Clutter.EVENT_PROPAGATE;
|
return Clutter.EVENT_PROPAGATE;
|
||||||
},
|
},
|
||||||
|
|
||||||
_doSearch: function () {
|
|
||||||
this._searchTimeoutId = 0;
|
|
||||||
|
|
||||||
let terms = getTermsForSearchString(this._entry.get_text());
|
|
||||||
|
|
||||||
this._searchResults.setTerms(terms);
|
|
||||||
this._showPage(this._searchPage);
|
|
||||||
|
|
||||||
return GLib.SOURCE_REMOVE;
|
|
||||||
},
|
|
||||||
|
|
||||||
getActivePage: function() {
|
getActivePage: function() {
|
||||||
if (this._activePage == this._workspacesPage)
|
if (this._activePage == this._workspacesPage)
|
||||||
return ViewPage.WINDOWS;
|
return ViewPage.WINDOWS;
|
||||||
|
@ -413,7 +413,7 @@ const TilePreview = new Lang.Class({
|
|||||||
y: monitor.y,
|
y: monitor.y,
|
||||||
width: monitor.width,
|
width: monitor.width,
|
||||||
height: monitor.height });
|
height: monitor.height });
|
||||||
let [, rect] = window.get_outer_rect().intersect(monitorRect);
|
let [, rect] = window.get_frame_rect().intersect(monitorRect);
|
||||||
this.actor.set_size(rect.width, rect.height);
|
this.actor.set_size(rect.width, rect.height);
|
||||||
this.actor.set_position(rect.x, rect.y);
|
this.actor.set_position(rect.x, rect.y);
|
||||||
this.actor.opacity = 0;
|
this.actor.opacity = 0;
|
||||||
@ -526,6 +526,11 @@ const AppSwitchAction = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
vfunc_gesture_prepare : function(action, actor) {
|
vfunc_gesture_prepare : function(action, actor) {
|
||||||
|
if (Main.overview.visible) {
|
||||||
|
this.cancel();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
return this.get_n_current_points() <= 4;
|
return this.get_n_current_points() <= 4;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -75,7 +75,7 @@ const WindowMenu = new Lang.Class({
|
|||||||
}));
|
}));
|
||||||
if (window.is_above())
|
if (window.is_above())
|
||||||
item.setOrnament(PopupMenu.Ornament.DOT);
|
item.setOrnament(PopupMenu.Ornament.DOT);
|
||||||
if (window.get_maximized() ||
|
if (window.get_maximized() == Meta.MaximizeFlags.BOTH ||
|
||||||
type == Meta.WindowType.DOCK ||
|
type == Meta.WindowType.DOCK ||
|
||||||
type == Meta.WindowType.DESKTOP ||
|
type == Meta.WindowType.DESKTOP ||
|
||||||
type == Meta.WindowType.SPLASHSCREEN)
|
type == Meta.WindowType.SPLASHSCREEN)
|
||||||
|
@ -254,7 +254,7 @@ const WindowClone = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_computeBoundingBox: function() {
|
_computeBoundingBox: function() {
|
||||||
let rect = this.metaWindow.get_outer_rect();
|
let rect = this.metaWindow.get_frame_rect();
|
||||||
|
|
||||||
this.actor.get_children().forEach(function (child) {
|
this.actor.get_children().forEach(function (child) {
|
||||||
let realWindow;
|
let realWindow;
|
||||||
@ -264,7 +264,7 @@ const WindowClone = new Lang.Class({
|
|||||||
realWindow = child.source;
|
realWindow = child.source;
|
||||||
|
|
||||||
let metaWindow = realWindow.meta_window;
|
let metaWindow = realWindow.meta_window;
|
||||||
rect = rect.union(metaWindow.get_outer_rect());
|
rect = rect.union(metaWindow.get_frame_rect());
|
||||||
}, this);
|
}, this);
|
||||||
|
|
||||||
// Convert from a MetaRectangle to a native JS object
|
// Convert from a MetaRectangle to a native JS object
|
||||||
@ -1209,14 +1209,18 @@ const Workspace = new Lang.Class({
|
|||||||
return this._windows.length == 0;
|
return this._windows.length == 0;
|
||||||
},
|
},
|
||||||
|
|
||||||
setReservedSlot: function(clone) {
|
setReservedSlot: function(metaWindow) {
|
||||||
if (this._reservedSlot == clone)
|
if (this._reservedSlotWindow == metaWindow)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (clone && this.containsMetaWindow(clone.metaWindow))
|
if (!metaWindow || this.containsMetaWindow(metaWindow)) {
|
||||||
clone = null;
|
this._reservedSlotWindow = null;
|
||||||
|
this._reservedSlot = null;
|
||||||
|
} else {
|
||||||
|
this._reservedSlotWindow = metaWindow;
|
||||||
|
this._reservedSlot = this._windows[this._lookupIndex(metaWindow)];
|
||||||
|
}
|
||||||
|
|
||||||
this._reservedSlot = clone;
|
|
||||||
this._recalculateWindowPositions(WindowPositionFlags.ANIMATE);
|
this._recalculateWindowPositions(WindowPositionFlags.ANIMATE);
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -1814,16 +1818,16 @@ const Workspace = new Lang.Class({
|
|||||||
Lang.bind(this, this._onCloneSelected));
|
Lang.bind(this, this._onCloneSelected));
|
||||||
clone.connect('drag-begin',
|
clone.connect('drag-begin',
|
||||||
Lang.bind(this, function() {
|
Lang.bind(this, function() {
|
||||||
Main.overview.beginWindowDrag(clone);
|
Main.overview.beginWindowDrag(clone.metaWindow);
|
||||||
overlay.hide();
|
overlay.hide();
|
||||||
}));
|
}));
|
||||||
clone.connect('drag-cancelled',
|
clone.connect('drag-cancelled',
|
||||||
Lang.bind(this, function() {
|
Lang.bind(this, function() {
|
||||||
Main.overview.cancelledWindowDrag(clone);
|
Main.overview.cancelledWindowDrag(clone.metaWindow);
|
||||||
}));
|
}));
|
||||||
clone.connect('drag-end',
|
clone.connect('drag-end',
|
||||||
Lang.bind(this, function() {
|
Lang.bind(this, function() {
|
||||||
Main.overview.endWindowDrag(clone);
|
Main.overview.endWindowDrag(clone.metaWindow);
|
||||||
overlay.show();
|
overlay.show();
|
||||||
}));
|
}));
|
||||||
clone.connect('size-changed',
|
clone.connect('size-changed',
|
||||||
|
@ -161,14 +161,14 @@ const WindowClone = new Lang.Class({
|
|||||||
|
|
||||||
_updateDialogPosition: function(realDialog, cloneDialog) {
|
_updateDialogPosition: function(realDialog, cloneDialog) {
|
||||||
let metaDialog = realDialog.meta_window;
|
let metaDialog = realDialog.meta_window;
|
||||||
let dialogRect = metaDialog.get_outer_rect();
|
let dialogRect = metaDialog.get_frame_rect();
|
||||||
let rect = this.metaWindow.get_outer_rect();
|
let rect = this.metaWindow.get_frame_rect();
|
||||||
|
|
||||||
cloneDialog.set_position(dialogRect.x - rect.x, dialogRect.y - rect.y);
|
cloneDialog.set_position(dialogRect.x - rect.x, dialogRect.y - rect.y);
|
||||||
},
|
},
|
||||||
|
|
||||||
_onPositionChanged: function() {
|
_onPositionChanged: function() {
|
||||||
let rect = this.metaWindow.get_outer_rect();
|
let rect = this.metaWindow.get_frame_rect();
|
||||||
this.actor.set_position(this.realWindow.x, this.realWindow.y);
|
this.actor.set_position(this.realWindow.x, this.realWindow.y);
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -518,15 +518,15 @@ const WorkspaceThumbnail = new Lang.Class({
|
|||||||
}));
|
}));
|
||||||
clone.connect('drag-begin',
|
clone.connect('drag-begin',
|
||||||
Lang.bind(this, function() {
|
Lang.bind(this, function() {
|
||||||
Main.overview.beginWindowDrag(clone);
|
Main.overview.beginWindowDrag(clone.metaWindow);
|
||||||
}));
|
}));
|
||||||
clone.connect('drag-cancelled',
|
clone.connect('drag-cancelled',
|
||||||
Lang.bind(this, function() {
|
Lang.bind(this, function() {
|
||||||
Main.overview.cancelledWindowDrag(clone);
|
Main.overview.cancelledWindowDrag(clone.metaWindow);
|
||||||
}));
|
}));
|
||||||
clone.connect('drag-end',
|
clone.connect('drag-end',
|
||||||
Lang.bind(this, function() {
|
Lang.bind(this, function() {
|
||||||
Main.overview.endWindowDrag(clone);
|
Main.overview.endWindowDrag(clone.metaWindow);
|
||||||
}));
|
}));
|
||||||
this._contents.add_actor(clone.actor);
|
this._contents.add_actor(clone.actor);
|
||||||
|
|
||||||
|
@ -63,9 +63,9 @@ const WorkspacesViewBase = new Lang.Class({
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_dragBegin: function(overview, clone) {
|
_dragBegin: function(overview, window) {
|
||||||
this._inDrag = true;
|
this._inDrag = true;
|
||||||
this._setReservedSlot(clone);
|
this._setReservedSlot(window);
|
||||||
},
|
},
|
||||||
|
|
||||||
_dragEnd: function() {
|
_dragEnd: function() {
|
||||||
@ -127,9 +127,9 @@ const WorkspacesView = new Lang.Class({
|
|||||||
Lang.bind(this, this._activeWorkspaceChanged));
|
Lang.bind(this, this._activeWorkspaceChanged));
|
||||||
},
|
},
|
||||||
|
|
||||||
_setReservedSlot: function(clone) {
|
_setReservedSlot: function(window) {
|
||||||
for (let i = 0; i < this._workspaces.length; i++)
|
for (let i = 0; i < this._workspaces.length; i++)
|
||||||
this._workspaces[i].setReservedSlot(clone);
|
this._workspaces[i].setReservedSlot(window);
|
||||||
},
|
},
|
||||||
|
|
||||||
_syncFullGeometry: function() {
|
_syncFullGeometry: function() {
|
||||||
@ -366,8 +366,8 @@ const ExtraWorkspaceView = new Lang.Class({
|
|||||||
this.actor.add_actor(this._workspace.actor);
|
this.actor.add_actor(this._workspace.actor);
|
||||||
},
|
},
|
||||||
|
|
||||||
_setReservedSlot: function(clone) {
|
_setReservedSlot: function(window) {
|
||||||
this._workspace.setReservedSlot(clone);
|
this._workspace.setReservedSlot(window);
|
||||||
},
|
},
|
||||||
|
|
||||||
_syncFullGeometry: function() {
|
_syncFullGeometry: function() {
|
||||||
|
@ -45,6 +45,7 @@ mk
|
|||||||
mr
|
mr
|
||||||
ms
|
ms
|
||||||
nb
|
nb
|
||||||
|
ne
|
||||||
nl
|
nl
|
||||||
nn
|
nn
|
||||||
or
|
or
|
||||||
@ -67,6 +68,7 @@ th
|
|||||||
tr
|
tr
|
||||||
ug
|
ug
|
||||||
uk
|
uk
|
||||||
|
uz@cyrillic
|
||||||
vi
|
vi
|
||||||
zh_CN
|
zh_CN
|
||||||
zh_HK
|
zh_HK
|
||||||
|
332
po/as.po
@ -9,8 +9,8 @@ msgstr ""
|
|||||||
"Project-Id-Version: gnome-shell master\n"
|
"Project-Id-Version: gnome-shell master\n"
|
||||||
"Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?product=gnome-"
|
"Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?product=gnome-"
|
||||||
"shell&keywords=I18N+L10N&component=general\n"
|
"shell&keywords=I18N+L10N&component=general\n"
|
||||||
"POT-Creation-Date: 2014-08-13 07:33+0000\n"
|
"POT-Creation-Date: 2014-09-15 07:36+0000\n"
|
||||||
"PO-Revision-Date: 2014-08-13 17:32+0530\n"
|
"PO-Revision-Date: 2014-09-15 14:59+0530\n"
|
||||||
"Last-Translator: Nilamdyuti Goswami <ngoswami@redhat.com>\n"
|
"Last-Translator: Nilamdyuti Goswami <ngoswami@redhat.com>\n"
|
||||||
"Language-Team: Assamese <kde-i18n-doc@kde.org>\n"
|
"Language-Team: Assamese <kde-i18n-doc@kde.org>\n"
|
||||||
"Language: as_IN\n"
|
"Language: as_IN\n"
|
||||||
@ -110,8 +110,9 @@ msgid ""
|
|||||||
"load all extensions regardless of the versions they claim to support."
|
"load all extensions regardless of the versions they claim to support."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"GNOME শ্বেলে কেৱল বৰ্তমান চলি থকা সংস্কৰণক সমৰ্থন কৰা সম্প্ৰসাৰনসমূহ ল'ড "
|
"GNOME শ্বেলে কেৱল বৰ্তমান চলি থকা সংস্কৰণক সমৰ্থন কৰা সম্প্ৰসাৰনসমূহ ল'ড "
|
||||||
"কৰিব। এই বিকল্প সামৰ্থবান কৰিলে এই নিৰীক্ষণ অসামৰ্থবান কৰা হব আৰু সিহতে "
|
"কৰিব। এই "
|
||||||
"সমৰ্থন কৰা সংস্কৰণসমূহৰ নিৰপেক্ষে সকলো সম্প্ৰসাৰন ল'ড কৰিব।"
|
"বিকল্প সামৰ্থবান কৰিলে এই নিৰীক্ষণ অসামৰ্থবান কৰা হব আৰু সিহতে সমৰ্থন কৰা "
|
||||||
|
"সংস্কৰণসমূহৰ নিৰপেক্ষে সকলো সম্প্ৰসাৰন ল'ড কৰিব।"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:7
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:7
|
||||||
msgid "List of desktop file IDs for favorite applications"
|
msgid "List of desktop file IDs for favorite applications"
|
||||||
@ -157,8 +158,8 @@ msgstr ""
|
|||||||
msgid ""
|
msgid ""
|
||||||
"Whether to remember password for mounting encrypted or remote filesystems"
|
"Whether to remember password for mounting encrypted or remote filesystems"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"ইনক্ৰিপ্টেড অথবা দূৰৱৰ্তী ফাইলচিস্টেমসমূহ মাউন্ট কৰাৰ বাবে পাছৱৰ্ড মনত ৰখা "
|
"ইনক্ৰিপ্টেড অথবা দূৰৱৰ্তী ফাইলচিস্টেমসমূহ মাউণ্ট কৰাৰ বাবে পাছৱৰ্ড মনত ৰখা হব "
|
||||||
"হব নে"
|
"নে"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:16
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:16
|
||||||
msgid ""
|
msgid ""
|
||||||
@ -169,10 +170,11 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"শ্বেলে এটা পাছৱৰ্ড অনুৰোধ কৰিব যেতিয়া এটা ইনক্ৰিপ্টেড ডিভাইচ অথবা এটা "
|
"শ্বেলে এটা পাছৱৰ্ড অনুৰোধ কৰিব যেতিয়া এটা ইনক্ৰিপ্টেড ডিভাইচ অথবা এটা "
|
||||||
"দূৰৱৰ্তী "
|
"দূৰৱৰ্তী "
|
||||||
"ফাইলচিস্টেম মাউন্ট কৰা হয়। যদি পাছৱৰ্ডক ভৱিষ্যত ব্যৱহাৰৰ বাবে সংৰক্ষণ কৰিব "
|
"ফাইলচিস্টেম মাউণ্ট কৰা হয়। যদি পাছৱৰ্ডক ভৱিষ্যত ব্যৱহাৰৰ বাবে সংৰক্ষণ কৰিব "
|
||||||
"পাৰি "
|
"পাৰি "
|
||||||
"তেন্তে এটা 'পাছৱৰ্ড মনত ৰাখক' চেকবাকচ উপস্থিত থাকিব। এই কি'য়ে চেকবাকচৰ "
|
"তেন্তে এটা 'পাছৱৰ্ড মনত ৰাখক' চেকবাকচ উপস্থিত থাকিব। এই কি'য়ে চেকবাকচৰ "
|
||||||
"অবিকল্পিত অৱস্থা সংহতি কৰে।"
|
"অবিকল্পিত "
|
||||||
|
"অৱস্থা সংহতি কৰে।"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:17
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:17
|
||||||
msgid "Show the week date in the calendar"
|
msgid "Show the week date in the calendar"
|
||||||
@ -248,7 +250,8 @@ msgid ""
|
|||||||
"shown in the switcher. Otherwise, all applications are included."
|
"shown in the switcher. Otherwise, all applications are included."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"যদি সত্য, কেৱল বৰ্তমান কাৰ্য্যস্থানক উইন্ডো থকা এপ্লিকেচনসমূক চুইচাৰত দেখুৱা "
|
"যদি সত্য, কেৱল বৰ্তমান কাৰ্য্যস্থানক উইন্ডো থকা এপ্লিকেচনসমূক চুইচাৰত দেখুৱা "
|
||||||
"হব। নহলে, সকলো এপ্লিকেচন অন্তৰ্ভুক্ত কৰা হয়।"
|
"হব। নহলে, "
|
||||||
|
"সকলো এপ্লিকেচন অন্তৰ্ভুক্ত কৰা হয়।"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:34
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:34
|
||||||
msgid "The application icon mode."
|
msgid "The application icon mode."
|
||||||
@ -271,7 +274,8 @@ msgid ""
|
|||||||
"Otherwise, all windows are included."
|
"Otherwise, all windows are included."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"যদি সত্য, কেৱল বৰ্তমান কাৰ্য্যস্থানৰ পৰা উইন্ডোসমূহক চুইচাৰত দেখুৱা হব। নহলে, "
|
"যদি সত্য, কেৱল বৰ্তমান কাৰ্য্যস্থানৰ পৰা উইন্ডোসমূহক চুইচাৰত দেখুৱা হব। নহলে, "
|
||||||
"সকলো উইন্ডো অন্তৰ্ভুক্ত কৰা হব।"
|
"সকলো "
|
||||||
|
"উইন্ডো অন্তৰ্ভুক্ত কৰা হব।"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:37
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:37
|
||||||
msgid "Attach modal dialog to the parent window"
|
msgid "Attach modal dialog to the parent window"
|
||||||
@ -303,18 +307,17 @@ msgstr ""
|
|||||||
msgid "Captive Portal"
|
msgid "Captive Portal"
|
||||||
msgstr "কেপটিভ পৰ্টেল"
|
msgstr "কেপটিভ পৰ্টেল"
|
||||||
|
|
||||||
#: ../js/extensionPrefs/main.js:127
|
#: ../js/extensionPrefs/main.js:123
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "There was an error loading the preferences dialog for %s:"
|
msgid "There was an error loading the preferences dialog for %s:"
|
||||||
msgstr "%s ৰ বাবে পছন্দসমূহ ডাইলগ ল'ড কৰোতে এটা ত্ৰুটি হৈছিল:"
|
msgstr "%s ৰ বাবে পছন্দসমূহ ডাইলগ ল'ড কৰোতে এটা ত্ৰুটি হৈছিল:"
|
||||||
|
|
||||||
#: ../js/extensionPrefs/main.js:159
|
#: ../js/extensionPrefs/main.js:155
|
||||||
#| msgid "Configure GNOME Shell Extensions"
|
|
||||||
msgid "GNOME Shell Extensions"
|
msgid "GNOME Shell Extensions"
|
||||||
msgstr "GNOME শ্বেল সম্প্ৰসাৰনসমূহ"
|
msgstr "GNOME শ্বেল সম্প্ৰসাৰনসমূহ"
|
||||||
|
|
||||||
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:143
|
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:143
|
||||||
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:429
|
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:452
|
||||||
#: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399
|
#: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399
|
||||||
#: ../js/ui/status/network.js:915
|
#: ../js/ui/status/network.js:915
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
@ -377,46 +380,44 @@ msgstr "কমান্ড বিশ্লেষন কৰিব নোৱাৰ
|
|||||||
msgid "Execution of “%s” failed:"
|
msgid "Execution of “%s” failed:"
|
||||||
msgstr "“%s” ৰ প্ৰেৰণ ব্যৰ্থ হল:"
|
msgstr "“%s” ৰ প্ৰেৰণ ব্যৰ্থ হল:"
|
||||||
|
|
||||||
#: ../js/portalHelper/main.js:84
|
#: ../js/portalHelper/main.js:85
|
||||||
#| msgid "Authentication Required"
|
|
||||||
msgid "Web Authentication Redirect"
|
msgid "Web Authentication Redirect"
|
||||||
msgstr "ৱেব প্ৰমাণীকৰণৰ পুনৰনিৰ্দেশ"
|
msgstr "ৱেব প্ৰমাণীকৰণৰ পুনৰনিৰ্দেশ"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:659
|
#: ../js/ui/appDisplay.js:772
|
||||||
msgid "Frequently used applications will appear here"
|
msgid "Frequently used applications will appear here"
|
||||||
msgstr "সঘনে ব্যৱহাৰ কৰা এপ্লিকেচনসমূহ ইয়াত উপস্থিত হব"
|
msgstr "সঘনে ব্যৱহাৰ কৰা এপ্লিকেচনসমূহ ইয়াত উপস্থিত হব"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:770
|
#: ../js/ui/appDisplay.js:883
|
||||||
msgid "Frequent"
|
msgid "Frequent"
|
||||||
msgstr "সঘন"
|
msgstr "সঘন"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:777
|
#: ../js/ui/appDisplay.js:890
|
||||||
msgid "All"
|
msgid "All"
|
||||||
msgstr "সকলো"
|
msgstr "সকলো"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1649
|
#: ../js/ui/appDisplay.js:1789
|
||||||
msgid "New Window"
|
msgid "New Window"
|
||||||
msgstr "নতুন উইন্ডো"
|
msgstr "নতুন উইন্ডো"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1672 ../js/ui/dash.js:285
|
#: ../js/ui/appDisplay.js:1815 ../js/ui/dash.js:285
|
||||||
msgid "Remove from Favorites"
|
msgid "Remove from Favorites"
|
||||||
msgstr "পছন্দৰ পৰা আতৰাওক"
|
msgstr "পছন্দৰ পৰা আতৰাওক"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1678
|
#: ../js/ui/appDisplay.js:1821
|
||||||
msgid "Add to Favorites"
|
msgid "Add to Favorites"
|
||||||
msgstr "পছন্দলে যোগ কৰক"
|
msgstr "পছন্দলে যোগ কৰক"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1687
|
#: ../js/ui/appDisplay.js:1830
|
||||||
#| msgid "Show Text"
|
|
||||||
msgid "Show Details"
|
msgid "Show Details"
|
||||||
msgstr "বিৱৰণসমূহ দেখুৱাওক"
|
msgstr "বিৱৰণসমূহ দেখুৱাওক"
|
||||||
|
|
||||||
#: ../js/ui/appFavorites.js:122
|
#: ../js/ui/appFavorites.js:124
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s has been added to your favorites."
|
msgid "%s has been added to your favorites."
|
||||||
msgstr "%s ক আপোনাৰ পছন্দলে যোগ কৰা হৈছে।"
|
msgstr "%s ক আপোনাৰ পছন্দলে যোগ কৰা হৈছে।"
|
||||||
|
|
||||||
#: ../js/ui/appFavorites.js:156
|
#: ../js/ui/appFavorites.js:158
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s has been removed from your favorites."
|
msgid "%s has been removed from your favorites."
|
||||||
msgstr "%s ক আপোনাৰ পছন্দৰ পৰা আতৰোৱা হৈছে।"
|
msgstr "%s ক আপোনাৰ পছন্দৰ পৰা আতৰোৱা হৈছে।"
|
||||||
@ -608,11 +609,11 @@ msgstr "%s ৰ সৈতে খোলক"
|
|||||||
msgid "Eject"
|
msgid "Eject"
|
||||||
msgstr "উলিৱাওক"
|
msgstr "উলিৱাওক"
|
||||||
|
|
||||||
#: ../js/ui/components/keyring.js:93 ../js/ui/components/polkitAgent.js:285
|
#: ../js/ui/components/keyring.js:94 ../js/ui/components/polkitAgent.js:285
|
||||||
msgid "Password:"
|
msgid "Password:"
|
||||||
msgstr "পাছৱৰ্ড:"
|
msgstr "পাছৱৰ্ড:"
|
||||||
|
|
||||||
#: ../js/ui/components/keyring.js:113
|
#: ../js/ui/components/keyring.js:120
|
||||||
msgid "Type again:"
|
msgid "Type again:"
|
||||||
msgstr "আকৌ টাইপ কৰক:"
|
msgstr "আকৌ টাইপ কৰক:"
|
||||||
|
|
||||||
@ -655,8 +656,7 @@ msgid ""
|
|||||||
"Passwords or encryption keys are required to access the wireless network "
|
"Passwords or encryption keys are required to access the wireless network "
|
||||||
"“%s”."
|
"“%s”."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"বেতাঁৰ নেটৱৰ্ক “%s” অভিগম কৰিবলে পাছৱৰ্ডসমূহ অথবা ইনক্ৰিপষণ কি'সমূহৰ "
|
"বেতাঁৰ নেটৱৰ্ক “%s” অভিগম কৰিবলে পাছৱৰ্ডসমূহ অথবা ইনক্ৰিপষণ কি'সমূহৰ প্ৰয়োজন।"
|
||||||
"প্ৰয়োজন।"
|
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:323
|
#: ../js/ui/components/networkAgent.js:323
|
||||||
msgid "Wired 802.1X authentication"
|
msgid "Wired 802.1X authentication"
|
||||||
@ -736,89 +736,77 @@ msgid "Mute"
|
|||||||
msgstr "মোন কৰক"
|
msgstr "মোন কৰক"
|
||||||
|
|
||||||
#. Translators: Time in 24h format */
|
#. Translators: Time in 24h format */
|
||||||
#: ../js/ui/components/telepathyClient.js:957
|
#: ../js/ui/components/telepathyClient.js:953
|
||||||
#| msgctxt "event list time"
|
|
||||||
#| msgid "%H∶%M"
|
|
||||||
msgid "%H∶%M"
|
msgid "%H∶%M"
|
||||||
msgstr "%H∶%M"
|
msgstr "%H∶%M"
|
||||||
|
|
||||||
#. Translators: this is the word "Yesterday" followed by a
|
#. Translators: this is the word "Yesterday" followed by a
|
||||||
#. time string in 24h format. i.e. "Yesterday, 14:30" */
|
#. time string in 24h format. i.e. "Yesterday, 14:30" */
|
||||||
#: ../js/ui/components/telepathyClient.js:964
|
#: ../js/ui/components/telepathyClient.js:960
|
||||||
#| msgid "<b>Yesterday</b>, <b>%H:%M</b>"
|
|
||||||
msgid "Yesterday, %H∶%M"
|
msgid "Yesterday, %H∶%M"
|
||||||
msgstr "যোৱাকালী, %H∶%M"
|
msgstr "যোৱাকালী, %H∶%M"
|
||||||
|
|
||||||
#. Translators: this is the week day name followed by a time
|
#. Translators: this is the week day name followed by a time
|
||||||
#. string in 24h format. i.e. "Monday, 14:30" */
|
#. string in 24h format. i.e. "Monday, 14:30" */
|
||||||
#: ../js/ui/components/telepathyClient.js:971
|
#: ../js/ui/components/telepathyClient.js:967
|
||||||
#| msgctxt "event list time"
|
|
||||||
#| msgid "%H∶%M"
|
|
||||||
msgid "%A, %H∶%M"
|
msgid "%A, %H∶%M"
|
||||||
msgstr "%A, %H∶%M"
|
msgstr "%A, %H∶%M"
|
||||||
|
|
||||||
#. Translators: this is the month name and day number
|
#. Translators: this is the month name and day number
|
||||||
#. followed by a time string in 24h format.
|
#. followed by a time string in 24h format.
|
||||||
#. i.e. "May 25, 14:30" */
|
#. i.e. "May 25, 14:30" */
|
||||||
#: ../js/ui/components/telepathyClient.js:978
|
#: ../js/ui/components/telepathyClient.js:974
|
||||||
#| msgctxt "event list time"
|
|
||||||
#| msgid "%H∶%M"
|
|
||||||
msgid "%B %d, %H∶%M"
|
msgid "%B %d, %H∶%M"
|
||||||
msgstr "%B %d, %H∶%M"
|
msgstr "%B %d, %H∶%M"
|
||||||
|
|
||||||
#. Translators: this is the month name, day number, year
|
#. Translators: this is the month name, day number, year
|
||||||
#. number followed by a time string in 24h format.
|
#. number followed by a time string in 24h format.
|
||||||
#. i.e. "May 25 2012, 14:30" */
|
#. i.e. "May 25 2012, 14:30" */
|
||||||
#: ../js/ui/components/telepathyClient.js:984
|
#: ../js/ui/components/telepathyClient.js:980
|
||||||
msgid "%B %d %Y, %H∶%M"
|
msgid "%B %d %Y, %H∶%M"
|
||||||
msgstr "%B %d %Y, %H∶%M"
|
msgstr "%B %d %Y, %H∶%M"
|
||||||
|
|
||||||
#. Translators: Time in 24h format */
|
#. Translators: Time in 24h format */
|
||||||
#: ../js/ui/components/telepathyClient.js:990
|
#: ../js/ui/components/telepathyClient.js:986
|
||||||
#| msgctxt "event list time"
|
|
||||||
#| msgid "%l∶%M %p"
|
|
||||||
msgid "%l∶%M %p"
|
msgid "%l∶%M %p"
|
||||||
msgstr "%l∶%M %p"
|
msgstr "%l∶%M %p"
|
||||||
|
|
||||||
#. Translators: this is the word "Yesterday" followed by a
|
#. Translators: this is the word "Yesterday" followed by a
|
||||||
#. time string in 12h format. i.e. "Yesterday, 2:30 pm" */
|
#. time string in 12h format. i.e. "Yesterday, 2:30 pm" */
|
||||||
#: ../js/ui/components/telepathyClient.js:997
|
#: ../js/ui/components/telepathyClient.js:993
|
||||||
msgid "Yesterday, %l∶%M %p"
|
msgid "Yesterday, %l∶%M %p"
|
||||||
msgstr "যোৱাকালী, %l∶%M %p"
|
msgstr "যোৱাকালী, %l∶%M %p"
|
||||||
|
|
||||||
#. Translators: this is the week day name followed by a time
|
#. Translators: this is the week day name followed by a time
|
||||||
#. string in 12h format. i.e. "Monday, 2:30 pm" */
|
#. string in 12h format. i.e. "Monday, 2:30 pm" */
|
||||||
#: ../js/ui/components/telepathyClient.js:1004
|
#: ../js/ui/components/telepathyClient.js:1000
|
||||||
#| msgid "%a %l:%M %p"
|
|
||||||
msgid "%A, %l∶%M %p"
|
msgid "%A, %l∶%M %p"
|
||||||
msgstr "%A, %l∶%M %p"
|
msgstr "%A, %l∶%M %p"
|
||||||
|
|
||||||
#. Translators: this is the month name and day number
|
#. Translators: this is the month name and day number
|
||||||
#. followed by a time string in 12h format.
|
#. followed by a time string in 12h format.
|
||||||
#. i.e. "May 25, 2:30 pm" */
|
#. i.e. "May 25, 2:30 pm" */
|
||||||
#: ../js/ui/components/telepathyClient.js:1011
|
#: ../js/ui/components/telepathyClient.js:1007
|
||||||
#| msgid "%a %b %e, %l:%M %p"
|
|
||||||
msgid "%B %d, %l∶%M %p"
|
msgid "%B %d, %l∶%M %p"
|
||||||
msgstr "%B %d, %l∶%M %p"
|
msgstr "%B %d, %l∶%M %p"
|
||||||
|
|
||||||
#. Translators: this is the month name, day number, year
|
#. Translators: this is the month name, day number, year
|
||||||
#. number followed by a time string in 12h format.
|
#. number followed by a time string in 12h format.
|
||||||
#. i.e. "May 25 2012, 2:30 pm"*/
|
#. i.e. "May 25 2012, 2:30 pm"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:1017
|
#: ../js/ui/components/telepathyClient.js:1013
|
||||||
#| msgid "%a %b %e, %l:%M %p"
|
|
||||||
msgid "%B %d %Y, %l∶%M %p"
|
msgid "%B %d %Y, %l∶%M %p"
|
||||||
msgstr "%B %d %Y, %l∶%M %p"
|
msgstr "%B %d %Y, %l∶%M %p"
|
||||||
|
|
||||||
#. Translators: this is the other person changing their old IM name to their new
|
#. Translators: this is the other person changing their old IM name to their new
|
||||||
#. IM name. */
|
#. IM name. */
|
||||||
#: ../js/ui/components/telepathyClient.js:1049
|
#: ../js/ui/components/telepathyClient.js:1045
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s is now known as %s"
|
msgid "%s is now known as %s"
|
||||||
msgstr "%s এতিয়া %s হিচাপে জনাজাত"
|
msgstr "%s এতিয়া %s হিচাপে জনাজাত"
|
||||||
|
|
||||||
#. translators: argument is a room name like
|
#. translators: argument is a room name like
|
||||||
#. * room@jabber.org for example. */
|
#. * room@jabber.org for example. */
|
||||||
#: ../js/ui/components/telepathyClient.js:1153
|
#: ../js/ui/components/telepathyClient.js:1149
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Invitation to %s"
|
msgid "Invitation to %s"
|
||||||
msgstr "%s লে নিমন্ত্ৰণ"
|
msgstr "%s লে নিমন্ত্ৰণ"
|
||||||
@ -826,38 +814,38 @@ msgstr "%s লে নিমন্ত্ৰণ"
|
|||||||
#. translators: first argument is the name of a contact and the second
|
#. translators: first argument is the name of a contact and the second
|
||||||
#. * one the name of a room. "Alice is inviting you to join room@jabber.org
|
#. * one the name of a room. "Alice is inviting you to join room@jabber.org
|
||||||
#. * for example. */
|
#. * for example. */
|
||||||
#: ../js/ui/components/telepathyClient.js:1161
|
#: ../js/ui/components/telepathyClient.js:1157
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s is inviting you to join %s"
|
msgid "%s is inviting you to join %s"
|
||||||
msgstr "%s এ আপোনাক %s ত অংশগ্ৰহণ কৰিবলে আমন্ত্ৰণ জনাইছে"
|
msgstr "%s এ আপোনাক %s ত অংশগ্ৰহণ কৰিবলে আমন্ত্ৰণ জনাইছে"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1163
|
#: ../js/ui/components/telepathyClient.js:1159
|
||||||
#: ../js/ui/components/telepathyClient.js:1198
|
#: ../js/ui/components/telepathyClient.js:1194
|
||||||
#: ../js/ui/components/telepathyClient.js:1232
|
#: ../js/ui/components/telepathyClient.js:1228
|
||||||
#: ../js/ui/components/telepathyClient.js:1290
|
#: ../js/ui/components/telepathyClient.js:1286
|
||||||
msgid "Decline"
|
msgid "Decline"
|
||||||
msgstr "নাকচ কৰক"
|
msgstr "নাকচ কৰক"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1169
|
#: ../js/ui/components/telepathyClient.js:1165
|
||||||
#: ../js/ui/components/telepathyClient.js:1238
|
#: ../js/ui/components/telepathyClient.js:1234
|
||||||
#: ../js/ui/components/telepathyClient.js:1295
|
#: ../js/ui/components/telepathyClient.js:1291
|
||||||
msgid "Accept"
|
msgid "Accept"
|
||||||
msgstr "গ্ৰহন কৰক"
|
msgstr "গ্ৰহন কৰক"
|
||||||
|
|
||||||
#. translators: argument is a contact name like Alice for example. */
|
#. translators: argument is a contact name like Alice for example. */
|
||||||
#: ../js/ui/components/telepathyClient.js:1188
|
#: ../js/ui/components/telepathyClient.js:1184
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Video call from %s"
|
msgid "Video call from %s"
|
||||||
msgstr "%s ৰ পৰা ভিডিঅ' কল"
|
msgstr "%s ৰ পৰা ভিডিঅ' কল"
|
||||||
|
|
||||||
#. translators: argument is a contact name like Alice for example. */
|
#. translators: argument is a contact name like Alice for example. */
|
||||||
#: ../js/ui/components/telepathyClient.js:1191
|
#: ../js/ui/components/telepathyClient.js:1187
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Call from %s"
|
msgid "Call from %s"
|
||||||
msgstr "%s ৰ পৰা কল"
|
msgstr "%s ৰ পৰা কল"
|
||||||
|
|
||||||
#. translators: this is a button label (verb), not a noun */
|
#. translators: this is a button label (verb), not a noun */
|
||||||
#: ../js/ui/components/telepathyClient.js:1205
|
#: ../js/ui/components/telepathyClient.js:1201
|
||||||
msgid "Answer"
|
msgid "Answer"
|
||||||
msgstr "উত্তৰ দিয়ক"
|
msgstr "উত্তৰ দিয়ক"
|
||||||
|
|
||||||
@ -866,110 +854,110 @@ msgstr "উত্তৰ দিয়ক"
|
|||||||
#. * file name. The string will be something
|
#. * file name. The string will be something
|
||||||
#. * like: "Alice is sending you test.ogg"
|
#. * like: "Alice is sending you test.ogg"
|
||||||
#. */
|
#. */
|
||||||
#: ../js/ui/components/telepathyClient.js:1226
|
#: ../js/ui/components/telepathyClient.js:1222
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s is sending you %s"
|
msgid "%s is sending you %s"
|
||||||
msgstr "%s এ আপোনাক %s পঠাই আছে"
|
msgstr "%s এ আপোনাক %s পঠাই আছে"
|
||||||
|
|
||||||
#. To translators: The parameter is the contact's alias */
|
#. To translators: The parameter is the contact's alias */
|
||||||
#: ../js/ui/components/telepathyClient.js:1255
|
#: ../js/ui/components/telepathyClient.js:1251
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s would like permission to see when you are online"
|
msgid "%s would like permission to see when you are online"
|
||||||
msgstr "আপুনি কেতিয়া অনলাইন আছে চাবলে %s এ অনুমতি বিচাৰিব"
|
msgstr "আপুনি কেতিয়া অনলাইন আছে চাবলে %s এ অনুমতি বিচাৰিব"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1341
|
#: ../js/ui/components/telepathyClient.js:1337
|
||||||
msgid "Network error"
|
msgid "Network error"
|
||||||
msgstr "নেটৱৰ্ক ত্ৰুটি"
|
msgstr "নেটৱৰ্ক ত্ৰুটি"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1343
|
#: ../js/ui/components/telepathyClient.js:1339
|
||||||
msgid "Authentication failed"
|
msgid "Authentication failed"
|
||||||
msgstr "প্ৰমাণীকৰণ ব্যৰ্থ"
|
msgstr "প্ৰমাণীকৰণ ব্যৰ্থ"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1345
|
#: ../js/ui/components/telepathyClient.js:1341
|
||||||
msgid "Encryption error"
|
msgid "Encryption error"
|
||||||
msgstr "ইনক্ৰিপষণ ত্ৰুটি"
|
msgstr "ইনক্ৰিপষণ ত্ৰুটি"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1347
|
#: ../js/ui/components/telepathyClient.js:1343
|
||||||
msgid "Certificate not provided"
|
msgid "Certificate not provided"
|
||||||
msgstr "প্ৰমাণপত্ৰ প্ৰদান কৰা হোৱা নাই"
|
msgstr "প্ৰমাণপত্ৰ প্ৰদান কৰা হোৱা নাই"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1349
|
#: ../js/ui/components/telepathyClient.js:1345
|
||||||
msgid "Certificate untrusted"
|
msgid "Certificate untrusted"
|
||||||
msgstr "প্ৰমাণপত্ৰক ভৰষা কৰিব নোৱাৰি"
|
msgstr "প্ৰমাণপত্ৰক ভৰষা কৰিব নোৱাৰি"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1351
|
#: ../js/ui/components/telepathyClient.js:1347
|
||||||
msgid "Certificate expired"
|
msgid "Certificate expired"
|
||||||
msgstr "প্ৰমাণপত্ৰৰ অৱসান ঘটিছে"
|
msgstr "প্ৰমাণপত্ৰৰ অৱসান ঘটিছে"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1353
|
#: ../js/ui/components/telepathyClient.js:1349
|
||||||
msgid "Certificate not activated"
|
msgid "Certificate not activated"
|
||||||
msgstr "প্ৰমাণপত্ৰ সক্ৰিয় কৰা হোৱা নাই"
|
msgstr "প্ৰমাণপত্ৰ সক্ৰিয় কৰা হোৱা নাই"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1355
|
#: ../js/ui/components/telepathyClient.js:1351
|
||||||
msgid "Certificate hostname mismatch"
|
msgid "Certificate hostname mismatch"
|
||||||
msgstr "প্ৰমাণপত্ৰ হস্টনাম অমিল"
|
msgstr "প্ৰমাণপত্ৰ হস্টনাম অমিল"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1357
|
#: ../js/ui/components/telepathyClient.js:1353
|
||||||
msgid "Certificate fingerprint mismatch"
|
msgid "Certificate fingerprint mismatch"
|
||||||
msgstr "প্ৰমাণপত্ৰ ফিংগাৰপ্ৰিন্ট অমিল"
|
msgstr "প্ৰমাণপত্ৰ ফিংগাৰপ্ৰিণ্ট অমিল"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1359
|
#: ../js/ui/components/telepathyClient.js:1355
|
||||||
msgid "Certificate self-signed"
|
msgid "Certificate self-signed"
|
||||||
msgstr "প্ৰমাণপত্ৰ স্ব-স্বাক্ষৰীত"
|
msgstr "প্ৰমাণপত্ৰ স্ব-স্বাক্ষৰীত"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1361
|
#: ../js/ui/components/telepathyClient.js:1357
|
||||||
msgid "Status is set to offline"
|
msgid "Status is set to offline"
|
||||||
msgstr "অৱস্থা অফলাইনলে সংহতি কৰা হৈছে"
|
msgstr "অৱস্থা অফলাইনলে সংহতি কৰা হৈছে"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1363
|
#: ../js/ui/components/telepathyClient.js:1359
|
||||||
msgid "Encryption is not available"
|
msgid "Encryption is not available"
|
||||||
msgstr "ইনক্ৰিপষণ উপলব্ধ নহয়"
|
msgstr "ইনক্ৰিপষণ উপলব্ধ নহয়"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1365
|
#: ../js/ui/components/telepathyClient.js:1361
|
||||||
msgid "Certificate is invalid"
|
msgid "Certificate is invalid"
|
||||||
msgstr "প্ৰমাণপত্ৰ অবৈধ"
|
msgstr "প্ৰমাণপত্ৰ অবৈধ"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1367
|
#: ../js/ui/components/telepathyClient.js:1363
|
||||||
msgid "Connection has been refused"
|
msgid "Connection has been refused"
|
||||||
msgstr "সংযোগ নাকচ কৰা হৈছে"
|
msgstr "সংযোগ নাকচ কৰা হৈছে"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1369
|
#: ../js/ui/components/telepathyClient.js:1365
|
||||||
msgid "Connection can't be established"
|
msgid "Connection can't be established"
|
||||||
msgstr "সংযোগ স্থাপন কৰিব নোৱাৰি"
|
msgstr "সংযোগ স্থাপন কৰিব নোৱাৰি"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1371
|
#: ../js/ui/components/telepathyClient.js:1367
|
||||||
msgid "Connection has been lost"
|
msgid "Connection has been lost"
|
||||||
msgstr "সংযোগ হেৰাইছে"
|
msgstr "সংযোগ হেৰাইছে"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1373
|
#: ../js/ui/components/telepathyClient.js:1369
|
||||||
msgid "This account is already connected to the server"
|
msgid "This account is already connected to the server"
|
||||||
msgstr "এই একাওন্ট ইতিমধ্যে চাৰ্ভাৰৰ সৈতে সংযোগিত"
|
msgstr "এই একাওণ্ট ইতিমধ্যে চাৰ্ভাৰৰ সৈতে সংযোগিত"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1375
|
#: ../js/ui/components/telepathyClient.js:1371
|
||||||
msgid ""
|
msgid ""
|
||||||
"Connection has been replaced by a new connection using the same resource"
|
"Connection has been replaced by a new connection using the same resource"
|
||||||
msgstr "সংযোগক একে সম্পদ ব্যৱহাৰ কৰি এটা নতুন সংযোগৰে প্ৰতিস্থাপন কৰা হৈছে"
|
msgstr "সংযোগক একে সম্পদ ব্যৱহাৰ কৰি এটা নতুন সংযোগৰে প্ৰতিস্থাপন কৰা হৈছে"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1377
|
#: ../js/ui/components/telepathyClient.js:1373
|
||||||
msgid "The account already exists on the server"
|
msgid "The account already exists on the server"
|
||||||
msgstr "একাওন্ট ইতিমধ্যে চাৰ্ভাৰত উপস্থিত"
|
msgstr "একাওণ্ট ইতিমধ্যে চাৰ্ভাৰত উপস্থিত"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1379
|
#: ../js/ui/components/telepathyClient.js:1375
|
||||||
msgid "Server is currently too busy to handle the connection"
|
msgid "Server is currently too busy to handle the connection"
|
||||||
msgstr "চাৰ্ভাৰ সংযোগ ব্যৱস্থাপনা কৰিবলে বৰ্তমানে অতি ব্যস্ত"
|
msgstr "চাৰ্ভাৰ সংযোগ ব্যৱস্থাপনা কৰিবলে বৰ্তমানে অতি ব্যস্ত"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1381
|
#: ../js/ui/components/telepathyClient.js:1377
|
||||||
msgid "Certificate has been revoked"
|
msgid "Certificate has been revoked"
|
||||||
msgstr "প্ৰমাণপত্ৰ প্ৰত্যাহাৰ কৰা হৈছে"
|
msgstr "প্ৰমাণপত্ৰ প্ৰত্যাহাৰ কৰা হৈছে"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1383
|
#: ../js/ui/components/telepathyClient.js:1379
|
||||||
msgid ""
|
msgid ""
|
||||||
"Certificate uses an insecure cipher algorithm or is cryptographically weak"
|
"Certificate uses an insecure cipher algorithm or is cryptographically weak"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"প্ৰমাণপত্ৰয় এটা অসুৰক্ষিত চিফাৰ এলগৰিথম ব্যৱহাৰ কৰে অথবা ক্ৰিপ্টোগ্ৰাফিয়ভাৱে "
|
"প্ৰমাণপত্ৰয় এটা অসুৰক্ষিত চিফাৰ এলগৰিথম ব্যৱহাৰ কৰে অথবা ক্ৰিপ্টোগ্ৰাফিয়ভাৱে "
|
||||||
"দুৰ্বল"
|
"দুৰ্বল"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1385
|
#: ../js/ui/components/telepathyClient.js:1381
|
||||||
msgid ""
|
msgid ""
|
||||||
"The length of the server certificate, or the depth of the server certificate "
|
"The length of the server certificate, or the depth of the server certificate "
|
||||||
"chain, exceed the limits imposed by the cryptography library"
|
"chain, exceed the limits imposed by the cryptography library"
|
||||||
@ -978,26 +966,26 @@ msgstr ""
|
|||||||
"ক্ৰিপ্টোগ্ৰাফী "
|
"ক্ৰিপ্টোগ্ৰাফী "
|
||||||
"লাইব্ৰেৰীয়ে প্ৰণয়ন কৰা সীমাসমূহত অতিক্ৰম কৰে"
|
"লাইব্ৰেৰীয়ে প্ৰণয়ন কৰা সীমাসমূহত অতিক্ৰম কৰে"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1387
|
#: ../js/ui/components/telepathyClient.js:1383
|
||||||
msgid "Internal error"
|
msgid "Internal error"
|
||||||
msgstr "অভ্যন্তৰীক ত্ৰুটি"
|
msgstr "অভ্যন্তৰীক ত্ৰুটি"
|
||||||
|
|
||||||
#. translators: argument is the account name, like
|
#. translators: argument is the account name, like
|
||||||
#. * name@jabber.org for example. */
|
#. * name@jabber.org for example. */
|
||||||
#: ../js/ui/components/telepathyClient.js:1397
|
#: ../js/ui/components/telepathyClient.js:1393
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Unable to connect to %s"
|
msgid "Unable to connect to %s"
|
||||||
msgstr "%s ৰ সৈতে সংযোগ কৰিবলে অক্ষম"
|
msgstr "%s ৰ সৈতে সংযোগ কৰিবলে অক্ষম"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1402
|
#: ../js/ui/components/telepathyClient.js:1398
|
||||||
msgid "View account"
|
msgid "View account"
|
||||||
msgstr "একাওন্ট দৰ্শন কৰক"
|
msgstr "একাওণ্ট দৰ্শন কৰক"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1439
|
#: ../js/ui/components/telepathyClient.js:1435
|
||||||
msgid "Unknown reason"
|
msgid "Unknown reason"
|
||||||
msgstr "অজ্ঞাত কাৰণ"
|
msgstr "অজ্ঞাত কাৰণ"
|
||||||
|
|
||||||
#: ../js/ui/ctrlAltTab.js:29 ../js/ui/viewSelector.js:228
|
#: ../js/ui/ctrlAltTab.js:29 ../js/ui/viewSelector.js:154
|
||||||
msgid "Windows"
|
msgid "Windows"
|
||||||
msgstr "উইন্ডোসমূহ"
|
msgstr "উইন্ডোসমূহ"
|
||||||
|
|
||||||
@ -1028,86 +1016,86 @@ msgstr "তাৰিখ আৰু সময সংহতিসমূহ"
|
|||||||
msgid "%A %B %e, %Y"
|
msgid "%A %B %e, %Y"
|
||||||
msgstr "%A %B %e, %Y"
|
msgstr "%A %B %e, %Y"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:66
|
#: ../js/ui/endSessionDialog.js:64
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Log Out %s"
|
msgid "Log Out %s"
|
||||||
msgstr "%s ক লগ আউট কৰক"
|
msgstr "%s ক লগ আউট কৰক"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:67
|
#: ../js/ui/endSessionDialog.js:65
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Log Out"
|
msgid "Log Out"
|
||||||
msgstr "লগ আউট কৰক"
|
msgstr "লগ আউট কৰক"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:69
|
#: ../js/ui/endSessionDialog.js:67
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s will be logged out automatically in %d second."
|
msgid "%s will be logged out automatically in %d second."
|
||||||
msgid_plural "%s will be logged out automatically in %d seconds."
|
msgid_plural "%s will be logged out automatically in %d seconds."
|
||||||
msgstr[0] "%s স্বচালিতভাৱে %d ছেকেণ্ডৰ পিছত লগ আউট হৈ যাব।"
|
msgstr[0] "%s স্বচালিতভাৱে %d ছেকেণ্ডৰ পিছত লগ আউট হৈ যাব।"
|
||||||
msgstr[1] "%s স্বচালিতভাৱে %d ছেকেণ্ডৰ পিছত লগ আউট হৈ যাব।"
|
msgstr[1] "%s স্বচালিতভাৱে %d ছেকেণ্ডৰ পিছত লগ আউট হৈ যাব।"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:74
|
#: ../js/ui/endSessionDialog.js:72
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "You will be logged out automatically in %d second."
|
msgid "You will be logged out automatically in %d second."
|
||||||
msgid_plural "You will be logged out automatically in %d seconds."
|
msgid_plural "You will be logged out automatically in %d seconds."
|
||||||
msgstr[0] "আপুনি স্বচালিতভাৱে %d ছেকেণ্ড পিছত লগ আউট হৈ যাব।"
|
msgstr[0] "আপুনি স্বচালিতভাৱে %d ছেকেণ্ড পিছত লগ আউট হৈ যাব।"
|
||||||
msgstr[1] "আপুনি স্বচালিতভাৱে %d ছেকেণ্ড পিছত লগ আউট হৈ যাব।"
|
msgstr[1] "আপুনি স্বচালিতভাৱে %d ছেকেণ্ড পিছত লগ আউট হৈ যাব।"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:80
|
#: ../js/ui/endSessionDialog.js:78
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Log Out"
|
msgid "Log Out"
|
||||||
msgstr "লগ আউট কৰক"
|
msgstr "লগ আউট কৰক"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:86
|
#: ../js/ui/endSessionDialog.js:84
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Power Off"
|
msgid "Power Off"
|
||||||
msgstr "বন্ধ কৰক"
|
msgstr "বন্ধ কৰক"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:87
|
#: ../js/ui/endSessionDialog.js:85
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Install Updates & Power Off"
|
msgid "Install Updates & Power Off"
|
||||||
msgstr "আপডেইটসমূহ ইনস্টল কৰি চিস্টেম বন্ধ কৰক"
|
msgstr "আপডেইটসমূহ ইনস্টল কৰি চিস্টেম বন্ধ কৰক"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:89
|
#: ../js/ui/endSessionDialog.js:87
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "The system will power off automatically in %d second."
|
msgid "The system will power off automatically in %d second."
|
||||||
msgid_plural "The system will power off automatically in %d seconds."
|
msgid_plural "The system will power off automatically in %d seconds."
|
||||||
msgstr[0] "চিস্টেম %d ছেকেণ্ড পিছত স্বচালিতভাৱে বন্ধ কৰক হব। "
|
msgstr[0] "চিস্টেম %d ছেকেণ্ড পিছত স্বচালিতভাৱে বন্ধ কৰক হব। "
|
||||||
msgstr[1] "চিস্টেম %d ছেকেণ্ডৰ পিছত স্বচালিতভাৱে বন্ধ হব। "
|
msgstr[1] "চিস্টেম %d ছেকেণ্ডৰ পিছত স্বচালিতভাৱে বন্ধ হব। "
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:93
|
#: ../js/ui/endSessionDialog.js:91
|
||||||
msgctxt "checkbox"
|
msgctxt "checkbox"
|
||||||
msgid "Install pending software updates"
|
msgid "Install pending software updates"
|
||||||
msgstr "বাকি থকা চফ্টৱেৰ আপডেইটসমূহ ইনস্টল কৰক"
|
msgstr "বাকি থকা চফ্টৱেৰ আপডেইটসমূহ ইনস্টল কৰক"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:96 ../js/ui/endSessionDialog.js:113
|
#: ../js/ui/endSessionDialog.js:94 ../js/ui/endSessionDialog.js:111
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Restart"
|
msgid "Restart"
|
||||||
msgstr "পুনৰাম্ভ কৰক"
|
msgstr "পুনৰাম্ভ কৰক"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:98
|
#: ../js/ui/endSessionDialog.js:96
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Power Off"
|
msgid "Power Off"
|
||||||
msgstr "বন্ধ কৰক"
|
msgstr "বন্ধ কৰক"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:105
|
#: ../js/ui/endSessionDialog.js:103
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Restart"
|
msgid "Restart"
|
||||||
msgstr "পুনৰাম্ভ কৰক"
|
msgstr "পুনৰাম্ভ কৰক"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:107
|
#: ../js/ui/endSessionDialog.js:105
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "The system will restart automatically in %d second."
|
msgid "The system will restart automatically in %d second."
|
||||||
msgid_plural "The system will restart automatically in %d seconds."
|
msgid_plural "The system will restart automatically in %d seconds."
|
||||||
msgstr[0] "চিস্টেম %d ছেকেণ্ডত স্বচালিতভাৱে পুনৰাম্ভ হব।"
|
msgstr[0] "চিস্টেম %d ছেকেণ্ডত স্বচালিতভাৱে পুনৰাম্ভ হব।"
|
||||||
msgstr[1] "চিস্টেম %d ছেকেণ্ডত স্বচালিতভাৱে পুনৰাম্ভ হব।"
|
msgstr[1] "চিস্টেম %d ছেকেণ্ডত স্বচালিতভাৱে পুনৰাম্ভ হব।"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:121
|
#: ../js/ui/endSessionDialog.js:119
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Restart & Install Updates"
|
msgid "Restart & Install Updates"
|
||||||
msgstr "পুনাৰম্ভ কৰক আৰু আপডেইটসমূহ ইনস্টল কৰক"
|
msgstr "পুনাৰম্ভ কৰক আৰু আপডেইটসমূহ ইনস্টল কৰক"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:123
|
#: ../js/ui/endSessionDialog.js:121
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "The system will automatically restart and install updates in %d second."
|
msgid "The system will automatically restart and install updates in %d second."
|
||||||
msgid_plural ""
|
msgid_plural ""
|
||||||
@ -1117,46 +1105,44 @@ msgstr[0] ""
|
|||||||
msgstr[1] ""
|
msgstr[1] ""
|
||||||
"চিস্টেম %d ছেকেণ্ডত স্বচালিতভাৱে পুনৰাম্ভ হব আৰু আপডেইটসমূহ ইনস্টল কৰিব।"
|
"চিস্টেম %d ছেকেণ্ডত স্বচালিতভাৱে পুনৰাম্ভ হব আৰু আপডেইটসমূহ ইনস্টল কৰিব।"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:129
|
#: ../js/ui/endSessionDialog.js:127
|
||||||
#| msgctxt "button"
|
|
||||||
#| msgid "Restart & Install"
|
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Restart & Install"
|
msgid "Restart & Install"
|
||||||
msgstr "পুনৰাম্ভ কৰক & ইনস্টল কৰক"
|
msgstr "পুনৰাম্ভ কৰক & ইনস্টল কৰক"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:130
|
#: ../js/ui/endSessionDialog.js:128
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Install & Power Off"
|
msgid "Install & Power Off"
|
||||||
msgstr "ইনস্টল কৰক & চিস্টেম বন্ধ কৰক"
|
msgstr "ইনস্টল কৰক & চিস্টেম বন্ধ কৰক"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:131
|
#: ../js/ui/endSessionDialog.js:129
|
||||||
msgctxt "checkbox"
|
msgctxt "checkbox"
|
||||||
msgid "Power off after updates are installed"
|
msgid "Power off after updates are installed"
|
||||||
msgstr "আপডেইটসমূহ ইনস্টল কৰাৰ পিছত চিস্টেম বন্ধ কৰক"
|
msgstr "আপডেইটসমূহ ইনস্টল কৰাৰ পিছত চিস্টেম বন্ধ কৰক"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:315
|
#: ../js/ui/endSessionDialog.js:338
|
||||||
msgid "Running on battery power: please plug in before installing updates."
|
msgid "Running on battery power: please plug in before installing updates."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"বেটাৰি শক্তিত চলি আছে: অনুগ্ৰহ কৰি আপডেইটসমূহ ইনস্টল কৰাৰ আগত চাৰ্জাৰ লগাওক।"
|
"বেটাৰি শক্তিত চলি আছে: অনুগ্ৰহ কৰি আপডেইটসমূহ ইনস্টল কৰাৰ আগত চাৰ্জাৰ লগাওক।"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:332
|
#: ../js/ui/endSessionDialog.js:355
|
||||||
msgid "Some applications are busy or have unsaved work."
|
msgid "Some applications are busy or have unsaved work."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"কিছুমান এপ্লিকেচন ব্যস্ত হব পাৰে অথবা সিহতৰ কিছুমান অসংৰক্ষিত কাৰ্য্য থাকিব "
|
"কিছুমান এপ্লিকেচন ব্যস্ত হব পাৰে অথবা সিহতৰ কিছুমান অসংৰক্ষিত কাৰ্য্য থাকিব "
|
||||||
"পাৰে।"
|
"পাৰে।"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:339
|
#: ../js/ui/endSessionDialog.js:362
|
||||||
msgid "Other users are logged in."
|
msgid "Other users are logged in."
|
||||||
msgstr "অন্য ব্যৱহাৰকাৰীসকল লগ্ড ইন আছে।"
|
msgstr "অন্য ব্যৱহাৰকাৰীসকল লগ্ড ইন আছে।"
|
||||||
|
|
||||||
#. Translators: Remote here refers to a remote session, like a ssh login */
|
#. Translators: Remote here refers to a remote session, like a ssh login */
|
||||||
#: ../js/ui/endSessionDialog.js:619
|
#: ../js/ui/endSessionDialog.js:640
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s (remote)"
|
msgid "%s (remote)"
|
||||||
msgstr "%s (দূৰৱৰ্তী)"
|
msgstr "%s (দূৰৱৰ্তী)"
|
||||||
|
|
||||||
#. Translators: Console here refers to a tty like a VT console */
|
#. Translators: Console here refers to a tty like a VT console */
|
||||||
#: ../js/ui/endSessionDialog.js:622
|
#: ../js/ui/endSessionDialog.js:643
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s (console)"
|
msgid "%s (console)"
|
||||||
msgstr "%s (কনচৌল)"
|
msgstr "%s (কনচৌল)"
|
||||||
@ -1170,7 +1156,7 @@ msgstr "ইনস্টল কৰক"
|
|||||||
msgid "Download and install “%s” from extensions.gnome.org?"
|
msgid "Download and install “%s” from extensions.gnome.org?"
|
||||||
msgstr "extensions.gnome.org ৰ পৰা “%s” ক ডাউনল'ড আৰু ইনস্টল কৰিব নে?"
|
msgstr "extensions.gnome.org ৰ পৰা “%s” ক ডাউনল'ড আৰু ইনস্টল কৰিব নে?"
|
||||||
|
|
||||||
#: ../js/ui/keyboard.js:653 ../js/ui/status/keyboard.js:339
|
#: ../js/ui/keyboard.js:692 ../js/ui/status/keyboard.js:523
|
||||||
msgid "Keyboard"
|
msgid "Keyboard"
|
||||||
msgstr "কিবৰ্ড"
|
msgstr "কিবৰ্ড"
|
||||||
|
|
||||||
@ -1192,8 +1178,8 @@ msgstr "ত্ৰুটিসমূহ লুকুৱাওক"
|
|||||||
msgid "Show Errors"
|
msgid "Show Errors"
|
||||||
msgstr "ত্ৰুটিসমূহ দেখুৱাওক"
|
msgstr "ত্ৰুটিসমূহ দেখুৱাওক"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:716 ../js/ui/status/location.js:62
|
#: ../js/ui/lookingGlass.js:716 ../js/ui/status/location.js:71
|
||||||
#: ../js/ui/status/location.js:164
|
#: ../js/ui/status/location.js:176
|
||||||
msgid "Enabled"
|
msgid "Enabled"
|
||||||
msgstr "সামৰ্থবান কৰা আছে"
|
msgstr "সামৰ্থবান কৰা আছে"
|
||||||
|
|
||||||
@ -1201,7 +1187,7 @@ msgstr "সামৰ্থবান কৰা আছে"
|
|||||||
#. because it's disabled by rfkill (airplane mode) */
|
#. because it's disabled by rfkill (airplane mode) */
|
||||||
#. translators:
|
#. translators:
|
||||||
#. * The device has been disabled
|
#. * The device has been disabled
|
||||||
#: ../js/ui/lookingGlass.js:719 ../js/ui/status/location.js:167
|
#: ../js/ui/lookingGlass.js:719 ../js/ui/status/location.js:179
|
||||||
#: ../js/ui/status/network.js:592 ../src/gvc/gvc-mixer-control.c:1830
|
#: ../js/ui/status/network.js:592 ../src/gvc/gvc-mixer-control.c:1830
|
||||||
msgid "Disabled"
|
msgid "Disabled"
|
||||||
msgstr "অসামৰ্থবান কৰা আছে"
|
msgstr "অসামৰ্থবান কৰা আছে"
|
||||||
@ -1226,39 +1212,39 @@ msgstr "উৎস দৰ্শন কৰক"
|
|||||||
msgid "Web Page"
|
msgid "Web Page"
|
||||||
msgstr "ৱেব পৃষ্ঠা"
|
msgstr "ৱেব পৃষ্ঠা"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1325
|
#: ../js/ui/messageTray.js:1326
|
||||||
msgid "Open"
|
msgid "Open"
|
||||||
msgstr "খোলক"
|
msgstr "খোলক"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1332
|
#: ../js/ui/messageTray.js:1333
|
||||||
msgid "Remove"
|
msgid "Remove"
|
||||||
msgstr "আতৰাওক"
|
msgstr "আতৰাওক"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1629
|
#: ../js/ui/messageTray.js:1630
|
||||||
msgid "Notifications"
|
msgid "Notifications"
|
||||||
msgstr "অধিসূচনাসমূহ"
|
msgstr "অধিসূচনাসমূহ"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1636
|
#: ../js/ui/messageTray.js:1637
|
||||||
msgid "Clear Messages"
|
msgid "Clear Messages"
|
||||||
msgstr "বাৰ্তাসমূহ পৰিষ্কাৰ কৰক"
|
msgstr "বাৰ্তাসমূহ পৰিষ্কাৰ কৰক"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1655
|
#: ../js/ui/messageTray.js:1656
|
||||||
msgid "Notification Settings"
|
msgid "Notification Settings"
|
||||||
msgstr "অধিসূচনা সংহতিসমূহ"
|
msgstr "অধিসূচনা সংহতিসমূহ"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1708
|
#: ../js/ui/messageTray.js:1709
|
||||||
msgid "Tray Menu"
|
msgid "Tray Menu"
|
||||||
msgstr "ট্ৰে মেনু"
|
msgstr "ট্ৰে মেনু"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1925
|
#: ../js/ui/messageTray.js:1926
|
||||||
msgid "No Messages"
|
msgid "No Messages"
|
||||||
msgstr "কোনো বাৰ্তা নাই"
|
msgstr "কোনো বাৰ্তা নাই"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1963
|
#: ../js/ui/messageTray.js:1968
|
||||||
msgid "Message Tray"
|
msgid "Message Tray"
|
||||||
msgstr "বাৰ্তা ট্ৰে"
|
msgstr "বাৰ্তা ট্ৰে"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:2966
|
#: ../js/ui/messageTray.js:2971
|
||||||
msgid "System Information"
|
msgid "System Information"
|
||||||
msgstr "চিস্টেম তথ্য"
|
msgstr "চিস্টেম তথ্য"
|
||||||
|
|
||||||
@ -1286,7 +1272,7 @@ msgstr "অভাৰভিউ"
|
|||||||
#. in the search entry when no search is
|
#. in the search entry when no search is
|
||||||
#. active; it should not exceed ~30
|
#. active; it should not exceed ~30
|
||||||
#. characters. */
|
#. characters. */
|
||||||
#: ../js/ui/overview.js:250
|
#: ../js/ui/overview.js:246
|
||||||
msgid "Type to search…"
|
msgid "Type to search…"
|
||||||
msgstr "সন্ধান কৰিবলে টাইপ কৰক…"
|
msgstr "সন্ধান কৰিবলে টাইপ কৰক…"
|
||||||
|
|
||||||
@ -1304,7 +1290,7 @@ msgstr "কাৰ্য্যসমূহ"
|
|||||||
msgid "Top Bar"
|
msgid "Top Bar"
|
||||||
msgstr "উপৰৰ বাৰ"
|
msgstr "উপৰৰ বাৰ"
|
||||||
|
|
||||||
#: ../js/ui/popupMenu.js:280
|
#: ../js/ui/popupMenu.js:269
|
||||||
msgid "toggle-switch-us"
|
msgid "toggle-switch-us"
|
||||||
msgstr "toggle-switch-us"
|
msgstr "toggle-switch-us"
|
||||||
|
|
||||||
@ -1316,8 +1302,7 @@ msgstr "এটা কমান্ড সুমুৱাওক"
|
|||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr "বন্ধ কৰক"
|
msgstr "বন্ধ কৰক"
|
||||||
|
|
||||||
#: ../js/ui/runDialog.js:273
|
#: ../js/ui/runDialog.js:277
|
||||||
#| msgid "Estimating…"
|
|
||||||
msgid "Restarting…"
|
msgid "Restarting…"
|
||||||
msgstr "পুনাৰম্ভ কৰা হৈছে…"
|
msgstr "পুনাৰম্ভ কৰা হৈছে…"
|
||||||
|
|
||||||
@ -1334,43 +1319,43 @@ msgid_plural "%d new notifications"
|
|||||||
msgstr[0] "%d নতুন অধিসূচনা"
|
msgstr[0] "%d নতুন অধিসূচনা"
|
||||||
msgstr[1] "%d নতুন অধিসূচনাসমূহ"
|
msgstr[1] "%d নতুন অধিসূচনাসমূহ"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:474 ../js/ui/status/system.js:345
|
#: ../js/ui/screenShield.js:472 ../js/ui/status/system.js:345
|
||||||
msgid "Lock"
|
msgid "Lock"
|
||||||
msgstr "লক কৰক"
|
msgstr "লক কৰক"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:708
|
#: ../js/ui/screenShield.js:706
|
||||||
msgid "GNOME needs to lock the screen"
|
msgid "GNOME needs to lock the screen"
|
||||||
msgstr "GNOME এ পৰ্দা লক কৰিব লাগিব"
|
msgstr "GNOME এ পৰ্দা লক কৰিব লাগিব"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:835 ../js/ui/screenShield.js:1306
|
#: ../js/ui/screenShield.js:833 ../js/ui/screenShield.js:1304
|
||||||
msgid "Unable to lock"
|
msgid "Unable to lock"
|
||||||
msgstr "লক কৰিবলে অক্ষম"
|
msgstr "লক কৰিবলে অক্ষম"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:836 ../js/ui/screenShield.js:1307
|
#: ../js/ui/screenShield.js:834 ../js/ui/screenShield.js:1305
|
||||||
msgid "Lock was blocked by an application"
|
msgid "Lock was blocked by an application"
|
||||||
msgstr "লক কাৰ্য্য এটা এপ্লিকেচন দ্বাৰা প্ৰতিৰোধ কৰা হৈছিল"
|
msgstr "লক কাৰ্য্য এটা এপ্লিকেচন দ্বাৰা প্ৰতিৰোধ কৰা হৈছিল"
|
||||||
|
|
||||||
#: ../js/ui/search.js:614
|
#: ../js/ui/search.js:594
|
||||||
msgid "Searching…"
|
msgid "Searching…"
|
||||||
msgstr "সন্ধান কৰা হৈছে…"
|
msgstr "সন্ধান কৰা হৈছে…"
|
||||||
|
|
||||||
#: ../js/ui/search.js:660
|
#: ../js/ui/search.js:596
|
||||||
msgid "No results."
|
msgid "No results."
|
||||||
msgstr "কোনো ফলাফল নাই।"
|
msgstr "কোনো ফলাফল নাই।"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:27
|
#: ../js/ui/shellEntry.js:25
|
||||||
msgid "Copy"
|
msgid "Copy"
|
||||||
msgstr "কপি কৰক"
|
msgstr "কপি কৰক"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:32
|
#: ../js/ui/shellEntry.js:30
|
||||||
msgid "Paste"
|
msgid "Paste"
|
||||||
msgstr "পেইস্ট কৰক"
|
msgstr "পেইস্ট কৰক"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:99
|
#: ../js/ui/shellEntry.js:97
|
||||||
msgid "Show Text"
|
msgid "Show Text"
|
||||||
msgstr "লিখনি দেখুৱাওক"
|
msgstr "লিখনি দেখুৱাওক"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:101
|
#: ../js/ui/shellEntry.js:99
|
||||||
msgid "Hide Text"
|
msgid "Hide Text"
|
||||||
msgstr "লিখনি লুকুৱাওক"
|
msgstr "লিখনি লুকুৱাওক"
|
||||||
|
|
||||||
@ -1456,26 +1441,28 @@ msgstr "সংযুক্ত নহয়"
|
|||||||
msgid "Brightness"
|
msgid "Brightness"
|
||||||
msgstr "উজ্জ্বলতা"
|
msgstr "উজ্জ্বলতা"
|
||||||
|
|
||||||
#: ../js/ui/status/keyboard.js:407
|
#: ../js/ui/status/keyboard.js:547
|
||||||
msgid "Show Keyboard Layout"
|
msgid "Show Keyboard Layout"
|
||||||
msgstr "কিবৰ্ড বিন্যাস দেখুৱাওক"
|
msgstr "কিবৰ্ড বিন্যাস দেখুৱাওক"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:56
|
#: ../js/ui/status/location.js:65
|
||||||
#| msgid "Notifications"
|
|
||||||
msgid "Location"
|
msgid "Location"
|
||||||
msgstr "অবস্থান"
|
msgstr "অবস্থান"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:63 ../js/ui/status/location.js:165
|
#: ../js/ui/status/location.js:72 ../js/ui/status/location.js:177
|
||||||
#| msgid "Disabled"
|
|
||||||
msgid "Disable"
|
msgid "Disable"
|
||||||
msgstr "অসামৰ্থবান কৰক"
|
msgstr "অসামৰ্থবান কৰক"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:164
|
#: ../js/ui/status/location.js:73
|
||||||
|
#| msgid "Power Settings"
|
||||||
|
msgid "Privacy Settings"
|
||||||
|
msgstr "গোপনীয়তা সংহতিসমূহ"
|
||||||
|
|
||||||
|
#: ../js/ui/status/location.js:176
|
||||||
msgid "In Use"
|
msgid "In Use"
|
||||||
msgstr "ব্যৱহৃত"
|
msgstr "ব্যৱহৃত"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:168
|
#: ../js/ui/status/location.js:180
|
||||||
#| msgid "Enabled"
|
|
||||||
msgid "Enable"
|
msgid "Enable"
|
||||||
msgstr "সামৰ্থবান কৰক"
|
msgstr "সামৰ্থবান কৰক"
|
||||||
|
|
||||||
@ -1489,37 +1476,31 @@ msgid "Off"
|
|||||||
msgstr "অফ"
|
msgstr "অফ"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:459
|
#: ../js/ui/status/network.js:459
|
||||||
#| msgid "Connect"
|
|
||||||
msgid "Connected"
|
msgid "Connected"
|
||||||
msgstr "সংযুক্ত"
|
msgstr "সংযুক্ত"
|
||||||
|
|
||||||
#. Translators: this is for network devices that are physically present but are not
|
#. Translators: this is for network devices that are physically present but are not
|
||||||
#. under NetworkManager's control (and thus cannot be used in the menu) */
|
#. under NetworkManager's control (and thus cannot be used in the menu) */
|
||||||
#: ../js/ui/status/network.js:463
|
#: ../js/ui/status/network.js:463
|
||||||
#| msgid "unmanaged"
|
|
||||||
msgid "Unmanaged"
|
msgid "Unmanaged"
|
||||||
msgstr "অব্যৱস্থাপিত"
|
msgstr "অব্যৱস্থাপিত"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:465
|
#: ../js/ui/status/network.js:465
|
||||||
#| msgid "disconnecting..."
|
|
||||||
msgid "Disconnecting"
|
msgid "Disconnecting"
|
||||||
msgstr "বিচ্ছিনিত কৰা হৈছে"
|
msgstr "বিচ্ছিনিত কৰা হৈছে"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:471 ../js/ui/status/network.js:1301
|
#: ../js/ui/status/network.js:471 ../js/ui/status/network.js:1301
|
||||||
#| msgid "Connection"
|
|
||||||
msgid "Connecting"
|
msgid "Connecting"
|
||||||
msgstr "সংযোগ কৰা হৈছে"
|
msgstr "সংযোগ কৰা হৈছে"
|
||||||
|
|
||||||
#. Translators: this is for network connections that require some kind of key or password */
|
#. Translators: this is for network connections that require some kind of key or password */
|
||||||
#: ../js/ui/status/network.js:474
|
#: ../js/ui/status/network.js:474
|
||||||
#| msgid "authentication required"
|
|
||||||
msgid "Authentication required"
|
msgid "Authentication required"
|
||||||
msgstr "প্ৰমাণীকৰণৰ প্ৰয়োজন"
|
msgstr "প্ৰমাণীকৰণৰ প্ৰয়োজন"
|
||||||
|
|
||||||
#. Translators: this is for devices that require some kind of firmware or kernel
|
#. Translators: this is for devices that require some kind of firmware or kernel
|
||||||
#. module, which is missing */
|
#. module, which is missing */
|
||||||
#: ../js/ui/status/network.js:482
|
#: ../js/ui/status/network.js:482
|
||||||
#| msgid "firmware missing"
|
|
||||||
msgid "Firmware missing"
|
msgid "Firmware missing"
|
||||||
msgstr "ফাৰ্মৱেৰ সন্ধানহীন"
|
msgstr "ফাৰ্মৱেৰ সন্ধানহীন"
|
||||||
|
|
||||||
@ -1623,7 +1604,6 @@ msgid "Network Settings"
|
|||||||
msgstr "নেটৱৰ্ক সংহতিসমূহ"
|
msgstr "নেটৱৰ্ক সংহতিসমূহ"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1482
|
#: ../js/ui/status/network.js:1482
|
||||||
#| msgid "Settings"
|
|
||||||
msgid "VPN Settings"
|
msgid "VPN Settings"
|
||||||
msgstr "VPN সংহতিসমূহ"
|
msgstr "VPN সংহতিসমূহ"
|
||||||
|
|
||||||
@ -1717,11 +1697,11 @@ msgstr "অন্য ব্যৱহাৰকাৰী হিচাপে লগ
|
|||||||
msgid "Unlock Window"
|
msgid "Unlock Window"
|
||||||
msgstr "উইন্ডো আনলক কৰক"
|
msgstr "উইন্ডো আনলক কৰক"
|
||||||
|
|
||||||
#: ../js/ui/viewSelector.js:232
|
#: ../js/ui/viewSelector.js:158
|
||||||
msgid "Applications"
|
msgid "Applications"
|
||||||
msgstr "এপ্লিকেচনসমূহ"
|
msgstr "এপ্লিকেচনসমূহ"
|
||||||
|
|
||||||
#: ../js/ui/viewSelector.js:236
|
#: ../js/ui/viewSelector.js:162
|
||||||
msgid "Search"
|
msgid "Search"
|
||||||
msgstr "সন্ধান কৰক"
|
msgstr "সন্ধান কৰক"
|
||||||
|
|
||||||
@ -1818,19 +1798,19 @@ msgstr[1] "%u ইনপুটসমূহ"
|
|||||||
msgid "System Sounds"
|
msgid "System Sounds"
|
||||||
msgstr "চিস্টেম শব্দসমূহ"
|
msgstr "চিস্টেম শব্দসমূহ"
|
||||||
|
|
||||||
#: ../src/main.c:371
|
#: ../src/main.c:373
|
||||||
msgid "Print version"
|
msgid "Print version"
|
||||||
msgstr "প্ৰিন্ট সংস্কৰণ"
|
msgstr "প্ৰিণ্ট সংস্কৰণ"
|
||||||
|
|
||||||
#: ../src/main.c:377
|
#: ../src/main.c:379
|
||||||
msgid "Mode used by GDM for login screen"
|
msgid "Mode used by GDM for login screen"
|
||||||
msgstr "লগিন স্ক্ৰিনৰ বাবে GDM দ্বাৰা ব্যৱহাৰ কৰা অৱস্থা"
|
msgstr "লগিন স্ক্ৰিনৰ বাবে GDM দ্বাৰা ব্যৱহাৰ কৰা অৱস্থা"
|
||||||
|
|
||||||
#: ../src/main.c:383
|
#: ../src/main.c:385
|
||||||
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
||||||
msgstr "লগিন পৰ্দাৰ বাবে এটা বিশেষ অৱস্থা, উদাহৰণস্বৰূপ \"gdm\" ব্যৱহাৰ কৰক"
|
msgstr "লগিন পৰ্দাৰ বাবে এটা বিশেষ অৱস্থা, উদাহৰণস্বৰূপ \"gdm\" ব্যৱহাৰ কৰক"
|
||||||
|
|
||||||
#: ../src/main.c:389
|
#: ../src/main.c:391
|
||||||
msgid "List possible modes"
|
msgid "List possible modes"
|
||||||
msgstr "সম্ভাব্য অৱস্থাসমূহ তালিকাভুক্ত কৰক"
|
msgstr "সম্ভাব্য অৱস্থাসমূহ তালিকাভুক্ত কৰক"
|
||||||
|
|
||||||
@ -2034,7 +2014,7 @@ msgstr "প্ৰমাণীকৰণ ডাইলগ ব্যৱহাৰক
|
|||||||
#~ "সংহিত, অবিকল্পিত পাইপলাইন ব্যৱহাৰ কৰা হব। এইটো বৰ্তমানত 'vp8enc "
|
#~ "সংহিত, অবিকল্পিত পাইপলাইন ব্যৱহাৰ কৰা হব। এইটো বৰ্তমানত 'vp8enc "
|
||||||
#~ "min_quantizer=13 max_quantizer=13 cpu-used=5 deadline=1000000 threads="
|
#~ "min_quantizer=13 max_quantizer=13 cpu-used=5 deadline=1000000 threads="
|
||||||
#~ "%T ! queue ! webmmux' আৰু VP8 কডেক ব্যৱহাৰ কৰি WEBM ত ৰেকৰ্ড কৰে। %T ক "
|
#~ "%T ! queue ! webmmux' আৰু VP8 কডেক ব্যৱহাৰ কৰি WEBM ত ৰেকৰ্ড কৰে। %T ক "
|
||||||
#~ "চিস্টেমত অনুকূলিত থ্ৰেড কাওন্টত এটা অনুমানৰ প্লেইচহল্ডাৰ হিচাপে ব্যৱহাৰ কৰা হয়।"
|
#~ "চিস্টেমত অনুকূলিত থ্ৰেড কাওণ্টত এটা অনুমানৰ প্লেইচহল্ডাৰ হিচাপে ব্যৱহাৰ কৰা হয়।"
|
||||||
|
|
||||||
#~ msgid "File extension used for storing the screencast"
|
#~ msgid "File extension used for storing the screencast"
|
||||||
#~ msgstr "screencast সংৰক্ষণ কৰাৰ কাৰণে লথিপত্ৰ সম্প্ৰসাৰন"
|
#~ msgstr "screencast সংৰক্ষণ কৰাৰ কাৰণে লথিপত্ৰ সম্প্ৰসাৰন"
|
||||||
@ -2317,7 +2297,7 @@ msgstr "প্ৰমাণীকৰণ ডাইলগ ব্যৱহাৰক
|
|||||||
#~ msgstr "চিস্টেম সংহতিসমূহ"
|
#~ msgstr "চিস্টেম সংহতিসমূহ"
|
||||||
|
|
||||||
#~ msgid "Failed to unmount '%s'"
|
#~ msgid "Failed to unmount '%s'"
|
||||||
#~ msgstr "'%s' আনমাউন্ট কৰিবলে ব্যৰ্থ"
|
#~ msgstr "'%s' আনমাউণ্ট কৰিবলে ব্যৰ্থ"
|
||||||
|
|
||||||
#~ msgid "Retry"
|
#~ msgid "Retry"
|
||||||
#~ msgstr "পুনৰ চেষ্টা কৰক"
|
#~ msgstr "পুনৰ চেষ্টা কৰক"
|
||||||
@ -2395,7 +2375,7 @@ msgstr "প্ৰমাণীকৰণ ডাইলগ ব্যৱহাৰক
|
|||||||
#~ msgstr "বন্ধ কৰক"
|
#~ msgstr "বন্ধ কৰক"
|
||||||
|
|
||||||
#~ msgid "Online Accounts"
|
#~ msgid "Online Accounts"
|
||||||
#~ msgstr "অনলাইন একাওন্টসমূহ"
|
#~ msgstr "অনলাইন একাওণ্টসমূহ"
|
||||||
|
|
||||||
#~ msgid "Lock Screen"
|
#~ msgid "Lock Screen"
|
||||||
#~ msgstr "পৰ্দা লক কৰক"
|
#~ msgstr "পৰ্দা লক কৰক"
|
||||||
|
2039
po/bn_IN.po
207
po/fa.po
@ -9,8 +9,8 @@ msgstr ""
|
|||||||
"Project-Id-Version: gnome-shell master\n"
|
"Project-Id-Version: gnome-shell master\n"
|
||||||
"Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?product=gnome-"
|
"Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?product=gnome-"
|
||||||
"shell&keywords=I18N+L10N&component=general\n"
|
"shell&keywords=I18N+L10N&component=general\n"
|
||||||
"POT-Creation-Date: 2014-08-28 07:38+0000\n"
|
"POT-Creation-Date: 2014-10-06 19:42+0000\n"
|
||||||
"PO-Revision-Date: 2014-08-28 20:57+0430\n"
|
"PO-Revision-Date: 2014-10-10 10:51+0330\n"
|
||||||
"Last-Translator: Arash Mousavi <mousavi.arash@gmail.com>\n"
|
"Last-Translator: Arash Mousavi <mousavi.arash@gmail.com>\n"
|
||||||
"Language-Team: Persian <>\n"
|
"Language-Team: Persian <>\n"
|
||||||
"Language: fa\n"
|
"Language: fa\n"
|
||||||
@ -19,7 +19,7 @@ msgstr ""
|
|||||||
"Content-Transfer-Encoding: 8bit\n"
|
"Content-Transfer-Encoding: 8bit\n"
|
||||||
"Plural-Forms: nplurals=2; plural=(n!=1);\n"
|
"Plural-Forms: nplurals=2; plural=(n!=1);\n"
|
||||||
"X-Poedit-SourceCharset: utf-8\n"
|
"X-Poedit-SourceCharset: utf-8\n"
|
||||||
"X-Generator: Gtranslator 2.91.6\n"
|
"X-Generator: Poedit 1.6.9\n"
|
||||||
|
|
||||||
#: ../data/50-gnome-shell-system.xml.in.h:1
|
#: ../data/50-gnome-shell-system.xml.in.h:1
|
||||||
msgid "System"
|
msgid "System"
|
||||||
@ -81,16 +81,10 @@ msgstr ""
|
|||||||
"F2."
|
"F2."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:3
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:3
|
||||||
#| msgid "Uuids of extensions to enable"
|
|
||||||
msgid "UUIDs of extensions to enable"
|
msgid "UUIDs of extensions to enable"
|
||||||
msgstr "شناسههای UUID افزونهها جهت فعالسازی"
|
msgstr "شناسههای UUID افزونهها جهت فعالسازی"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:4
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:4
|
||||||
#| msgid ""
|
|
||||||
#| "GNOME Shell extensions have a uuid property; this key lists extensions "
|
|
||||||
#| "which should be loaded. Any extension that wants to be loaded needs to be "
|
|
||||||
#| "in this list. You can also manipulate this list with the EnableExtension "
|
|
||||||
#| "and DisableExtension DBus methods on org.gnome.Shell."
|
|
||||||
msgid ""
|
msgid ""
|
||||||
"GNOME Shell extensions have a UUID property; this key lists extensions which "
|
"GNOME Shell extensions have a UUID property; this key lists extensions which "
|
||||||
"should be loaded. Any extension that wants to be loaded needs to be in this "
|
"should be loaded. Any extension that wants to be loaded needs to be in this "
|
||||||
@ -143,14 +137,10 @@ msgid "History for the looking glass dialog"
|
|||||||
msgstr "تاریخچه برای نما محاوره شیشهای"
|
msgstr "تاریخچه برای نما محاوره شیشهای"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:13
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:13
|
||||||
#| msgid "Always show the 'Log out' menuitem in the user menu."
|
|
||||||
msgid "Always show the 'Log out' menu item in the user menu."
|
msgid "Always show the 'Log out' menu item in the user menu."
|
||||||
msgstr "همیشه «خروج از سیستم» را در منو کاربر نمایش بده."
|
msgstr "همیشه «خروج از سیستم» را در منو کاربر نمایش بده."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:14
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:14
|
||||||
#| msgid ""
|
|
||||||
#| "This key overrides the automatic hiding of the 'Log out' menuitem in "
|
|
||||||
#| "single-user, single-session situations."
|
|
||||||
msgid ""
|
msgid ""
|
||||||
"This key overrides the automatic hiding of the 'Log out' menu item in single-"
|
"This key overrides the automatic hiding of the 'Log out' menu item in single-"
|
||||||
"user, single-session situations."
|
"user, single-session situations."
|
||||||
@ -307,18 +297,17 @@ msgstr ""
|
|||||||
msgid "Captive Portal"
|
msgid "Captive Portal"
|
||||||
msgstr "پرتال درگیر"
|
msgstr "پرتال درگیر"
|
||||||
|
|
||||||
#: ../js/extensionPrefs/main.js:127
|
#: ../js/extensionPrefs/main.js:123
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "There was an error loading the preferences dialog for %s:"
|
msgid "There was an error loading the preferences dialog for %s:"
|
||||||
msgstr "خطایی هنگام باز کردن محاورهی ترجیحات برای %s رُخ داد:"
|
msgstr "خطایی هنگام باز کردن محاورهی ترجیحات برای %s رُخ داد:"
|
||||||
|
|
||||||
#: ../js/extensionPrefs/main.js:159
|
#: ../js/extensionPrefs/main.js:155
|
||||||
#| msgid "Configure GNOME Shell Extensions"
|
|
||||||
msgid "GNOME Shell Extensions"
|
msgid "GNOME Shell Extensions"
|
||||||
msgstr "افزونههای گنومشل"
|
msgstr "افزونههای گنومشل"
|
||||||
|
|
||||||
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:143
|
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:143
|
||||||
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:429
|
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:452
|
||||||
#: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399
|
#: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399
|
||||||
#: ../js/ui/status/network.js:915
|
#: ../js/ui/status/network.js:915
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
@ -378,50 +367,47 @@ msgstr "عدم توانایی در تجزیه فرمان:"
|
|||||||
|
|
||||||
#: ../js/misc/util.js:156
|
#: ../js/misc/util.js:156
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
#| msgid "Execution of '%s' failed:"
|
|
||||||
msgid "Execution of “%s” failed:"
|
msgid "Execution of “%s” failed:"
|
||||||
msgstr "اجرای «%s» شکست خورد:"
|
msgstr "اجرای «%s» شکست خورد:"
|
||||||
|
|
||||||
#: ../js/portalHelper/main.js:85
|
#: ../js/portalHelper/main.js:85
|
||||||
#| msgid "Authentication Required"
|
|
||||||
msgid "Web Authentication Redirect"
|
msgid "Web Authentication Redirect"
|
||||||
msgstr "تغییر مسیر برای تایید هویت وب"
|
msgstr "تغییر مسیر برای تایید هویت وب"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:660
|
#: ../js/ui/appDisplay.js:772
|
||||||
msgid "Frequently used applications will appear here"
|
msgid "Frequently used applications will appear here"
|
||||||
msgstr "برنامههای بیشتر استفاده شده در اینجا نمایش داده میشود"
|
msgstr "برنامههای بیشتر استفاده شده در اینجا نمایش داده میشود"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:771
|
#: ../js/ui/appDisplay.js:883
|
||||||
msgid "Frequent"
|
msgid "Frequent"
|
||||||
msgstr "پُراستفاده"
|
msgstr "پُراستفاده"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:778
|
#: ../js/ui/appDisplay.js:890
|
||||||
msgid "All"
|
msgid "All"
|
||||||
msgstr "همه"
|
msgstr "همه"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1650
|
#: ../js/ui/appDisplay.js:1790
|
||||||
msgid "New Window"
|
msgid "New Window"
|
||||||
msgstr "پنجرهی جدید"
|
msgstr "پنجرهی جدید"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1673 ../js/ui/dash.js:285
|
#: ../js/ui/appDisplay.js:1816 ../js/ui/dash.js:285
|
||||||
msgid "Remove from Favorites"
|
msgid "Remove from Favorites"
|
||||||
msgstr "حذف از مورد پسندها"
|
msgstr "حذف از مورد پسندها"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1679
|
#: ../js/ui/appDisplay.js:1822
|
||||||
msgid "Add to Favorites"
|
msgid "Add to Favorites"
|
||||||
msgstr "اضافه کردن به مورد پسندها"
|
msgstr "اضافه کردن به مورد پسندها"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1688
|
#: ../js/ui/appDisplay.js:1831
|
||||||
#| msgid "Show Text"
|
|
||||||
msgid "Show Details"
|
msgid "Show Details"
|
||||||
msgstr "نمایش جزئیات"
|
msgstr "نمایش جزئیات"
|
||||||
|
|
||||||
#: ../js/ui/appFavorites.js:122
|
#: ../js/ui/appFavorites.js:132
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s has been added to your favorites."
|
msgid "%s has been added to your favorites."
|
||||||
msgstr "مورد %s به مورد پسندهای شما اضافه شد."
|
msgstr "مورد %s به مورد پسندهای شما اضافه شد."
|
||||||
|
|
||||||
#: ../js/ui/appFavorites.js:156
|
#: ../js/ui/appFavorites.js:166
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s has been removed from your favorites."
|
msgid "%s has been removed from your favorites."
|
||||||
msgstr "مورد %s ازمورد پسندهای شما حذف شد."
|
msgstr "مورد %s ازمورد پسندهای شما حذف شد."
|
||||||
@ -613,11 +599,11 @@ msgstr "باز کردن با %s"
|
|||||||
msgid "Eject"
|
msgid "Eject"
|
||||||
msgstr "بیرون دادن"
|
msgstr "بیرون دادن"
|
||||||
|
|
||||||
#: ../js/ui/components/keyring.js:93 ../js/ui/components/polkitAgent.js:285
|
#: ../js/ui/components/keyring.js:94 ../js/ui/components/polkitAgent.js:285
|
||||||
msgid "Password:"
|
msgid "Password:"
|
||||||
msgstr "گذرواژه"
|
msgstr "گذرواژه"
|
||||||
|
|
||||||
#: ../js/ui/components/keyring.js:113
|
#: ../js/ui/components/keyring.js:120
|
||||||
msgid "Type again:"
|
msgid "Type again:"
|
||||||
msgstr "تلاش مجدد:"
|
msgstr "تلاش مجدد:"
|
||||||
|
|
||||||
@ -656,9 +642,6 @@ msgstr "تایید هویت برای شبکه بیسیم لازم است"
|
|||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:319
|
#: ../js/ui/components/networkAgent.js:319
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
#| msgid ""
|
|
||||||
#| "Passwords or encryption keys are required to access the wireless network "
|
|
||||||
#| "'%s'."
|
|
||||||
msgid ""
|
msgid ""
|
||||||
"Passwords or encryption keys are required to access the wireless network "
|
"Passwords or encryption keys are required to access the wireless network "
|
||||||
"“%s”."
|
"“%s”."
|
||||||
@ -694,7 +677,6 @@ msgstr "گذرواژه شبکه پهنباند تلفن همراه"
|
|||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:346
|
#: ../js/ui/components/networkAgent.js:346
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
#| msgid "A password is required to connect to '%s'."
|
|
||||||
msgid "A password is required to connect to “%s”."
|
msgid "A password is required to connect to “%s”."
|
||||||
msgstr "برای اتصال به «%s» گذرواژه لازم است."
|
msgstr "برای اتصال به «%s» گذرواژه لازم است."
|
||||||
|
|
||||||
@ -744,23 +726,18 @@ msgstr "بیصدا"
|
|||||||
|
|
||||||
#. Translators: Time in 24h format */
|
#. Translators: Time in 24h format */
|
||||||
#: ../js/ui/components/telepathyClient.js:953
|
#: ../js/ui/components/telepathyClient.js:953
|
||||||
#| msgctxt "event list time"
|
|
||||||
#| msgid "%H∶%M"
|
|
||||||
msgid "%H∶%M"
|
msgid "%H∶%M"
|
||||||
msgstr "%OH∶%OM"
|
msgstr "%OH∶%OM"
|
||||||
|
|
||||||
#. Translators: this is the word "Yesterday" followed by a
|
#. Translators: this is the word "Yesterday" followed by a
|
||||||
#. time string in 24h format. i.e. "Yesterday, 14:30" */
|
#. time string in 24h format. i.e. "Yesterday, 14:30" */
|
||||||
#: ../js/ui/components/telepathyClient.js:960
|
#: ../js/ui/components/telepathyClient.js:960
|
||||||
#| msgid "<b>Yesterday</b>, <b>%H:%M</b>"
|
|
||||||
msgid "Yesterday, %H∶%M"
|
msgid "Yesterday, %H∶%M"
|
||||||
msgstr "<b>دیروز</b>، <b>%OH:%OM"
|
msgstr "<b>دیروز</b>، <b>%OH:%OM"
|
||||||
|
|
||||||
#. Translators: this is the week day name followed by a time
|
#. Translators: this is the week day name followed by a time
|
||||||
#. string in 24h format. i.e. "Monday, 14:30" */
|
#. string in 24h format. i.e. "Monday, 14:30" */
|
||||||
#: ../js/ui/components/telepathyClient.js:967
|
#: ../js/ui/components/telepathyClient.js:967
|
||||||
#| msgctxt "event list time"
|
|
||||||
#| msgid "%H∶%M"
|
|
||||||
msgid "%A, %H∶%M"
|
msgid "%A, %H∶%M"
|
||||||
msgstr "%A، %OH∶%OM"
|
msgstr "%A، %OH∶%OM"
|
||||||
|
|
||||||
@ -768,8 +745,6 @@ msgstr "%A، %OH∶%OM"
|
|||||||
#. followed by a time string in 24h format.
|
#. followed by a time string in 24h format.
|
||||||
#. i.e. "May 25, 14:30" */
|
#. i.e. "May 25, 14:30" */
|
||||||
#: ../js/ui/components/telepathyClient.js:974
|
#: ../js/ui/components/telepathyClient.js:974
|
||||||
#| msgctxt "event list time"
|
|
||||||
#| msgid "%H∶%M"
|
|
||||||
msgid "%B %d, %H∶%M"
|
msgid "%B %d, %H∶%M"
|
||||||
msgstr "%d %B، %OH∶%OM"
|
msgstr "%d %B، %OH∶%OM"
|
||||||
|
|
||||||
@ -782,8 +757,6 @@ msgstr "%Od %OB %OY، %OH:%OM"
|
|||||||
|
|
||||||
#. Translators: Time in 24h format */
|
#. Translators: Time in 24h format */
|
||||||
#: ../js/ui/components/telepathyClient.js:986
|
#: ../js/ui/components/telepathyClient.js:986
|
||||||
#| msgctxt "event list time"
|
|
||||||
#| msgid "%l∶%M %p"
|
|
||||||
msgid "%l∶%M %p"
|
msgid "%l∶%M %p"
|
||||||
msgstr "%Ol∶%OM %p"
|
msgstr "%Ol∶%OM %p"
|
||||||
|
|
||||||
@ -796,7 +769,6 @@ msgstr "دیروز، %OI:%OM"
|
|||||||
#. Translators: this is the week day name followed by a time
|
#. Translators: this is the week day name followed by a time
|
||||||
#. string in 12h format. i.e. "Monday, 2:30 pm" */
|
#. string in 12h format. i.e. "Monday, 2:30 pm" */
|
||||||
#: ../js/ui/components/telepathyClient.js:1000
|
#: ../js/ui/components/telepathyClient.js:1000
|
||||||
#| msgid "%a %l:%M %p"
|
|
||||||
msgid "%A, %l∶%M %p"
|
msgid "%A, %l∶%M %p"
|
||||||
msgstr "%A، %OH:%OM"
|
msgstr "%A، %OH:%OM"
|
||||||
|
|
||||||
@ -804,7 +776,6 @@ msgstr "%A، %OH:%OM"
|
|||||||
#. followed by a time string in 12h format.
|
#. followed by a time string in 12h format.
|
||||||
#. i.e. "May 25, 2:30 pm" */
|
#. i.e. "May 25, 2:30 pm" */
|
||||||
#: ../js/ui/components/telepathyClient.js:1007
|
#: ../js/ui/components/telepathyClient.js:1007
|
||||||
#| msgid "%a %b %e, %l:%M %p"
|
|
||||||
msgid "%B %d, %l∶%M %p"
|
msgid "%B %d, %l∶%M %p"
|
||||||
msgstr "%Od %B، %OH:%OM"
|
msgstr "%Od %B، %OH:%OM"
|
||||||
|
|
||||||
@ -812,7 +783,6 @@ msgstr "%Od %B، %OH:%OM"
|
|||||||
#. number followed by a time string in 12h format.
|
#. number followed by a time string in 12h format.
|
||||||
#. i.e. "May 25 2012, 2:30 pm"*/
|
#. i.e. "May 25 2012, 2:30 pm"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:1013
|
#: ../js/ui/components/telepathyClient.js:1013
|
||||||
#| msgid "%a %b %e, %l:%M %p"
|
|
||||||
msgid "%B %d %Y, %l∶%M %p"
|
msgid "%B %d %Y, %l∶%M %p"
|
||||||
msgstr "%Od %B، %OH:%OM"
|
msgstr "%Od %B، %OH:%OM"
|
||||||
|
|
||||||
@ -1004,7 +974,7 @@ msgstr "نمایش حساب"
|
|||||||
msgid "Unknown reason"
|
msgid "Unknown reason"
|
||||||
msgstr "دلیل ناشناخته"
|
msgstr "دلیل ناشناخته"
|
||||||
|
|
||||||
#: ../js/ui/ctrlAltTab.js:29 ../js/ui/viewSelector.js:228
|
#: ../js/ui/ctrlAltTab.js:29 ../js/ui/viewSelector.js:154
|
||||||
msgid "Windows"
|
msgid "Windows"
|
||||||
msgstr "پنجرهها"
|
msgstr "پنجرهها"
|
||||||
|
|
||||||
@ -1016,105 +986,105 @@ msgstr "نمایش برنامهها"
|
|||||||
msgid "Dash"
|
msgid "Dash"
|
||||||
msgstr "دَش"
|
msgstr "دَش"
|
||||||
|
|
||||||
#: ../js/ui/dateMenu.js:96
|
#: ../js/ui/dateMenu.js:97
|
||||||
msgid "Open Calendar"
|
msgid "Open Calendar"
|
||||||
msgstr "بازکردن تقویم"
|
msgstr "بازکردن تقویم"
|
||||||
|
|
||||||
#: ../js/ui/dateMenu.js:100
|
#: ../js/ui/dateMenu.js:101
|
||||||
msgid "Open Clocks"
|
msgid "Open Clocks"
|
||||||
msgstr "باز کردن ساعتها"
|
msgstr "باز کردن ساعتها"
|
||||||
|
|
||||||
#: ../js/ui/dateMenu.js:107
|
#: ../js/ui/dateMenu.js:108
|
||||||
msgid "Date & Time Settings"
|
msgid "Date & Time Settings"
|
||||||
msgstr "تنظیمات تاریخ و ساعت"
|
msgstr "تنظیمات تاریخ و ساعت"
|
||||||
|
|
||||||
#. Translators: This is the date format to use when the calendar popup is
|
#. Translators: This is the date format to use when the calendar popup is
|
||||||
#. * shown - it is shown just below the time in the shell (e.g. "Tue 9:29 AM").
|
#. * shown - it is shown just below the time in the shell (e.g. "Tue 9:29 AM").
|
||||||
#. */
|
#. */
|
||||||
#: ../js/ui/dateMenu.js:204
|
#: ../js/ui/dateMenu.js:132
|
||||||
msgid "%A %B %e, %Y"
|
msgid "%A %B %e, %Y"
|
||||||
msgstr "%A %Od %B"
|
msgstr "%A %Od %B"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:66
|
#: ../js/ui/endSessionDialog.js:64
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Log Out %s"
|
msgid "Log Out %s"
|
||||||
msgstr "خروج از %s"
|
msgstr "خروج از %s"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:67
|
#: ../js/ui/endSessionDialog.js:65
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Log Out"
|
msgid "Log Out"
|
||||||
msgstr "خروج از سیستم"
|
msgstr "خروج از سیستم"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:69
|
#: ../js/ui/endSessionDialog.js:67
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s will be logged out automatically in %d second."
|
msgid "%s will be logged out automatically in %d second."
|
||||||
msgid_plural "%s will be logged out automatically in %d seconds."
|
msgid_plural "%s will be logged out automatically in %d seconds."
|
||||||
msgstr[0] "%s به طور خودکار در مدت %Id ثانیه از سیستم خارج خواهد شد."
|
msgstr[0] "%s به طور خودکار در مدت %Id ثانیه از سیستم خارج خواهد شد."
|
||||||
msgstr[1] "%s به طور خودکار در مدت %Id ثانیه از سیستم خارج خواهد شد."
|
msgstr[1] "%s به طور خودکار در مدت %Id ثانیه از سیستم خارج خواهد شد."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:74
|
#: ../js/ui/endSessionDialog.js:72
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "You will be logged out automatically in %d second."
|
msgid "You will be logged out automatically in %d second."
|
||||||
msgid_plural "You will be logged out automatically in %d seconds."
|
msgid_plural "You will be logged out automatically in %d seconds."
|
||||||
msgstr[0] "شما پس از %Id ثانیه به طور خودکار از سیستم خارج میشوید."
|
msgstr[0] "شما پس از %Id ثانیه به طور خودکار از سیستم خارج میشوید."
|
||||||
msgstr[1] "شما پس از %Id ثانیه به طور خودکار از سیستم خارج میشوید."
|
msgstr[1] "شما پس از %Id ثانیه به طور خودکار از سیستم خارج میشوید."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:80
|
#: ../js/ui/endSessionDialog.js:78
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Log Out"
|
msgid "Log Out"
|
||||||
msgstr "خروج از سیستم"
|
msgstr "خروج از سیستم"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:86
|
#: ../js/ui/endSessionDialog.js:84
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Power Off"
|
msgid "Power Off"
|
||||||
msgstr "خاموش کردن"
|
msgstr "خاموش کردن"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:87
|
#: ../js/ui/endSessionDialog.js:85
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Install Updates & Power Off"
|
msgid "Install Updates & Power Off"
|
||||||
msgstr "نصب بروزرسانیها و خاموش کردن"
|
msgstr "نصب بروزرسانیها و خاموش کردن"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:89
|
#: ../js/ui/endSessionDialog.js:87
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "The system will power off automatically in %d second."
|
msgid "The system will power off automatically in %d second."
|
||||||
msgid_plural "The system will power off automatically in %d seconds."
|
msgid_plural "The system will power off automatically in %d seconds."
|
||||||
msgstr[0] "سیستم پس از %Id ثانیه به طور خودکار خاموش میشود."
|
msgstr[0] "سیستم پس از %Id ثانیه به طور خودکار خاموش میشود."
|
||||||
msgstr[1] "سیستم پس از %Id ثانیه به طور خودکار خاموش میشود."
|
msgstr[1] "سیستم پس از %Id ثانیه به طور خودکار خاموش میشود."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:93
|
#: ../js/ui/endSessionDialog.js:91
|
||||||
msgctxt "checkbox"
|
msgctxt "checkbox"
|
||||||
msgid "Install pending software updates"
|
msgid "Install pending software updates"
|
||||||
msgstr "نصب بروزرسانیهایِ در انتظار"
|
msgstr "نصب بروزرسانیهایِ در انتظار"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:96 ../js/ui/endSessionDialog.js:113
|
#: ../js/ui/endSessionDialog.js:94 ../js/ui/endSessionDialog.js:111
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Restart"
|
msgid "Restart"
|
||||||
msgstr "راهاندازی مجدد"
|
msgstr "راهاندازی مجدد"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:98
|
#: ../js/ui/endSessionDialog.js:96
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Power Off"
|
msgid "Power Off"
|
||||||
msgstr "خاموش کردن"
|
msgstr "خاموش کردن"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:105
|
#: ../js/ui/endSessionDialog.js:103
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Restart"
|
msgid "Restart"
|
||||||
msgstr "راهاندازی مجدد"
|
msgstr "راهاندازی مجدد"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:107
|
#: ../js/ui/endSessionDialog.js:105
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "The system will restart automatically in %d second."
|
msgid "The system will restart automatically in %d second."
|
||||||
msgid_plural "The system will restart automatically in %d seconds."
|
msgid_plural "The system will restart automatically in %d seconds."
|
||||||
msgstr[0] "سیستم پس از %Id ثانیه به طور خودکار مجددا راهاندازی میشود."
|
msgstr[0] "سیستم پس از %Id ثانیه به طور خودکار مجددا راهاندازی میشود."
|
||||||
msgstr[1] "سیستم پس از %Id ثانیه به طور خودکار مجددا راهاندازی میشود."
|
msgstr[1] "سیستم پس از %Id ثانیه به طور خودکار مجددا راهاندازی میشود."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:121
|
#: ../js/ui/endSessionDialog.js:119
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Restart & Install Updates"
|
msgid "Restart & Install Updates"
|
||||||
msgstr "راهاندازی مجدد و نصب بروزرسانیها"
|
msgstr "راهاندازی مجدد و نصب بروزرسانیها"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:123
|
#: ../js/ui/endSessionDialog.js:121
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "The system will automatically restart and install updates in %d second."
|
msgid "The system will automatically restart and install updates in %d second."
|
||||||
msgid_plural ""
|
msgid_plural ""
|
||||||
@ -1126,44 +1096,42 @@ msgstr[1] ""
|
|||||||
"سیستم پس از %Id ثانیه به طور خودکار مجددا راهاندازی میشود و بروزرسانیهای را "
|
"سیستم پس از %Id ثانیه به طور خودکار مجددا راهاندازی میشود و بروزرسانیهای را "
|
||||||
"نصب میکند."
|
"نصب میکند."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:129
|
#: ../js/ui/endSessionDialog.js:127
|
||||||
#| msgctxt "button"
|
|
||||||
#| msgid "Restart & Install"
|
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Restart & Install"
|
msgid "Restart & Install"
|
||||||
msgstr "راهاندازی مجدد و نصب"
|
msgstr "راهاندازی مجدد و نصب"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:130
|
#: ../js/ui/endSessionDialog.js:128
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Install & Power Off"
|
msgid "Install & Power Off"
|
||||||
msgstr "نصب و خاموش کردن"
|
msgstr "نصب و خاموش کردن"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:131
|
#: ../js/ui/endSessionDialog.js:129
|
||||||
msgctxt "checkbox"
|
msgctxt "checkbox"
|
||||||
msgid "Power off after updates are installed"
|
msgid "Power off after updates are installed"
|
||||||
msgstr "خاموش کردن بعد از نصب بروزرسانیها"
|
msgstr "خاموش کردن بعد از نصب بروزرسانیها"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:315
|
#: ../js/ui/endSessionDialog.js:338
|
||||||
msgid "Running on battery power: please plug in before installing updates."
|
msgid "Running on battery power: please plug in before installing updates."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"درحال اجرا بر روی انرژی باتری: لطفا قبل از نصب بروزرسانیها، به برق وصل کنید."
|
"درحال اجرا بر روی انرژی باتری: لطفا قبل از نصب بروزرسانیها، به برق وصل کنید."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:332
|
#: ../js/ui/endSessionDialog.js:355
|
||||||
msgid "Some applications are busy or have unsaved work."
|
msgid "Some applications are busy or have unsaved work."
|
||||||
msgstr "تعدادی از برنامهها مشغول هستند یا کارهای ذخیره نشده دارند."
|
msgstr "تعدادی از برنامهها مشغول هستند یا کارهای ذخیره نشده دارند."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:339
|
#: ../js/ui/endSessionDialog.js:362
|
||||||
msgid "Other users are logged in."
|
msgid "Other users are logged in."
|
||||||
msgstr "کاربران دیگر وارد سیستم هستند."
|
msgstr "کاربران دیگر وارد سیستم هستند."
|
||||||
|
|
||||||
#. Translators: Remote here refers to a remote session, like a ssh login */
|
#. Translators: Remote here refers to a remote session, like a ssh login */
|
||||||
#: ../js/ui/endSessionDialog.js:619
|
#: ../js/ui/endSessionDialog.js:640
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s (remote)"
|
msgid "%s (remote)"
|
||||||
msgstr "%s (دوردست)"
|
msgstr "%s (دوردست)"
|
||||||
|
|
||||||
#. Translators: Console here refers to a tty like a VT console */
|
#. Translators: Console here refers to a tty like a VT console */
|
||||||
#: ../js/ui/endSessionDialog.js:622
|
#: ../js/ui/endSessionDialog.js:643
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s (console)"
|
msgid "%s (console)"
|
||||||
msgstr "%s (پایانه)"
|
msgstr "%s (پایانه)"
|
||||||
@ -1174,11 +1142,10 @@ msgstr "نصب"
|
|||||||
|
|
||||||
#: ../js/ui/extensionDownloader.js:204
|
#: ../js/ui/extensionDownloader.js:204
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
#| msgid "Download and install '%s' from extensions.gnome.org?"
|
|
||||||
msgid "Download and install “%s” from extensions.gnome.org?"
|
msgid "Download and install “%s” from extensions.gnome.org?"
|
||||||
msgstr "بارگیری و نصب «%s» از extensions.gnome.org؟"
|
msgstr "بارگیری و نصب «%s» از extensions.gnome.org؟"
|
||||||
|
|
||||||
#: ../js/ui/keyboard.js:653 ../js/ui/status/keyboard.js:339
|
#: ../js/ui/keyboard.js:700 ../js/ui/status/keyboard.js:523
|
||||||
msgid "Keyboard"
|
msgid "Keyboard"
|
||||||
msgstr "صفحهکلید"
|
msgstr "صفحهکلید"
|
||||||
|
|
||||||
@ -1200,8 +1167,8 @@ msgstr "مخفی کردن خطاها"
|
|||||||
msgid "Show Errors"
|
msgid "Show Errors"
|
||||||
msgstr "نمایش خطاها"
|
msgstr "نمایش خطاها"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:716 ../js/ui/status/location.js:62
|
#: ../js/ui/lookingGlass.js:716 ../js/ui/status/location.js:71
|
||||||
#: ../js/ui/status/location.js:166
|
#: ../js/ui/status/location.js:176
|
||||||
msgid "Enabled"
|
msgid "Enabled"
|
||||||
msgstr "به کار انداختن"
|
msgstr "به کار انداختن"
|
||||||
|
|
||||||
@ -1209,7 +1176,7 @@ msgstr "به کار انداختن"
|
|||||||
#. because it's disabled by rfkill (airplane mode) */
|
#. because it's disabled by rfkill (airplane mode) */
|
||||||
#. translators:
|
#. translators:
|
||||||
#. * The device has been disabled
|
#. * The device has been disabled
|
||||||
#: ../js/ui/lookingGlass.js:719 ../js/ui/status/location.js:169
|
#: ../js/ui/lookingGlass.js:719 ../js/ui/status/location.js:179
|
||||||
#: ../js/ui/status/network.js:592 ../src/gvc/gvc-mixer-control.c:1830
|
#: ../js/ui/status/network.js:592 ../src/gvc/gvc-mixer-control.c:1830
|
||||||
msgid "Disabled"
|
msgid "Disabled"
|
||||||
msgstr "از کار انداختن"
|
msgstr "از کار انداختن"
|
||||||
@ -1234,39 +1201,39 @@ msgstr "نمایش منبع"
|
|||||||
msgid "Web Page"
|
msgid "Web Page"
|
||||||
msgstr "صفحهی وب"
|
msgstr "صفحهی وب"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1325
|
#: ../js/ui/messageTray.js:1327
|
||||||
msgid "Open"
|
msgid "Open"
|
||||||
msgstr "بازکردن"
|
msgstr "بازکردن"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1332
|
#: ../js/ui/messageTray.js:1334
|
||||||
msgid "Remove"
|
msgid "Remove"
|
||||||
msgstr "حذف"
|
msgstr "حذف"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1629
|
#: ../js/ui/messageTray.js:1631
|
||||||
msgid "Notifications"
|
msgid "Notifications"
|
||||||
msgstr "اعلانها"
|
msgstr "اعلانها"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1636
|
#: ../js/ui/messageTray.js:1638
|
||||||
msgid "Clear Messages"
|
msgid "Clear Messages"
|
||||||
msgstr "پاک کردن پیامها"
|
msgstr "پاک کردن پیامها"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1655
|
#: ../js/ui/messageTray.js:1657
|
||||||
msgid "Notification Settings"
|
msgid "Notification Settings"
|
||||||
msgstr "تنظیمات اعلانها"
|
msgstr "تنظیمات اعلانها"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1708
|
#: ../js/ui/messageTray.js:1710
|
||||||
msgid "Tray Menu"
|
msgid "Tray Menu"
|
||||||
msgstr "منو سینی"
|
msgstr "منو سینی"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1925
|
#: ../js/ui/messageTray.js:1934
|
||||||
msgid "No Messages"
|
msgid "No Messages"
|
||||||
msgstr "پیامی وجود ندارد"
|
msgstr "پیامی وجود ندارد"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1963
|
#: ../js/ui/messageTray.js:1979
|
||||||
msgid "Message Tray"
|
msgid "Message Tray"
|
||||||
msgstr "سینی پیام"
|
msgstr "سینی پیام"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:2966
|
#: ../js/ui/messageTray.js:2992
|
||||||
msgid "System Information"
|
msgid "System Information"
|
||||||
msgstr "اطلاعات سیستم"
|
msgstr "اطلاعات سیستم"
|
||||||
|
|
||||||
@ -1294,7 +1261,7 @@ msgstr "نمایکلی"
|
|||||||
#. in the search entry when no search is
|
#. in the search entry when no search is
|
||||||
#. active; it should not exceed ~30
|
#. active; it should not exceed ~30
|
||||||
#. characters. */
|
#. characters. */
|
||||||
#: ../js/ui/overview.js:250
|
#: ../js/ui/overview.js:246
|
||||||
msgid "Type to search…"
|
msgid "Type to search…"
|
||||||
msgstr "برای جستجو تایپ کنید..."
|
msgstr "برای جستجو تایپ کنید..."
|
||||||
|
|
||||||
@ -1325,7 +1292,6 @@ msgid "Close"
|
|||||||
msgstr "بستن"
|
msgstr "بستن"
|
||||||
|
|
||||||
#: ../js/ui/runDialog.js:277
|
#: ../js/ui/runDialog.js:277
|
||||||
#| msgid "Estimating…"
|
|
||||||
msgid "Restarting…"
|
msgid "Restarting…"
|
||||||
msgstr "درحال راهاندازی مجدد..."
|
msgstr "درحال راهاندازی مجدد..."
|
||||||
|
|
||||||
@ -1358,27 +1324,27 @@ msgstr "نمیتوان قفل کرد"
|
|||||||
msgid "Lock was blocked by an application"
|
msgid "Lock was blocked by an application"
|
||||||
msgstr "قفل توسط یک برنامه مسدود شده بود"
|
msgstr "قفل توسط یک برنامه مسدود شده بود"
|
||||||
|
|
||||||
#: ../js/ui/search.js:606
|
#: ../js/ui/search.js:611
|
||||||
msgid "Searching…"
|
msgid "Searching…"
|
||||||
msgstr "درحال حستجو..."
|
msgstr "درحال حستجو..."
|
||||||
|
|
||||||
#: ../js/ui/search.js:652
|
#: ../js/ui/search.js:613
|
||||||
msgid "No results."
|
msgid "No results."
|
||||||
msgstr "بدون نتیجه."
|
msgstr "بدون نتیجه."
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:27
|
#: ../js/ui/shellEntry.js:25
|
||||||
msgid "Copy"
|
msgid "Copy"
|
||||||
msgstr "رونوشت"
|
msgstr "رونوشت"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:32
|
#: ../js/ui/shellEntry.js:30
|
||||||
msgid "Paste"
|
msgid "Paste"
|
||||||
msgstr "چسباندن"
|
msgstr "چسباندن"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:99
|
#: ../js/ui/shellEntry.js:97
|
||||||
msgid "Show Text"
|
msgid "Show Text"
|
||||||
msgstr "نمایش متن"
|
msgstr "نمایش متن"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:101
|
#: ../js/ui/shellEntry.js:99
|
||||||
msgid "Hide Text"
|
msgid "Hide Text"
|
||||||
msgstr "مخفیکردن متن"
|
msgstr "مخفیکردن متن"
|
||||||
|
|
||||||
@ -1464,26 +1430,27 @@ msgstr "متصل نیست"
|
|||||||
msgid "Brightness"
|
msgid "Brightness"
|
||||||
msgstr "روشنایی"
|
msgstr "روشنایی"
|
||||||
|
|
||||||
#: ../js/ui/status/keyboard.js:406
|
#: ../js/ui/status/keyboard.js:547
|
||||||
msgid "Show Keyboard Layout"
|
msgid "Show Keyboard Layout"
|
||||||
msgstr "نمایش چیدمان صفحهکلید"
|
msgstr "نمایش چیدمان صفحهکلید"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:56
|
#: ../js/ui/status/location.js:65
|
||||||
#| msgid "Notifications"
|
|
||||||
msgid "Location"
|
msgid "Location"
|
||||||
msgstr "مکان"
|
msgstr "مکان"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:63 ../js/ui/status/location.js:167
|
#: ../js/ui/status/location.js:72 ../js/ui/status/location.js:177
|
||||||
#| msgid "Disabled"
|
|
||||||
msgid "Disable"
|
msgid "Disable"
|
||||||
msgstr "از کار انداختن"
|
msgstr "از کار انداختن"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:166
|
#: ../js/ui/status/location.js:73
|
||||||
|
msgid "Privacy Settings"
|
||||||
|
msgstr "تنظیمات حریمخصوصی"
|
||||||
|
|
||||||
|
#: ../js/ui/status/location.js:176
|
||||||
msgid "In Use"
|
msgid "In Use"
|
||||||
msgstr "درحال استفاده"
|
msgstr "درحال استفاده"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:170
|
#: ../js/ui/status/location.js:180
|
||||||
#| msgid "Enabled"
|
|
||||||
msgid "Enable"
|
msgid "Enable"
|
||||||
msgstr "به کار انداختن"
|
msgstr "به کار انداختن"
|
||||||
|
|
||||||
@ -1497,37 +1464,31 @@ msgid "Off"
|
|||||||
msgstr "خاموش"
|
msgstr "خاموش"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:459
|
#: ../js/ui/status/network.js:459
|
||||||
#| msgid "Connect"
|
|
||||||
msgid "Connected"
|
msgid "Connected"
|
||||||
msgstr "متصل شده"
|
msgstr "متصل شده"
|
||||||
|
|
||||||
#. Translators: this is for network devices that are physically present but are not
|
#. Translators: this is for network devices that are physically present but are not
|
||||||
#. under NetworkManager's control (and thus cannot be used in the menu) */
|
#. under NetworkManager's control (and thus cannot be used in the menu) */
|
||||||
#: ../js/ui/status/network.js:463
|
#: ../js/ui/status/network.js:463
|
||||||
#| msgid "unmanaged"
|
|
||||||
msgid "Unmanaged"
|
msgid "Unmanaged"
|
||||||
msgstr "مدیریت نشده"
|
msgstr "مدیریت نشده"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:465
|
#: ../js/ui/status/network.js:465
|
||||||
#| msgid "disconnecting..."
|
|
||||||
msgid "Disconnecting"
|
msgid "Disconnecting"
|
||||||
msgstr "درحال قطع ارتباط"
|
msgstr "درحال قطع ارتباط"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:471 ../js/ui/status/network.js:1301
|
#: ../js/ui/status/network.js:471 ../js/ui/status/network.js:1301
|
||||||
#| msgid "Connection"
|
|
||||||
msgid "Connecting"
|
msgid "Connecting"
|
||||||
msgstr "درحال اتصال"
|
msgstr "درحال اتصال"
|
||||||
|
|
||||||
#. Translators: this is for network connections that require some kind of key or password */
|
#. Translators: this is for network connections that require some kind of key or password */
|
||||||
#: ../js/ui/status/network.js:474
|
#: ../js/ui/status/network.js:474
|
||||||
#| msgid "authentication required"
|
|
||||||
msgid "Authentication required"
|
msgid "Authentication required"
|
||||||
msgstr "تایید هویت لازم است"
|
msgstr "تایید هویت لازم است"
|
||||||
|
|
||||||
#. Translators: this is for devices that require some kind of firmware or kernel
|
#. Translators: this is for devices that require some kind of firmware or kernel
|
||||||
#. module, which is missing */
|
#. module, which is missing */
|
||||||
#: ../js/ui/status/network.js:482
|
#: ../js/ui/status/network.js:482
|
||||||
#| msgid "firmware missing"
|
|
||||||
msgid "Firmware missing"
|
msgid "Firmware missing"
|
||||||
msgstr "میانافزار موجود نیست"
|
msgstr "میانافزار موجود نیست"
|
||||||
|
|
||||||
@ -1542,7 +1503,6 @@ msgid "Connection failed"
|
|||||||
msgstr "اتصال شکست خورد"
|
msgstr "اتصال شکست خورد"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:504
|
#: ../js/ui/status/network.js:504
|
||||||
#| msgid "Wi-Fi Settings"
|
|
||||||
msgid "Wired Settings"
|
msgid "Wired Settings"
|
||||||
msgstr "تنظیمات اتصال سیمی"
|
msgstr "تنظیمات اتصال سیمی"
|
||||||
|
|
||||||
@ -1559,7 +1519,6 @@ msgid "Use as Internet connection"
|
|||||||
msgstr "استفاده به عنوان اتصال اینترنت"
|
msgstr "استفاده به عنوان اتصال اینترنت"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:813
|
#: ../js/ui/status/network.js:813
|
||||||
#| msgid "Airplane Mode"
|
|
||||||
msgid "Airplane Mode is On"
|
msgid "Airplane Mode is On"
|
||||||
msgstr "حالت هواپیمایی روشن است"
|
msgstr "حالت هواپیمایی روشن است"
|
||||||
|
|
||||||
@ -1568,12 +1527,10 @@ msgid "Wi-Fi is disabled when airplane mode is on."
|
|||||||
msgstr "در زمان روشن بودن حالت هواپیمایی وای-فای غیرفعال میشود."
|
msgstr "در زمان روشن بودن حالت هواپیمایی وای-فای غیرفعال میشود."
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:815
|
#: ../js/ui/status/network.js:815
|
||||||
#| msgid "Airplane Mode"
|
|
||||||
msgid "Turn Off Airplane Mode"
|
msgid "Turn Off Airplane Mode"
|
||||||
msgstr "خاموش کردن حالت هواپیمایی"
|
msgstr "خاموش کردن حالت هواپیمایی"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:824
|
#: ../js/ui/status/network.js:824
|
||||||
#| msgid "Wi-Fi Settings"
|
|
||||||
msgid "Wi-Fi is Off"
|
msgid "Wi-Fi is Off"
|
||||||
msgstr "بیسیم خاموش است"
|
msgstr "بیسیم خاموش است"
|
||||||
|
|
||||||
@ -1582,7 +1539,6 @@ msgid "Wi-Fi needs to be turned on in order to connect to a network."
|
|||||||
msgstr "برای اتصال به شبکه باید وای-فای روشن شود."
|
msgstr "برای اتصال به شبکه باید وای-فای روشن شود."
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:826
|
#: ../js/ui/status/network.js:826
|
||||||
#| msgid "Turn On"
|
|
||||||
msgid "Turn On Wi-Fi"
|
msgid "Turn On Wi-Fi"
|
||||||
msgstr "روشن کردن بیسیم"
|
msgstr "روشن کردن بیسیم"
|
||||||
|
|
||||||
@ -1636,7 +1592,6 @@ msgid "Network Settings"
|
|||||||
msgstr "تنظیمات شبکه"
|
msgstr "تنظیمات شبکه"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1482
|
#: ../js/ui/status/network.js:1482
|
||||||
#| msgid "Settings"
|
|
||||||
msgid "VPN Settings"
|
msgid "VPN Settings"
|
||||||
msgstr "تنظیمات VPN"
|
msgstr "تنظیمات VPN"
|
||||||
|
|
||||||
@ -1730,17 +1685,16 @@ msgstr "ورود به سیستم بعنوان کاربری دیگر"
|
|||||||
msgid "Unlock Window"
|
msgid "Unlock Window"
|
||||||
msgstr "بازکردن قفل پنجره"
|
msgstr "بازکردن قفل پنجره"
|
||||||
|
|
||||||
#: ../js/ui/viewSelector.js:232
|
#: ../js/ui/viewSelector.js:158
|
||||||
msgid "Applications"
|
msgid "Applications"
|
||||||
msgstr "برنامهها"
|
msgstr "برنامهها"
|
||||||
|
|
||||||
#: ../js/ui/viewSelector.js:236
|
#: ../js/ui/viewSelector.js:162
|
||||||
msgid "Search"
|
msgid "Search"
|
||||||
msgstr "جستجو"
|
msgstr "جستجو"
|
||||||
|
|
||||||
#: ../js/ui/windowAttentionHandler.js:19
|
#: ../js/ui/windowAttentionHandler.js:19
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
#| msgid "'%s' is ready"
|
|
||||||
msgid "“%s” is ready"
|
msgid "“%s” is ready"
|
||||||
msgstr "«%s» آماده است"
|
msgstr "«%s» آماده است"
|
||||||
|
|
||||||
@ -1832,25 +1786,24 @@ msgstr[1] "%Iu ورودی"
|
|||||||
msgid "System Sounds"
|
msgid "System Sounds"
|
||||||
msgstr "صداهای سیستم"
|
msgstr "صداهای سیستم"
|
||||||
|
|
||||||
#: ../src/main.c:371
|
#: ../src/main.c:373
|
||||||
msgid "Print version"
|
msgid "Print version"
|
||||||
msgstr "چاپ نسخه"
|
msgstr "چاپ نسخه"
|
||||||
|
|
||||||
#: ../src/main.c:377
|
#: ../src/main.c:379
|
||||||
msgid "Mode used by GDM for login screen"
|
msgid "Mode used by GDM for login screen"
|
||||||
msgstr "حالت استفاده شده توسط GDM برای صفحه ورود به سیستم"
|
msgstr "حالت استفاده شده توسط GDM برای صفحه ورود به سیستم"
|
||||||
|
|
||||||
#: ../src/main.c:383
|
#: ../src/main.c:385
|
||||||
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
||||||
msgstr "استفاده از حالت مشخص، مثال «gdm» برای صفحه ورود به سیستم"
|
msgstr "استفاده از حالت مشخص، مثال «gdm» برای صفحه ورود به سیستم"
|
||||||
|
|
||||||
#: ../src/main.c:389
|
#: ../src/main.c:391
|
||||||
msgid "List possible modes"
|
msgid "List possible modes"
|
||||||
msgstr "فهرست کردن حالتهای ممکن"
|
msgstr "فهرست کردن حالتهای ممکن"
|
||||||
|
|
||||||
#: ../src/shell-app.c:666
|
#: ../src/shell-app.c:666
|
||||||
#, c-format
|
#, c-format
|
||||||
#| msgid "Failed to launch '%s'"
|
|
||||||
msgid "Failed to launch “%s”"
|
msgid "Failed to launch “%s”"
|
||||||
msgstr "راهاندازی «%s» شکست خورد"
|
msgstr "راهاندازی «%s» شکست خورد"
|
||||||
|
|
||||||
|
148
po/fr.po
@ -19,7 +19,7 @@ msgstr ""
|
|||||||
"Project-Id-Version: gnome-shell master fr\n"
|
"Project-Id-Version: gnome-shell master fr\n"
|
||||||
"Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?product=gnome-"
|
"Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?product=gnome-"
|
||||||
"shell&keywords=I18N+L10N&component=general\n"
|
"shell&keywords=I18N+L10N&component=general\n"
|
||||||
"POT-Creation-Date: 2014-08-25 07:37+0000\n"
|
"POT-Creation-Date: 2014-09-12 17:00+0000\n"
|
||||||
"PO-Revision-Date: 2014-08-25 17:00+0200\n"
|
"PO-Revision-Date: 2014-08-25 17:00+0200\n"
|
||||||
"Last-Translator: Alain Lojewski <allomervan@gmail.com>\n"
|
"Last-Translator: Alain Lojewski <allomervan@gmail.com>\n"
|
||||||
"Language-Team: français <gnomefr@traduc.org>\n"
|
"Language-Team: français <gnomefr@traduc.org>\n"
|
||||||
@ -242,8 +242,8 @@ msgstr "Combinaison de touches pour donner le focus à la notification active."
|
|||||||
msgid ""
|
msgid ""
|
||||||
"Keybinding that pauses and resumes all running tweens, for debugging purposes"
|
"Keybinding that pauses and resumes all running tweens, for debugging purposes"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Combinaison de touches pour stopper et fermer toutes les transitions à des fins "
|
"Combinaison de touches pour stopper et fermer toutes les transitions à des "
|
||||||
"de débogage"
|
"fins de débogage"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:30
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:30
|
||||||
msgid "Which keyboard to use"
|
msgid "Which keyboard to use"
|
||||||
@ -322,19 +322,19 @@ msgstr ""
|
|||||||
msgid "Captive Portal"
|
msgid "Captive Portal"
|
||||||
msgstr "Portail captif"
|
msgstr "Portail captif"
|
||||||
|
|
||||||
#: ../js/extensionPrefs/main.js:127
|
#: ../js/extensionPrefs/main.js:123
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "There was an error loading the preferences dialog for %s:"
|
msgid "There was an error loading the preferences dialog for %s:"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Une erreur s'est produite lors du chargement de la boîte de dialogue des "
|
"Une erreur s'est produite lors du chargement de la boîte de dialogue des "
|
||||||
"préférences de %s :"
|
"préférences de %s :"
|
||||||
|
|
||||||
#: ../js/extensionPrefs/main.js:159
|
#: ../js/extensionPrefs/main.js:155
|
||||||
msgid "GNOME Shell Extensions"
|
msgid "GNOME Shell Extensions"
|
||||||
msgstr "Extensions GNOME Shell"
|
msgstr "Extensions GNOME Shell"
|
||||||
|
|
||||||
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:143
|
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:143
|
||||||
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:429
|
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:452
|
||||||
#: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399
|
#: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399
|
||||||
#: ../js/ui/status/network.js:915
|
#: ../js/ui/status/network.js:915
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
@ -401,40 +401,40 @@ msgstr "Exécution de « %s » impossible :"
|
|||||||
msgid "Web Authentication Redirect"
|
msgid "Web Authentication Redirect"
|
||||||
msgstr "Redirection de l'authentification Web"
|
msgstr "Redirection de l'authentification Web"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:660
|
#: ../js/ui/appDisplay.js:772
|
||||||
msgid "Frequently used applications will appear here"
|
msgid "Frequently used applications will appear here"
|
||||||
msgstr "Les applications fréquemment utilisées apparaîtront ici"
|
msgstr "Les applications fréquemment utilisées apparaîtront ici"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:771
|
#: ../js/ui/appDisplay.js:883
|
||||||
msgid "Frequent"
|
msgid "Frequent"
|
||||||
msgstr "Fréquemment utilisées"
|
msgstr "Fréquemment utilisées"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:778
|
#: ../js/ui/appDisplay.js:890
|
||||||
msgid "All"
|
msgid "All"
|
||||||
msgstr "Toutes"
|
msgstr "Toutes"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1650
|
#: ../js/ui/appDisplay.js:1789
|
||||||
msgid "New Window"
|
msgid "New Window"
|
||||||
msgstr "Nouvelle fenêtre"
|
msgstr "Nouvelle fenêtre"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1673 ../js/ui/dash.js:285
|
#: ../js/ui/appDisplay.js:1815 ../js/ui/dash.js:285
|
||||||
msgid "Remove from Favorites"
|
msgid "Remove from Favorites"
|
||||||
msgstr "Enlever des favoris"
|
msgstr "Enlever des favoris"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1679
|
#: ../js/ui/appDisplay.js:1821
|
||||||
msgid "Add to Favorites"
|
msgid "Add to Favorites"
|
||||||
msgstr "Ajouter aux favoris"
|
msgstr "Ajouter aux favoris"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1688
|
#: ../js/ui/appDisplay.js:1830
|
||||||
msgid "Show Details"
|
msgid "Show Details"
|
||||||
msgstr "Afficher les détails"
|
msgstr "Afficher les détails"
|
||||||
|
|
||||||
#: ../js/ui/appFavorites.js:122
|
#: ../js/ui/appFavorites.js:124
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s has been added to your favorites."
|
msgid "%s has been added to your favorites."
|
||||||
msgstr "%s a été ajouté à vos favoris."
|
msgstr "%s a été ajouté à vos favoris."
|
||||||
|
|
||||||
#: ../js/ui/appFavorites.js:156
|
#: ../js/ui/appFavorites.js:158
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s has been removed from your favorites."
|
msgid "%s has been removed from your favorites."
|
||||||
msgstr "%s a été supprimé de vos favoris."
|
msgstr "%s a été supprimé de vos favoris."
|
||||||
@ -647,11 +647,11 @@ msgstr "Ouvrir avec %s"
|
|||||||
msgid "Eject"
|
msgid "Eject"
|
||||||
msgstr "Éjecter"
|
msgstr "Éjecter"
|
||||||
|
|
||||||
#: ../js/ui/components/keyring.js:93 ../js/ui/components/polkitAgent.js:285
|
#: ../js/ui/components/keyring.js:94 ../js/ui/components/polkitAgent.js:285
|
||||||
msgid "Password:"
|
msgid "Password:"
|
||||||
msgstr "Mot de passe :"
|
msgstr "Mot de passe :"
|
||||||
|
|
||||||
#: ../js/ui/components/keyring.js:113
|
#: ../js/ui/components/keyring.js:120
|
||||||
msgid "Type again:"
|
msgid "Type again:"
|
||||||
msgstr "Saisissez à nouveau :"
|
msgstr "Saisissez à nouveau :"
|
||||||
|
|
||||||
@ -1025,7 +1025,7 @@ msgstr "Afficher le compte"
|
|||||||
msgid "Unknown reason"
|
msgid "Unknown reason"
|
||||||
msgstr "Raison inconnue"
|
msgstr "Raison inconnue"
|
||||||
|
|
||||||
#: ../js/ui/ctrlAltTab.js:29 ../js/ui/viewSelector.js:228
|
#: ../js/ui/ctrlAltTab.js:29 ../js/ui/viewSelector.js:154
|
||||||
msgid "Windows"
|
msgid "Windows"
|
||||||
msgstr "Fenêtres"
|
msgstr "Fenêtres"
|
||||||
|
|
||||||
@ -1062,86 +1062,86 @@ msgstr "Paramètres de date et heure"
|
|||||||
msgid "%A %B %e, %Y"
|
msgid "%A %B %e, %Y"
|
||||||
msgstr "%A %e %B %Y"
|
msgstr "%A %e %B %Y"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:66
|
#: ../js/ui/endSessionDialog.js:64
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Log Out %s"
|
msgid "Log Out %s"
|
||||||
msgstr "Fermer la session de %s"
|
msgstr "Fermer la session de %s"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:67
|
#: ../js/ui/endSessionDialog.js:65
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Log Out"
|
msgid "Log Out"
|
||||||
msgstr "Fermer la session"
|
msgstr "Fermer la session"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:69
|
#: ../js/ui/endSessionDialog.js:67
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s will be logged out automatically in %d second."
|
msgid "%s will be logged out automatically in %d second."
|
||||||
msgid_plural "%s will be logged out automatically in %d seconds."
|
msgid_plural "%s will be logged out automatically in %d seconds."
|
||||||
msgstr[0] "%s sera déconnecté automatiquement dans %d seconde."
|
msgstr[0] "%s sera déconnecté automatiquement dans %d seconde."
|
||||||
msgstr[1] "%s sera déconnecté automatiquement dans %d secondes."
|
msgstr[1] "%s sera déconnecté automatiquement dans %d secondes."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:74
|
#: ../js/ui/endSessionDialog.js:72
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "You will be logged out automatically in %d second."
|
msgid "You will be logged out automatically in %d second."
|
||||||
msgid_plural "You will be logged out automatically in %d seconds."
|
msgid_plural "You will be logged out automatically in %d seconds."
|
||||||
msgstr[0] "Vous allez être déconnecté automatiquement dans %d seconde."
|
msgstr[0] "Vous allez être déconnecté automatiquement dans %d seconde."
|
||||||
msgstr[1] "Vous allez être déconnecté automatiquement dans %d secondes."
|
msgstr[1] "Vous allez être déconnecté automatiquement dans %d secondes."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:80
|
#: ../js/ui/endSessionDialog.js:78
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Log Out"
|
msgid "Log Out"
|
||||||
msgstr "Fermer la session"
|
msgstr "Fermer la session"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:86
|
#: ../js/ui/endSessionDialog.js:84
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Power Off"
|
msgid "Power Off"
|
||||||
msgstr "Éteindre"
|
msgstr "Éteindre"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:87
|
#: ../js/ui/endSessionDialog.js:85
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Install Updates & Power Off"
|
msgid "Install Updates & Power Off"
|
||||||
msgstr "Installer les mises à jour et éteindre"
|
msgstr "Installer les mises à jour et éteindre"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:89
|
#: ../js/ui/endSessionDialog.js:87
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "The system will power off automatically in %d second."
|
msgid "The system will power off automatically in %d second."
|
||||||
msgid_plural "The system will power off automatically in %d seconds."
|
msgid_plural "The system will power off automatically in %d seconds."
|
||||||
msgstr[0] "Cet ordinateur s'éteindra automatiquement dans %d seconde."
|
msgstr[0] "Cet ordinateur s'éteindra automatiquement dans %d seconde."
|
||||||
msgstr[1] "Cet ordinateur s'éteindra automatiquement dans %d secondes."
|
msgstr[1] "Cet ordinateur s'éteindra automatiquement dans %d secondes."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:93
|
#: ../js/ui/endSessionDialog.js:91
|
||||||
msgctxt "checkbox"
|
msgctxt "checkbox"
|
||||||
msgid "Install pending software updates"
|
msgid "Install pending software updates"
|
||||||
msgstr "Installer les mises à jour logicielles en attente"
|
msgstr "Installer les mises à jour logicielles en attente"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:96 ../js/ui/endSessionDialog.js:113
|
#: ../js/ui/endSessionDialog.js:94 ../js/ui/endSessionDialog.js:111
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Restart"
|
msgid "Restart"
|
||||||
msgstr "Redémarrer"
|
msgstr "Redémarrer"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:98
|
#: ../js/ui/endSessionDialog.js:96
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Power Off"
|
msgid "Power Off"
|
||||||
msgstr "Éteindre"
|
msgstr "Éteindre"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:105
|
#: ../js/ui/endSessionDialog.js:103
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Restart"
|
msgid "Restart"
|
||||||
msgstr "Redémarrer"
|
msgstr "Redémarrer"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:107
|
#: ../js/ui/endSessionDialog.js:105
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "The system will restart automatically in %d second."
|
msgid "The system will restart automatically in %d second."
|
||||||
msgid_plural "The system will restart automatically in %d seconds."
|
msgid_plural "The system will restart automatically in %d seconds."
|
||||||
msgstr[0] "Cet ordinateur redémarrera automatiquement dans %d seconde."
|
msgstr[0] "Cet ordinateur redémarrera automatiquement dans %d seconde."
|
||||||
msgstr[1] "Cet ordinateur redémarrera automatiquement dans %d secondes."
|
msgstr[1] "Cet ordinateur redémarrera automatiquement dans %d secondes."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:121
|
#: ../js/ui/endSessionDialog.js:119
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Restart & Install Updates"
|
msgid "Restart & Install Updates"
|
||||||
msgstr "Redémarrer et installer les mises à jour"
|
msgstr "Redémarrer et installer les mises à jour"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:123
|
#: ../js/ui/endSessionDialog.js:121
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "The system will automatically restart and install updates in %d second."
|
msgid "The system will automatically restart and install updates in %d second."
|
||||||
msgid_plural ""
|
msgid_plural ""
|
||||||
@ -1149,44 +1149,44 @@ msgid_plural ""
|
|||||||
msgstr[0] "Le système redémarrera automatiquement dans %d seconde."
|
msgstr[0] "Le système redémarrera automatiquement dans %d seconde."
|
||||||
msgstr[1] "Le système redémarrera automatiquement dans %d secondes."
|
msgstr[1] "Le système redémarrera automatiquement dans %d secondes."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:129
|
#: ../js/ui/endSessionDialog.js:127
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Restart & Install"
|
msgid "Restart & Install"
|
||||||
msgstr "Redémarrer et installer"
|
msgstr "Redémarrer et installer"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:130
|
#: ../js/ui/endSessionDialog.js:128
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Install & Power Off"
|
msgid "Install & Power Off"
|
||||||
msgstr "Installer et éteindre"
|
msgstr "Installer et éteindre"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:131
|
#: ../js/ui/endSessionDialog.js:129
|
||||||
msgctxt "checkbox"
|
msgctxt "checkbox"
|
||||||
msgid "Power off after updates are installed"
|
msgid "Power off after updates are installed"
|
||||||
msgstr "Éteindre après l'installation des mises à jour"
|
msgstr "Éteindre après l'installation des mises à jour"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:315
|
#: ../js/ui/endSessionDialog.js:338
|
||||||
msgid "Running on battery power: please plug in before installing updates."
|
msgid "Running on battery power: please plug in before installing updates."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Fonctionnement sur batterie : veuillez vous brancher avant d'installer les "
|
"Fonctionnement sur batterie : veuillez vous brancher avant d'installer les "
|
||||||
"mises à jour."
|
"mises à jour."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:332
|
#: ../js/ui/endSessionDialog.js:355
|
||||||
msgid "Some applications are busy or have unsaved work."
|
msgid "Some applications are busy or have unsaved work."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Certaines applications sont occupées ou ont des travaux non-sauvegardés."
|
"Certaines applications sont occupées ou ont des travaux non-sauvegardés."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:339
|
#: ../js/ui/endSessionDialog.js:362
|
||||||
msgid "Other users are logged in."
|
msgid "Other users are logged in."
|
||||||
msgstr "D'autres utilisateurs sont connectés."
|
msgstr "D'autres utilisateurs sont connectés."
|
||||||
|
|
||||||
#. Translators: Remote here refers to a remote session, like a ssh login */
|
#. Translators: Remote here refers to a remote session, like a ssh login */
|
||||||
#: ../js/ui/endSessionDialog.js:619
|
#: ../js/ui/endSessionDialog.js:640
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s (remote)"
|
msgid "%s (remote)"
|
||||||
msgstr "%s (distant)"
|
msgstr "%s (distant)"
|
||||||
|
|
||||||
#. Translators: Console here refers to a tty like a VT console */
|
#. Translators: Console here refers to a tty like a VT console */
|
||||||
#: ../js/ui/endSessionDialog.js:622
|
#: ../js/ui/endSessionDialog.js:643
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s (console)"
|
msgid "%s (console)"
|
||||||
msgstr "%s (console)"
|
msgstr "%s (console)"
|
||||||
@ -1200,7 +1200,7 @@ msgstr "Installer"
|
|||||||
msgid "Download and install “%s” from extensions.gnome.org?"
|
msgid "Download and install “%s” from extensions.gnome.org?"
|
||||||
msgstr "Télécharger et installer « %s » à partir de extensions.gnome.org ?"
|
msgstr "Télécharger et installer « %s » à partir de extensions.gnome.org ?"
|
||||||
|
|
||||||
#: ../js/ui/keyboard.js:653 ../js/ui/status/keyboard.js:339
|
#: ../js/ui/keyboard.js:692 ../js/ui/status/keyboard.js:523
|
||||||
msgid "Keyboard"
|
msgid "Keyboard"
|
||||||
msgstr "Clavier"
|
msgstr "Clavier"
|
||||||
|
|
||||||
@ -1222,8 +1222,8 @@ msgstr "Masquer les erreurs"
|
|||||||
msgid "Show Errors"
|
msgid "Show Errors"
|
||||||
msgstr "Afficher les erreurs"
|
msgstr "Afficher les erreurs"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:716 ../js/ui/status/location.js:62
|
#: ../js/ui/lookingGlass.js:716 ../js/ui/status/location.js:71
|
||||||
#: ../js/ui/status/location.js:166
|
#: ../js/ui/status/location.js:176
|
||||||
msgid "Enabled"
|
msgid "Enabled"
|
||||||
msgstr "Activé"
|
msgstr "Activé"
|
||||||
|
|
||||||
@ -1231,7 +1231,7 @@ msgstr "Activé"
|
|||||||
#. because it's disabled by rfkill (airplane mode) */
|
#. because it's disabled by rfkill (airplane mode) */
|
||||||
#. translators:
|
#. translators:
|
||||||
#. * The device has been disabled
|
#. * The device has been disabled
|
||||||
#: ../js/ui/lookingGlass.js:719 ../js/ui/status/location.js:169
|
#: ../js/ui/lookingGlass.js:719 ../js/ui/status/location.js:179
|
||||||
#: ../js/ui/status/network.js:592 ../src/gvc/gvc-mixer-control.c:1830
|
#: ../js/ui/status/network.js:592 ../src/gvc/gvc-mixer-control.c:1830
|
||||||
msgid "Disabled"
|
msgid "Disabled"
|
||||||
msgstr "Désactivé"
|
msgstr "Désactivé"
|
||||||
@ -1256,39 +1256,39 @@ msgstr "Afficher la source"
|
|||||||
msgid "Web Page"
|
msgid "Web Page"
|
||||||
msgstr "Page Web"
|
msgstr "Page Web"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1325
|
#: ../js/ui/messageTray.js:1326
|
||||||
msgid "Open"
|
msgid "Open"
|
||||||
msgstr "Ouvrir"
|
msgstr "Ouvrir"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1332
|
#: ../js/ui/messageTray.js:1333
|
||||||
msgid "Remove"
|
msgid "Remove"
|
||||||
msgstr "Enlever"
|
msgstr "Enlever"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1629
|
#: ../js/ui/messageTray.js:1630
|
||||||
msgid "Notifications"
|
msgid "Notifications"
|
||||||
msgstr "Notifications"
|
msgstr "Notifications"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1636
|
#: ../js/ui/messageTray.js:1637
|
||||||
msgid "Clear Messages"
|
msgid "Clear Messages"
|
||||||
msgstr "Effacer les messages"
|
msgstr "Effacer les messages"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1655
|
#: ../js/ui/messageTray.js:1656
|
||||||
msgid "Notification Settings"
|
msgid "Notification Settings"
|
||||||
msgstr "Paramètres de notifications"
|
msgstr "Paramètres de notifications"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1708
|
#: ../js/ui/messageTray.js:1709
|
||||||
msgid "Tray Menu"
|
msgid "Tray Menu"
|
||||||
msgstr "Menu du tiroir de messagerie"
|
msgstr "Menu du tiroir de messagerie"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1925
|
#: ../js/ui/messageTray.js:1926
|
||||||
msgid "No Messages"
|
msgid "No Messages"
|
||||||
msgstr "Aucun message"
|
msgstr "Aucun message"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1963
|
#: ../js/ui/messageTray.js:1968
|
||||||
msgid "Message Tray"
|
msgid "Message Tray"
|
||||||
msgstr "Tiroir de messagerie"
|
msgstr "Tiroir de messagerie"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:2966
|
#: ../js/ui/messageTray.js:2971
|
||||||
msgid "System Information"
|
msgid "System Information"
|
||||||
msgstr "Informations du système"
|
msgstr "Informations du système"
|
||||||
|
|
||||||
@ -1316,7 +1316,7 @@ msgstr "Vue d'ensemble"
|
|||||||
#. in the search entry when no search is
|
#. in the search entry when no search is
|
||||||
#. active; it should not exceed ~30
|
#. active; it should not exceed ~30
|
||||||
#. characters. */
|
#. characters. */
|
||||||
#: ../js/ui/overview.js:250
|
#: ../js/ui/overview.js:246
|
||||||
msgid "Type to search…"
|
msgid "Type to search…"
|
||||||
msgstr "Rechercher…"
|
msgstr "Rechercher…"
|
||||||
|
|
||||||
@ -1379,27 +1379,27 @@ msgstr "Impossible de verrouiller"
|
|||||||
msgid "Lock was blocked by an application"
|
msgid "Lock was blocked by an application"
|
||||||
msgstr "Le verrouillage a été bloqué par une application"
|
msgstr "Le verrouillage a été bloqué par une application"
|
||||||
|
|
||||||
#: ../js/ui/search.js:606
|
#: ../js/ui/search.js:594
|
||||||
msgid "Searching…"
|
msgid "Searching…"
|
||||||
msgstr "Recherche en cours…"
|
msgstr "Recherche en cours…"
|
||||||
|
|
||||||
#: ../js/ui/search.js:652
|
#: ../js/ui/search.js:596
|
||||||
msgid "No results."
|
msgid "No results."
|
||||||
msgstr "Aucun résultat."
|
msgstr "Aucun résultat."
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:27
|
#: ../js/ui/shellEntry.js:25
|
||||||
msgid "Copy"
|
msgid "Copy"
|
||||||
msgstr "Copier"
|
msgstr "Copier"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:32
|
#: ../js/ui/shellEntry.js:30
|
||||||
msgid "Paste"
|
msgid "Paste"
|
||||||
msgstr "Coller"
|
msgstr "Coller"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:99
|
#: ../js/ui/shellEntry.js:97
|
||||||
msgid "Show Text"
|
msgid "Show Text"
|
||||||
msgstr "Afficher le texte"
|
msgstr "Afficher le texte"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:101
|
#: ../js/ui/shellEntry.js:99
|
||||||
msgid "Hide Text"
|
msgid "Hide Text"
|
||||||
msgstr "Masquer le texte"
|
msgstr "Masquer le texte"
|
||||||
|
|
||||||
@ -1485,23 +1485,27 @@ msgstr "Non connecté"
|
|||||||
msgid "Brightness"
|
msgid "Brightness"
|
||||||
msgstr "Luminosité"
|
msgstr "Luminosité"
|
||||||
|
|
||||||
#: ../js/ui/status/keyboard.js:406
|
#: ../js/ui/status/keyboard.js:547
|
||||||
msgid "Show Keyboard Layout"
|
msgid "Show Keyboard Layout"
|
||||||
msgstr "Afficher la disposition du clavier"
|
msgstr "Afficher la disposition du clavier"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:56
|
#: ../js/ui/status/location.js:65
|
||||||
msgid "Location"
|
msgid "Location"
|
||||||
msgstr "Localisation"
|
msgstr "Localisation"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:63 ../js/ui/status/location.js:167
|
#: ../js/ui/status/location.js:72 ../js/ui/status/location.js:177
|
||||||
msgid "Disable"
|
msgid "Disable"
|
||||||
msgstr "Désactiver"
|
msgstr "Désactiver"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:166
|
#: ../js/ui/status/location.js:73
|
||||||
|
msgid "Privacy Settings"
|
||||||
|
msgstr "Paramètres de confidentialité"
|
||||||
|
|
||||||
|
#: ../js/ui/status/location.js:176
|
||||||
msgid "In Use"
|
msgid "In Use"
|
||||||
msgstr "En cours d'utilisation"
|
msgstr "En cours d'utilisation"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:170
|
#: ../js/ui/status/location.js:180
|
||||||
msgid "Enable"
|
msgid "Enable"
|
||||||
msgstr "Activer"
|
msgstr "Activer"
|
||||||
|
|
||||||
@ -1736,11 +1740,11 @@ msgstr "Se connecter en tant qu'autre utilisateur"
|
|||||||
msgid "Unlock Window"
|
msgid "Unlock Window"
|
||||||
msgstr "Fenêtre de déverrouillage"
|
msgstr "Fenêtre de déverrouillage"
|
||||||
|
|
||||||
#: ../js/ui/viewSelector.js:232
|
#: ../js/ui/viewSelector.js:158
|
||||||
msgid "Applications"
|
msgid "Applications"
|
||||||
msgstr "Applications"
|
msgstr "Applications"
|
||||||
|
|
||||||
#: ../js/ui/viewSelector.js:236
|
#: ../js/ui/viewSelector.js:162
|
||||||
msgid "Search"
|
msgid "Search"
|
||||||
msgstr "Recherche"
|
msgstr "Recherche"
|
||||||
|
|
||||||
@ -1837,20 +1841,20 @@ msgstr[1] "%u entrées"
|
|||||||
msgid "System Sounds"
|
msgid "System Sounds"
|
||||||
msgstr "Sons système"
|
msgstr "Sons système"
|
||||||
|
|
||||||
#: ../src/main.c:371
|
#: ../src/main.c:373
|
||||||
msgid "Print version"
|
msgid "Print version"
|
||||||
msgstr "Affiche la version"
|
msgstr "Affiche la version"
|
||||||
|
|
||||||
#: ../src/main.c:377
|
#: ../src/main.c:379
|
||||||
msgid "Mode used by GDM for login screen"
|
msgid "Mode used by GDM for login screen"
|
||||||
msgstr "Mode utilisé par GDM pour l'écran de connexion"
|
msgstr "Mode utilisé par GDM pour l'écran de connexion"
|
||||||
|
|
||||||
#: ../src/main.c:383
|
#: ../src/main.c:385
|
||||||
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Utiliser un mode particulier, par ex. « gdm » pour l'écran de connexion"
|
"Utiliser un mode particulier, par ex. « gdm » pour l'écran de connexion"
|
||||||
|
|
||||||
#: ../src/main.c:389
|
#: ../src/main.c:391
|
||||||
msgid "List possible modes"
|
msgid "List possible modes"
|
||||||
msgstr "Lister les modes possibles"
|
msgstr "Lister les modes possibles"
|
||||||
|
|
||||||
|
308
po/gl.po
@ -11,8 +11,8 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: gnome-shell master\n"
|
"Project-Id-Version: gnome-shell master\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2014-08-25 23:06+0200\n"
|
"POT-Creation-Date: 2014-09-23 01:50+0200\n"
|
||||||
"PO-Revision-Date: 2014-08-25 23:08+0200\n"
|
"PO-Revision-Date: 2014-09-23 01:51+0200\n"
|
||||||
"Last-Translator: Fran Dieguez <frandieguez@gnome.org>\n"
|
"Last-Translator: Fran Dieguez <frandieguez@gnome.org>\n"
|
||||||
"Language-Team: gnome-l10n-gl@gnome.org\n"
|
"Language-Team: gnome-l10n-gl@gnome.org\n"
|
||||||
"Language: gl\n"
|
"Language: gl\n"
|
||||||
@ -300,17 +300,17 @@ msgstr "Atrasar os cambios de foco no modo rato até que o punteiro se pare"
|
|||||||
msgid "Captive Portal"
|
msgid "Captive Portal"
|
||||||
msgstr "Portal cautivo"
|
msgstr "Portal cautivo"
|
||||||
|
|
||||||
#: ../js/extensionPrefs/main.js:127
|
#: ../js/extensionPrefs/main.js:123
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "There was an error loading the preferences dialog for %s:"
|
msgid "There was an error loading the preferences dialog for %s:"
|
||||||
msgstr "Produciuse un erro ao cargar o diálogo de preferenzas para %s:"
|
msgstr "Produciuse un erro ao cargar o diálogo de preferenzas para %s:"
|
||||||
|
|
||||||
#: ../js/extensionPrefs/main.js:159
|
#: ../js/extensionPrefs/main.js:155
|
||||||
msgid "GNOME Shell Extensions"
|
msgid "GNOME Shell Extensions"
|
||||||
msgstr "Extensións de GNOME Shell"
|
msgstr "Extensións de GNOME Shell"
|
||||||
|
|
||||||
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:143
|
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:143
|
||||||
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:429
|
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:452
|
||||||
#: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399
|
#: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399
|
||||||
#: ../js/ui/status/network.js:915
|
#: ../js/ui/status/network.js:915
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
@ -334,15 +334,23 @@ msgstr "Iniciar sesión"
|
|||||||
msgid "Choose Session"
|
msgid "Choose Session"
|
||||||
msgstr "Escolla unha sesión"
|
msgstr "Escolla unha sesión"
|
||||||
|
|
||||||
|
#. translators: this message is shown below the user list on the
|
||||||
|
#. login screen. It can be activated to reveal an entry for
|
||||||
|
#. manually entering the username.
|
||||||
#: ../js/gdm/loginDialog.js:429
|
#: ../js/gdm/loginDialog.js:429
|
||||||
msgid "Not listed?"
|
msgid "Not listed?"
|
||||||
msgstr "Non está na lista?"
|
msgstr "Non está na lista?"
|
||||||
|
|
||||||
|
#. Translators: this message is shown below the username entry field
|
||||||
|
#. to clue the user in on how to login to the local network realm
|
||||||
#: ../js/gdm/loginDialog.js:614
|
#: ../js/gdm/loginDialog.js:614
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "(e.g., user or %s)"
|
msgid "(e.g., user or %s)"
|
||||||
msgstr "(p.ex., usuario ou %s)"
|
msgstr "(p.ex., usuario ou %s)"
|
||||||
|
|
||||||
|
#. TTLS and PEAP are actually much more complicated, but this complication
|
||||||
|
#. is not visible here since we only care about phase2 authentication
|
||||||
|
#. (and don't even care of which one)
|
||||||
#: ../js/gdm/loginDialog.js:619 ../js/ui/components/networkAgent.js:269
|
#: ../js/gdm/loginDialog.js:619 ../js/ui/components/networkAgent.js:269
|
||||||
#: ../js/ui/components/networkAgent.js:287
|
#: ../js/ui/components/networkAgent.js:287
|
||||||
msgid "Username: "
|
msgid "Username: "
|
||||||
@ -356,6 +364,11 @@ msgstr "Xanela de inicio de sesión"
|
|||||||
msgid "Authentication error"
|
msgid "Authentication error"
|
||||||
msgstr "Erro de autenticación"
|
msgstr "Erro de autenticación"
|
||||||
|
|
||||||
|
#. We don't show fingerprint messages directly since it's
|
||||||
|
#. not the main auth service. Instead we use the messages
|
||||||
|
#. as a cue to display our own message.
|
||||||
|
#. Translators: this message is shown below the password entry field
|
||||||
|
#. to indicate the user can swipe their finger instead
|
||||||
#: ../js/gdm/util.js:453
|
#: ../js/gdm/util.js:453
|
||||||
msgid "(or swipe finger)"
|
msgid "(or swipe finger)"
|
||||||
msgstr "(ou pase o dedo)"
|
msgstr "(ou pase o dedo)"
|
||||||
@ -364,6 +377,8 @@ msgstr "(ou pase o dedo)"
|
|||||||
msgid "Command not found"
|
msgid "Command not found"
|
||||||
msgstr "Orde non atopada"
|
msgstr "Orde non atopada"
|
||||||
|
|
||||||
|
#. Replace "Error invoking GLib.shell_parse_argv: " with
|
||||||
|
#. something nicer
|
||||||
#: ../js/misc/util.js:148
|
#: ../js/misc/util.js:148
|
||||||
msgid "Could not parse command:"
|
msgid "Could not parse command:"
|
||||||
msgstr "Non foi posíbel analizar a orde:"
|
msgstr "Non foi posíbel analizar a orde:"
|
||||||
@ -373,44 +388,46 @@ msgstr "Non foi posíbel analizar a orde:"
|
|||||||
msgid "Execution of “%s” failed:"
|
msgid "Execution of “%s” failed:"
|
||||||
msgstr "Produciuse un fallo na execución de «%s»:"
|
msgstr "Produciuse un fallo na execución de «%s»:"
|
||||||
|
|
||||||
|
#. TRANSLATORS: this is the title of the wifi captive portal login
|
||||||
|
#. window, until we know the title of the actual login page
|
||||||
#: ../js/portalHelper/main.js:85
|
#: ../js/portalHelper/main.js:85
|
||||||
msgid "Web Authentication Redirect"
|
msgid "Web Authentication Redirect"
|
||||||
msgstr "Redirección web de autenticación"
|
msgstr "Redirección web de autenticación"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:660
|
#: ../js/ui/appDisplay.js:772
|
||||||
msgid "Frequently used applications will appear here"
|
msgid "Frequently used applications will appear here"
|
||||||
msgstr "Os aplicativos usados recentemente aparecerán aquí"
|
msgstr "Os aplicativos usados recentemente aparecerán aquí"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:771
|
#: ../js/ui/appDisplay.js:883
|
||||||
msgid "Frequent"
|
msgid "Frequent"
|
||||||
msgstr "Frecuentes"
|
msgstr "Frecuentes"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:778
|
#: ../js/ui/appDisplay.js:890
|
||||||
msgid "All"
|
msgid "All"
|
||||||
msgstr "Todos"
|
msgstr "Todos"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1650
|
#: ../js/ui/appDisplay.js:1790
|
||||||
msgid "New Window"
|
msgid "New Window"
|
||||||
msgstr "Xanela nova"
|
msgstr "Xanela nova"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1673 ../js/ui/dash.js:285
|
#: ../js/ui/appDisplay.js:1816 ../js/ui/dash.js:285
|
||||||
msgid "Remove from Favorites"
|
msgid "Remove from Favorites"
|
||||||
msgstr "Retirar dos marcadores"
|
msgstr "Retirar dos marcadores"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1679
|
#: ../js/ui/appDisplay.js:1822
|
||||||
msgid "Add to Favorites"
|
msgid "Add to Favorites"
|
||||||
msgstr "Engadir aos favoritos"
|
msgstr "Engadir aos favoritos"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1688
|
#: ../js/ui/appDisplay.js:1831
|
||||||
msgid "Show Details"
|
msgid "Show Details"
|
||||||
msgstr "Mostrar detalles"
|
msgstr "Mostrar detalles"
|
||||||
|
|
||||||
#: ../js/ui/appFavorites.js:122
|
#: ../js/ui/appFavorites.js:132
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s has been added to your favorites."
|
msgid "%s has been added to your favorites."
|
||||||
msgstr "%s foi engadido aos seus favoritos."
|
msgstr "%s foi engadido aos seus favoritos."
|
||||||
|
|
||||||
#: ../js/ui/appFavorites.js:156
|
#: ../js/ui/appFavorites.js:166
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s has been removed from your favorites."
|
msgid "%s has been removed from your favorites."
|
||||||
msgstr "%s retirouse dos seus marcadores."
|
msgstr "%s retirouse dos seus marcadores."
|
||||||
@ -426,14 +443,14 @@ msgstr "Cambiar fondo de escritorio…"
|
|||||||
|
|
||||||
#. Translators: Shown in calendar event list for all day events
|
#. Translators: Shown in calendar event list for all day events
|
||||||
#. * Keep it short, best if you can use less then 10 characters
|
#. * Keep it short, best if you can use less then 10 characters
|
||||||
#. */
|
#.
|
||||||
#: ../js/ui/calendar.js:67
|
#: ../js/ui/calendar.js:67
|
||||||
msgctxt "event list time"
|
msgctxt "event list time"
|
||||||
msgid "All Day"
|
msgid "All Day"
|
||||||
msgstr "Todo o día"
|
msgstr "Todo o día"
|
||||||
|
|
||||||
#. Translators: Shown in calendar event list, if 24h format,
|
#. Translators: Shown in calendar event list, if 24h format,
|
||||||
#. \u2236 is a ratio character, similar to : */
|
#. \u2236 is a ratio character, similar to :
|
||||||
#: ../js/ui/calendar.js:73
|
#: ../js/ui/calendar.js:73
|
||||||
msgctxt "event list time"
|
msgctxt "event list time"
|
||||||
msgid "%H∶%M"
|
msgid "%H∶%M"
|
||||||
@ -441,7 +458,7 @@ msgstr "%H∶%M"
|
|||||||
|
|
||||||
#. Translators: Shown in calendar event list, if 12h format,
|
#. Translators: Shown in calendar event list, if 12h format,
|
||||||
#. \u2236 is a ratio character, similar to : and \u2009 is
|
#. \u2236 is a ratio character, similar to : and \u2009 is
|
||||||
#. a thin space */
|
#. a thin space
|
||||||
#: ../js/ui/calendar.js:82
|
#: ../js/ui/calendar.js:82
|
||||||
msgctxt "event list time"
|
msgctxt "event list time"
|
||||||
msgid "%l∶%M %p"
|
msgid "%l∶%M %p"
|
||||||
@ -451,43 +468,43 @@ msgstr "%l∶%M %p"
|
|||||||
#. *
|
#. *
|
||||||
#. * NOTE: These grid abbreviations are always shown together
|
#. * NOTE: These grid abbreviations are always shown together
|
||||||
#. * and in order, e.g. "S M T W T F S".
|
#. * and in order, e.g. "S M T W T F S".
|
||||||
#. */
|
#.
|
||||||
#: ../js/ui/calendar.js:113
|
#: ../js/ui/calendar.js:113
|
||||||
msgctxt "grid sunday"
|
msgctxt "grid sunday"
|
||||||
msgid "S"
|
msgid "S"
|
||||||
msgstr "D"
|
msgstr "D"
|
||||||
|
|
||||||
#. Translators: Calendar grid abbreviation for Monday */
|
#. Translators: Calendar grid abbreviation for Monday
|
||||||
#: ../js/ui/calendar.js:115
|
#: ../js/ui/calendar.js:115
|
||||||
msgctxt "grid monday"
|
msgctxt "grid monday"
|
||||||
msgid "M"
|
msgid "M"
|
||||||
msgstr "L"
|
msgstr "L"
|
||||||
|
|
||||||
#. Translators: Calendar grid abbreviation for Tuesday */
|
#. Translators: Calendar grid abbreviation for Tuesday
|
||||||
#: ../js/ui/calendar.js:117
|
#: ../js/ui/calendar.js:117
|
||||||
msgctxt "grid tuesday"
|
msgctxt "grid tuesday"
|
||||||
msgid "T"
|
msgid "T"
|
||||||
msgstr "M"
|
msgstr "M"
|
||||||
|
|
||||||
#. Translators: Calendar grid abbreviation for Wednesday */
|
#. Translators: Calendar grid abbreviation for Wednesday
|
||||||
#: ../js/ui/calendar.js:119
|
#: ../js/ui/calendar.js:119
|
||||||
msgctxt "grid wednesday"
|
msgctxt "grid wednesday"
|
||||||
msgid "W"
|
msgid "W"
|
||||||
msgstr "W"
|
msgstr "W"
|
||||||
|
|
||||||
#. Translators: Calendar grid abbreviation for Thursday */
|
#. Translators: Calendar grid abbreviation for Thursday
|
||||||
#: ../js/ui/calendar.js:121
|
#: ../js/ui/calendar.js:121
|
||||||
msgctxt "grid thursday"
|
msgctxt "grid thursday"
|
||||||
msgid "T"
|
msgid "T"
|
||||||
msgstr "X"
|
msgstr "X"
|
||||||
|
|
||||||
#. Translators: Calendar grid abbreviation for Friday */
|
#. Translators: Calendar grid abbreviation for Friday
|
||||||
#: ../js/ui/calendar.js:123
|
#: ../js/ui/calendar.js:123
|
||||||
msgctxt "grid friday"
|
msgctxt "grid friday"
|
||||||
msgid "F"
|
msgid "F"
|
||||||
msgstr "V"
|
msgstr "V"
|
||||||
|
|
||||||
#. Translators: Calendar grid abbreviation for Saturday */
|
#. Translators: Calendar grid abbreviation for Saturday
|
||||||
#: ../js/ui/calendar.js:125
|
#: ../js/ui/calendar.js:125
|
||||||
msgctxt "grid saturday"
|
msgctxt "grid saturday"
|
||||||
msgid "S"
|
msgid "S"
|
||||||
@ -498,43 +515,43 @@ msgstr "S"
|
|||||||
#. * NOTE: These list abbreviations are normally not shown together
|
#. * NOTE: These list abbreviations are normally not shown together
|
||||||
#. * so they need to be unique (e.g. Tuesday and Thursday cannot
|
#. * so they need to be unique (e.g. Tuesday and Thursday cannot
|
||||||
#. * both be 'T').
|
#. * both be 'T').
|
||||||
#. */
|
#.
|
||||||
#: ../js/ui/calendar.js:138
|
#: ../js/ui/calendar.js:138
|
||||||
msgctxt "list sunday"
|
msgctxt "list sunday"
|
||||||
msgid "Su"
|
msgid "Su"
|
||||||
msgstr "Do"
|
msgstr "Do"
|
||||||
|
|
||||||
#. Translators: Event list abbreviation for Monday */
|
#. Translators: Event list abbreviation for Monday
|
||||||
#: ../js/ui/calendar.js:140
|
#: ../js/ui/calendar.js:140
|
||||||
msgctxt "list monday"
|
msgctxt "list monday"
|
||||||
msgid "M"
|
msgid "M"
|
||||||
msgstr "L"
|
msgstr "L"
|
||||||
|
|
||||||
#. Translators: Event list abbreviation for Tuesday */
|
#. Translators: Event list abbreviation for Tuesday
|
||||||
#: ../js/ui/calendar.js:142
|
#: ../js/ui/calendar.js:142
|
||||||
msgctxt "list tuesday"
|
msgctxt "list tuesday"
|
||||||
msgid "T"
|
msgid "T"
|
||||||
msgstr "M"
|
msgstr "M"
|
||||||
|
|
||||||
#. Translators: Event list abbreviation for Wednesday */
|
#. Translators: Event list abbreviation for Wednesday
|
||||||
#: ../js/ui/calendar.js:144
|
#: ../js/ui/calendar.js:144
|
||||||
msgctxt "list wednesday"
|
msgctxt "list wednesday"
|
||||||
msgid "W"
|
msgid "W"
|
||||||
msgstr "W"
|
msgstr "W"
|
||||||
|
|
||||||
#. Translators: Event list abbreviation for Thursday */
|
#. Translators: Event list abbreviation for Thursday
|
||||||
#: ../js/ui/calendar.js:146
|
#: ../js/ui/calendar.js:146
|
||||||
msgctxt "list thursday"
|
msgctxt "list thursday"
|
||||||
msgid "Th"
|
msgid "Th"
|
||||||
msgstr "X"
|
msgstr "X"
|
||||||
|
|
||||||
#. Translators: Event list abbreviation for Friday */
|
#. Translators: Event list abbreviation for Friday
|
||||||
#: ../js/ui/calendar.js:148
|
#: ../js/ui/calendar.js:148
|
||||||
msgctxt "list friday"
|
msgctxt "list friday"
|
||||||
msgid "F"
|
msgid "F"
|
||||||
msgstr "V"
|
msgstr "V"
|
||||||
|
|
||||||
#. Translators: Event list abbreviation for Saturday */
|
#. Translators: Event list abbreviation for Saturday
|
||||||
#: ../js/ui/calendar.js:150
|
#: ../js/ui/calendar.js:150
|
||||||
msgctxt "list saturday"
|
msgctxt "list saturday"
|
||||||
msgid "S"
|
msgid "S"
|
||||||
@ -548,18 +565,18 @@ msgstr "Anterior mes"
|
|||||||
msgid "Next month"
|
msgid "Next month"
|
||||||
msgstr "Seguinte mes"
|
msgstr "Seguinte mes"
|
||||||
|
|
||||||
#. Translators: Text to show if there are no events */
|
#. Translators: Text to show if there are no events
|
||||||
#: ../js/ui/calendar.js:781
|
#: ../js/ui/calendar.js:781
|
||||||
msgid "Nothing Scheduled"
|
msgid "Nothing Scheduled"
|
||||||
msgstr "Nada programado"
|
msgstr "Nada programado"
|
||||||
|
|
||||||
#. Translators: Shown on calendar heading when selected day occurs on current year */
|
#. Translators: Shown on calendar heading when selected day occurs on current year
|
||||||
#: ../js/ui/calendar.js:799
|
#: ../js/ui/calendar.js:799
|
||||||
msgctxt "calendar heading"
|
msgctxt "calendar heading"
|
||||||
msgid "%A, %B %d"
|
msgid "%A, %B %d"
|
||||||
msgstr "%A, %d de %B"
|
msgstr "%A, %d de %B"
|
||||||
|
|
||||||
#. Translators: Shown on calendar heading when selected day occurs on different year */
|
#. Translators: Shown on calendar heading when selected day occurs on different year
|
||||||
#: ../js/ui/calendar.js:802
|
#: ../js/ui/calendar.js:802
|
||||||
msgctxt "calendar heading"
|
msgctxt "calendar heading"
|
||||||
msgid "%A, %B %d, %Y"
|
msgid "%A, %B %d, %Y"
|
||||||
@ -602,11 +619,11 @@ msgstr "Abrir con %s"
|
|||||||
msgid "Eject"
|
msgid "Eject"
|
||||||
msgstr "Expulsar"
|
msgstr "Expulsar"
|
||||||
|
|
||||||
#: ../js/ui/components/keyring.js:93 ../js/ui/components/polkitAgent.js:285
|
#: ../js/ui/components/keyring.js:94 ../js/ui/components/polkitAgent.js:285
|
||||||
msgid "Password:"
|
msgid "Password:"
|
||||||
msgstr "Contrasinal:"
|
msgstr "Contrasinal:"
|
||||||
|
|
||||||
#: ../js/ui/components/keyring.js:113
|
#: ../js/ui/components/keyring.js:120
|
||||||
msgid "Type again:"
|
msgid "Type again:"
|
||||||
msgstr "Escriba de novo:"
|
msgstr "Escriba de novo:"
|
||||||
|
|
||||||
@ -615,6 +632,7 @@ msgstr "Escriba de novo:"
|
|||||||
msgid "Connect"
|
msgid "Connect"
|
||||||
msgstr "Conectar"
|
msgstr "Conectar"
|
||||||
|
|
||||||
|
#. Cisco LEAP
|
||||||
#: ../js/ui/components/networkAgent.js:231
|
#: ../js/ui/components/networkAgent.js:231
|
||||||
#: ../js/ui/components/networkAgent.js:243
|
#: ../js/ui/components/networkAgent.js:243
|
||||||
#: ../js/ui/components/networkAgent.js:271
|
#: ../js/ui/components/networkAgent.js:271
|
||||||
@ -623,6 +641,7 @@ msgstr "Conectar"
|
|||||||
msgid "Password: "
|
msgid "Password: "
|
||||||
msgstr "Contrasinal: "
|
msgstr "Contrasinal: "
|
||||||
|
|
||||||
|
#. static WEP
|
||||||
#: ../js/ui/components/networkAgent.js:236
|
#: ../js/ui/components/networkAgent.js:236
|
||||||
msgid "Key: "
|
msgid "Key: "
|
||||||
msgstr "Chave: "
|
msgstr "Chave: "
|
||||||
@ -700,19 +719,23 @@ msgstr "Autenticar"
|
|||||||
#. Translators: "that didn't work" refers to the fact that the
|
#. Translators: "that didn't work" refers to the fact that the
|
||||||
#. * requested authentication was not gained; this can happen
|
#. * requested authentication was not gained; this can happen
|
||||||
#. * because of an authentication error (like invalid password),
|
#. * because of an authentication error (like invalid password),
|
||||||
#. * for instance. */
|
#. * for instance.
|
||||||
#: ../js/ui/components/polkitAgent.js:271 ../js/ui/shellMountOperation.js:383
|
#: ../js/ui/components/polkitAgent.js:271 ../js/ui/shellMountOperation.js:383
|
||||||
msgid "Sorry, that didn't work. Please try again."
|
msgid "Sorry, that didn't work. Please try again."
|
||||||
msgstr "Desculpe, iso non funcionou. Ténteo de novo."
|
msgstr "Desculpe, iso non funcionou. Ténteo de novo."
|
||||||
|
|
||||||
|
#. FIXME: We don't have a 'chat room' icon (bgo #653737) use
|
||||||
|
#. system-users for now as Empathy does.
|
||||||
#: ../js/ui/components/telepathyClient.js:240
|
#: ../js/ui/components/telepathyClient.js:240
|
||||||
msgid "Invitation"
|
msgid "Invitation"
|
||||||
msgstr "Convite"
|
msgstr "Convite"
|
||||||
|
|
||||||
|
#. We got the TpContact
|
||||||
#: ../js/ui/components/telepathyClient.js:300
|
#: ../js/ui/components/telepathyClient.js:300
|
||||||
msgid "Call"
|
msgid "Call"
|
||||||
msgstr "Chamar"
|
msgstr "Chamar"
|
||||||
|
|
||||||
|
#. We got the TpContact
|
||||||
#: ../js/ui/components/telepathyClient.js:316
|
#: ../js/ui/components/telepathyClient.js:316
|
||||||
msgid "File Transfer"
|
msgid "File Transfer"
|
||||||
msgstr "Transferencia de ficheiro"
|
msgstr "Transferencia de ficheiro"
|
||||||
@ -729,77 +752,85 @@ msgstr "Desactivar silencio"
|
|||||||
msgid "Mute"
|
msgid "Mute"
|
||||||
msgstr "Silenciar"
|
msgstr "Silenciar"
|
||||||
|
|
||||||
#. Translators: Time in 24h format */
|
#. Translators: Time in 24h format
|
||||||
#: ../js/ui/components/telepathyClient.js:953
|
#: ../js/ui/components/telepathyClient.js:953
|
||||||
msgid "%H∶%M"
|
msgid "%H∶%M"
|
||||||
msgstr "%H∶%M"
|
msgstr "%H∶%M"
|
||||||
|
|
||||||
#. Translators: this is the word "Yesterday" followed by a
|
#. Translators: this is the word "Yesterday" followed by a
|
||||||
#. time string in 24h format. i.e. "Yesterday, 14:30" */
|
#. time string in 24h format. i.e. "Yesterday, 14:30"
|
||||||
#: ../js/ui/components/telepathyClient.js:960
|
#: ../js/ui/components/telepathyClient.js:960
|
||||||
|
#, no-c-format
|
||||||
msgid "Yesterday, %H∶%M"
|
msgid "Yesterday, %H∶%M"
|
||||||
msgstr "Onte, %H:%M"
|
msgstr "Onte, %H:%M"
|
||||||
|
|
||||||
#. Translators: this is the week day name followed by a time
|
#. Translators: this is the week day name followed by a time
|
||||||
#. string in 24h format. i.e. "Monday, 14:30" */
|
#. string in 24h format. i.e. "Monday, 14:30"
|
||||||
#: ../js/ui/components/telepathyClient.js:967
|
#: ../js/ui/components/telepathyClient.js:967
|
||||||
|
#, no-c-format
|
||||||
msgid "%A, %H∶%M"
|
msgid "%A, %H∶%M"
|
||||||
msgstr "%A ás %H:%M"
|
msgstr "%A ás %H:%M"
|
||||||
|
|
||||||
#. Translators: this is the month name and day number
|
#. Translators: this is the month name and day number
|
||||||
#. followed by a time string in 24h format.
|
#. followed by a time string in 24h format.
|
||||||
#. i.e. "May 25, 14:30" */
|
#. i.e. "May 25, 14:30"
|
||||||
#: ../js/ui/components/telepathyClient.js:974
|
#: ../js/ui/components/telepathyClient.js:974
|
||||||
|
#, no-c-format
|
||||||
msgid "%B %d, %H∶%M"
|
msgid "%B %d, %H∶%M"
|
||||||
msgstr "%d de %B ás %H:%M"
|
msgstr "%d de %B ás %H:%M"
|
||||||
|
|
||||||
#. Translators: this is the month name, day number, year
|
#. Translators: this is the month name, day number, year
|
||||||
#. number followed by a time string in 24h format.
|
#. number followed by a time string in 24h format.
|
||||||
#. i.e. "May 25 2012, 14:30" */
|
#. i.e. "May 25 2012, 14:30"
|
||||||
#: ../js/ui/components/telepathyClient.js:980
|
#: ../js/ui/components/telepathyClient.js:980
|
||||||
|
#, no-c-format
|
||||||
msgid "%B %d %Y, %H∶%M"
|
msgid "%B %d %Y, %H∶%M"
|
||||||
msgstr "%d de %B de %Y ás %H:%M"
|
msgstr "%d de %B de %Y ás %H:%M"
|
||||||
|
|
||||||
#. Translators: Time in 24h format */
|
#. Translators: Time in 24h format
|
||||||
#: ../js/ui/components/telepathyClient.js:986
|
#: ../js/ui/components/telepathyClient.js:986
|
||||||
msgid "%l∶%M %p"
|
msgid "%l∶%M %p"
|
||||||
msgstr "%l:%M %p"
|
msgstr "%l:%M %p"
|
||||||
|
|
||||||
#. Translators: this is the word "Yesterday" followed by a
|
#. Translators: this is the word "Yesterday" followed by a
|
||||||
#. time string in 12h format. i.e. "Yesterday, 2:30 pm" */
|
#. time string in 12h format. i.e. "Yesterday, 2:30 pm"
|
||||||
#: ../js/ui/components/telepathyClient.js:993
|
#: ../js/ui/components/telepathyClient.js:993
|
||||||
|
#, no-c-format
|
||||||
msgid "Yesterday, %l∶%M %p"
|
msgid "Yesterday, %l∶%M %p"
|
||||||
msgstr "Onte, %H:%M"
|
msgstr "Onte, %H:%M"
|
||||||
|
|
||||||
#. Translators: this is the week day name followed by a time
|
#. Translators: this is the week day name followed by a time
|
||||||
#. string in 12h format. i.e. "Monday, 2:30 pm" */
|
#. string in 12h format. i.e. "Monday, 2:30 pm"
|
||||||
#: ../js/ui/components/telepathyClient.js:1000
|
#: ../js/ui/components/telepathyClient.js:1000
|
||||||
|
#, no-c-format
|
||||||
msgid "%A, %l∶%M %p"
|
msgid "%A, %l∶%M %p"
|
||||||
msgstr "%A, %l∶%M %p"
|
msgstr "%A, %l∶%M %p"
|
||||||
|
|
||||||
#. Translators: this is the month name and day number
|
#. Translators: this is the month name and day number
|
||||||
#. followed by a time string in 12h format.
|
#. followed by a time string in 12h format.
|
||||||
#. i.e. "May 25, 2:30 pm" */
|
#. i.e. "May 25, 2:30 pm"
|
||||||
#: ../js/ui/components/telepathyClient.js:1007
|
#: ../js/ui/components/telepathyClient.js:1007
|
||||||
|
#, no-c-format
|
||||||
msgid "%B %d, %l∶%M %p"
|
msgid "%B %d, %l∶%M %p"
|
||||||
msgstr "%d de %B, %l∶%M %p"
|
msgstr "%d de %B, %l∶%M %p"
|
||||||
|
|
||||||
#. Translators: this is the month name, day number, year
|
#. Translators: this is the month name, day number, year
|
||||||
#. number followed by a time string in 12h format.
|
#. number followed by a time string in 12h format.
|
||||||
#. i.e. "May 25 2012, 2:30 pm"*/
|
#. i.e. "May 25 2012, 2:30 pm"
|
||||||
#: ../js/ui/components/telepathyClient.js:1013
|
#: ../js/ui/components/telepathyClient.js:1013
|
||||||
|
#, no-c-format
|
||||||
msgid "%B %d %Y, %l∶%M %p"
|
msgid "%B %d %Y, %l∶%M %p"
|
||||||
msgstr "%d de %B de %Y, %l∶%M %p"
|
msgstr "%d de %B de %Y, %l∶%M %p"
|
||||||
|
|
||||||
#. Translators: this is the other person changing their old IM name to their new
|
#. Translators: this is the other person changing their old IM name to their new
|
||||||
#. IM name. */
|
#. IM name.
|
||||||
#: ../js/ui/components/telepathyClient.js:1045
|
#: ../js/ui/components/telepathyClient.js:1045
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s is now known as %s"
|
msgid "%s is now known as %s"
|
||||||
msgstr "Agora %s chámase %s"
|
msgstr "Agora %s chámase %s"
|
||||||
|
|
||||||
#. translators: argument is a room name like
|
#. translators: argument is a room name like
|
||||||
#. * room@jabber.org for example. */
|
#. * room@jabber.org for example.
|
||||||
#: ../js/ui/components/telepathyClient.js:1149
|
#: ../js/ui/components/telepathyClient.js:1149
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Invitation to %s"
|
msgid "Invitation to %s"
|
||||||
@ -807,7 +838,7 @@ msgstr "Convite a %s"
|
|||||||
|
|
||||||
#. translators: first argument is the name of a contact and the second
|
#. translators: first argument is the name of a contact and the second
|
||||||
#. * one the name of a room. "Alice is inviting you to join room@jabber.org
|
#. * one the name of a room. "Alice is inviting you to join room@jabber.org
|
||||||
#. * for example. */
|
#. * for example.
|
||||||
#: ../js/ui/components/telepathyClient.js:1157
|
#: ../js/ui/components/telepathyClient.js:1157
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s is inviting you to join %s"
|
msgid "%s is inviting you to join %s"
|
||||||
@ -826,19 +857,19 @@ msgstr "Rexeitar"
|
|||||||
msgid "Accept"
|
msgid "Accept"
|
||||||
msgstr "Aceptar"
|
msgstr "Aceptar"
|
||||||
|
|
||||||
#. translators: argument is a contact name like Alice for example. */
|
#. translators: argument is a contact name like Alice for example.
|
||||||
#: ../js/ui/components/telepathyClient.js:1184
|
#: ../js/ui/components/telepathyClient.js:1184
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Video call from %s"
|
msgid "Video call from %s"
|
||||||
msgstr "Videochamada de %s"
|
msgstr "Videochamada de %s"
|
||||||
|
|
||||||
#. translators: argument is a contact name like Alice for example. */
|
#. translators: argument is a contact name like Alice for example.
|
||||||
#: ../js/ui/components/telepathyClient.js:1187
|
#: ../js/ui/components/telepathyClient.js:1187
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Call from %s"
|
msgid "Call from %s"
|
||||||
msgstr "Chamada de %s"
|
msgstr "Chamada de %s"
|
||||||
|
|
||||||
#. translators: this is a button label (verb), not a noun */
|
#. translators: this is a button label (verb), not a noun
|
||||||
#: ../js/ui/components/telepathyClient.js:1201
|
#: ../js/ui/components/telepathyClient.js:1201
|
||||||
msgid "Answer"
|
msgid "Answer"
|
||||||
msgstr "Responder"
|
msgstr "Responder"
|
||||||
@ -847,13 +878,13 @@ msgstr "Responder"
|
|||||||
#. * the contact's alias and the second one is the
|
#. * the contact's alias and the second one is the
|
||||||
#. * file name. The string will be something
|
#. * file name. The string will be something
|
||||||
#. * like: "Alice is sending you test.ogg"
|
#. * like: "Alice is sending you test.ogg"
|
||||||
#. */
|
#.
|
||||||
#: ../js/ui/components/telepathyClient.js:1222
|
#: ../js/ui/components/telepathyClient.js:1222
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s is sending you %s"
|
msgid "%s is sending you %s"
|
||||||
msgstr "%s esta enviándolle %s"
|
msgstr "%s esta enviándolle %s"
|
||||||
|
|
||||||
#. To translators: The parameter is the contact's alias */
|
#. To translators: The parameter is the contact's alias
|
||||||
#: ../js/ui/components/telepathyClient.js:1251
|
#: ../js/ui/components/telepathyClient.js:1251
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s would like permission to see when you are online"
|
msgid "%s would like permission to see when you are online"
|
||||||
@ -967,7 +998,7 @@ msgid "Internal error"
|
|||||||
msgstr "Erro interno"
|
msgstr "Erro interno"
|
||||||
|
|
||||||
#. translators: argument is the account name, like
|
#. translators: argument is the account name, like
|
||||||
#. * name@jabber.org for example. */
|
#. * name@jabber.org for example.
|
||||||
#: ../js/ui/components/telepathyClient.js:1393
|
#: ../js/ui/components/telepathyClient.js:1393
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Unable to connect to %s"
|
msgid "Unable to connect to %s"
|
||||||
@ -981,7 +1012,7 @@ msgstr "Ver conta"
|
|||||||
msgid "Unknown reason"
|
msgid "Unknown reason"
|
||||||
msgstr "Razón descoñecida"
|
msgstr "Razón descoñecida"
|
||||||
|
|
||||||
#: ../js/ui/ctrlAltTab.js:29 ../js/ui/viewSelector.js:228
|
#: ../js/ui/ctrlAltTab.js:29 ../js/ui/viewSelector.js:154
|
||||||
msgid "Windows"
|
msgid "Windows"
|
||||||
msgstr "Xanelas"
|
msgstr "Xanelas"
|
||||||
|
|
||||||
@ -989,6 +1020,8 @@ msgstr "Xanelas"
|
|||||||
msgid "Show Applications"
|
msgid "Show Applications"
|
||||||
msgstr "Mostrar aplicativos"
|
msgstr "Mostrar aplicativos"
|
||||||
|
|
||||||
|
#. Translators: this is the name of the dock/favorites area on
|
||||||
|
#. the left of the overview
|
||||||
#: ../js/ui/dash.js:445
|
#: ../js/ui/dash.js:445
|
||||||
msgid "Dash"
|
msgid "Dash"
|
||||||
msgstr "Taboleiro"
|
msgstr "Taboleiro"
|
||||||
@ -1007,91 +1040,91 @@ msgstr "Preferencias de data e hora"
|
|||||||
|
|
||||||
#. Translators: This is the date format to use when the calendar popup is
|
#. Translators: This is the date format to use when the calendar popup is
|
||||||
#. * shown - it is shown just below the time in the shell (e.g. "Tue 9:29 AM").
|
#. * shown - it is shown just below the time in the shell (e.g. "Tue 9:29 AM").
|
||||||
#. */
|
#.
|
||||||
#: ../js/ui/dateMenu.js:204
|
#: ../js/ui/dateMenu.js:204
|
||||||
msgid "%A %B %e, %Y"
|
msgid "%A %B %e, %Y"
|
||||||
msgstr "%a, %e de %B, %Y"
|
msgstr "%a, %e de %B, %Y"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:66
|
#: ../js/ui/endSessionDialog.js:64
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Log Out %s"
|
msgid "Log Out %s"
|
||||||
msgstr "Saír da sesión %s"
|
msgstr "Saír da sesión %s"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:67
|
#: ../js/ui/endSessionDialog.js:65
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Log Out"
|
msgid "Log Out"
|
||||||
msgstr "Saír da sesión"
|
msgstr "Saír da sesión"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:69
|
#: ../js/ui/endSessionDialog.js:67
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s will be logged out automatically in %d second."
|
msgid "%s will be logged out automatically in %d second."
|
||||||
msgid_plural "%s will be logged out automatically in %d seconds."
|
msgid_plural "%s will be logged out automatically in %d seconds."
|
||||||
msgstr[0] "Vaise pechar a sesión de %s en %d segundo."
|
msgstr[0] "Vaise pechar a sesión de %s en %d segundo."
|
||||||
msgstr[1] "Vaise pechar a sesión de %s en %d segundos."
|
msgstr[1] "Vaise pechar a sesión de %s en %d segundos."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:74
|
#: ../js/ui/endSessionDialog.js:72
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "You will be logged out automatically in %d second."
|
msgid "You will be logged out automatically in %d second."
|
||||||
msgid_plural "You will be logged out automatically in %d seconds."
|
msgid_plural "You will be logged out automatically in %d seconds."
|
||||||
msgstr[0] "A súa sesión pecharase automaticamente en %d segundo."
|
msgstr[0] "A súa sesión pecharase automaticamente en %d segundo."
|
||||||
msgstr[1] "A súa sesión pecharase automaticamente en %d segundos."
|
msgstr[1] "A súa sesión pecharase automaticamente en %d segundos."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:80
|
#: ../js/ui/endSessionDialog.js:78
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Log Out"
|
msgid "Log Out"
|
||||||
msgstr "Saír da sesión"
|
msgstr "Saír da sesión"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:86
|
#: ../js/ui/endSessionDialog.js:84
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Power Off"
|
msgid "Power Off"
|
||||||
msgstr "Apagar"
|
msgstr "Apagar"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:87
|
#: ../js/ui/endSessionDialog.js:85
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Install Updates & Power Off"
|
msgid "Install Updates & Power Off"
|
||||||
msgstr "Instalar anovacións e apagar"
|
msgstr "Instalar anovacións e apagar"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:89
|
#: ../js/ui/endSessionDialog.js:87
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "The system will power off automatically in %d second."
|
msgid "The system will power off automatically in %d second."
|
||||||
msgid_plural "The system will power off automatically in %d seconds."
|
msgid_plural "The system will power off automatically in %d seconds."
|
||||||
msgstr[0] "O sistema apagarase automaticamente en %d segundo."
|
msgstr[0] "O sistema apagarase automaticamente en %d segundo."
|
||||||
msgstr[1] "O sistema apagarase automaticamente en %d segundos."
|
msgstr[1] "O sistema apagarase automaticamente en %d segundos."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:93
|
#: ../js/ui/endSessionDialog.js:91
|
||||||
msgctxt "checkbox"
|
msgctxt "checkbox"
|
||||||
msgid "Install pending software updates"
|
msgid "Install pending software updates"
|
||||||
msgstr "Instalar anovacións de software pendentes"
|
msgstr "Instalar anovacións de software pendentes"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:96 ../js/ui/endSessionDialog.js:113
|
#: ../js/ui/endSessionDialog.js:94 ../js/ui/endSessionDialog.js:111
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Restart"
|
msgid "Restart"
|
||||||
msgstr "Reiniciar"
|
msgstr "Reiniciar"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:98
|
#: ../js/ui/endSessionDialog.js:96
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Power Off"
|
msgid "Power Off"
|
||||||
msgstr "Apagar"
|
msgstr "Apagar"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:105
|
#: ../js/ui/endSessionDialog.js:103
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Restart"
|
msgid "Restart"
|
||||||
msgstr "Reiniciar"
|
msgstr "Reiniciar"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:107
|
#: ../js/ui/endSessionDialog.js:105
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "The system will restart automatically in %d second."
|
msgid "The system will restart automatically in %d second."
|
||||||
msgid_plural "The system will restart automatically in %d seconds."
|
msgid_plural "The system will restart automatically in %d seconds."
|
||||||
msgstr[0] "O sistema reiniciarase automaticamente en %d segundo."
|
msgstr[0] "O sistema reiniciarase automaticamente en %d segundo."
|
||||||
msgstr[1] "O sistema reiniciarase automaticamente en %d segundos."
|
msgstr[1] "O sistema reiniciarase automaticamente en %d segundos."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:121
|
#: ../js/ui/endSessionDialog.js:119
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Restart & Install Updates"
|
msgid "Restart & Install Updates"
|
||||||
msgstr "Reiniciar e instalar actualizacións"
|
msgstr "Reiniciar e instalar actualizacións"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:123
|
#: ../js/ui/endSessionDialog.js:121
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "The system will automatically restart and install updates in %d second."
|
msgid "The system will automatically restart and install updates in %d second."
|
||||||
msgid_plural ""
|
msgid_plural ""
|
||||||
@ -1103,41 +1136,41 @@ msgstr[1] ""
|
|||||||
"O sistema reiniciarase automaticamente e instalará as actualizacións en %d "
|
"O sistema reiniciarase automaticamente e instalará as actualizacións en %d "
|
||||||
"segundos."
|
"segundos."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:129
|
#: ../js/ui/endSessionDialog.js:127
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Restart & Install"
|
msgid "Restart & Install"
|
||||||
msgstr "Reiniciar e instalar"
|
msgstr "Reiniciar e instalar"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:130
|
#: ../js/ui/endSessionDialog.js:128
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Install & Power Off"
|
msgid "Install & Power Off"
|
||||||
msgstr "Instalar e apagar"
|
msgstr "Instalar e apagar"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:131
|
#: ../js/ui/endSessionDialog.js:129
|
||||||
msgctxt "checkbox"
|
msgctxt "checkbox"
|
||||||
msgid "Power off after updates are installed"
|
msgid "Power off after updates are installed"
|
||||||
msgstr "Apagar despois de instalar as anovacións"
|
msgstr "Apagar despois de instalar as anovacións"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:315
|
#: ../js/ui/endSessionDialog.js:338
|
||||||
msgid "Running on battery power: please plug in before installing updates."
|
msgid "Running on battery power: please plug in before installing updates."
|
||||||
msgstr "Con enerxía da batería: enchufar antes de instalar anovacións."
|
msgstr "Con enerxía da batería: enchufar antes de instalar anovacións."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:332
|
#: ../js/ui/endSessionDialog.js:355
|
||||||
msgid "Some applications are busy or have unsaved work."
|
msgid "Some applications are busy or have unsaved work."
|
||||||
msgstr "Algúns aplicativos están ocupados ou teñen traballo sen gardar."
|
msgstr "Algúns aplicativos están ocupados ou teñen traballo sen gardar."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:339
|
#: ../js/ui/endSessionDialog.js:362
|
||||||
msgid "Other users are logged in."
|
msgid "Other users are logged in."
|
||||||
msgstr "Hai outros usuarios conectados."
|
msgstr "Hai outros usuarios conectados."
|
||||||
|
|
||||||
#. Translators: Remote here refers to a remote session, like a ssh login */
|
#. Translators: Remote here refers to a remote session, like a ssh login
|
||||||
#: ../js/ui/endSessionDialog.js:619
|
#: ../js/ui/endSessionDialog.js:640
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s (remote)"
|
msgid "%s (remote)"
|
||||||
msgstr "%s (remoto)"
|
msgstr "%s (remoto)"
|
||||||
|
|
||||||
#. Translators: Console here refers to a tty like a VT console */
|
#. Translators: Console here refers to a tty like a VT console
|
||||||
#: ../js/ui/endSessionDialog.js:622
|
#: ../js/ui/endSessionDialog.js:643
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s (console)"
|
msgid "%s (console)"
|
||||||
msgstr "%s (consola)"
|
msgstr "%s (consola)"
|
||||||
@ -1151,7 +1184,7 @@ msgstr "Instalar"
|
|||||||
msgid "Download and install “%s” from extensions.gnome.org?"
|
msgid "Download and install “%s” from extensions.gnome.org?"
|
||||||
msgstr "Desexa descargar e instalar «%s» desde extensions.gnome.org?"
|
msgstr "Desexa descargar e instalar «%s» desde extensions.gnome.org?"
|
||||||
|
|
||||||
#: ../js/ui/keyboard.js:653 ../js/ui/status/keyboard.js:339
|
#: ../js/ui/keyboard.js:692 ../js/ui/status/keyboard.js:523
|
||||||
msgid "Keyboard"
|
msgid "Keyboard"
|
||||||
msgstr "Teclado"
|
msgstr "Teclado"
|
||||||
|
|
||||||
@ -1159,7 +1192,7 @@ msgstr "Teclado"
|
|||||||
msgid "No extensions installed"
|
msgid "No extensions installed"
|
||||||
msgstr "Non hai ningunha extensión instalada"
|
msgstr "Non hai ningunha extensión instalada"
|
||||||
|
|
||||||
#. Translators: argument is an extension UUID. */
|
#. Translators: argument is an extension UUID.
|
||||||
#: ../js/ui/lookingGlass.js:697
|
#: ../js/ui/lookingGlass.js:697
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s has not emitted any errors."
|
msgid "%s has not emitted any errors."
|
||||||
@ -1173,16 +1206,16 @@ msgstr "Ocultar erros"
|
|||||||
msgid "Show Errors"
|
msgid "Show Errors"
|
||||||
msgstr "Mostrar erros"
|
msgstr "Mostrar erros"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:716 ../js/ui/status/location.js:62
|
#: ../js/ui/lookingGlass.js:716 ../js/ui/status/location.js:71
|
||||||
#: ../js/ui/status/location.js:166
|
#: ../js/ui/status/location.js:176
|
||||||
msgid "Enabled"
|
msgid "Enabled"
|
||||||
msgstr "Activado"
|
msgstr "Activado"
|
||||||
|
|
||||||
#. Translators: this is for a network device that cannot be activated
|
#. Translators: this is for a network device that cannot be activated
|
||||||
#. because it's disabled by rfkill (airplane mode) */
|
#. because it's disabled by rfkill (airplane mode)
|
||||||
#. translators:
|
#. translators:
|
||||||
#. * The device has been disabled
|
#. * The device has been disabled
|
||||||
#: ../js/ui/lookingGlass.js:719 ../js/ui/status/location.js:169
|
#: ../js/ui/lookingGlass.js:719 ../js/ui/status/location.js:179
|
||||||
#: ../js/ui/status/network.js:592 ../src/gvc/gvc-mixer-control.c:1830
|
#: ../js/ui/status/network.js:592 ../src/gvc/gvc-mixer-control.c:1830
|
||||||
msgid "Disabled"
|
msgid "Disabled"
|
||||||
msgstr "Desactivado"
|
msgstr "Desactivado"
|
||||||
@ -1207,39 +1240,39 @@ msgstr "Ver fonte"
|
|||||||
msgid "Web Page"
|
msgid "Web Page"
|
||||||
msgstr "Páxina web"
|
msgstr "Páxina web"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1325
|
#: ../js/ui/messageTray.js:1327
|
||||||
msgid "Open"
|
msgid "Open"
|
||||||
msgstr "Abrir"
|
msgstr "Abrir"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1332
|
#: ../js/ui/messageTray.js:1334
|
||||||
msgid "Remove"
|
msgid "Remove"
|
||||||
msgstr "Retirar"
|
msgstr "Retirar"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1629
|
#: ../js/ui/messageTray.js:1631
|
||||||
msgid "Notifications"
|
msgid "Notifications"
|
||||||
msgstr "Notificacións"
|
msgstr "Notificacións"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1636
|
#: ../js/ui/messageTray.js:1638
|
||||||
msgid "Clear Messages"
|
msgid "Clear Messages"
|
||||||
msgstr "Limpar mensaxes"
|
msgstr "Limpar mensaxes"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1655
|
#: ../js/ui/messageTray.js:1657
|
||||||
msgid "Notification Settings"
|
msgid "Notification Settings"
|
||||||
msgstr "Preferencias das notificacións"
|
msgstr "Preferencias das notificacións"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1708
|
#: ../js/ui/messageTray.js:1710
|
||||||
msgid "Tray Menu"
|
msgid "Tray Menu"
|
||||||
msgstr "Menú da bandexa do sistema"
|
msgstr "Menú da bandexa do sistema"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1925
|
#: ../js/ui/messageTray.js:1934
|
||||||
msgid "No Messages"
|
msgid "No Messages"
|
||||||
msgstr "Non hai mensaxes"
|
msgstr "Non hai mensaxes"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1963
|
#: ../js/ui/messageTray.js:1979
|
||||||
msgid "Message Tray"
|
msgid "Message Tray"
|
||||||
msgstr "Bandexa de mensaxes"
|
msgstr "Bandexa de mensaxes"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:2966
|
#: ../js/ui/messageTray.js:2992
|
||||||
msgid "System Information"
|
msgid "System Information"
|
||||||
msgstr "Información do sistema"
|
msgstr "Información do sistema"
|
||||||
|
|
||||||
@ -1266,8 +1299,8 @@ msgstr "Vista xeral"
|
|||||||
#. Translators: this is the text displayed
|
#. Translators: this is the text displayed
|
||||||
#. in the search entry when no search is
|
#. in the search entry when no search is
|
||||||
#. active; it should not exceed ~30
|
#. active; it should not exceed ~30
|
||||||
#. characters. */
|
#. characters.
|
||||||
#: ../js/ui/overview.js:250
|
#: ../js/ui/overview.js:246
|
||||||
msgid "Type to search…"
|
msgid "Type to search…"
|
||||||
msgstr "Escriba para buscar…"
|
msgstr "Escriba para buscar…"
|
||||||
|
|
||||||
@ -1276,7 +1309,7 @@ msgid "Quit"
|
|||||||
msgstr "Saír"
|
msgstr "Saír"
|
||||||
|
|
||||||
#. Translators: If there is no suitable word for "Activities"
|
#. Translators: If there is no suitable word for "Activities"
|
||||||
#. in your language, you can use the word for "Overview". */
|
#. in your language, you can use the word for "Overview".
|
||||||
#: ../js/ui/panel.js:567
|
#: ../js/ui/panel.js:567
|
||||||
msgid "Activities"
|
msgid "Activities"
|
||||||
msgstr "Actividades"
|
msgstr "Actividades"
|
||||||
@ -1285,6 +1318,11 @@ msgstr "Actividades"
|
|||||||
msgid "Top Bar"
|
msgid "Top Bar"
|
||||||
msgstr "Barra superior"
|
msgstr "Barra superior"
|
||||||
|
|
||||||
|
#. Translators: this MUST be either "toggle-switch-us"
|
||||||
|
#. (for toggle switches containing the English words
|
||||||
|
#. "ON" and "OFF") or "toggle-switch-intl" (for toggle
|
||||||
|
#. switches containing "◯" and "|"). Other values will
|
||||||
|
#. simply result in invisible toggle switches.
|
||||||
#: ../js/ui/popupMenu.js:269
|
#: ../js/ui/popupMenu.js:269
|
||||||
msgid "toggle-switch-us"
|
msgid "toggle-switch-us"
|
||||||
msgstr "toggle-switch-intl"
|
msgstr "toggle-switch-intl"
|
||||||
@ -1302,7 +1340,7 @@ msgid "Restarting…"
|
|||||||
msgstr "Restimando…"
|
msgstr "Restimando…"
|
||||||
|
|
||||||
#. Translators: This is a time format for a date in
|
#. Translators: This is a time format for a date in
|
||||||
#. long format */
|
#. long format
|
||||||
#: ../js/ui/screenShield.js:88
|
#: ../js/ui/screenShield.js:88
|
||||||
msgid "%A, %B %d"
|
msgid "%A, %B %d"
|
||||||
msgstr "%A, %d de %B"
|
msgstr "%A, %d de %B"
|
||||||
@ -1322,6 +1360,13 @@ msgstr "Bloquear"
|
|||||||
msgid "GNOME needs to lock the screen"
|
msgid "GNOME needs to lock the screen"
|
||||||
msgstr "GNOME precisa bloquear a pantalla"
|
msgstr "GNOME precisa bloquear a pantalla"
|
||||||
|
|
||||||
|
#. We could not become modal, so we can't activate the
|
||||||
|
#. screenshield. The user is probably very upset at this
|
||||||
|
#. point, but any application using global grabs is broken
|
||||||
|
#. Just tell him to stop using this app
|
||||||
|
#.
|
||||||
|
#. XXX: another option is to kick the user into the gdm login
|
||||||
|
#. screen, where we're not affected by grabs
|
||||||
#: ../js/ui/screenShield.js:833 ../js/ui/screenShield.js:1304
|
#: ../js/ui/screenShield.js:833 ../js/ui/screenShield.js:1304
|
||||||
msgid "Unable to lock"
|
msgid "Unable to lock"
|
||||||
msgstr "Non foi posíbel bloquear"
|
msgstr "Non foi posíbel bloquear"
|
||||||
@ -1330,27 +1375,27 @@ msgstr "Non foi posíbel bloquear"
|
|||||||
msgid "Lock was blocked by an application"
|
msgid "Lock was blocked by an application"
|
||||||
msgstr "Un aplicativo impediu o bloqueo"
|
msgstr "Un aplicativo impediu o bloqueo"
|
||||||
|
|
||||||
#: ../js/ui/search.js:606
|
#: ../js/ui/search.js:594
|
||||||
msgid "Searching…"
|
msgid "Searching…"
|
||||||
msgstr "Buscando…"
|
msgstr "Buscando…"
|
||||||
|
|
||||||
#: ../js/ui/search.js:652
|
#: ../js/ui/search.js:596
|
||||||
msgid "No results."
|
msgid "No results."
|
||||||
msgstr "Sen resultados."
|
msgstr "Sen resultados."
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:27
|
#: ../js/ui/shellEntry.js:25
|
||||||
msgid "Copy"
|
msgid "Copy"
|
||||||
msgstr "Copiar"
|
msgstr "Copiar"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:32
|
#: ../js/ui/shellEntry.js:30
|
||||||
msgid "Paste"
|
msgid "Paste"
|
||||||
msgstr "Pegar"
|
msgstr "Pegar"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:99
|
#: ../js/ui/shellEntry.js:97
|
||||||
msgid "Show Text"
|
msgid "Show Text"
|
||||||
msgstr "Mostrar texto"
|
msgstr "Mostrar texto"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:101
|
#: ../js/ui/shellEntry.js:99
|
||||||
msgid "Hide Text"
|
msgid "Hide Text"
|
||||||
msgstr "Ocultar texto"
|
msgstr "Ocultar texto"
|
||||||
|
|
||||||
@ -1406,6 +1451,8 @@ msgstr "Contraste alto"
|
|||||||
msgid "Large Text"
|
msgid "Large Text"
|
||||||
msgstr "Texto grande"
|
msgstr "Texto grande"
|
||||||
|
|
||||||
|
#. The Bluetooth menu only appears when Bluetooth is in use,
|
||||||
|
#. so just statically build it with a "Turn Off" menu item.
|
||||||
#: ../js/ui/status/bluetooth.js:49
|
#: ../js/ui/status/bluetooth.js:49
|
||||||
msgid "Bluetooth"
|
msgid "Bluetooth"
|
||||||
msgstr "Bluetooth"
|
msgstr "Bluetooth"
|
||||||
@ -1436,23 +1483,27 @@ msgstr "Non conectado"
|
|||||||
msgid "Brightness"
|
msgid "Brightness"
|
||||||
msgstr "Brillo"
|
msgstr "Brillo"
|
||||||
|
|
||||||
#: ../js/ui/status/keyboard.js:406
|
#: ../js/ui/status/keyboard.js:547
|
||||||
msgid "Show Keyboard Layout"
|
msgid "Show Keyboard Layout"
|
||||||
msgstr "Mostrar a distribución do teclado"
|
msgstr "Mostrar a distribución do teclado"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:56
|
#: ../js/ui/status/location.js:65
|
||||||
msgid "Location"
|
msgid "Location"
|
||||||
msgstr "Localización"
|
msgstr "Localización"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:63 ../js/ui/status/location.js:167
|
#: ../js/ui/status/location.js:72 ../js/ui/status/location.js:177
|
||||||
msgid "Disable"
|
msgid "Disable"
|
||||||
msgstr "Desactivar"
|
msgstr "Desactivar"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:166
|
#: ../js/ui/status/location.js:73
|
||||||
|
msgid "Privacy Settings"
|
||||||
|
msgstr "Preferencias da privacidade"
|
||||||
|
|
||||||
|
#: ../js/ui/status/location.js:176
|
||||||
msgid "In Use"
|
msgid "In Use"
|
||||||
msgstr "En uso"
|
msgstr "En uso"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:170
|
#: ../js/ui/status/location.js:180
|
||||||
msgid "Enable"
|
msgid "Enable"
|
||||||
msgstr "Activar"
|
msgstr "Activar"
|
||||||
|
|
||||||
@ -1470,7 +1521,7 @@ msgid "Connected"
|
|||||||
msgstr "Conectado"
|
msgstr "Conectado"
|
||||||
|
|
||||||
#. Translators: this is for network devices that are physically present but are not
|
#. Translators: this is for network devices that are physically present but are not
|
||||||
#. under NetworkManager's control (and thus cannot be used in the menu) */
|
#. under NetworkManager's control (and thus cannot be used in the menu)
|
||||||
#: ../js/ui/status/network.js:463
|
#: ../js/ui/status/network.js:463
|
||||||
msgid "Unmanaged"
|
msgid "Unmanaged"
|
||||||
msgstr "Sen xestionar"
|
msgstr "Sen xestionar"
|
||||||
@ -1483,19 +1534,19 @@ msgstr "Desconectando…"
|
|||||||
msgid "Connecting"
|
msgid "Connecting"
|
||||||
msgstr "Conectando"
|
msgstr "Conectando"
|
||||||
|
|
||||||
#. Translators: this is for network connections that require some kind of key or password */
|
#. Translators: this is for network connections that require some kind of key or password
|
||||||
#: ../js/ui/status/network.js:474
|
#: ../js/ui/status/network.js:474
|
||||||
msgid "Authentication required"
|
msgid "Authentication required"
|
||||||
msgstr "Requírese autenticación"
|
msgstr "Requírese autenticación"
|
||||||
|
|
||||||
#. Translators: this is for devices that require some kind of firmware or kernel
|
#. Translators: this is for devices that require some kind of firmware or kernel
|
||||||
#. module, which is missing */
|
#. module, which is missing
|
||||||
#: ../js/ui/status/network.js:482
|
#: ../js/ui/status/network.js:482
|
||||||
msgid "Firmware missing"
|
msgid "Firmware missing"
|
||||||
msgstr "Falta o «firmware»"
|
msgstr "Falta o «firmware»"
|
||||||
|
|
||||||
#. Translators: this is for a network device that cannot be activated (for example it
|
#. Translators: this is for a network device that cannot be activated (for example it
|
||||||
#. is disabled by rfkill, or it has no coverage */
|
#. is disabled by rfkill, or it has no coverage
|
||||||
#: ../js/ui/status/network.js:486
|
#: ../js/ui/status/network.js:486
|
||||||
msgid "Unavailable"
|
msgid "Unavailable"
|
||||||
msgstr "Non dispoñíbel"
|
msgstr "Non dispoñíbel"
|
||||||
@ -1580,7 +1631,7 @@ msgstr "Punto wifi activo"
|
|||||||
msgid "connecting..."
|
msgid "connecting..."
|
||||||
msgstr "conectando…"
|
msgstr "conectando…"
|
||||||
|
|
||||||
#. Translators: this is for network connections that require some kind of key or password */
|
#. Translators: this is for network connections that require some kind of key or password
|
||||||
#: ../js/ui/status/network.js:1412
|
#: ../js/ui/status/network.js:1412
|
||||||
msgid "authentication required"
|
msgid "authentication required"
|
||||||
msgstr "requírese autenticación"
|
msgstr "requírese autenticación"
|
||||||
@ -1617,15 +1668,19 @@ msgstr "Preferencias de enerxía"
|
|||||||
msgid "Fully Charged"
|
msgid "Fully Charged"
|
||||||
msgstr "Carga completa"
|
msgstr "Carga completa"
|
||||||
|
|
||||||
|
#. 0 is reported when UPower does not have enough data
|
||||||
|
#. to estimate battery life
|
||||||
#: ../js/ui/status/power.js:72 ../js/ui/status/power.js:78
|
#: ../js/ui/status/power.js:72 ../js/ui/status/power.js:78
|
||||||
msgid "Estimating…"
|
msgid "Estimating…"
|
||||||
msgstr "Estimando…"
|
msgstr "Estimando…"
|
||||||
|
|
||||||
|
#. Translators: this is <hours>:<minutes> Remaining (<percentage>)
|
||||||
#: ../js/ui/status/power.js:86
|
#: ../js/ui/status/power.js:86
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%d∶%02d Remaining (%d%%)"
|
msgid "%d∶%02d Remaining (%d%%)"
|
||||||
msgstr "Faltan %d:%02d (%d%%)"
|
msgstr "Faltan %d:%02d (%d%%)"
|
||||||
|
|
||||||
|
#. Translators: this is <hours>:<minutes> Until Full (<percentage>)
|
||||||
#: ../js/ui/status/power.js:91
|
#: ../js/ui/status/power.js:91
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%d∶%02d Until Full (%d%%)"
|
msgid "%d∶%02d Until Full (%d%%)"
|
||||||
@ -1639,6 +1694,9 @@ msgstr "SAI"
|
|||||||
msgid "Battery"
|
msgid "Battery"
|
||||||
msgstr "Batería"
|
msgstr "Batería"
|
||||||
|
|
||||||
|
#. The menu only appears when airplane mode is on, so just
|
||||||
|
#. statically build it as if it was on, rather than dynamically
|
||||||
|
#. changing the menu contents.
|
||||||
#: ../js/ui/status/rfkill.js:83
|
#: ../js/ui/status/rfkill.js:83
|
||||||
msgid "Airplane Mode"
|
msgid "Airplane Mode"
|
||||||
msgstr "Modo avión"
|
msgstr "Modo avión"
|
||||||
@ -1687,11 +1745,11 @@ msgstr "Iniciar sesión como outro usuario"
|
|||||||
msgid "Unlock Window"
|
msgid "Unlock Window"
|
||||||
msgstr "Desbloquear xanela"
|
msgstr "Desbloquear xanela"
|
||||||
|
|
||||||
#: ../js/ui/viewSelector.js:232
|
#: ../js/ui/viewSelector.js:158
|
||||||
msgid "Applications"
|
msgid "Applications"
|
||||||
msgstr "Aplicativos"
|
msgstr "Aplicativos"
|
||||||
|
|
||||||
#: ../js/ui/viewSelector.js:236
|
#: ../js/ui/viewSelector.js:162
|
||||||
msgid "Search"
|
msgid "Search"
|
||||||
msgstr "Buscar"
|
msgstr "Buscar"
|
||||||
|
|
||||||
@ -1706,7 +1764,7 @@ msgstr "Desexa manter estas preferencias de pantalla?"
|
|||||||
|
|
||||||
#. Translators: this and the following message should be limited in lenght,
|
#. Translators: this and the following message should be limited in lenght,
|
||||||
#. to avoid ellipsizing the labels.
|
#. to avoid ellipsizing the labels.
|
||||||
#. */
|
#.
|
||||||
#: ../js/ui/windowManager.js:84
|
#: ../js/ui/windowManager.js:84
|
||||||
msgid "Revert Settings"
|
msgid "Revert Settings"
|
||||||
msgstr "Reverter preferencias"
|
msgstr "Reverter preferencias"
|
||||||
@ -1788,21 +1846,21 @@ msgstr[1] "%u entradas"
|
|||||||
msgid "System Sounds"
|
msgid "System Sounds"
|
||||||
msgstr "Sons do sistema"
|
msgstr "Sons do sistema"
|
||||||
|
|
||||||
#: ../src/main.c:371
|
#: ../src/main.c:373
|
||||||
msgid "Print version"
|
msgid "Print version"
|
||||||
msgstr "Imprimir versión"
|
msgstr "Imprimir versión"
|
||||||
|
|
||||||
#: ../src/main.c:377
|
#: ../src/main.c:379
|
||||||
msgid "Mode used by GDM for login screen"
|
msgid "Mode used by GDM for login screen"
|
||||||
msgstr "Modo usado por GDM para a pantalla de inicio"
|
msgstr "Modo usado por GDM para a pantalla de inicio"
|
||||||
|
|
||||||
#: ../src/main.c:383
|
#: ../src/main.c:385
|
||||||
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Usar un modo específico, por exemplo, «gdm» para a pantalla de inicio de "
|
"Usar un modo específico, por exemplo, «gdm» para a pantalla de inicio de "
|
||||||
"sesión"
|
"sesión"
|
||||||
|
|
||||||
#: ../src/main.c:389
|
#: ../src/main.c:391
|
||||||
msgid "List possible modes"
|
msgid "List possible modes"
|
||||||
msgstr "Listar os modos posíbeis"
|
msgstr "Listar os modos posíbeis"
|
||||||
|
|
||||||
|
327
po/gu.po
@ -9,8 +9,8 @@ msgstr ""
|
|||||||
"Project-Id-Version: gu\n"
|
"Project-Id-Version: gu\n"
|
||||||
"Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug."
|
"Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug."
|
||||||
"cgi?product=gnome-shell&keywords=I18N+L10N&component=general\n"
|
"cgi?product=gnome-shell&keywords=I18N+L10N&component=general\n"
|
||||||
"POT-Creation-Date: 2014-08-26 07:37+0000\n"
|
"POT-Creation-Date: 2014-10-01 07:39+0000\n"
|
||||||
"PO-Revision-Date: 2014-08-26 16:19+0530\n"
|
"PO-Revision-Date: 2014-10-01 15:51+0530\n"
|
||||||
"Last-Translator: \n"
|
"Last-Translator: \n"
|
||||||
"Language-Team: American English <kde-i18n-doc@kde.org>\n"
|
"Language-Team: American English <kde-i18n-doc@kde.org>\n"
|
||||||
"Language: \n"
|
"Language: \n"
|
||||||
@ -63,7 +63,7 @@ msgstr "GNOME Shell ઍક્સટેન્શનને રૂપરેખા
|
|||||||
|
|
||||||
#: ../data/gnome-shell-wayland.desktop.in.in.h:1
|
#: ../data/gnome-shell-wayland.desktop.in.in.h:1
|
||||||
msgid "GNOME Shell (wayland compositor)"
|
msgid "GNOME Shell (wayland compositor)"
|
||||||
msgstr ""
|
msgstr "GNOME Shell (વેલૅન્ડ કંપોઝીટર)"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:1
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:1
|
||||||
msgid "Enable internal tools useful for developers and testers from Alt-F2"
|
msgid "Enable internal tools useful for developers and testers from Alt-F2"
|
||||||
@ -76,12 +76,10 @@ msgid ""
|
|||||||
msgstr "Alt-F2 સંવાદની મદદથી આંતરિક ડિબગીંગ અને મોનિટરીંગ સાધનોને વાપરવા પરવાનગી આપે છે."
|
msgstr "Alt-F2 સંવાદની મદદથી આંતરિક ડિબગીંગ અને મોનિટરીંગ સાધનોને વાપરવા પરવાનગી આપે છે."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:3
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:3
|
||||||
#| msgid "Uuids of extensions to enable"
|
|
||||||
msgid "UUIDs of extensions to enable"
|
msgid "UUIDs of extensions to enable"
|
||||||
msgstr "સક્રિય કરવા માટે એક્સટેન્શનનું UUIDs"
|
msgstr "સક્રિય કરવા માટે એક્સટેન્શનનું UUIDs"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:4
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:4
|
||||||
#, fuzzy
|
|
||||||
#| msgid ""
|
#| msgid ""
|
||||||
#| "GNOME Shell extensions have a uuid property; this key lists extensions "
|
#| "GNOME Shell extensions have a uuid property; this key lists extensions "
|
||||||
#| "which should be loaded. Any extension that wants to be loaded needs to be "
|
#| "which should be loaded. Any extension that wants to be loaded needs to be "
|
||||||
@ -93,14 +91,14 @@ msgid ""
|
|||||||
"list. You can also manipulate this list with the EnableExtension and "
|
"list. You can also manipulate this list with the EnableExtension and "
|
||||||
"DisableExtension D-Bus methods on org.gnome.Shell."
|
"DisableExtension D-Bus methods on org.gnome.Shell."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"GNOME Shell ઍક્સટેન્શન પાસે uuid ગુણધર્મ છે; આ કી ઍક્સટેન્શનની યાદી કરે છે કે જેને લાવેલ હોવુ "
|
"GNOME Shell ઍક્સટેન્શન પાસે UUID ગુણધર્મ છે; આ કી ઍક્સટેન્શનની યાદી કરે છે કે જેને લાવેલ હોવુ "
|
||||||
"જોઇએ. કોઇપણ ઍક્સટેન્શન કે જેને આ યાદીમાં લાવવાની જરૂર છે. તમે પણ org.gnome.Shell પર "
|
"જોઇએ. કોઇપણ ઍક્સટેન્શન કે જેને આ યાદીમાં લાવવાની જરૂર છે. તમે પણ org.gnome.Shell પર "
|
||||||
"EnableExtension અને DisableExtension DBus પદ્દતિઓ સાથે આ યાદીને કુશળતાપૂર્વક વાપરી "
|
"EnableExtension અને DisableExtension DBus પદ્દતિઓ સાથે આ યાદીને કુશળતાપૂર્વક વાપરી "
|
||||||
"શકો છો."
|
"શકો છો."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:5
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:5
|
||||||
msgid "Disables the validation of extension version compatibility"
|
msgid "Disables the validation of extension version compatibility"
|
||||||
msgstr ""
|
msgstr "ઍક્સટેન્શન આવૃત્તિ સુસંગતતાની માન્યતાને નિષ્ક્રિય કરે છે"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:6
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:6
|
||||||
msgid ""
|
msgid ""
|
||||||
@ -108,6 +106,9 @@ msgid ""
|
|||||||
"running version. Enabling this option will disable this check and try to "
|
"running version. Enabling this option will disable this check and try to "
|
||||||
"load all extensions regardless of the versions they claim to support."
|
"load all extensions regardless of the versions they claim to support."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
"GNOME Shell એ ફક્ત ઍક્સટેન્શનને લાવશે કે જે હાલની ચાલતી આવૃત્તિને આધાર આપવા માટે દાવો કરે છે. "
|
||||||
|
"આ વિકલ્પને સક્રિય કરવાનું આ ચકાસણીને નિષ્ક્રિય કરશે અને આવૃત્તિને બાદ કરતા બધા ઍક્સટેન્શનને "
|
||||||
|
"લાવવાનો પ્રયત્ન કરે છે જે તેઓ આધાર આપવા માટે દાવો કરે છે."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:7
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:7
|
||||||
msgid "List of desktop file IDs for favorite applications"
|
msgid "List of desktop file IDs for favorite applications"
|
||||||
@ -121,11 +122,11 @@ msgstr "કાર્યક્રમો આ ઓળખકર્તાઓ સાથ
|
|||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:9
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:9
|
||||||
msgid "App Picker View"
|
msgid "App Picker View"
|
||||||
msgstr ""
|
msgstr "કાર્યક્રમ પસંદકર્તા દૃશ્ય"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:10
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:10
|
||||||
msgid "Index of the currently selected view in the application picker."
|
msgid "Index of the currently selected view in the application picker."
|
||||||
msgstr ""
|
msgstr "કાર્યક્રમ પસંદકર્તામાં હાલમાં પસંદ થયેલ દૃશ્યની અનુક્રમણિકા."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:11
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:11
|
||||||
msgid "History for command (Alt-F2) dialog"
|
msgid "History for command (Alt-F2) dialog"
|
||||||
@ -136,13 +137,10 @@ msgid "History for the looking glass dialog"
|
|||||||
msgstr "ગ્લાસ સંવાદને જોવા માટે ઇતિહાસ"
|
msgstr "ગ્લાસ સંવાદને જોવા માટે ઇતિહાસ"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:13
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:13
|
||||||
#, fuzzy
|
|
||||||
#| msgid "Always show the 'Log out' menuitem in the user menu."
|
|
||||||
msgid "Always show the 'Log out' menu item in the user menu."
|
msgid "Always show the 'Log out' menu item in the user menu."
|
||||||
msgstr "હંમેશા વપરાશકર્તા મેનુમાં 'બહાર નીકળો' મેનુવસ્તુને બતાવે છે."
|
msgstr "વપરાશકર્તા મેનુમાં હંમેશા 'બહાર નીકળો' મેનુ વસ્તુને બતાવો."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:14
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:14
|
||||||
#, fuzzy
|
|
||||||
#| msgid ""
|
#| msgid ""
|
||||||
#| "This key overrides the automatic hiding of the 'Log out' menuitem in "
|
#| "This key overrides the automatic hiding of the 'Log out' menuitem in "
|
||||||
#| "single-user, single-session situations."
|
#| "single-user, single-session situations."
|
||||||
@ -150,7 +148,8 @@ msgid ""
|
|||||||
"This key overrides the automatic hiding of the 'Log out' menu item in single-"
|
"This key overrides the automatic hiding of the 'Log out' menu item in single-"
|
||||||
"user, single-session situations."
|
"user, single-session situations."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"આ કી એકજ વપરાશકર્તામાં 'બહાર નીકળો' મેનુવસ્તુને આપમેળે છુપાવવા આ કીને ઓવરરાઇડ કરવામાં "
|
"આ કી એકજ વપરાશકર્તા, એકજ-સત્ર પરિસ્થિતિઓમાં 'બહાર નીકળો' મેનુવસ્તુને આપમેળે છુપાવવા આ કીને "
|
||||||
|
"ઓવરરાઇડ કરવામાં "
|
||||||
"આવી છે."
|
"આવી છે."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:15
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:15
|
||||||
@ -193,16 +192,12 @@ msgid "Keybinding to open the \"Show Applications\" view of the Activities Overv
|
|||||||
msgstr "પ્રવૃત્તિ ઝાંખીનાં \"કાર્યક્રમો બતાવો\" દૃશ્યને ખોલવા માટે કિબાઇન્ડીંગ."
|
msgstr "પ્રવૃત્તિ ઝાંખીનાં \"કાર્યક્રમો બતાવો\" દૃશ્યને ખોલવા માટે કિબાઇન્ડીંગ."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:23
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:23
|
||||||
#, fuzzy
|
|
||||||
#| msgid "Keybinding to open the \"Show Applications\" view"
|
|
||||||
msgid "Keybinding to open the overview"
|
msgid "Keybinding to open the overview"
|
||||||
msgstr "\"કાર્યક્રમો બતાવો\" દૃશ્યને ખોલવા માટે કિબાઇન્ડીંગ"
|
msgstr "ઝાંખીને ખોલવા માટે કિબાઇન્ડીંગ"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:24
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:24
|
||||||
#, fuzzy
|
|
||||||
#| msgid "Keybinding to open the \"Show Applications\" view"
|
|
||||||
msgid "Keybinding to open the Activities Overview."
|
msgid "Keybinding to open the Activities Overview."
|
||||||
msgstr "\"કાર્યક્રમો બતાવો\" દૃશ્યને ખોલવા માટે કિબાઇન્ડીંગ"
|
msgstr "પ્રવૃત્તિ ઝાંખીને ખોલવા માટે કિબાઇન્ડીંગ"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:25
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:25
|
||||||
msgid "Keybinding to toggle the visibility of the message tray"
|
msgid "Keybinding to toggle the visibility of the message tray"
|
||||||
@ -222,7 +217,7 @@ msgstr "સક્રિય સૂચના પર પ્રકાશ નાં
|
|||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:29
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:29
|
||||||
msgid "Keybinding that pauses and resumes all running tweens, for debugging purposes"
|
msgid "Keybinding that pauses and resumes all running tweens, for debugging purposes"
|
||||||
msgstr ""
|
msgstr "કીબાઇન્ડીંગ કે જે બધી ચાલતી ટ્વીનને અટકાવે છે અને પાછુ લાવે છે, ડિબગીંગ હેતુઓ માટે"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:30
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:30
|
||||||
msgid "Which keyboard to use"
|
msgid "Which keyboard to use"
|
||||||
@ -234,13 +229,15 @@ msgstr "વાપરવા માટે કિબોર્ડનો પ્રક
|
|||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:32
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:32
|
||||||
msgid "Limit switcher to current workspace."
|
msgid "Limit switcher to current workspace."
|
||||||
msgstr ""
|
msgstr "વર્તમાન કામ કરવાની જગ્યા માટે સ્વિચર મર્યાદિત કરી છે."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:33
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:33
|
||||||
msgid ""
|
msgid ""
|
||||||
"If true, only applications that have windows on the current workspace are "
|
"If true, only applications that have windows on the current workspace are "
|
||||||
"shown in the switcher. Otherwise, all applications are included."
|
"shown in the switcher. Otherwise, all applications are included."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
"જો true હોય તો, ફક્ત કાર્યક્રમો કે જેની પાસે હાલની કાર્ય કરવાની જગ્યા પર વિન્ડો છે તે "
|
||||||
|
"સ્વીચરમાં બતાવેલ છે. નહિંતો, બધા કાર્યક્રમનો સમાવેલ છે."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:34
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:34
|
||||||
msgid "The application icon mode."
|
msgid "The application icon mode."
|
||||||
@ -261,6 +258,8 @@ msgid ""
|
|||||||
"If true, only windows from the current workspace are shown in the switcher. "
|
"If true, only windows from the current workspace are shown in the switcher. "
|
||||||
"Otherwise, all windows are included."
|
"Otherwise, all windows are included."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
"જો true હોય તો, હાલની કાર્ય કરવાની જગ્યામાંથી વિન્ડો સ્વીચરમાં બતાવેલ છે. નહિં તો, બધી "
|
||||||
|
"વિન્ડોને સમાવેલ છે."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:37
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:37
|
||||||
msgid "Attach modal dialog to the parent window"
|
msgid "Attach modal dialog to the parent window"
|
||||||
@ -284,24 +283,23 @@ msgstr "ફક્ત પ્રાથમિક મોનિટર પર કા
|
|||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:42
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:42
|
||||||
msgid "Delay focus changes in mouse mode until the pointer stops moving"
|
msgid "Delay focus changes in mouse mode until the pointer stops moving"
|
||||||
msgstr ""
|
msgstr "માઉસ સ્થિતિમાં ફેરફારો કરવામાં વિલંબ જ્યાં સુધી પોઇંટર ખસેડવાનું બંધ થાય"
|
||||||
|
|
||||||
#: ../data/org.gnome.Shell.PortalHelper.desktop.in.h:1
|
#: ../data/org.gnome.Shell.PortalHelper.desktop.in.h:1
|
||||||
msgid "Captive Portal"
|
msgid "Captive Portal"
|
||||||
msgstr ""
|
msgstr "કૅપ્ટીવ પોર્ટલ"
|
||||||
|
|
||||||
#: ../js/extensionPrefs/main.js:127
|
#: ../js/extensionPrefs/main.js:123
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "There was an error loading the preferences dialog for %s:"
|
msgid "There was an error loading the preferences dialog for %s:"
|
||||||
msgstr "ત્યાં %s માટે પસંદગી સંવાદને લાવવામાં ભૂલ હતી:"
|
msgstr "ત્યાં %s માટે પસંદગી સંવાદને લાવવામાં ભૂલ હતી:"
|
||||||
|
|
||||||
#: ../js/extensionPrefs/main.js:159
|
#: ../js/extensionPrefs/main.js:155
|
||||||
#| msgid "Configure GNOME Shell Extensions"
|
|
||||||
msgid "GNOME Shell Extensions"
|
msgid "GNOME Shell Extensions"
|
||||||
msgstr "GNOME Shell ઍક્સટેન્શન"
|
msgstr "GNOME Shell ઍક્સટેન્શન"
|
||||||
|
|
||||||
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:143
|
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:143
|
||||||
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:429
|
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:452
|
||||||
#: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399
|
#: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399
|
||||||
#: ../js/ui/status/network.js:915
|
#: ../js/ui/status/network.js:915
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
@ -322,7 +320,6 @@ msgid "Sign In"
|
|||||||
msgstr "પ્રવેશો"
|
msgstr "પ્રવેશો"
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:269
|
#: ../js/gdm/loginDialog.js:269
|
||||||
#| msgid "Switch Session"
|
|
||||||
msgid "Choose Session"
|
msgid "Choose Session"
|
||||||
msgstr "સત્ર પસંદ કરો"
|
msgstr "સત્ર પસંદ કરો"
|
||||||
|
|
||||||
@ -361,52 +358,48 @@ msgid "Could not parse command:"
|
|||||||
msgstr "આદેશનું પદચ્છેદન કરી શક્યા નથી:"
|
msgstr "આદેશનું પદચ્છેદન કરી શક્યા નથી:"
|
||||||
|
|
||||||
#: ../js/misc/util.js:156
|
#: ../js/misc/util.js:156
|
||||||
#, fuzzy, javascript-format
|
#, javascript-format
|
||||||
#| msgid "Execution of '%s' failed:"
|
|
||||||
msgid "Execution of “%s” failed:"
|
msgid "Execution of “%s” failed:"
|
||||||
msgstr "'%s' ને અમલમાં મૂકવાનુ નિષ્ફળ:"
|
msgstr "“%s” ને અમલમાં મૂકવાનુ નિષ્ફળ:"
|
||||||
|
|
||||||
#: ../js/portalHelper/main.js:85
|
#: ../js/portalHelper/main.js:85
|
||||||
#, fuzzy
|
|
||||||
#| msgid "Authentication Required"
|
|
||||||
msgid "Web Authentication Redirect"
|
msgid "Web Authentication Redirect"
|
||||||
msgstr "સત્તાધિકરણ જરૂરી"
|
msgstr "વેબ સત્તાધિકરણ દિશામાન"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:660
|
#: ../js/ui/appDisplay.js:772
|
||||||
msgid "Frequently used applications will appear here"
|
msgid "Frequently used applications will appear here"
|
||||||
msgstr ""
|
msgstr "વારંવાર વપરાતા કાર્યક્રમો અહિંયા દેખાશે"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:771
|
#: ../js/ui/appDisplay.js:883
|
||||||
msgid "Frequent"
|
msgid "Frequent"
|
||||||
msgstr "સામાન્ય"
|
msgstr "સામાન્ય"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:778
|
#: ../js/ui/appDisplay.js:890
|
||||||
msgid "All"
|
msgid "All"
|
||||||
msgstr "બધા"
|
msgstr "બધા"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1650
|
#: ../js/ui/appDisplay.js:1790
|
||||||
msgid "New Window"
|
msgid "New Window"
|
||||||
msgstr "નવી વિન્ડો"
|
msgstr "નવી વિન્ડો"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1673 ../js/ui/dash.js:285
|
#: ../js/ui/appDisplay.js:1816 ../js/ui/dash.js:285
|
||||||
msgid "Remove from Favorites"
|
msgid "Remove from Favorites"
|
||||||
msgstr "પસંદીદાઓ માંથી દૂર કરો"
|
msgstr "પસંદીદાઓ માંથી દૂર કરો"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1679
|
#: ../js/ui/appDisplay.js:1822
|
||||||
msgid "Add to Favorites"
|
msgid "Add to Favorites"
|
||||||
msgstr "પસંદીદાને ઉમેરો"
|
msgstr "પસંદીદાને ઉમેરો"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1688
|
#: ../js/ui/appDisplay.js:1831
|
||||||
#| msgid "Show Text"
|
|
||||||
msgid "Show Details"
|
msgid "Show Details"
|
||||||
msgstr "વિગતો બતાવો"
|
msgstr "વિગતો બતાવો"
|
||||||
|
|
||||||
#: ../js/ui/appFavorites.js:122
|
#: ../js/ui/appFavorites.js:132
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s has been added to your favorites."
|
msgid "%s has been added to your favorites."
|
||||||
msgstr "%s ને તમારી પસંદીદામાં ઉમેરી દેવામાં આવ્યુ છે."
|
msgstr "%s ને તમારી પસંદીદામાં ઉમેરી દેવામાં આવ્યુ છે."
|
||||||
|
|
||||||
#: ../js/ui/appFavorites.js:156
|
#: ../js/ui/appFavorites.js:166
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s has been removed from your favorites."
|
msgid "%s has been removed from your favorites."
|
||||||
msgstr "%s ને તમારી પસંદીદામાંથી દૂર કરી દેવામાં આવ્યુ છે."
|
msgstr "%s ને તમારી પસંદીદામાંથી દૂર કરી દેવામાં આવ્યુ છે."
|
||||||
@ -598,11 +591,11 @@ msgstr "%s સાથે ખોલો"
|
|||||||
msgid "Eject"
|
msgid "Eject"
|
||||||
msgstr "રદ કરો"
|
msgstr "રદ કરો"
|
||||||
|
|
||||||
#: ../js/ui/components/keyring.js:93 ../js/ui/components/polkitAgent.js:285
|
#: ../js/ui/components/keyring.js:94 ../js/ui/components/polkitAgent.js:285
|
||||||
msgid "Password:"
|
msgid "Password:"
|
||||||
msgstr "પાસવર્ડ:"
|
msgstr "પાસવર્ડ:"
|
||||||
|
|
||||||
#: ../js/ui/components/keyring.js:113
|
#: ../js/ui/components/keyring.js:120
|
||||||
msgid "Type again:"
|
msgid "Type again:"
|
||||||
msgstr "ફરીથી પ્રયત્ન કરો:"
|
msgstr "ફરીથી પ્રયત્ન કરો:"
|
||||||
|
|
||||||
@ -640,14 +633,11 @@ msgid "Authentication required by wireless network"
|
|||||||
msgstr "વાયરલેસ નેટવર્ક દ્દારાસત્તાધિકરણ જરૂરી"
|
msgstr "વાયરલેસ નેટવર્ક દ્દારાસત્તાધિકરણ જરૂરી"
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:319
|
#: ../js/ui/components/networkAgent.js:319
|
||||||
#, fuzzy, javascript-format
|
#, javascript-format
|
||||||
#| msgid ""
|
|
||||||
#| "Passwords or encryption keys are required to access the wireless network "
|
|
||||||
#| "'%s'."
|
|
||||||
msgid ""
|
msgid ""
|
||||||
"Passwords or encryption keys are required to access the wireless network "
|
"Passwords or encryption keys are required to access the wireless network "
|
||||||
"“%s”."
|
"“%s”."
|
||||||
msgstr "પાસવર્ડ અથવા એનક્રિપ્શન કીઓને વાયરલેસ નેટવર્ક '%s' માં પ્રવેશની જરૂર છે."
|
msgstr "પાસવર્ડ અથવા એનક્રિપ્શન કીઓને વાયરલેસ નેટવર્ક “%s” માં પ્રવેશની જરૂર છે."
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:323
|
#: ../js/ui/components/networkAgent.js:323
|
||||||
msgid "Wired 802.1X authentication"
|
msgid "Wired 802.1X authentication"
|
||||||
@ -679,7 +669,6 @@ msgstr "મોબાઇલ બ્રોડબેન્ડ નેટવર્ક
|
|||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:346
|
#: ../js/ui/components/networkAgent.js:346
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
#| msgid "A password is required to connect to '%s'."
|
|
||||||
msgid "A password is required to connect to “%s”."
|
msgid "A password is required to connect to “%s”."
|
||||||
msgstr "પાસવર્ડ “%s” સાથે જોડાવા માટે જરૂરી છે."
|
msgstr "પાસવર્ડ “%s” સાથે જોડાવા માટે જરૂરી છે."
|
||||||
|
|
||||||
@ -735,14 +724,12 @@ msgstr "%H∶%M"
|
|||||||
#. Translators: this is the word "Yesterday" followed by a
|
#. Translators: this is the word "Yesterday" followed by a
|
||||||
#. time string in 24h format. i.e. "Yesterday, 14:30" */
|
#. time string in 24h format. i.e. "Yesterday, 14:30" */
|
||||||
#: ../js/ui/components/telepathyClient.js:960
|
#: ../js/ui/components/telepathyClient.js:960
|
||||||
#| msgid "<b>Yesterday</b>, <b>%H:%M</b>"
|
|
||||||
msgid "Yesterday, %H∶%M"
|
msgid "Yesterday, %H∶%M"
|
||||||
msgstr "ગઇ કાલે, %H:%M"
|
msgstr "ગઇ કાલે, %H:%M"
|
||||||
|
|
||||||
#. Translators: this is the week day name followed by a time
|
#. Translators: this is the week day name followed by a time
|
||||||
#. string in 24h format. i.e. "Monday, 14:30" */
|
#. string in 24h format. i.e. "Monday, 14:30" */
|
||||||
#: ../js/ui/components/telepathyClient.js:967
|
#: ../js/ui/components/telepathyClient.js:967
|
||||||
#| msgid "%A, %B %d"
|
|
||||||
msgid "%A, %H∶%M"
|
msgid "%A, %H∶%M"
|
||||||
msgstr "%A, %H∶%M"
|
msgstr "%A, %H∶%M"
|
||||||
|
|
||||||
@ -762,8 +749,6 @@ msgstr "%B %d %Y, %H∶%M"
|
|||||||
|
|
||||||
#. Translators: Time in 24h format */
|
#. Translators: Time in 24h format */
|
||||||
#: ../js/ui/components/telepathyClient.js:986
|
#: ../js/ui/components/telepathyClient.js:986
|
||||||
#| msgctxt "event list time"
|
|
||||||
#| msgid "%l:%M %p"
|
|
||||||
msgid "%l∶%M %p"
|
msgid "%l∶%M %p"
|
||||||
msgstr "%l∶%M %p"
|
msgstr "%l∶%M %p"
|
||||||
|
|
||||||
@ -776,7 +761,6 @@ msgstr "ગઈકાલે ∶%l:%M %p"
|
|||||||
#. Translators: this is the week day name followed by a time
|
#. Translators: this is the week day name followed by a time
|
||||||
#. string in 12h format. i.e. "Monday, 2:30 pm" */
|
#. string in 12h format. i.e. "Monday, 2:30 pm" */
|
||||||
#: ../js/ui/components/telepathyClient.js:1000
|
#: ../js/ui/components/telepathyClient.js:1000
|
||||||
#| msgid "%a %l:%M %p"
|
|
||||||
msgid "%A, %l∶%M %p"
|
msgid "%A, %l∶%M %p"
|
||||||
msgstr "%A, %l∶%M %p"
|
msgstr "%A, %l∶%M %p"
|
||||||
|
|
||||||
@ -784,7 +768,6 @@ msgstr "%A, %l∶%M %p"
|
|||||||
#. followed by a time string in 12h format.
|
#. followed by a time string in 12h format.
|
||||||
#. i.e. "May 25, 2:30 pm" */
|
#. i.e. "May 25, 2:30 pm" */
|
||||||
#: ../js/ui/components/telepathyClient.js:1007
|
#: ../js/ui/components/telepathyClient.js:1007
|
||||||
#| msgid "%a %b %e, %l:%M %p"
|
|
||||||
msgid "%B %d, %l∶%M %p"
|
msgid "%B %d, %l∶%M %p"
|
||||||
msgstr "%B %d, %l∶%M %p"
|
msgstr "%B %d, %l∶%M %p"
|
||||||
|
|
||||||
@ -792,7 +775,6 @@ msgstr "%B %d, %l∶%M %p"
|
|||||||
#. number followed by a time string in 12h format.
|
#. number followed by a time string in 12h format.
|
||||||
#. i.e. "May 25 2012, 2:30 pm"*/
|
#. i.e. "May 25 2012, 2:30 pm"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:1013
|
#: ../js/ui/components/telepathyClient.js:1013
|
||||||
#| msgid "%a %b %e, %l:%M %p"
|
|
||||||
msgid "%B %d %Y, %l∶%M %p"
|
msgid "%B %d %Y, %l∶%M %p"
|
||||||
msgstr "%B %d %Y, %l∶%M %p"
|
msgstr "%B %d %Y, %l∶%M %p"
|
||||||
|
|
||||||
@ -979,7 +961,7 @@ msgstr "ખાતામાં જુઓ"
|
|||||||
msgid "Unknown reason"
|
msgid "Unknown reason"
|
||||||
msgstr "અજ્ઞાત કારણ"
|
msgstr "અજ્ઞાત કારણ"
|
||||||
|
|
||||||
#: ../js/ui/ctrlAltTab.js:29 ../js/ui/viewSelector.js:228
|
#: ../js/ui/ctrlAltTab.js:29 ../js/ui/viewSelector.js:154
|
||||||
msgid "Windows"
|
msgid "Windows"
|
||||||
msgstr "વિન્ડો"
|
msgstr "વિન્ડો"
|
||||||
|
|
||||||
@ -1010,132 +992,129 @@ msgstr "તારીખ અને સમય સુયોજનો"
|
|||||||
msgid "%A %B %e, %Y"
|
msgid "%A %B %e, %Y"
|
||||||
msgstr "%A %B %e, %Y"
|
msgstr "%A %B %e, %Y"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:66
|
#: ../js/ui/endSessionDialog.js:64
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Log Out %s"
|
msgid "Log Out %s"
|
||||||
msgstr "%s માંથી બહાર નીકળો"
|
msgstr "%s માંથી બહાર નીકળો"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:67
|
#: ../js/ui/endSessionDialog.js:65
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Log Out"
|
msgid "Log Out"
|
||||||
msgstr "બહાર નીકળો"
|
msgstr "બહાર નીકળો"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:69
|
#: ../js/ui/endSessionDialog.js:67
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s will be logged out automatically in %d second."
|
msgid "%s will be logged out automatically in %d second."
|
||||||
msgid_plural "%s will be logged out automatically in %d seconds."
|
msgid_plural "%s will be logged out automatically in %d seconds."
|
||||||
msgstr[0] "%s એ %d સેકંડમાં આપમેળે બહાર નીકળી જશે."
|
msgstr[0] "%s એ %d સેકંડમાં આપમેળે બહાર નીકળી જશે."
|
||||||
msgstr[1] "%s એ %d સેકંડોમાં આપમેળે બહાર નીકળી જશે."
|
msgstr[1] "%s એ %d સેકંડોમાં આપમેળે બહાર નીકળી જશે."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:74
|
#: ../js/ui/endSessionDialog.js:72
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "You will be logged out automatically in %d second."
|
msgid "You will be logged out automatically in %d second."
|
||||||
msgid_plural "You will be logged out automatically in %d seconds."
|
msgid_plural "You will be logged out automatically in %d seconds."
|
||||||
msgstr[0] "તમે %d સેકંડમાં આપમેળે બહાર નીકળી જશે."
|
msgstr[0] "તમે %d સેકંડમાં આપમેળે બહાર નીકળી જશે."
|
||||||
msgstr[1] "તમે %d સેકંડોમાં આપમેળે બહાર નીકળી જશે."
|
msgstr[1] "તમે %d સેકંડોમાં આપમેળે બહાર નીકળી જશે."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:80
|
#: ../js/ui/endSessionDialog.js:78
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Log Out"
|
msgid "Log Out"
|
||||||
msgstr "બહાર નીકળો"
|
msgstr "બહાર નીકળો"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:86
|
#: ../js/ui/endSessionDialog.js:84
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Power Off"
|
msgid "Power Off"
|
||||||
msgstr "પાવર બંધ"
|
msgstr "પાવર બંધ"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:87
|
#: ../js/ui/endSessionDialog.js:85
|
||||||
#, fuzzy
|
|
||||||
#| msgid "Install Updates & Restart"
|
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Install Updates & Power Off"
|
msgid "Install Updates & Power Off"
|
||||||
msgstr "સુધારા સ્થાપિત કરો અને પુન:શરૂ કરો"
|
msgstr "સુધારા સ્થાપિત કરો અને પાવર બંધ કરો"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:89
|
#: ../js/ui/endSessionDialog.js:87
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "The system will power off automatically in %d second."
|
msgid "The system will power off automatically in %d second."
|
||||||
msgid_plural "The system will power off automatically in %d seconds."
|
msgid_plural "The system will power off automatically in %d seconds."
|
||||||
msgstr[0] "સિસ્ટમ %d સેકંડમાં આપમેળે પાવર બંધ થઇ જશે."
|
msgstr[0] "સિસ્ટમ %d સેકંડમાં આપમેળે પાવર બંધ થઇ જશે."
|
||||||
msgstr[1] "સિસ્ટમ %d સેકંડમાં આપમેળે પાવર બંધ થઇ જશે."
|
msgstr[1] "સિસ્ટમ %d સેકંડમાં આપમેળે પાવર બંધ થઇ જશે."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:93
|
#: ../js/ui/endSessionDialog.js:91
|
||||||
msgctxt "checkbox"
|
msgctxt "checkbox"
|
||||||
msgid "Install pending software updates"
|
msgid "Install pending software updates"
|
||||||
msgstr ""
|
msgstr "બાકી રહેલા સોફ્ટવેર સુધારાને સ્થાપિત કરો"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:96 ../js/ui/endSessionDialog.js:113
|
#: ../js/ui/endSessionDialog.js:94 ../js/ui/endSessionDialog.js:111
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Restart"
|
msgid "Restart"
|
||||||
msgstr "પુન:શરૂ કરો"
|
msgstr "પુન:શરૂ કરો"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:98
|
#: ../js/ui/endSessionDialog.js:96
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Power Off"
|
msgid "Power Off"
|
||||||
msgstr "પાવર બંધ"
|
msgstr "પાવર બંધ"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:105
|
#: ../js/ui/endSessionDialog.js:103
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Restart"
|
msgid "Restart"
|
||||||
msgstr "પુન:શરૂ કરો"
|
msgstr "પુન:શરૂ કરો"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:107
|
#: ../js/ui/endSessionDialog.js:105
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "The system will restart automatically in %d second."
|
msgid "The system will restart automatically in %d second."
|
||||||
msgid_plural "The system will restart automatically in %d seconds."
|
msgid_plural "The system will restart automatically in %d seconds."
|
||||||
msgstr[0] "સિસ્ટમ %d સેકંડમાં આપમેળે પુન:શરૂ થઇ જશે."
|
msgstr[0] "સિસ્ટમ %d સેકંડમાં આપમેળે પુન:શરૂ થઇ જશે."
|
||||||
msgstr[1] "સિસ્ટમ %d સેકંડોમાં આપમેળે પુન:શરૂ થઇ જશે."
|
msgstr[1] "સિસ્ટમ %d સેકંડોમાં આપમેળે પુન:શરૂ થઇ જશે."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:121
|
#: ../js/ui/endSessionDialog.js:119
|
||||||
#| msgid "Install Updates & Restart"
|
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Restart & Install Updates"
|
msgid "Restart & Install Updates"
|
||||||
msgstr "સુધારા સ્થાપિત કરો અને પુન:શરૂ કરો"
|
msgstr "સુધારા સ્થાપિત કરો અને પુન:શરૂ કરો"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:123
|
#: ../js/ui/endSessionDialog.js:121
|
||||||
#, fuzzy, javascript-format
|
#, javascript-format
|
||||||
#| msgid "The system will restart automatically in %d second."
|
#| msgid "The system will restart automatically in %d second."
|
||||||
#| msgid_plural "The system will restart automatically in %d seconds."
|
#| msgid_plural "The system will restart automatically in %d seconds."
|
||||||
msgid "The system will automatically restart and install updates in %d second."
|
msgid "The system will automatically restart and install updates in %d second."
|
||||||
msgid_plural "The system will automatically restart and install updates in %d seconds."
|
msgid_plural "The system will automatically restart and install updates in %d seconds."
|
||||||
msgstr[0] "સિસ્ટમ %d સેકંડમાં આપમેળે પુન:શરૂ થઇ જશે."
|
msgstr[0] "સિસ્ટમ %d સેકંડમાં આપમેળે સુધારાઓને પુન:શરૂ અને સ્થાપિત કરશે."
|
||||||
msgstr[1] "સિસ્ટમ %d સેકંડોમાં આપમેળે પુન:શરૂ થઇ જશે."
|
msgstr[1] "સિસ્ટમ %d સેકંડોમાં આપમેળે સુધારાઓને પુન:શરૂ અને સ્થાપિત કરશે."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:129
|
#: ../js/ui/endSessionDialog.js:127
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Restart & Install"
|
msgid "Restart & Install"
|
||||||
msgstr ""
|
msgstr "પુન:શરૂ કરો અને સ્થાપિત કરો"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:130
|
#: ../js/ui/endSessionDialog.js:128
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Install & Power Off"
|
msgid "Install & Power Off"
|
||||||
msgstr ""
|
msgstr "સ્થાપિત કરો અને પાવર બંધ "
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:131
|
#: ../js/ui/endSessionDialog.js:129
|
||||||
msgctxt "checkbox"
|
msgctxt "checkbox"
|
||||||
msgid "Power off after updates are installed"
|
msgid "Power off after updates are installed"
|
||||||
msgstr ""
|
msgstr "સુધારા સ્થાપિત થાય પછી પાવર બંધ કરો"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:315
|
#: ../js/ui/endSessionDialog.js:338
|
||||||
msgid "Running on battery power: please plug in before installing updates."
|
msgid "Running on battery power: please plug in before installing updates."
|
||||||
msgstr ""
|
msgstr "બેટરી પાવર પર ચાલી રહ્યુ છે: મહેરબાની કરીને સુધારા સ્થાપિત કરતા પહેલાં પ્લગઇન કરો."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:332
|
#: ../js/ui/endSessionDialog.js:355
|
||||||
msgid "Some applications are busy or have unsaved work."
|
msgid "Some applications are busy or have unsaved work."
|
||||||
msgstr ""
|
msgstr "અમુક કાર્યક્રમો વ્યસ્ત છે અથવા તેની પાસે અસંગ્રહેલ કામ છે."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:339
|
#: ../js/ui/endSessionDialog.js:362
|
||||||
msgid "Other users are logged in."
|
msgid "Other users are logged in."
|
||||||
msgstr "બીજા વપરાશકર્તાઓ પ્રવેશેલ છે."
|
msgstr "બીજા વપરાશકર્તાઓ પ્રવેશેલ છે."
|
||||||
|
|
||||||
#. Translators: Remote here refers to a remote session, like a ssh login */
|
#. Translators: Remote here refers to a remote session, like a ssh login */
|
||||||
#: ../js/ui/endSessionDialog.js:619
|
#: ../js/ui/endSessionDialog.js:640
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s (remote)"
|
msgid "%s (remote)"
|
||||||
msgstr "%s (દૂરસ્થ)"
|
msgstr "%s (દૂરસ્થ)"
|
||||||
|
|
||||||
#. Translators: Console here refers to a tty like a VT console */
|
#. Translators: Console here refers to a tty like a VT console */
|
||||||
#: ../js/ui/endSessionDialog.js:622
|
#: ../js/ui/endSessionDialog.js:643
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s (console)"
|
msgid "%s (console)"
|
||||||
msgstr "%s (કન્સોલ)"
|
msgstr "%s (કન્સોલ)"
|
||||||
@ -1145,12 +1124,11 @@ msgid "Install"
|
|||||||
msgstr "સ્થાપિત કરો"
|
msgstr "સ્થાપિત કરો"
|
||||||
|
|
||||||
#: ../js/ui/extensionDownloader.js:204
|
#: ../js/ui/extensionDownloader.js:204
|
||||||
#, fuzzy, javascript-format
|
#, javascript-format
|
||||||
#| msgid "Download and install '%s' from extensions.gnome.org?"
|
|
||||||
msgid "Download and install “%s” from extensions.gnome.org?"
|
msgid "Download and install “%s” from extensions.gnome.org?"
|
||||||
msgstr "extensions.gnome.org માંથી '%s' ને સ્થાપિત અને ડાઉનલોડ કરો?"
|
msgstr "extensions.gnome.org માંથી “%s” ને સ્થાપિત અને ડાઉનલોડ કરો?"
|
||||||
|
|
||||||
#: ../js/ui/keyboard.js:653 ../js/ui/status/keyboard.js:339
|
#: ../js/ui/keyboard.js:700 ../js/ui/status/keyboard.js:523
|
||||||
msgid "Keyboard"
|
msgid "Keyboard"
|
||||||
msgstr "કિબોર્ડ"
|
msgstr "કિબોર્ડ"
|
||||||
|
|
||||||
@ -1172,8 +1150,8 @@ msgstr "ભૂલો છુપાડો"
|
|||||||
msgid "Show Errors"
|
msgid "Show Errors"
|
||||||
msgstr "ભૂલો બતાવો"
|
msgstr "ભૂલો બતાવો"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:716 ../js/ui/status/location.js:62
|
#: ../js/ui/lookingGlass.js:716 ../js/ui/status/location.js:71
|
||||||
#: ../js/ui/status/location.js:166
|
#: ../js/ui/status/location.js:176
|
||||||
msgid "Enabled"
|
msgid "Enabled"
|
||||||
msgstr "સક્રિય"
|
msgstr "સક્રિય"
|
||||||
|
|
||||||
@ -1181,7 +1159,7 @@ msgstr "સક્રિય"
|
|||||||
#. because it's disabled by rfkill (airplane mode) */
|
#. because it's disabled by rfkill (airplane mode) */
|
||||||
#. translators:
|
#. translators:
|
||||||
#. * The device has been disabled
|
#. * The device has been disabled
|
||||||
#: ../js/ui/lookingGlass.js:719 ../js/ui/status/location.js:169
|
#: ../js/ui/lookingGlass.js:719 ../js/ui/status/location.js:179
|
||||||
#: ../js/ui/status/network.js:592 ../src/gvc/gvc-mixer-control.c:1830
|
#: ../js/ui/status/network.js:592 ../src/gvc/gvc-mixer-control.c:1830
|
||||||
msgid "Disabled"
|
msgid "Disabled"
|
||||||
msgstr "નિષ્ક્રિય"
|
msgstr "નિષ્ક્રિય"
|
||||||
@ -1206,39 +1184,39 @@ msgstr "સ્ત્રોત દર્શાવો"
|
|||||||
msgid "Web Page"
|
msgid "Web Page"
|
||||||
msgstr "વેબ પાનું"
|
msgstr "વેબ પાનું"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1325
|
#: ../js/ui/messageTray.js:1327
|
||||||
msgid "Open"
|
msgid "Open"
|
||||||
msgstr "ખોલો"
|
msgstr "ખોલો"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1332
|
#: ../js/ui/messageTray.js:1334
|
||||||
msgid "Remove"
|
msgid "Remove"
|
||||||
msgstr "દૂર કરો"
|
msgstr "દૂર કરો"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1629
|
#: ../js/ui/messageTray.js:1631
|
||||||
msgid "Notifications"
|
msgid "Notifications"
|
||||||
msgstr "સૂચનાઓ"
|
msgstr "સૂચનાઓ"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1636
|
#: ../js/ui/messageTray.js:1638
|
||||||
msgid "Clear Messages"
|
msgid "Clear Messages"
|
||||||
msgstr "સંદેશા સાફ કરો"
|
msgstr "સંદેશા સાફ કરો"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1655
|
#: ../js/ui/messageTray.js:1657
|
||||||
msgid "Notification Settings"
|
msgid "Notification Settings"
|
||||||
msgstr "સૂચના સુયોજનો"
|
msgstr "સૂચના સુયોજનો"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1708
|
#: ../js/ui/messageTray.js:1710
|
||||||
msgid "Tray Menu"
|
msgid "Tray Menu"
|
||||||
msgstr ""
|
msgstr "ટ્રે મેનુ"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1925
|
#: ../js/ui/messageTray.js:1934
|
||||||
msgid "No Messages"
|
msgid "No Messages"
|
||||||
msgstr "સંદેશા નથી"
|
msgstr "સંદેશા નથી"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1963
|
#: ../js/ui/messageTray.js:1979
|
||||||
msgid "Message Tray"
|
msgid "Message Tray"
|
||||||
msgstr "સંદેશો ટ્રે"
|
msgstr "સંદેશો ટ્રે"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:2966
|
#: ../js/ui/messageTray.js:2992
|
||||||
msgid "System Information"
|
msgid "System Information"
|
||||||
msgstr "સિસ્ટમ જાણકારી"
|
msgstr "સિસ્ટમ જાણકારી"
|
||||||
|
|
||||||
@ -1266,7 +1244,7 @@ msgstr "ઝાંખી"
|
|||||||
#. in the search entry when no search is
|
#. in the search entry when no search is
|
||||||
#. active; it should not exceed ~30
|
#. active; it should not exceed ~30
|
||||||
#. characters. */
|
#. characters. */
|
||||||
#: ../js/ui/overview.js:250
|
#: ../js/ui/overview.js:246
|
||||||
msgid "Type to search…"
|
msgid "Type to search…"
|
||||||
msgstr "શોધવા માટે ટાઇપ કરો..."
|
msgstr "શોધવા માટે ટાઇપ કરો..."
|
||||||
|
|
||||||
@ -1297,7 +1275,6 @@ msgid "Close"
|
|||||||
msgstr "બંધ કરો"
|
msgstr "બંધ કરો"
|
||||||
|
|
||||||
#: ../js/ui/runDialog.js:277
|
#: ../js/ui/runDialog.js:277
|
||||||
#| msgid "Estimating…"
|
|
||||||
msgid "Restarting…"
|
msgid "Restarting…"
|
||||||
msgstr "પુન:શરૂ કરી રહ્યા છે…"
|
msgstr "પુન:શરૂ કરી રહ્યા છે…"
|
||||||
|
|
||||||
@ -1330,27 +1307,27 @@ msgstr "તાળુ મારવામાં અસમર્થ"
|
|||||||
msgid "Lock was blocked by an application"
|
msgid "Lock was blocked by an application"
|
||||||
msgstr "તાળુ કાર્યક્રમ દ્દારા બ્લોક થયેલ છે"
|
msgstr "તાળુ કાર્યક્રમ દ્દારા બ્લોક થયેલ છે"
|
||||||
|
|
||||||
#: ../js/ui/search.js:606
|
#: ../js/ui/search.js:607
|
||||||
msgid "Searching…"
|
msgid "Searching…"
|
||||||
msgstr "શોધી રહ્યા છે..."
|
msgstr "શોધી રહ્યા છે..."
|
||||||
|
|
||||||
#: ../js/ui/search.js:652
|
#: ../js/ui/search.js:609
|
||||||
msgid "No results."
|
msgid "No results."
|
||||||
msgstr "પરિણામો નથી."
|
msgstr "પરિણામો નથી."
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:27
|
#: ../js/ui/shellEntry.js:25
|
||||||
msgid "Copy"
|
msgid "Copy"
|
||||||
msgstr "નકલ કરો"
|
msgstr "નકલ કરો"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:32
|
#: ../js/ui/shellEntry.js:30
|
||||||
msgid "Paste"
|
msgid "Paste"
|
||||||
msgstr "ચોંટાડો"
|
msgstr "ચોંટાડો"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:99
|
#: ../js/ui/shellEntry.js:97
|
||||||
msgid "Show Text"
|
msgid "Show Text"
|
||||||
msgstr "લખાણ બતાવો"
|
msgstr "લખાણ બતાવો"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:101
|
#: ../js/ui/shellEntry.js:99
|
||||||
msgid "Hide Text"
|
msgid "Hide Text"
|
||||||
msgstr "લખાણ છુપાડો"
|
msgstr "લખાણ છુપાડો"
|
||||||
|
|
||||||
@ -1422,15 +1399,13 @@ msgid "Bluetooth Settings"
|
|||||||
msgstr "બ્લુટુથ સુયોજનો"
|
msgstr "બ્લુટુથ સુયોજનો"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:104
|
#: ../js/ui/status/bluetooth.js:104
|
||||||
#, fuzzy, javascript-format
|
#, javascript-format
|
||||||
#| msgid "Connected (private)"
|
|
||||||
msgid "%d Connected Device"
|
msgid "%d Connected Device"
|
||||||
msgid_plural "%d Connected Devices"
|
msgid_plural "%d Connected Devices"
|
||||||
msgstr[0] "જોડાયેલ (ખાનગી)"
|
msgstr[0] "%d જોડાયેલ ઉપકરણ"
|
||||||
msgstr[1] "જોડાયેલ (ખાનગી)"
|
msgstr[1] "%d જોડાયેલ ઉપકરણો"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:106 ../js/ui/status/network.js:1309
|
#: ../js/ui/status/bluetooth.js:106 ../js/ui/status/network.js:1309
|
||||||
#| msgid "Connect"
|
|
||||||
msgid "Not Connected"
|
msgid "Not Connected"
|
||||||
msgstr "જોડાયેલ નથી"
|
msgstr "જોડાયેલ નથી"
|
||||||
|
|
||||||
@ -1438,26 +1413,28 @@ msgstr "જોડાયેલ નથી"
|
|||||||
msgid "Brightness"
|
msgid "Brightness"
|
||||||
msgstr "તેજસ્વિતા"
|
msgstr "તેજસ્વિતા"
|
||||||
|
|
||||||
#: ../js/ui/status/keyboard.js:406
|
#: ../js/ui/status/keyboard.js:547
|
||||||
msgid "Show Keyboard Layout"
|
msgid "Show Keyboard Layout"
|
||||||
msgstr "કીબોર્ડ લેઆઉટને બતાવો"
|
msgstr "કીબોર્ડ લેઆઉટને બતાવો"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:56
|
#: ../js/ui/status/location.js:65
|
||||||
#| msgid "Notifications"
|
|
||||||
msgid "Location"
|
msgid "Location"
|
||||||
msgstr "સ્થાન"
|
msgstr "સ્થાન"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:63 ../js/ui/status/location.js:167
|
#: ../js/ui/status/location.js:72 ../js/ui/status/location.js:177
|
||||||
#| msgid "Disabled"
|
|
||||||
msgid "Disable"
|
msgid "Disable"
|
||||||
msgstr "નિષ્ક્રિય"
|
msgstr "નિષ્ક્રિય"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:166
|
#: ../js/ui/status/location.js:73
|
||||||
|
#| msgid "Power Settings"
|
||||||
|
msgid "Privacy Settings"
|
||||||
|
msgstr "ખાનગી સુયોજનો"
|
||||||
|
|
||||||
|
#: ../js/ui/status/location.js:176
|
||||||
msgid "In Use"
|
msgid "In Use"
|
||||||
msgstr "વપરાશમાં"
|
msgstr "વપરાશમાં"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:170
|
#: ../js/ui/status/location.js:180
|
||||||
#| msgid "Enabled"
|
|
||||||
msgid "Enable"
|
msgid "Enable"
|
||||||
msgstr "સક્રિય"
|
msgstr "સક્રિય"
|
||||||
|
|
||||||
@ -1467,42 +1444,35 @@ msgstr "<અજ્ઞાત>"
|
|||||||
|
|
||||||
#: ../js/ui/status/network.js:457 ../js/ui/status/network.js:1307
|
#: ../js/ui/status/network.js:457 ../js/ui/status/network.js:1307
|
||||||
#: ../js/ui/status/network.js:1511
|
#: ../js/ui/status/network.js:1511
|
||||||
#| msgid "Offline"
|
|
||||||
msgid "Off"
|
msgid "Off"
|
||||||
msgstr "બંધ"
|
msgstr "બંધ"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:459
|
#: ../js/ui/status/network.js:459
|
||||||
#| msgid "Connect"
|
|
||||||
msgid "Connected"
|
msgid "Connected"
|
||||||
msgstr "જોડાયેલ"
|
msgstr "જોડાયેલ"
|
||||||
|
|
||||||
#. Translators: this is for network devices that are physically present but are not
|
#. Translators: this is for network devices that are physically present but are not
|
||||||
#. under NetworkManager's control (and thus cannot be used in the menu) */
|
#. under NetworkManager's control (and thus cannot be used in the menu) */
|
||||||
#: ../js/ui/status/network.js:463
|
#: ../js/ui/status/network.js:463
|
||||||
#| msgid "unmanaged"
|
|
||||||
msgid "Unmanaged"
|
msgid "Unmanaged"
|
||||||
msgstr "સંચાલિત થયેલ નથી"
|
msgstr "સંચાલિત થયેલ નથી"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:465
|
#: ../js/ui/status/network.js:465
|
||||||
#| msgid "disconnecting..."
|
|
||||||
msgid "Disconnecting"
|
msgid "Disconnecting"
|
||||||
msgstr "જોડાઇ તૂટી રહ્યુ છે"
|
msgstr "જોડાઇ તૂટી રહ્યુ છે"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:471 ../js/ui/status/network.js:1301
|
#: ../js/ui/status/network.js:471 ../js/ui/status/network.js:1301
|
||||||
#| msgid "Connection"
|
|
||||||
msgid "Connecting"
|
msgid "Connecting"
|
||||||
msgstr "જોડાઇ રહ્યા છે"
|
msgstr "જોડાઇ રહ્યા છે"
|
||||||
|
|
||||||
#. Translators: this is for network connections that require some kind of key or password */
|
#. Translators: this is for network connections that require some kind of key or password */
|
||||||
#: ../js/ui/status/network.js:474
|
#: ../js/ui/status/network.js:474
|
||||||
#| msgid "authentication required"
|
|
||||||
msgid "Authentication required"
|
msgid "Authentication required"
|
||||||
msgstr "સત્તાધિકરણ જરૂરી"
|
msgstr "સત્તાધિકરણ જરૂરી"
|
||||||
|
|
||||||
#. Translators: this is for devices that require some kind of firmware or kernel
|
#. Translators: this is for devices that require some kind of firmware or kernel
|
||||||
#. module, which is missing */
|
#. module, which is missing */
|
||||||
#: ../js/ui/status/network.js:482
|
#: ../js/ui/status/network.js:482
|
||||||
#| msgid "firmware missing"
|
|
||||||
msgid "Firmware missing"
|
msgid "Firmware missing"
|
||||||
msgstr "ફર્મવેર ગેરહાજર"
|
msgstr "ફર્મવેર ગેરહાજર"
|
||||||
|
|
||||||
@ -1517,36 +1487,32 @@ msgid "Connection failed"
|
|||||||
msgstr "જોડાણ નિષ્ફળ"
|
msgstr "જોડાણ નિષ્ફળ"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:504
|
#: ../js/ui/status/network.js:504
|
||||||
#, fuzzy
|
|
||||||
#| msgid "Settings"
|
|
||||||
msgid "Wired Settings"
|
msgid "Wired Settings"
|
||||||
msgstr "સુયોજનો"
|
msgstr "વાયર થયેલ સુયોજનો"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:546 ../js/ui/status/network.js:624
|
#: ../js/ui/status/network.js:546 ../js/ui/status/network.js:624
|
||||||
#| msgid "Mobile broadband"
|
|
||||||
msgid "Mobile Broadband Settings"
|
msgid "Mobile Broadband Settings"
|
||||||
msgstr "મોબાઇલ બ્રોડબેન્ડ સુયોજનો"
|
msgstr "મોબાઇલ બ્રોડબેન્ડ સુયોજનો"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:588 ../js/ui/status/network.js:1305
|
#: ../js/ui/status/network.js:588 ../js/ui/status/network.js:1305
|
||||||
#| msgid "hardware disabled"
|
|
||||||
msgid "Hardware Disabled"
|
msgid "Hardware Disabled"
|
||||||
msgstr "હાર્ડવેર નિષ્ક્રિય"
|
msgstr "હાર્ડવેર નિષ્ક્રિય"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:632
|
#: ../js/ui/status/network.js:632
|
||||||
msgid "Use as Internet connection"
|
msgid "Use as Internet connection"
|
||||||
msgstr ""
|
msgstr "ઇન્ટરનેટ જોડાણ તરીકે વાપરો"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:813
|
#: ../js/ui/status/network.js:813
|
||||||
msgid "Airplane Mode is On"
|
msgid "Airplane Mode is On"
|
||||||
msgstr ""
|
msgstr "ઍરપ્લેન સ્થિતિ ચાલુ છે"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:814
|
#: ../js/ui/status/network.js:814
|
||||||
msgid "Wi-Fi is disabled when airplane mode is on."
|
msgid "Wi-Fi is disabled when airplane mode is on."
|
||||||
msgstr ""
|
msgstr "Wi-Fi નિષ્ક્રિય થયેલ છે જ્યારે ઍરપ્લેન સ્થિતિ ચાલુ હોય."
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:815
|
#: ../js/ui/status/network.js:815
|
||||||
msgid "Turn Off Airplane Mode"
|
msgid "Turn Off Airplane Mode"
|
||||||
msgstr ""
|
msgstr "ઍરપ્લેન સ્થિતિને બંધ કરો"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:824
|
#: ../js/ui/status/network.js:824
|
||||||
msgid "Wi-Fi is Off"
|
msgid "Wi-Fi is Off"
|
||||||
@ -1554,38 +1520,33 @@ msgstr "Wi-Fi બંધ છે"
|
|||||||
|
|
||||||
#: ../js/ui/status/network.js:825
|
#: ../js/ui/status/network.js:825
|
||||||
msgid "Wi-Fi needs to be turned on in order to connect to a network."
|
msgid "Wi-Fi needs to be turned on in order to connect to a network."
|
||||||
msgstr ""
|
msgstr "નેટવર્કમાં જોડાવા માટે ક્રમમાં Wi-Fi ને ચાલુ કરવાની જરૂર છે."
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:826
|
#: ../js/ui/status/network.js:826
|
||||||
msgid "Turn On Wi-Fi"
|
msgid "Turn On Wi-Fi"
|
||||||
msgstr ""
|
msgstr "Wi-Fi ચાલુ કરો"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:851
|
#: ../js/ui/status/network.js:851
|
||||||
#| msgid "Network"
|
|
||||||
msgid "Wi-Fi Networks"
|
msgid "Wi-Fi Networks"
|
||||||
msgstr "Wi-Fi નેટવર્ક"
|
msgstr "Wi-Fi નેટવર્ક"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:853
|
#: ../js/ui/status/network.js:853
|
||||||
#| msgid "Enable networking"
|
|
||||||
msgid "Select a network"
|
msgid "Select a network"
|
||||||
msgstr "નેટવર્ક પસંદ કરો"
|
msgstr "નેટવર્ક પસંદ કરો"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:882
|
#: ../js/ui/status/network.js:882
|
||||||
#| msgid "Network"
|
|
||||||
msgid "No Networks"
|
msgid "No Networks"
|
||||||
msgstr "નેટવર્ક નથી"
|
msgstr "નેટવર્ક નથી"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:903 ../js/ui/status/rfkill.js:112
|
#: ../js/ui/status/network.js:903 ../js/ui/status/rfkill.js:112
|
||||||
msgid "Use hardware switch to turn off"
|
msgid "Use hardware switch to turn off"
|
||||||
msgstr ""
|
msgstr "બંધ કરવા માટે હાર્ડવેર સ્વીચને વાપરો"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1173
|
#: ../js/ui/status/network.js:1173
|
||||||
#| msgid "Network"
|
|
||||||
msgid "Select Network"
|
msgid "Select Network"
|
||||||
msgstr "નેટવર્ક પસંદ કરો"
|
msgstr "નેટવર્ક પસંદ કરો"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1179
|
#: ../js/ui/status/network.js:1179
|
||||||
#| msgid "Settings"
|
|
||||||
msgid "Wi-Fi Settings"
|
msgid "Wi-Fi Settings"
|
||||||
msgstr "Wi-Fi સુયોજનો"
|
msgstr "Wi-Fi સુયોજનો"
|
||||||
|
|
||||||
@ -1595,7 +1556,7 @@ msgstr "ચાલુ કરો"
|
|||||||
|
|
||||||
#: ../js/ui/status/network.js:1298
|
#: ../js/ui/status/network.js:1298
|
||||||
msgid "Hotspot Active"
|
msgid "Hotspot Active"
|
||||||
msgstr ""
|
msgstr "હૉટસ્પોટ સક્રિય"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1409
|
#: ../js/ui/status/network.js:1409
|
||||||
msgid "connecting..."
|
msgid "connecting..."
|
||||||
@ -1615,7 +1576,6 @@ msgid "Network Settings"
|
|||||||
msgstr "નેટવર્ક સુયોજનો"
|
msgstr "નેટવર્ક સુયોજનો"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1482
|
#: ../js/ui/status/network.js:1482
|
||||||
#| msgid "Settings"
|
|
||||||
msgid "VPN Settings"
|
msgid "VPN Settings"
|
||||||
msgstr "VPN સુયોજનો"
|
msgstr "VPN સુયોજનો"
|
||||||
|
|
||||||
@ -1646,12 +1606,12 @@ msgstr "અંદાજ કરી રહ્યા છે..."
|
|||||||
#: ../js/ui/status/power.js:86
|
#: ../js/ui/status/power.js:86
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%d∶%02d Remaining (%d%%)"
|
msgid "%d∶%02d Remaining (%d%%)"
|
||||||
msgstr ""
|
msgstr "%d∶%02d બાકી રહેલ છે (%d%%)"
|
||||||
|
|
||||||
#: ../js/ui/status/power.js:91
|
#: ../js/ui/status/power.js:91
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%d∶%02d Until Full (%d%%)"
|
msgid "%d∶%02d Until Full (%d%%)"
|
||||||
msgstr ""
|
msgstr "%d∶%02d જ્યાં સુધી સંપૂર્ણ થાય (%d%%)"
|
||||||
|
|
||||||
#: ../js/ui/status/power.js:119
|
#: ../js/ui/status/power.js:119
|
||||||
msgid "UPS"
|
msgid "UPS"
|
||||||
@ -1663,10 +1623,9 @@ msgstr "બેટરી"
|
|||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:83
|
#: ../js/ui/status/rfkill.js:83
|
||||||
msgid "Airplane Mode"
|
msgid "Airplane Mode"
|
||||||
msgstr ""
|
msgstr "ઍરપ્લેન સ્થિતિ"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:85
|
#: ../js/ui/status/rfkill.js:85
|
||||||
#| msgid "Open"
|
|
||||||
msgid "On"
|
msgid "On"
|
||||||
msgstr "ચાલુ"
|
msgstr "ચાલુ"
|
||||||
|
|
||||||
@ -1680,7 +1639,7 @@ msgstr "બહાર નીકળો"
|
|||||||
|
|
||||||
#: ../js/ui/status/system.js:341
|
#: ../js/ui/status/system.js:341
|
||||||
msgid "Orientation Lock"
|
msgid "Orientation Lock"
|
||||||
msgstr ""
|
msgstr "દિશા તાળુ"
|
||||||
|
|
||||||
#: ../js/ui/status/system.js:349
|
#: ../js/ui/status/system.js:349
|
||||||
msgid "Suspend"
|
msgid "Suspend"
|
||||||
@ -1710,43 +1669,40 @@ msgstr "બીજા વપરાશકર્તા તરીકે પ્રવ
|
|||||||
msgid "Unlock Window"
|
msgid "Unlock Window"
|
||||||
msgstr "વિન્ડોનું તાળુ ખોલો"
|
msgstr "વિન્ડોનું તાળુ ખોલો"
|
||||||
|
|
||||||
#: ../js/ui/viewSelector.js:232
|
#: ../js/ui/viewSelector.js:158
|
||||||
msgid "Applications"
|
msgid "Applications"
|
||||||
msgstr "કાર્યક્રમો"
|
msgstr "કાર્યક્રમો"
|
||||||
|
|
||||||
#: ../js/ui/viewSelector.js:236
|
#: ../js/ui/viewSelector.js:162
|
||||||
msgid "Search"
|
msgid "Search"
|
||||||
msgstr "શોધો"
|
msgstr "શોધો"
|
||||||
|
|
||||||
#: ../js/ui/windowAttentionHandler.js:19
|
#: ../js/ui/windowAttentionHandler.js:19
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
#| msgid "'%s' is ready"
|
|
||||||
msgid "“%s” is ready"
|
msgid "“%s” is ready"
|
||||||
msgstr "“%s” તૈયાર છે"
|
msgstr "“%s” તૈયાર છે"
|
||||||
|
|
||||||
#: ../js/ui/windowManager.js:65
|
#: ../js/ui/windowManager.js:65
|
||||||
msgid "Do you want to keep these display settings?"
|
msgid "Do you want to keep these display settings?"
|
||||||
msgstr ""
|
msgstr "શું તમને આ દર્શાવ સુયોજનોને રાખવા માંગો છો?ે"
|
||||||
|
|
||||||
#. Translators: this and the following message should be limited in lenght,
|
#. Translators: this and the following message should be limited in lenght,
|
||||||
#. to avoid ellipsizing the labels.
|
#. to avoid ellipsizing the labels.
|
||||||
#. */
|
#. */
|
||||||
#: ../js/ui/windowManager.js:84
|
#: ../js/ui/windowManager.js:84
|
||||||
#, fuzzy
|
|
||||||
#| msgid "Power Settings"
|
|
||||||
msgid "Revert Settings"
|
msgid "Revert Settings"
|
||||||
msgstr "પાવર સુયોજનો"
|
msgstr "સુયોજનોને પાછા લાવો"
|
||||||
|
|
||||||
#: ../js/ui/windowManager.js:88
|
#: ../js/ui/windowManager.js:88
|
||||||
msgid "Keep Changes"
|
msgid "Keep Changes"
|
||||||
msgstr ""
|
msgstr "ફેરફારો કરો"
|
||||||
|
|
||||||
#: ../js/ui/windowManager.js:107
|
#: ../js/ui/windowManager.js:107
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Settings changes will revert in %d second"
|
msgid "Settings changes will revert in %d second"
|
||||||
msgid_plural "Settings changes will revert in %d seconds"
|
msgid_plural "Settings changes will revert in %d seconds"
|
||||||
msgstr[0] ""
|
msgstr[0] "સુયોજન ફેરફારો એ %d સેકંડમાં પાછા આવશે"
|
||||||
msgstr[1] ""
|
msgstr[1] "સુયોજન ફેરફારો એ %d સેકંડોમાં પાછા આવશે"
|
||||||
|
|
||||||
#: ../js/ui/windowMenu.js:34
|
#: ../js/ui/windowMenu.js:34
|
||||||
msgid "Minimize"
|
msgid "Minimize"
|
||||||
@ -1770,7 +1726,7 @@ msgstr "માપ બદલો"
|
|||||||
|
|
||||||
#: ../js/ui/windowMenu.js:65
|
#: ../js/ui/windowMenu.js:65
|
||||||
msgid "Move Titlebar Onscreen"
|
msgid "Move Titlebar Onscreen"
|
||||||
msgstr ""
|
msgstr "શીર્ષકપટ્ટી ઓનસ્ક્રીનને ખસેડો"
|
||||||
|
|
||||||
#: ../js/ui/windowMenu.js:70
|
#: ../js/ui/windowMenu.js:70
|
||||||
msgid "Always on Top"
|
msgid "Always on Top"
|
||||||
@ -1778,15 +1734,15 @@ msgstr "હંમેશા ટોચ ઉપર"
|
|||||||
|
|
||||||
#: ../js/ui/windowMenu.js:89
|
#: ../js/ui/windowMenu.js:89
|
||||||
msgid "Always on Visible Workspace"
|
msgid "Always on Visible Workspace"
|
||||||
msgstr ""
|
msgstr "હંમેશા દૃશ્ય કામ કરવાની જગ્યા પર"
|
||||||
|
|
||||||
#: ../js/ui/windowMenu.js:106
|
#: ../js/ui/windowMenu.js:106
|
||||||
msgid "Move to Workspace Up"
|
msgid "Move to Workspace Up"
|
||||||
msgstr ""
|
msgstr "ઉપર કામ કરવાની જગ્યા પર ખસેડો"
|
||||||
|
|
||||||
#: ../js/ui/windowMenu.js:111
|
#: ../js/ui/windowMenu.js:111
|
||||||
msgid "Move to Workspace Down"
|
msgid "Move to Workspace Down"
|
||||||
msgstr ""
|
msgstr "નીચે કામ કરવાની જગ્યાએ ખસેડો"
|
||||||
|
|
||||||
#: ../src/calendar-server/evolution-calendar.desktop.in.in.h:1
|
#: ../src/calendar-server/evolution-calendar.desktop.in.in.h:1
|
||||||
msgid "Evolution Calendar"
|
msgid "Evolution Calendar"
|
||||||
@ -1814,25 +1770,24 @@ msgstr[1] "%u ઇનપુટો"
|
|||||||
msgid "System Sounds"
|
msgid "System Sounds"
|
||||||
msgstr "સિસ્ટમ અવાજો"
|
msgstr "સિસ્ટમ અવાજો"
|
||||||
|
|
||||||
#: ../src/main.c:371
|
#: ../src/main.c:373
|
||||||
msgid "Print version"
|
msgid "Print version"
|
||||||
msgstr "ા"
|
msgstr "ા"
|
||||||
|
|
||||||
#: ../src/main.c:377
|
#: ../src/main.c:379
|
||||||
msgid "Mode used by GDM for login screen"
|
msgid "Mode used by GDM for login screen"
|
||||||
msgstr "લૉગિન સ્ક્રીન માટે GDM દ્દારા વાપરેલ સ્થિતિ"
|
msgstr "લૉગિન સ્ક્રીન માટે GDM દ્દારા વાપરેલ સ્થિતિ"
|
||||||
|
|
||||||
#: ../src/main.c:383
|
#: ../src/main.c:385
|
||||||
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
||||||
msgstr "ખાસ સ્થિતિને વાપરો, દા.ત. પ્રવેશ સ્ક્રીન માટે \"gdm\""
|
msgstr "ખાસ સ્થિતિને વાપરો, દા.ત. પ્રવેશ સ્ક્રીન માટે \"gdm\""
|
||||||
|
|
||||||
#: ../src/main.c:389
|
#: ../src/main.c:391
|
||||||
msgid "List possible modes"
|
msgid "List possible modes"
|
||||||
msgstr "શક્ય સ્થિતિઓની યાદી કરો"
|
msgstr "શક્ય સ્થિતિઓની યાદી કરો"
|
||||||
|
|
||||||
#: ../src/shell-app.c:666
|
#: ../src/shell-app.c:666
|
||||||
#, c-format
|
#, c-format
|
||||||
#| msgid "Failed to launch '%s'"
|
|
||||||
msgid "Failed to launch “%s”"
|
msgid "Failed to launch “%s”"
|
||||||
msgstr "“%s” ને શરૂ કરવામાં નિષ્ફળતા"
|
msgstr "“%s” ને શરૂ કરવામાં નિષ્ફળતા"
|
||||||
|
|
||||||
|
118
po/id.po
@ -10,8 +10,8 @@ msgstr ""
|
|||||||
"Project-Id-Version: gnome-shell master\n"
|
"Project-Id-Version: gnome-shell master\n"
|
||||||
"Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?product=gnome-"
|
"Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?product=gnome-"
|
||||||
"shell&keywords=I18N+L10N&component=general\n"
|
"shell&keywords=I18N+L10N&component=general\n"
|
||||||
"POT-Creation-Date: 2014-09-02 07:38+0000\n"
|
"POT-Creation-Date: 2014-09-13 07:37+0000\n"
|
||||||
"PO-Revision-Date: 2014-09-02 19:20+0700\n"
|
"PO-Revision-Date: 2014-09-13 19:20+0700\n"
|
||||||
"Last-Translator: Andika Triwidada <andika@gmail.com>\n"
|
"Last-Translator: Andika Triwidada <andika@gmail.com>\n"
|
||||||
"Language-Team: Indonesian <gnome-l10n-id@googlegroups.com>\n"
|
"Language-Team: Indonesian <gnome-l10n-id@googlegroups.com>\n"
|
||||||
"Language: id\n"
|
"Language: id\n"
|
||||||
@ -304,17 +304,17 @@ msgstr ""
|
|||||||
msgid "Captive Portal"
|
msgid "Captive Portal"
|
||||||
msgstr "Portal Captive"
|
msgstr "Portal Captive"
|
||||||
|
|
||||||
#: ../js/extensionPrefs/main.js:127
|
#: ../js/extensionPrefs/main.js:123
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "There was an error loading the preferences dialog for %s:"
|
msgid "There was an error loading the preferences dialog for %s:"
|
||||||
msgstr "Ada galat saat memuat dialog preferensi bagi %s:"
|
msgstr "Ada galat saat memuat dialog preferensi bagi %s:"
|
||||||
|
|
||||||
#: ../js/extensionPrefs/main.js:159
|
#: ../js/extensionPrefs/main.js:155
|
||||||
msgid "GNOME Shell Extensions"
|
msgid "GNOME Shell Extensions"
|
||||||
msgstr "Ekstensi GNOME Shell"
|
msgstr "Ekstensi GNOME Shell"
|
||||||
|
|
||||||
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:143
|
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:143
|
||||||
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:429
|
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:452
|
||||||
#: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399
|
#: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399
|
||||||
#: ../js/ui/status/network.js:915
|
#: ../js/ui/status/network.js:915
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
@ -393,19 +393,19 @@ msgstr "Sering"
|
|||||||
msgid "All"
|
msgid "All"
|
||||||
msgstr "Semua"
|
msgstr "Semua"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1788
|
#: ../js/ui/appDisplay.js:1789
|
||||||
msgid "New Window"
|
msgid "New Window"
|
||||||
msgstr "Jendela Baru"
|
msgstr "Jendela Baru"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1814 ../js/ui/dash.js:285
|
#: ../js/ui/appDisplay.js:1815 ../js/ui/dash.js:285
|
||||||
msgid "Remove from Favorites"
|
msgid "Remove from Favorites"
|
||||||
msgstr "Hapus dari Favorit"
|
msgstr "Hapus dari Favorit"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1820
|
#: ../js/ui/appDisplay.js:1821
|
||||||
msgid "Add to Favorites"
|
msgid "Add to Favorites"
|
||||||
msgstr "Tambah ke Favorit"
|
msgstr "Tambah ke Favorit"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1829
|
#: ../js/ui/appDisplay.js:1830
|
||||||
msgid "Show Details"
|
msgid "Show Details"
|
||||||
msgstr "Tampilkan Rincian"
|
msgstr "Tampilkan Rincian"
|
||||||
|
|
||||||
@ -606,11 +606,11 @@ msgstr "Buka dengan %s"
|
|||||||
msgid "Eject"
|
msgid "Eject"
|
||||||
msgstr "Keluarkan"
|
msgstr "Keluarkan"
|
||||||
|
|
||||||
#: ../js/ui/components/keyring.js:93 ../js/ui/components/polkitAgent.js:285
|
#: ../js/ui/components/keyring.js:94 ../js/ui/components/polkitAgent.js:285
|
||||||
msgid "Password:"
|
msgid "Password:"
|
||||||
msgstr "Sandi:"
|
msgstr "Sandi:"
|
||||||
|
|
||||||
#: ../js/ui/components/keyring.js:113
|
#: ../js/ui/components/keyring.js:120
|
||||||
msgid "Type again:"
|
msgid "Type again:"
|
||||||
msgstr "Ketik lagi:"
|
msgstr "Ketik lagi:"
|
||||||
|
|
||||||
@ -983,7 +983,7 @@ msgstr "Tilik akun"
|
|||||||
msgid "Unknown reason"
|
msgid "Unknown reason"
|
||||||
msgstr "Alasan yang tidak diketahui"
|
msgstr "Alasan yang tidak diketahui"
|
||||||
|
|
||||||
#: ../js/ui/ctrlAltTab.js:29 ../js/ui/viewSelector.js:159
|
#: ../js/ui/ctrlAltTab.js:29 ../js/ui/viewSelector.js:154
|
||||||
msgid "Windows"
|
msgid "Windows"
|
||||||
msgstr "Jendela"
|
msgstr "Jendela"
|
||||||
|
|
||||||
@ -1014,82 +1014,82 @@ msgstr "Pengaturan Waktu & Tanggal"
|
|||||||
msgid "%A %B %e, %Y"
|
msgid "%A %B %e, %Y"
|
||||||
msgstr "%A, %e %B %Y"
|
msgstr "%A, %e %B %Y"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:66
|
#: ../js/ui/endSessionDialog.js:64
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Log Out %s"
|
msgid "Log Out %s"
|
||||||
msgstr "Keluar %s"
|
msgstr "Keluar %s"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:67
|
#: ../js/ui/endSessionDialog.js:65
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Log Out"
|
msgid "Log Out"
|
||||||
msgstr "Keluar"
|
msgstr "Keluar"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:69
|
#: ../js/ui/endSessionDialog.js:67
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s will be logged out automatically in %d second."
|
msgid "%s will be logged out automatically in %d second."
|
||||||
msgid_plural "%s will be logged out automatically in %d seconds."
|
msgid_plural "%s will be logged out automatically in %d seconds."
|
||||||
msgstr[0] "%s akan log keluar otomatis dalam %d detik.\t\t"
|
msgstr[0] "%s akan log keluar otomatis dalam %d detik.\t\t"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:74
|
#: ../js/ui/endSessionDialog.js:72
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "You will be logged out automatically in %d second."
|
msgid "You will be logged out automatically in %d second."
|
||||||
msgid_plural "You will be logged out automatically in %d seconds."
|
msgid_plural "You will be logged out automatically in %d seconds."
|
||||||
msgstr[0] "Anda akan log keluar otomatis dalam %d detik."
|
msgstr[0] "Anda akan log keluar otomatis dalam %d detik."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:80
|
#: ../js/ui/endSessionDialog.js:78
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Log Out"
|
msgid "Log Out"
|
||||||
msgstr "Keluar"
|
msgstr "Keluar"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:86
|
#: ../js/ui/endSessionDialog.js:84
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Power Off"
|
msgid "Power Off"
|
||||||
msgstr "Matikan"
|
msgstr "Matikan"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:87
|
#: ../js/ui/endSessionDialog.js:85
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Install Updates & Power Off"
|
msgid "Install Updates & Power Off"
|
||||||
msgstr "Pasang Pemutakhiran & Matikan"
|
msgstr "Pasang Pemutakhiran & Matikan"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:89
|
#: ../js/ui/endSessionDialog.js:87
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "The system will power off automatically in %d second."
|
msgid "The system will power off automatically in %d second."
|
||||||
msgid_plural "The system will power off automatically in %d seconds."
|
msgid_plural "The system will power off automatically in %d seconds."
|
||||||
msgstr[0] "Sistem ini akan otomatis dimatikan dalam %d detik."
|
msgstr[0] "Sistem ini akan otomatis dimatikan dalam %d detik."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:93
|
#: ../js/ui/endSessionDialog.js:91
|
||||||
msgctxt "checkbox"
|
msgctxt "checkbox"
|
||||||
msgid "Install pending software updates"
|
msgid "Install pending software updates"
|
||||||
msgstr "Pasang pemutakhiran perangkat lunak yang tertunda"
|
msgstr "Pasang pemutakhiran perangkat lunak yang tertunda"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:96 ../js/ui/endSessionDialog.js:113
|
#: ../js/ui/endSessionDialog.js:94 ../js/ui/endSessionDialog.js:111
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Restart"
|
msgid "Restart"
|
||||||
msgstr "Nyalakan Ulang"
|
msgstr "Nyalakan Ulang"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:98
|
#: ../js/ui/endSessionDialog.js:96
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Power Off"
|
msgid "Power Off"
|
||||||
msgstr "Matikan"
|
msgstr "Matikan"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:105
|
#: ../js/ui/endSessionDialog.js:103
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Restart"
|
msgid "Restart"
|
||||||
msgstr "Nyalakan Ulang"
|
msgstr "Nyalakan Ulang"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:107
|
#: ../js/ui/endSessionDialog.js:105
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "The system will restart automatically in %d second."
|
msgid "The system will restart automatically in %d second."
|
||||||
msgid_plural "The system will restart automatically in %d seconds."
|
msgid_plural "The system will restart automatically in %d seconds."
|
||||||
msgstr[0] "Sistem ini akan otomatis dimulai ulang dalam %d detik."
|
msgstr[0] "Sistem ini akan otomatis dimulai ulang dalam %d detik."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:121
|
#: ../js/ui/endSessionDialog.js:119
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Restart & Install Updates"
|
msgid "Restart & Install Updates"
|
||||||
msgstr "Start Ulang & Pasang Pemutakhiran"
|
msgstr "Start Ulang & Pasang Pemutakhiran"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:123
|
#: ../js/ui/endSessionDialog.js:121
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "The system will automatically restart and install updates in %d second."
|
msgid "The system will automatically restart and install updates in %d second."
|
||||||
msgid_plural ""
|
msgid_plural ""
|
||||||
@ -1098,42 +1098,42 @@ msgstr[0] ""
|
|||||||
"Sistem ini akan otomatis dimulai ulang dan memasang pemutakhiran dalam %d "
|
"Sistem ini akan otomatis dimulai ulang dan memasang pemutakhiran dalam %d "
|
||||||
"detik."
|
"detik."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:129
|
#: ../js/ui/endSessionDialog.js:127
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Restart & Install"
|
msgid "Restart & Install"
|
||||||
msgstr "Start Ulang & Pasang"
|
msgstr "Start Ulang & Pasang"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:130
|
#: ../js/ui/endSessionDialog.js:128
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Install & Power Off"
|
msgid "Install & Power Off"
|
||||||
msgstr "Pasang & Matikan"
|
msgstr "Pasang & Matikan"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:131
|
#: ../js/ui/endSessionDialog.js:129
|
||||||
msgctxt "checkbox"
|
msgctxt "checkbox"
|
||||||
msgid "Power off after updates are installed"
|
msgid "Power off after updates are installed"
|
||||||
msgstr "Matikan daya setelah pemutakhiran dipasang"
|
msgstr "Matikan daya setelah pemutakhiran dipasang"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:315
|
#: ../js/ui/endSessionDialog.js:338
|
||||||
msgid "Running on battery power: please plug in before installing updates."
|
msgid "Running on battery power: please plug in before installing updates."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Berjalan memakai daya baterai: harap tancapkan sebelum memasang pemutakhiran."
|
"Berjalan memakai daya baterai: harap tancapkan sebelum memasang pemutakhiran."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:332
|
#: ../js/ui/endSessionDialog.js:355
|
||||||
msgid "Some applications are busy or have unsaved work."
|
msgid "Some applications are busy or have unsaved work."
|
||||||
msgstr "Beberapa aplikasi sedang sibuk atau belum disimpan perubahannya."
|
msgstr "Beberapa aplikasi sedang sibuk atau belum disimpan perubahannya."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:339
|
#: ../js/ui/endSessionDialog.js:362
|
||||||
msgid "Other users are logged in."
|
msgid "Other users are logged in."
|
||||||
msgstr "Pengguna lain sedang log masuk."
|
msgstr "Pengguna lain sedang log masuk."
|
||||||
|
|
||||||
#. Translators: Remote here refers to a remote session, like a ssh login */
|
#. Translators: Remote here refers to a remote session, like a ssh login */
|
||||||
#: ../js/ui/endSessionDialog.js:619
|
#: ../js/ui/endSessionDialog.js:640
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s (remote)"
|
msgid "%s (remote)"
|
||||||
msgstr "%s (jarak jauh)"
|
msgstr "%s (jarak jauh)"
|
||||||
|
|
||||||
#. Translators: Console here refers to a tty like a VT console */
|
#. Translators: Console here refers to a tty like a VT console */
|
||||||
#: ../js/ui/endSessionDialog.js:622
|
#: ../js/ui/endSessionDialog.js:643
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s (console)"
|
msgid "%s (console)"
|
||||||
msgstr "%s (konsol)"
|
msgstr "%s (konsol)"
|
||||||
@ -1147,7 +1147,7 @@ msgstr "Pasang"
|
|||||||
msgid "Download and install “%s” from extensions.gnome.org?"
|
msgid "Download and install “%s” from extensions.gnome.org?"
|
||||||
msgstr "Unduh dan pasang \"%s\" dari extensions.gnome.org?"
|
msgstr "Unduh dan pasang \"%s\" dari extensions.gnome.org?"
|
||||||
|
|
||||||
#: ../js/ui/keyboard.js:634 ../js/ui/status/keyboard.js:339
|
#: ../js/ui/keyboard.js:692 ../js/ui/status/keyboard.js:523
|
||||||
msgid "Keyboard"
|
msgid "Keyboard"
|
||||||
msgstr "Papan Ketik"
|
msgstr "Papan Ketik"
|
||||||
|
|
||||||
@ -1169,8 +1169,8 @@ msgstr "Sembunyikan Galat"
|
|||||||
msgid "Show Errors"
|
msgid "Show Errors"
|
||||||
msgstr "Tampilkan Galat"
|
msgstr "Tampilkan Galat"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:716 ../js/ui/status/location.js:62
|
#: ../js/ui/lookingGlass.js:716 ../js/ui/status/location.js:71
|
||||||
#: ../js/ui/status/location.js:166
|
#: ../js/ui/status/location.js:176
|
||||||
msgid "Enabled"
|
msgid "Enabled"
|
||||||
msgstr "Diaktifkan"
|
msgstr "Diaktifkan"
|
||||||
|
|
||||||
@ -1178,7 +1178,7 @@ msgstr "Diaktifkan"
|
|||||||
#. because it's disabled by rfkill (airplane mode) */
|
#. because it's disabled by rfkill (airplane mode) */
|
||||||
#. translators:
|
#. translators:
|
||||||
#. * The device has been disabled
|
#. * The device has been disabled
|
||||||
#: ../js/ui/lookingGlass.js:719 ../js/ui/status/location.js:169
|
#: ../js/ui/lookingGlass.js:719 ../js/ui/status/location.js:179
|
||||||
#: ../js/ui/status/network.js:592 ../src/gvc/gvc-mixer-control.c:1830
|
#: ../js/ui/status/network.js:592 ../src/gvc/gvc-mixer-control.c:1830
|
||||||
msgid "Disabled"
|
msgid "Disabled"
|
||||||
msgstr "Dinonaktifkan"
|
msgstr "Dinonaktifkan"
|
||||||
@ -1262,7 +1262,7 @@ msgstr "Gambaran"
|
|||||||
#. in the search entry when no search is
|
#. in the search entry when no search is
|
||||||
#. active; it should not exceed ~30
|
#. active; it should not exceed ~30
|
||||||
#. characters. */
|
#. characters. */
|
||||||
#: ../js/ui/overview.js:250
|
#: ../js/ui/overview.js:246
|
||||||
msgid "Type to search…"
|
msgid "Type to search…"
|
||||||
msgstr "Ketik untuk mencari…"
|
msgstr "Ketik untuk mencari…"
|
||||||
|
|
||||||
@ -1325,27 +1325,27 @@ msgstr "Tak bisa mengunci"
|
|||||||
msgid "Lock was blocked by an application"
|
msgid "Lock was blocked by an application"
|
||||||
msgstr "Kunci diblokir oleh suatu aplikasi"
|
msgstr "Kunci diblokir oleh suatu aplikasi"
|
||||||
|
|
||||||
#: ../js/ui/search.js:557
|
#: ../js/ui/search.js:594
|
||||||
msgid "Searching…"
|
msgid "Searching…"
|
||||||
msgstr "Mencari…"
|
msgstr "Mencari…"
|
||||||
|
|
||||||
#: ../js/ui/search.js:598
|
#: ../js/ui/search.js:596
|
||||||
msgid "No results."
|
msgid "No results."
|
||||||
msgstr "Tak ada yang cocok."
|
msgstr "Tak ada yang cocok."
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:27
|
#: ../js/ui/shellEntry.js:25
|
||||||
msgid "Copy"
|
msgid "Copy"
|
||||||
msgstr "Salin"
|
msgstr "Salin"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:32
|
#: ../js/ui/shellEntry.js:30
|
||||||
msgid "Paste"
|
msgid "Paste"
|
||||||
msgstr "Tempel"
|
msgstr "Tempel"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:99
|
#: ../js/ui/shellEntry.js:97
|
||||||
msgid "Show Text"
|
msgid "Show Text"
|
||||||
msgstr "Tampilkan Teks"
|
msgstr "Tampilkan Teks"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:101
|
#: ../js/ui/shellEntry.js:99
|
||||||
msgid "Hide Text"
|
msgid "Hide Text"
|
||||||
msgstr "Sembunyikan Teks"
|
msgstr "Sembunyikan Teks"
|
||||||
|
|
||||||
@ -1430,23 +1430,27 @@ msgstr "Tak Tersambung"
|
|||||||
msgid "Brightness"
|
msgid "Brightness"
|
||||||
msgstr "Kecerahan"
|
msgstr "Kecerahan"
|
||||||
|
|
||||||
#: ../js/ui/status/keyboard.js:406
|
#: ../js/ui/status/keyboard.js:547
|
||||||
msgid "Show Keyboard Layout"
|
msgid "Show Keyboard Layout"
|
||||||
msgstr "Tampilkan Tata Letak Papan Tik"
|
msgstr "Tampilkan Tata Letak Papan Tik"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:56
|
#: ../js/ui/status/location.js:65
|
||||||
msgid "Location"
|
msgid "Location"
|
||||||
msgstr "Lokasi"
|
msgstr "Lokasi"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:63 ../js/ui/status/location.js:167
|
#: ../js/ui/status/location.js:72 ../js/ui/status/location.js:177
|
||||||
msgid "Disable"
|
msgid "Disable"
|
||||||
msgstr "Nonaktifkan"
|
msgstr "Nonaktifkan"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:166
|
#: ../js/ui/status/location.js:73
|
||||||
|
msgid "Privacy Settings"
|
||||||
|
msgstr "Pengaturan Privasi"
|
||||||
|
|
||||||
|
#: ../js/ui/status/location.js:176
|
||||||
msgid "In Use"
|
msgid "In Use"
|
||||||
msgstr "Dipakai"
|
msgstr "Dipakai"
|
||||||
|
|
||||||
#: ../js/ui/status/location.js:170
|
#: ../js/ui/status/location.js:180
|
||||||
msgid "Enable"
|
msgid "Enable"
|
||||||
msgstr "Fungsikan"
|
msgstr "Fungsikan"
|
||||||
|
|
||||||
@ -1681,11 +1685,11 @@ msgstr "Masuk sebagai pengguna lain"
|
|||||||
msgid "Unlock Window"
|
msgid "Unlock Window"
|
||||||
msgstr "Buka Kunci Jendela"
|
msgstr "Buka Kunci Jendela"
|
||||||
|
|
||||||
#: ../js/ui/viewSelector.js:163
|
#: ../js/ui/viewSelector.js:158
|
||||||
msgid "Applications"
|
msgid "Applications"
|
||||||
msgstr "Aplikasi"
|
msgstr "Aplikasi"
|
||||||
|
|
||||||
#: ../js/ui/viewSelector.js:167
|
#: ../js/ui/viewSelector.js:162
|
||||||
msgid "Search"
|
msgid "Search"
|
||||||
msgstr "Cari"
|
msgstr "Cari"
|
||||||
|
|
||||||
@ -1779,19 +1783,19 @@ msgstr[0] "%u Masukan"
|
|||||||
msgid "System Sounds"
|
msgid "System Sounds"
|
||||||
msgstr "Suara Sistem"
|
msgstr "Suara Sistem"
|
||||||
|
|
||||||
#: ../src/main.c:371
|
#: ../src/main.c:373
|
||||||
msgid "Print version"
|
msgid "Print version"
|
||||||
msgstr "Versi Cetak"
|
msgstr "Versi Cetak"
|
||||||
|
|
||||||
#: ../src/main.c:377
|
#: ../src/main.c:379
|
||||||
msgid "Mode used by GDM for login screen"
|
msgid "Mode used by GDM for login screen"
|
||||||
msgstr "Mode yang dipakai oleh layar log masuk GDM"
|
msgstr "Mode yang dipakai oleh layar log masuk GDM"
|
||||||
|
|
||||||
#: ../src/main.c:383
|
#: ../src/main.c:385
|
||||||
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
||||||
msgstr "Menggunakan mode tertentu, mis. \"gdm\" untuk layar masuk"
|
msgstr "Menggunakan mode tertentu, mis. \"gdm\" untuk layar masuk"
|
||||||
|
|
||||||
#: ../src/main.c:389
|
#: ../src/main.c:391
|
||||||
msgid "List possible modes"
|
msgid "List possible modes"
|
||||||
msgstr "Menampilkan mode yang mungkin"
|
msgstr "Menampilkan mode yang mungkin"
|
||||||
|
|
||||||
|