Compare commits
129 Commits
wip/overvi
...
3.11.90
Author | SHA1 | Date | |
---|---|---|---|
3c58f4abd3 | |||
e2a9b27b2b | |||
fcd5f06c09 | |||
6d93c8b3fd | |||
2663e1be5d | |||
0fa6be4614 | |||
46163a6607 | |||
645ef093f7 | |||
7551e134da | |||
5bec5fb6cb | |||
c176af4da5 | |||
2631f03108 | |||
525c71658b | |||
10e5778deb | |||
6512a5fd6b | |||
1af40b1345 | |||
0418b68051 | |||
a7283864e8 | |||
4950bad2a7 | |||
470ac0eae3 | |||
87abbf9b20 | |||
3e7e88cd5f | |||
b7e1539699 | |||
8492f2ba24 | |||
737f4eb1c1 | |||
58191ea66b | |||
1f786df462 | |||
fa4c481aed | |||
d555fd7883 | |||
fe7ece1f5a | |||
2bb3aed729 | |||
488a42696c | |||
f43ff45683 | |||
bde1451896 | |||
fff2ca6f26 | |||
bec57a6cee | |||
a012ca4fac | |||
3ba49b0a50 | |||
314aa024b5 | |||
598f750859 | |||
8057848458 | |||
e80c28a530 | |||
5d05b66902 | |||
59634b2cf5 | |||
7c3892f5a2 | |||
19406a238b | |||
d6146197dd | |||
38f241479c | |||
aa45999824 | |||
3b7593ed7f | |||
f959cafb36 | |||
e92d204d42 | |||
f543161234 | |||
9cc1017912 | |||
fc719c19f9 | |||
ad97fc6855 | |||
407dc74502 | |||
e5e764b402 | |||
65ad65fe52 | |||
8d09d20510 | |||
5a5b04b2b0 | |||
3113bac8e6 | |||
9217f2c916 | |||
32a49b7846 | |||
12ef034b7b | |||
e70e4a21f2 | |||
7826fb4f04 | |||
8f1b8909dc | |||
3f7a989d38 | |||
4d3fd7598d | |||
620e3cef20 | |||
812a61939e | |||
793c6c2f7b | |||
f8f4d0f646 | |||
3a92aa751f | |||
6882273aa0 | |||
3b0197620f | |||
f6240e114c | |||
0f3c129b95 | |||
6f87b01c47 | |||
32110a9866 | |||
ba459f4d20 | |||
d868e6bfaf | |||
9f3499a7c3 | |||
ccec7732a7 | |||
3b980a173f | |||
246139f90b | |||
4e85fb7d8d | |||
ab32411b0c | |||
477f28a6bd | |||
96ef0a178d | |||
ab603e7ef7 | |||
d52104a62a | |||
8d8d1cfdd6 | |||
5451751513 | |||
92ae26bb9f | |||
3c8ee0c8cb | |||
20f76b8118 | |||
d8eeeead18 | |||
5452162bc3 | |||
a4adcba405 | |||
66da594382 | |||
aa426842f2 | |||
ed53a45228 | |||
2ddbcb2369 | |||
61a58ff3c9 | |||
638aee65c0 | |||
f21c49f8da | |||
583d2cb4e4 | |||
aa70dcfc8f | |||
ffb61c425b | |||
858cf5e0c9 | |||
881dd4666e | |||
c4aeaf7fe8 | |||
ea1f5a8fc6 | |||
7f1e420a0a | |||
1272eaf07f | |||
2fe760cc4b | |||
df3a50bae8 | |||
0db3605f33 | |||
173fa92116 | |||
02ca58c1eb | |||
4a22fe58bf | |||
3fc478a14b | |||
203bc674fe | |||
a4a9f0a04c | |||
918e7fffeb | |||
e1648de661 | |||
f7c94e6343 |
66
NEWS
66
NEWS
@ -1,3 +1,69 @@
|
|||||||
|
3.11.90
|
||||||
|
=======
|
||||||
|
* Stop showing two bluetooth entries [Giovanni; #709353]
|
||||||
|
* Improve styling of login/lock screen [Reda; #723833]
|
||||||
|
* Fix magnifier crosshairs [Magdalen; #723709]
|
||||||
|
* Make NetworkManager support optional [Michael; #669495]
|
||||||
|
* Make middle-click open a new instance [Florian; #695010]
|
||||||
|
* Scale the UI on high resolution displays [Cosimo, Adel; #705410, #724607]
|
||||||
|
* Remove notification counter on screen shield [Carlos; #709275]
|
||||||
|
* Improve app picker transition [Carlos; #722331]
|
||||||
|
* Add geolocation indicator to status menu [Zeeshan; #723684]
|
||||||
|
* Improve timestamps in chat notifications [Carlos; #708031, #715158]
|
||||||
|
* Improve network menus [Giovanni; #723570]
|
||||||
|
* Add "VPN Setting" item to VPN submenu [Giovanni; #709167]
|
||||||
|
* Improve appearance of disclosure arrows [Carlos; #720206]
|
||||||
|
* Add GSetting key to disable version validation of extensions [Adel; #724683]
|
||||||
|
* Delay auto-removing empty workspaces [Florian; #709064]
|
||||||
|
* Offer offline updates in the shutdown dialog [Kalev; #722898]
|
||||||
|
* Animate tile previews [Florian; #665758]
|
||||||
|
* Misc. bug fixes and cleanups [Giovanni, Ryan, Debarshi, Florian; #709128,
|
||||||
|
#722342, #723661, #724184, #724256, #724293, #724305, #722554, #724282,
|
||||||
|
#724690, #722928]
|
||||||
|
|
||||||
|
Contributors:
|
||||||
|
Zeeshan Ali (Khattak), Magdalen Berns, Michael Biebl, Giovanni Campagna,
|
||||||
|
Cosimo Cecchi, Adel Gadllah, Reda Lazri, Kalev Lember, Ryan Lortie,
|
||||||
|
Florian Müllner, Debarshi Ray, Carlos Soriano, Jasper St. Pierre,
|
||||||
|
Colin Walters
|
||||||
|
|
||||||
|
Translations:
|
||||||
|
Victor Ibragimov [tg], Daniel Mustieles [es], Khaled Hosny [ar],
|
||||||
|
Enrico Nicoletto [pt_BR], Yosef Or Boczko [he], Fran Diéguez [gl],
|
||||||
|
Marek Černocký [cs], Baurzhan Muftakhidinov [kk], Jorge Pérez Pérez [an],
|
||||||
|
Kjartan Maraas [nb], David Lüder [de], Daniel Korostil [uk], ngoswami [as],
|
||||||
|
Rafael Ferreira [pt_BR]
|
||||||
|
|
||||||
|
3.11.5
|
||||||
|
======
|
||||||
|
* Fix extension preference tool [Florian; #722334]
|
||||||
|
* Fix keyboard activation of legacy tray icons [Giovanni; #721267]
|
||||||
|
* Add radial background shade for modal dialogs [Giovanni; #669798]
|
||||||
|
* Show attached modal windows in the overview [Giovanni; #650843]
|
||||||
|
* Add support for desktop actions [Giovanni; #669603]
|
||||||
|
* Indicate in system status when location service is used [Zeeshan; #709372]
|
||||||
|
* Add support for extended app folder schema [Jasper; #723179]
|
||||||
|
* Show status icon for wired network connections [Jasper; #708966]
|
||||||
|
* Indicate airplane mode in network selection dialog [Giovanni; #709128]
|
||||||
|
* Misc bug fixes and cleanups [Florian, Sebastian, Giovanni, Tim, Matt, Jasper;
|
||||||
|
#722417, #722494, #722547, #722593, #722434, #722787, #722690, #722840,
|
||||||
|
#722660, #722812, #723197, #722927, #723306, #723308, #723523, #709685,
|
||||||
|
#723570]
|
||||||
|
|
||||||
|
Contributors:
|
||||||
|
Zeeshan Ali (Khattak), Magdalen Berns, Giovanni Campagna, William Jon McCann,
|
||||||
|
Sebastian Keller, Tim Lunn, Florian Müllner, Carlos Soriano,
|
||||||
|
Jasper St. Pierre, Rico Tzschichholz, Matt Watson
|
||||||
|
|
||||||
|
Translations:
|
||||||
|
Marek Černocký [cs], Mattias Põldaru [et], Tong Hui [zh_CN],
|
||||||
|
Victor Ibragimov [tg], Enrico Nicoletto [pt_BR], Daniel Mustieles [es],
|
||||||
|
Fran Diéguez [gl], Kjartan Maraas [nb], Nilamdyuti Goswami [as],
|
||||||
|
Aurimas Černius [lt], Stas Solovey [ru], Yosef Or Boczko [he],
|
||||||
|
Jorge Pérez Pérez [an], Dimitris Spingos [el], Baurzhan Muftakhidinov [kk],
|
||||||
|
Chao-Hsiung Liao [zh_HK, zh_TW], Shankar Prasad [kn], Yaron Shahrabani [he],
|
||||||
|
Andika Triwidada [id]
|
||||||
|
|
||||||
3.11.4
|
3.11.4
|
||||||
======
|
======
|
||||||
* Fix removal of workspacaes that are not at the end [Giovanni; #721417]
|
* Fix removal of workspacaes that are not at the end [Giovanni; #721417]
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#!/bin/bash
|
#!/bin/sh
|
||||||
# Run this to generate all the initial makefiles, etc.
|
# Run this to generate all the initial makefiles, etc.
|
||||||
|
|
||||||
srcdir=`dirname $0`
|
srcdir=`dirname $0`
|
||||||
|
@ -41,6 +41,8 @@
|
|||||||
|
|
||||||
#define PLUGIN_API_VERSION 5
|
#define PLUGIN_API_VERSION 5
|
||||||
|
|
||||||
|
#define EXTENSION_DISABLE_VERSION_CHECK_KEY "disable-extension-version-validation"
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
GDBusProxy *proxy;
|
GDBusProxy *proxy;
|
||||||
} PluginData;
|
} PluginData;
|
||||||
@ -831,6 +833,16 @@ plugin_get_shell_version (PluginObject *obj,
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
plugin_get_version_validation_enabled (PluginObject *obj,
|
||||||
|
NPVariant *result)
|
||||||
|
{
|
||||||
|
gboolean is_enabled = !g_settings_get_boolean (obj->settings, EXTENSION_DISABLE_VERSION_CHECK_KEY);
|
||||||
|
BOOLEAN_TO_NPVARIANT(is_enabled, *result);
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
#define METHODS \
|
#define METHODS \
|
||||||
METHOD (list_extensions) \
|
METHOD (list_extensions) \
|
||||||
METHOD (get_info) \
|
METHOD (get_info) \
|
||||||
@ -850,6 +862,8 @@ static NPIdentifier api_version_id;
|
|||||||
static NPIdentifier shell_version_id;
|
static NPIdentifier shell_version_id;
|
||||||
static NPIdentifier onextension_changed_id;
|
static NPIdentifier onextension_changed_id;
|
||||||
static NPIdentifier onrestart_id;
|
static NPIdentifier onrestart_id;
|
||||||
|
static NPIdentifier version_validation_enabled_id;
|
||||||
|
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
plugin_object_has_method (NPObject *npobj,
|
plugin_object_has_method (NPObject *npobj,
|
||||||
@ -892,7 +906,8 @@ plugin_object_has_property (NPObject *npobj,
|
|||||||
return (name == onextension_changed_id ||
|
return (name == onextension_changed_id ||
|
||||||
name == onrestart_id ||
|
name == onrestart_id ||
|
||||||
name == api_version_id ||
|
name == api_version_id ||
|
||||||
name == shell_version_id);
|
name == shell_version_id ||
|
||||||
|
name == version_validation_enabled_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
@ -910,6 +925,8 @@ plugin_object_get_property (NPObject *npobj,
|
|||||||
return plugin_get_api_version (obj, result);
|
return plugin_get_api_version (obj, result);
|
||||||
else if (name == shell_version_id)
|
else if (name == shell_version_id)
|
||||||
return plugin_get_shell_version (obj, result);
|
return plugin_get_shell_version (obj, result);
|
||||||
|
else if (name == version_validation_enabled_id)
|
||||||
|
return plugin_get_version_validation_enabled (obj, result);
|
||||||
else if (name == onextension_changed_id)
|
else if (name == onextension_changed_id)
|
||||||
{
|
{
|
||||||
if (obj->listener)
|
if (obj->listener)
|
||||||
@ -988,6 +1005,7 @@ init_methods_and_properties (void)
|
|||||||
/* this is the JS public API; it is manipulated through NPIdentifiers for speed */
|
/* this is the JS public API; it is manipulated through NPIdentifiers for speed */
|
||||||
api_version_id = funcs.getstringidentifier ("apiVersion");
|
api_version_id = funcs.getstringidentifier ("apiVersion");
|
||||||
shell_version_id = funcs.getstringidentifier ("shellVersion");
|
shell_version_id = funcs.getstringidentifier ("shellVersion");
|
||||||
|
version_validation_enabled_id = funcs.getstringidentifier ("versionValidationEnabled");
|
||||||
|
|
||||||
get_info_id = funcs.getstringidentifier ("getExtensionInfo");
|
get_info_id = funcs.getstringidentifier ("getExtensionInfo");
|
||||||
list_extensions_id = funcs.getstringidentifier ("listExtensions");
|
list_extensions_id = funcs.getstringidentifier ("listExtensions");
|
||||||
|
52
configure.ac
52
configure.ac
@ -1,5 +1,5 @@
|
|||||||
AC_PREREQ(2.63)
|
AC_PREREQ(2.63)
|
||||||
AC_INIT([gnome-shell],[3.11.4],[https://bugzilla.gnome.org/enter_bug.cgi?product=gnome-shell],[gnome-shell])
|
AC_INIT([gnome-shell],[3.11.90],[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])
|
||||||
@ -76,7 +76,7 @@ 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.11.1
|
MUTTER_MIN_VERSION=3.11.90
|
||||||
GTK_MIN_VERSION=3.7.9
|
GTK_MIN_VERSION=3.7.9
|
||||||
GIO_MIN_VERSION=2.37.0
|
GIO_MIN_VERSION=2.37.0
|
||||||
LIBECAL_MIN_VERSION=3.5.3
|
LIBECAL_MIN_VERSION=3.5.3
|
||||||
@ -105,9 +105,7 @@ SHARED_PCS="gio-unix-2.0 >= $GIO_MIN_VERSION
|
|||||||
libcanberra libcanberra-gtk3
|
libcanberra libcanberra-gtk3
|
||||||
telepathy-glib >= $TELEPATHY_GLIB_MIN_VERSION
|
telepathy-glib >= $TELEPATHY_GLIB_MIN_VERSION
|
||||||
polkit-agent-1 >= $POLKIT_MIN_VERSION
|
polkit-agent-1 >= $POLKIT_MIN_VERSION
|
||||||
libnm-glib libnm-util >= $NETWORKMANAGER_MIN_VERSION
|
gcr-base-3 >= $GCR_MIN_VERSION"
|
||||||
libnm-gtk >= $NETWORKMANAGER_MIN_VERSION
|
|
||||||
libsecret-unstable gcr-base-3 >= $GCR_MIN_VERSION"
|
|
||||||
if test x$have_systemd = xyes; then
|
if test x$have_systemd = xyes; then
|
||||||
SHARED_PCS="${SHARED_PCS} libsystemd-journal"
|
SHARED_PCS="${SHARED_PCS} libsystemd-journal"
|
||||||
fi
|
fi
|
||||||
@ -182,6 +180,38 @@ if test "$langinfo_ok" = "yes"; then
|
|||||||
[Define if _NL_TIME_FIRST_WEEKDAY is available])
|
[Define if _NL_TIME_FIRST_WEEKDAY is available])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
AC_ARG_ENABLE(networkmanager,
|
||||||
|
AS_HELP_STRING([--disable-networkmanager],
|
||||||
|
[disable NetworkManager support @<:@default=auto@:>@]),,
|
||||||
|
[enable_networkmanager=auto])
|
||||||
|
|
||||||
|
if test "x$enable_networkmanager" != "xno"; then
|
||||||
|
PKG_CHECK_MODULES(NETWORKMANAGER,
|
||||||
|
[libnm-glib
|
||||||
|
libnm-util >= $NETWORKMANAGER_MIN_VERSION
|
||||||
|
libnm-gtk >= $NETWORKMANAGER_MIN_VERSION
|
||||||
|
libsecret-unstable],
|
||||||
|
[have_networkmanager=yes],
|
||||||
|
[have_networkmanager=no])
|
||||||
|
|
||||||
|
GNOME_SHELL_CFLAGS="$GNOME_SHELL_CFLAGS $NETWORKMANAGER_CFLAGS"
|
||||||
|
GNOME_SHELL_LIBS="$GNOME_SHELL_LIBS $NETWORKMANAGER_LIBS"
|
||||||
|
else
|
||||||
|
have_networkmanager="no (disabled)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test "x$have_networkmanager" = "xyes"; then
|
||||||
|
AC_DEFINE(HAVE_NETWORKMANAGER, [1], [Define if we have NetworkManager])
|
||||||
|
AC_SUBST([HAVE_NETWORKMANAGER], [1])
|
||||||
|
else
|
||||||
|
if test "x$enable_networkmanager" = "xyes"; then
|
||||||
|
AC_MSG_ERROR([Couldn't find NetworkManager.])
|
||||||
|
fi
|
||||||
|
AC_SUBST([HAVE_NETWORKMANAGER], [0])
|
||||||
|
fi
|
||||||
|
|
||||||
|
AM_CONDITIONAL(HAVE_NETWORKMANAGER, test "$have_networkmanager" = "yes")
|
||||||
|
|
||||||
# Sets GLIB_GENMARSHAL and GLIB_MKENUMS
|
# Sets GLIB_GENMARSHAL and GLIB_MKENUMS
|
||||||
AM_PATH_GLIB_2_0()
|
AM_PATH_GLIB_2_0()
|
||||||
|
|
||||||
@ -223,3 +253,15 @@ AC_CONFIG_FILES([
|
|||||||
man/Makefile
|
man/Makefile
|
||||||
])
|
])
|
||||||
AC_OUTPUT
|
AC_OUTPUT
|
||||||
|
|
||||||
|
echo "
|
||||||
|
Build configuration:
|
||||||
|
|
||||||
|
Prefix: ${prefix}
|
||||||
|
Source code location: ${srcdir}
|
||||||
|
Compiler: ${CC}
|
||||||
|
Compiler Warnings: $enable_compile_warnings
|
||||||
|
|
||||||
|
Support for NetworkManager: $have_networkmanager
|
||||||
|
Support for GStreamer recording: $build_recorder
|
||||||
|
"
|
||||||
|
@ -39,6 +39,7 @@ dist_theme_DATA = \
|
|||||||
theme/filter-selected-rtl.svg \
|
theme/filter-selected-rtl.svg \
|
||||||
theme/gnome-shell.css \
|
theme/gnome-shell.css \
|
||||||
theme/logged-in-indicator.svg \
|
theme/logged-in-indicator.svg \
|
||||||
|
theme/menu-arrow-symbolic.svg \
|
||||||
theme/message-tray-background.png \
|
theme/message-tray-background.png \
|
||||||
theme/more-results.svg \
|
theme/more-results.svg \
|
||||||
theme/noise-texture.png \
|
theme/noise-texture.png \
|
||||||
|
@ -21,6 +21,15 @@
|
|||||||
EnableExtension and DisableExtension D-Bus methods on org.gnome.Shell.
|
EnableExtension and DisableExtension D-Bus methods on org.gnome.Shell.
|
||||||
</_description>
|
</_description>
|
||||||
</key>
|
</key>
|
||||||
|
<key name="disable-extension-version-validation" type="b">
|
||||||
|
<default>false</default>
|
||||||
|
<_summary>Disables the validation of extension version compatibility</_summary>
|
||||||
|
<_description>
|
||||||
|
GNOME Shell will only load extensions that claim to support the current
|
||||||
|
running version. Enabling this option will disable this check and try to
|
||||||
|
load all extensions regardless of the versions they claim to support.
|
||||||
|
</_description>
|
||||||
|
</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', 'nautilus.desktop', 'gnome-documents.desktop' ]</default>
|
<default>[ 'epiphany.desktop', 'evolution.desktop', 'empathy.desktop', 'rhythmbox.desktop', 'shotwell.desktop', 'libreoffice-writer.desktop', 'nautilus.desktop', 'gnome-documents.desktop' ]</default>
|
||||||
<_summary>List of desktop file IDs for favorite applications</_summary>
|
<_summary>List of desktop file IDs for favorite applications</_summary>
|
||||||
@ -65,6 +74,7 @@
|
|||||||
<child name="calendar" schema="org.gnome.shell.calendar"/>
|
<child name="calendar" schema="org.gnome.shell.calendar"/>
|
||||||
<child name="keybindings" schema="org.gnome.shell.keybindings"/>
|
<child name="keybindings" schema="org.gnome.shell.keybindings"/>
|
||||||
<child name="keyboard" schema="org.gnome.shell.keyboard"/>
|
<child name="keyboard" schema="org.gnome.shell.keyboard"/>
|
||||||
|
<child name="location" schema="org.gnome.shell.location"/>
|
||||||
</schema>
|
</schema>
|
||||||
|
|
||||||
<schema id="org.gnome.shell.calendar" path="/org/gnome/shell/calendar/"
|
<schema id="org.gnome.shell.calendar" path="/org/gnome/shell/calendar/"
|
||||||
@ -134,6 +144,32 @@
|
|||||||
</key>
|
</key>
|
||||||
</schema>
|
</schema>
|
||||||
|
|
||||||
|
<enum id="org.gnome.shell.geoclue.AccuracyLevel">
|
||||||
|
<value value="0" nick="off"/>
|
||||||
|
<value value="1" nick="country"/>
|
||||||
|
<value value="4" nick="city"/>
|
||||||
|
<value value="5" nick="neighborhood"/>
|
||||||
|
<value value="6" nick="street"/>
|
||||||
|
<value value="8" nick="exact"/>
|
||||||
|
</enum>
|
||||||
|
<schema id="org.gnome.shell.location"
|
||||||
|
path="/org/gnome/shell/location/"
|
||||||
|
gettext-domain="@GETTEXT_PACKAGE@">
|
||||||
|
<key name="max-accuracy-level" enum="org.gnome.shell.geoclue.AccuracyLevel">
|
||||||
|
<default>'exact'</default>
|
||||||
|
<_summary>The maximum accuracy level of location.</_summary>
|
||||||
|
<_description>
|
||||||
|
Configures the maximum level of location accuracy applications are
|
||||||
|
allowed to see. Valid options are 'off' (disable location tracking),
|
||||||
|
'country', 'city', 'neighborhood', 'street', and 'exact' (typically
|
||||||
|
requires GPS receiver). Please keep in mind that this only controls
|
||||||
|
what Geoclue will allow applications to see and they can find user's
|
||||||
|
location on their own using network resources (albeit with street-level
|
||||||
|
accuracy at best).
|
||||||
|
</_description>
|
||||||
|
</key>
|
||||||
|
</schema>
|
||||||
|
|
||||||
<schema id="org.gnome.shell.app-switcher"
|
<schema id="org.gnome.shell.app-switcher"
|
||||||
path="/org/gnome/shell/app-switcher/"
|
path="/org/gnome/shell/app-switcher/"
|
||||||
gettext-domain="@GETTEXT_PACKAGE@">
|
gettext-domain="@GETTEXT_PACKAGE@">
|
||||||
|
@ -157,8 +157,9 @@ StScrollBar StButton#vhandle:active {
|
|||||||
min-width: 200px;
|
min-width: 200px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.unicode-arrow {
|
.popup-menu-arrow {
|
||||||
font-size: 120%;
|
width: 16px;
|
||||||
|
height: 16px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.popup-submenu-menu-item:open {
|
.popup-submenu-menu-item:open {
|
||||||
@ -289,6 +290,20 @@ StScrollBar StButton#vhandle:active {
|
|||||||
spacing: 10px;
|
spacing: 10px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.nm-dialog-airplane-box {
|
||||||
|
spacing: 12px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nm-dialog-airplane-headline {
|
||||||
|
font-size: 1.1em;
|
||||||
|
font-weight: bold;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nm-dialog-airplane-text {
|
||||||
|
color: #999999;
|
||||||
|
}
|
||||||
|
|
||||||
.nm-dialog-header-icon {
|
.nm-dialog-header-icon {
|
||||||
icon-size: 32px;
|
icon-size: 32px;
|
||||||
}
|
}
|
||||||
@ -1453,6 +1468,10 @@ StScrollBar StButton#vhandle:active {
|
|||||||
color: #999999;
|
color: #999999;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.no-networks-box {
|
||||||
|
spacing: 12px;
|
||||||
|
}
|
||||||
|
|
||||||
.notification {
|
.notification {
|
||||||
border-radius: 10px 10px 0px 0px;
|
border-radius: 10px 10px 0px 0px;
|
||||||
background: rgba(0,0,0,0.9);
|
background: rgba(0,0,0,0.9);
|
||||||
@ -1630,8 +1649,8 @@ StScrollBar StButton#vhandle:active {
|
|||||||
color: #888888;
|
color: #888888;
|
||||||
}
|
}
|
||||||
|
|
||||||
.chat-group-sent, .chat-group-meta {
|
.chat-empty-line {
|
||||||
padding: 8px 0;
|
font-size: 4px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.chat-received {
|
.chat-received {
|
||||||
@ -1656,6 +1675,7 @@ StScrollBar StButton#vhandle:active {
|
|||||||
.chat-meta-message {
|
.chat-meta-message {
|
||||||
padding-left: 4px;
|
padding-left: 4px;
|
||||||
font-size: 9pt;
|
font-size: 9pt;
|
||||||
|
font-weight: bold;
|
||||||
color: #bbbbbb;
|
color: #bbbbbb;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1857,6 +1877,27 @@ StScrollBar StButton#vhandle:active {
|
|||||||
border-radius: 8px;
|
border-radius: 8px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Tile previews */
|
||||||
|
.tile-preview {
|
||||||
|
background-color: rgba(74, 144, 217, 0.35);
|
||||||
|
border: 1px solid #4a90d9; /* Adwaita selected bg color */
|
||||||
|
}
|
||||||
|
|
||||||
|
.tile-preview-left.on-primary {
|
||||||
|
/* keep in sync with -panel-corner-radius */
|
||||||
|
border-radius: 6px 0 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tile-preview-right.on-primary {
|
||||||
|
/* keep in sync with -panel-corner-radius */
|
||||||
|
border-radius: 0 6px 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tile-preview-left.tile-preview-right.on-primary {
|
||||||
|
/* keep in sync with -panel-corner-radius */
|
||||||
|
border-radius: 6px 6px 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
/* Modal Dialogs */
|
/* Modal Dialogs */
|
||||||
|
|
||||||
/* Dialog Subject Text Style */
|
/* Dialog Subject Text Style */
|
||||||
@ -1927,45 +1968,57 @@ StScrollBar StButton#vhandle:active {
|
|||||||
padding-top: 20px;
|
padding-top: 20px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.end-session-dialog-subject {
|
.end-session-dialog-layout {
|
||||||
padding-left: 17px;
|
padding-left: 17px;
|
||||||
padding-bottom: 20px;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.end-session-dialog-subject:rtl {
|
.end-session-dialog-layout:rtl {
|
||||||
padding-left: 0px;
|
|
||||||
padding-right: 17px;
|
padding-right: 17px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.end-session-dialog-description {
|
.end-session-dialog-description {
|
||||||
padding-left: 17px;
|
|
||||||
width: 28em;
|
width: 28em;
|
||||||
|
padding-bottom: 10px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.end-session-dialog-description:rtl {
|
.end-session-dialog-description:rtl {
|
||||||
padding-right: 17px;
|
width: 28em;
|
||||||
|
padding-bottom: 10px;
|
||||||
|
text-align: right;
|
||||||
|
}
|
||||||
|
|
||||||
|
.end-session-dialog-warning {
|
||||||
|
width: 28em;
|
||||||
|
color: #f57900;
|
||||||
|
padding-top: 6px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.end-session-dialog-warning:rtl {
|
||||||
|
width: 28em;
|
||||||
|
color: #f57900;
|
||||||
|
padding-top: 6px;
|
||||||
text-align: right;
|
text-align: right;
|
||||||
}
|
}
|
||||||
|
|
||||||
.end-session-dialog-logout-icon {
|
.end-session-dialog-logout-icon {
|
||||||
border: 2px solid #8b8b8b;
|
border: 2px solid #8b8b8b;
|
||||||
border-radius: 5px;
|
border-radius: 5px;
|
||||||
width: 32px;
|
width: 48px;
|
||||||
height: 32px;
|
height: 48px;
|
||||||
background-size: contain;
|
background-size: contain;
|
||||||
}
|
}
|
||||||
|
|
||||||
.end-session-dialog-shutdown-icon {
|
.end-session-dialog-shutdown-icon {
|
||||||
color: #bebebe;
|
color: #bebebe;
|
||||||
width: 32px;
|
width: 48px;
|
||||||
height: 32px;
|
height: 48px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.end-session-dialog-inhibitor-layout {
|
.end-session-dialog-inhibitor-layout {
|
||||||
spacing: 16px;
|
spacing: 16px;
|
||||||
max-height: 200px;
|
max-height: 200px;
|
||||||
padding-right: 50px;
|
padding-right: 65px;
|
||||||
padding-left: 50px;
|
padding-left: 65px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.end-session-dialog-session-list,
|
.end-session-dialog-session-list,
|
||||||
@ -2388,12 +2441,13 @@ StScrollBar StButton#vhandle:active {
|
|||||||
color: #E8E8E8;
|
color: #E8E8E8;
|
||||||
}
|
}
|
||||||
|
|
||||||
.login-dialog-username {
|
.login-dialog-username,
|
||||||
|
.user-widget-label {
|
||||||
font-size: 16pt;
|
font-size: 16pt;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
text-align: left;
|
text-align: left;
|
||||||
padding-left: 15px;
|
padding-left: 15px;
|
||||||
text-shadow: black 0px 4px 3px 0px;
|
text-shadow: rgba(0, 0, 0, 0.5) 0px 2px 1px 0px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.login-dialog-prompt-layout {
|
.login-dialog-prompt-layout {
|
||||||
@ -2485,11 +2539,6 @@ StScrollBar StButton#vhandle:active {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.user-widget-label {
|
.user-widget-label {
|
||||||
font-size: 20px;
|
|
||||||
font-weight: bold;
|
|
||||||
text-align: left;
|
|
||||||
color:white;
|
|
||||||
text-shadow: black 0px 4px 3px 0px;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.user-widget-label:ltr {
|
.user-widget-label:ltr {
|
||||||
|
90
data/theme/menu-arrow-symbolic.svg
Normal file
90
data/theme/menu-arrow-symbolic.svg
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
<?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="16"
|
||||||
|
height="16"
|
||||||
|
id="svg3863"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.48.4 r9939"
|
||||||
|
sodipodi:docname="menu-arrow.svg">
|
||||||
|
<defs
|
||||||
|
id="defs3865" />
|
||||||
|
<sodipodi:namedview
|
||||||
|
id="base"
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1.0"
|
||||||
|
inkscape:pageopacity="0.0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:zoom="15.836083"
|
||||||
|
inkscape:cx="-3.1641676"
|
||||||
|
inkscape:cy="11.823817"
|
||||||
|
inkscape:current-layer="layer1"
|
||||||
|
showgrid="true"
|
||||||
|
inkscape:grid-bbox="true"
|
||||||
|
inkscape:document-units="px"
|
||||||
|
showguides="true"
|
||||||
|
inkscape:guide-bbox="true"
|
||||||
|
inkscape:window-width="1366"
|
||||||
|
inkscape:window-height="702"
|
||||||
|
inkscape:window-x="0"
|
||||||
|
inkscape:window-y="27"
|
||||||
|
inkscape:window-maximized="1"
|
||||||
|
inkscape:snap-bbox="true">
|
||||||
|
<sodipodi:guide
|
||||||
|
orientation="1,0"
|
||||||
|
position="15.996443,16.922964"
|
||||||
|
id="guide3873" />
|
||||||
|
<sodipodi:guide
|
||||||
|
orientation="0,1"
|
||||||
|
position="28.041217,3.1256134"
|
||||||
|
id="guide3875" />
|
||||||
|
<sodipodi:guide
|
||||||
|
orientation="0,1"
|
||||||
|
position="-0.80372916,24.469088"
|
||||||
|
id="guide3877" />
|
||||||
|
<sodipodi:guide
|
||||||
|
orientation="1,0"
|
||||||
|
position="3.0363102,34.649657"
|
||||||
|
id="guide3879" />
|
||||||
|
<sodipodi:guide
|
||||||
|
orientation="1,0"
|
||||||
|
position="29.023553,28.577037"
|
||||||
|
id="guide3881" />
|
||||||
|
<inkscape:grid
|
||||||
|
type="xygrid"
|
||||||
|
id="grid2988" />
|
||||||
|
</sodipodi:namedview>
|
||||||
|
<metadata
|
||||||
|
id="metadata3868">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title></dc:title>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<g
|
||||||
|
id="layer1"
|
||||||
|
inkscape:label="Layer 1"
|
||||||
|
inkscape:groupmode="layer"
|
||||||
|
transform="translate(0,-16)">
|
||||||
|
<path
|
||||||
|
style="fill:#ffffff;fill-opacity:1;stroke:none"
|
||||||
|
d="m 4,23 8,0 -4,5 z"
|
||||||
|
id="path3883"
|
||||||
|
inkscape:connector-curvature="0"
|
||||||
|
sodipodi:nodetypes="cccc" />
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 2.5 KiB |
@ -6,6 +6,7 @@ misc/config.js: misc/config.js.in Makefile
|
|||||||
sed -e "s|[@]PACKAGE_NAME@|$(PACKAGE_NAME)|g" \
|
sed -e "s|[@]PACKAGE_NAME@|$(PACKAGE_NAME)|g" \
|
||||||
-e "s|[@]PACKAGE_VERSION@|$(PACKAGE_VERSION)|g" \
|
-e "s|[@]PACKAGE_VERSION@|$(PACKAGE_VERSION)|g" \
|
||||||
-e "s|[@]HAVE_BLUETOOTH@|$(HAVE_BLUETOOTH)|g" \
|
-e "s|[@]HAVE_BLUETOOTH@|$(HAVE_BLUETOOTH)|g" \
|
||||||
|
-e "s|[@]HAVE_NETWORKMANAGER@|$(HAVE_NETWORKMANAGER)|g" \
|
||||||
-e "s|[@]GETTEXT_PACKAGE@|$(GETTEXT_PACKAGE)|g" \
|
-e "s|[@]GETTEXT_PACKAGE@|$(GETTEXT_PACKAGE)|g" \
|
||||||
-e "s|[@]datadir@|$(datadir)|g" \
|
-e "s|[@]datadir@|$(datadir)|g" \
|
||||||
-e "s|[@]libexecdir@|$(libexecdir)|g" \
|
-e "s|[@]libexecdir@|$(libexecdir)|g" \
|
||||||
|
@ -6,6 +6,8 @@ const PACKAGE_NAME = '@PACKAGE_NAME@';
|
|||||||
const PACKAGE_VERSION = '@PACKAGE_VERSION@';
|
const PACKAGE_VERSION = '@PACKAGE_VERSION@';
|
||||||
/* 1 if gnome-bluetooth is available, 0 otherwise */
|
/* 1 if gnome-bluetooth is available, 0 otherwise */
|
||||||
const HAVE_BLUETOOTH = @HAVE_BLUETOOTH@;
|
const HAVE_BLUETOOTH = @HAVE_BLUETOOTH@;
|
||||||
|
/* 1 if networkmanager is available, 0 otherwise */
|
||||||
|
const HAVE_NETWORKMANAGER = @HAVE_NETWORKMANAGER@;
|
||||||
/* gettext package */
|
/* gettext package */
|
||||||
const GETTEXT_PACKAGE = '@GETTEXT_PACKAGE@';
|
const GETTEXT_PACKAGE = '@GETTEXT_PACKAGE@';
|
||||||
/* locale dir */
|
/* locale dir */
|
||||||
|
@ -24,7 +24,7 @@ const WINDOW_PREVIEW_SIZE = 128;
|
|||||||
const APP_ICON_SIZE = 96;
|
const APP_ICON_SIZE = 96;
|
||||||
const APP_ICON_SIZE_SMALL = 48;
|
const APP_ICON_SIZE_SMALL = 48;
|
||||||
|
|
||||||
const iconSizes = [96, 64, 48, 32, 22];
|
const baseIconSizes = [96, 64, 48, 32, 22];
|
||||||
|
|
||||||
const AppIconMode = {
|
const AppIconMode = {
|
||||||
THUMBNAIL_ONLY: 1,
|
THUMBNAIL_ONLY: 1,
|
||||||
@ -430,7 +430,6 @@ const AppIcon = new Lang.Class({
|
|||||||
|
|
||||||
set_size: function(size) {
|
set_size: function(size) {
|
||||||
this.icon = this.app.create_icon_texture(size);
|
this.icon = this.app.create_icon_texture(size);
|
||||||
this._iconBin.set_size(size, size);
|
|
||||||
this._iconBin.child = this.icon;
|
this._iconBin.child = this.icon;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -479,12 +478,13 @@ const AppSwitcher = new Lang.Class({
|
|||||||
Mainloop.source_remove(this._mouseTimeOutId);
|
Mainloop.source_remove(this._mouseTimeOutId);
|
||||||
},
|
},
|
||||||
|
|
||||||
_getPreferredHeight: function (actor, forWidth, alloc) {
|
_setIconSize: function() {
|
||||||
let j = 0;
|
let j = 0;
|
||||||
while(this._items.length > 1 && this._items[j].style_class != 'item-box') {
|
while(this._items.length > 1 && this._items[j].style_class != 'item-box') {
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
let themeNode = this._items[j].get_theme_node();
|
let themeNode = this._items[j].get_theme_node();
|
||||||
|
|
||||||
let iconPadding = themeNode.get_horizontal_padding();
|
let iconPadding = themeNode.get_horizontal_padding();
|
||||||
let iconBorder = themeNode.get_border_width(St.Side.LEFT) + themeNode.get_border_width(St.Side.RIGHT);
|
let iconBorder = themeNode.get_border_width(St.Side.LEFT) + themeNode.get_border_width(St.Side.RIGHT);
|
||||||
let [iconMinHeight, iconNaturalHeight] = this.icons[j].label.get_preferred_height(-1);
|
let [iconMinHeight, iconNaturalHeight] = this.icons[j].label.get_preferred_height(-1);
|
||||||
@ -495,19 +495,22 @@ const AppSwitcher = new Lang.Class({
|
|||||||
let primary = Main.layoutManager.primaryMonitor;
|
let primary = Main.layoutManager.primaryMonitor;
|
||||||
let parentPadding = this.actor.get_parent().get_theme_node().get_horizontal_padding();
|
let parentPadding = this.actor.get_parent().get_theme_node().get_horizontal_padding();
|
||||||
let availWidth = primary.width - parentPadding - this.actor.get_theme_node().get_horizontal_padding();
|
let availWidth = primary.width - parentPadding - this.actor.get_theme_node().get_horizontal_padding();
|
||||||
let height = 0;
|
|
||||||
|
|
||||||
for(let i = 0; i < iconSizes.length; i++) {
|
let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor;
|
||||||
this._iconSize = iconSizes[i];
|
let iconSizes = baseIconSizes.map(function(s) {
|
||||||
height = iconSizes[i] + iconSpacing;
|
return s * scaleFactor;
|
||||||
let w = height * this._items.length + totalSpacing;
|
});
|
||||||
if (w <= availWidth)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._items.length == 1) {
|
if (this._items.length == 1) {
|
||||||
this._iconSize = iconSizes[0];
|
this._iconSize = baseIconSizes[0];
|
||||||
height = iconSizes[0] + iconSpacing;
|
} else {
|
||||||
|
for(let i = 0; i < baseIconSizes.length; i++) {
|
||||||
|
this._iconSize = baseIconSizes[i];
|
||||||
|
let height = iconSizes[i] + iconSpacing;
|
||||||
|
let w = height * this._items.length + totalSpacing;
|
||||||
|
if (w <= availWidth)
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for(let i = 0; i < this.icons.length; i++) {
|
for(let i = 0; i < this.icons.length; i++) {
|
||||||
@ -515,9 +518,11 @@ const AppSwitcher = new Lang.Class({
|
|||||||
break;
|
break;
|
||||||
this.icons[i].set_size(this._iconSize);
|
this.icons[i].set_size(this._iconSize);
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
|
||||||
alloc.min_size = height;
|
_getPreferredHeight: function (actor, forWidth, alloc) {
|
||||||
alloc.natural_size = height;
|
this._setIconSize();
|
||||||
|
this.parent(actor, forWidth, alloc);
|
||||||
},
|
},
|
||||||
|
|
||||||
_allocate: function (actor, box, flags) {
|
_allocate: function (actor, box, flags) {
|
||||||
@ -650,17 +655,19 @@ const ThumbnailList = new Lang.Class({
|
|||||||
totalPadding += this.actor.get_theme_node().get_horizontal_padding() + this.actor.get_theme_node().get_vertical_padding();
|
totalPadding += this.actor.get_theme_node().get_horizontal_padding() + this.actor.get_theme_node().get_vertical_padding();
|
||||||
let [labelMinHeight, labelNaturalHeight] = this._labels[0].get_preferred_height(-1);
|
let [labelMinHeight, labelNaturalHeight] = this._labels[0].get_preferred_height(-1);
|
||||||
let spacing = this._items[0].child.get_theme_node().get_length('spacing');
|
let spacing = this._items[0].child.get_theme_node().get_length('spacing');
|
||||||
|
let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor;
|
||||||
|
let thumbnailSize = THUMBNAIL_DEFAULT_SIZE * scaleFactor;
|
||||||
|
|
||||||
availHeight = Math.min(availHeight - labelNaturalHeight - totalPadding - spacing, THUMBNAIL_DEFAULT_SIZE);
|
availHeight = Math.min(availHeight - labelNaturalHeight - totalPadding - spacing, thumbnailSize);
|
||||||
let binHeight = availHeight + this._items[0].get_theme_node().get_vertical_padding() + this.actor.get_theme_node().get_vertical_padding() - spacing;
|
let binHeight = availHeight + this._items[0].get_theme_node().get_vertical_padding() + this.actor.get_theme_node().get_vertical_padding() - spacing;
|
||||||
binHeight = Math.min(THUMBNAIL_DEFAULT_SIZE, binHeight);
|
binHeight = Math.min(thumbnailSize, binHeight);
|
||||||
|
|
||||||
for (let i = 0; i < this._thumbnailBins.length; i++) {
|
for (let i = 0; i < this._thumbnailBins.length; i++) {
|
||||||
let mutterWindow = this._windows[i].get_compositor_private();
|
let mutterWindow = this._windows[i].get_compositor_private();
|
||||||
if (!mutterWindow)
|
if (!mutterWindow)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
let clone = _createWindowClone(mutterWindow, THUMBNAIL_DEFAULT_SIZE);
|
let clone = _createWindowClone(mutterWindow, thumbnailSize);
|
||||||
this._thumbnailBins[i].set_height(binHeight);
|
this._thumbnailBins[i].set_height(binHeight);
|
||||||
this._thumbnailBins[i].add_actor(clone);
|
this._thumbnailBins[i].add_actor(clone);
|
||||||
this._clones.push(clone);
|
this._clones.push(clone);
|
||||||
|
@ -46,6 +46,9 @@ const INDICATORS_ANIMATION_MAX_TIME = 0.75;
|
|||||||
const PAGE_SWITCH_TRESHOLD = 0.2;
|
const PAGE_SWITCH_TRESHOLD = 0.2;
|
||||||
const PAGE_SWITCH_TIME = 0.3;
|
const PAGE_SWITCH_TIME = 0.3;
|
||||||
|
|
||||||
|
const VIEWS_SWITCH_TIME = 0.4;
|
||||||
|
const VIEWS_SWITCH_ANIMATION_DELAY = 0.1;
|
||||||
|
|
||||||
function _getCategories(info) {
|
function _getCategories(info) {
|
||||||
let categoriesStr = info.get_categories();
|
let categoriesStr = info.get_categories();
|
||||||
if (!categoriesStr)
|
if (!categoriesStr)
|
||||||
@ -53,14 +56,6 @@ function _getCategories(info) {
|
|||||||
return categoriesStr.split(';');
|
return categoriesStr.split(';');
|
||||||
}
|
}
|
||||||
|
|
||||||
function _isTerminal(app) {
|
|
||||||
let info = app.get_app_info();
|
|
||||||
if (!info)
|
|
||||||
return false;
|
|
||||||
let categories = _getCategories(info);
|
|
||||||
return categories.indexOf('TerminalEmulator') > -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
function _listsIntersect(a, b) {
|
function _listsIntersect(a, b) {
|
||||||
for (let itemA of a)
|
for (let itemA of a)
|
||||||
if (b.indexOf(itemA) >= 0)
|
if (b.indexOf(itemA) >= 0)
|
||||||
@ -256,7 +251,8 @@ const PageIndicators = new Lang.Class({
|
|||||||
Tweener.addTween(children[i],
|
Tweener.addTween(children[i],
|
||||||
{ translation_x: 0,
|
{ translation_x: 0,
|
||||||
time: INDICATORS_BASE_TIME + delay * i,
|
time: INDICATORS_BASE_TIME + delay * i,
|
||||||
transition: 'easeInOutQuad'
|
transition: 'easeInOutQuad',
|
||||||
|
delay: VIEWS_SWITCH_ANIMATION_DELAY
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -791,8 +787,10 @@ const AppDisplay = new Lang.Class({
|
|||||||
_showView: function(activeIndex) {
|
_showView: function(activeIndex) {
|
||||||
for (let i = 0; i < this._views.length; i++) {
|
for (let i = 0; i < this._views.length; i++) {
|
||||||
let actor = this._views[i].view.actor;
|
let actor = this._views[i].view.actor;
|
||||||
let params = { time: OverviewControls.SIDE_CONTROLS_ANIMATION_TIME,
|
|
||||||
opacity: (i == activeIndex) ? 255 : 0 };
|
let params = { time: VIEWS_SWITCH_TIME,
|
||||||
|
opacity: (i == activeIndex) ? 255 : 0,
|
||||||
|
delay: (i == activeIndex) ? VIEWS_SWITCH_ANIMATION_DELAY : 0 };
|
||||||
if (i == activeIndex)
|
if (i == activeIndex)
|
||||||
actor.visible = true;
|
actor.visible = true;
|
||||||
else
|
else
|
||||||
@ -888,7 +886,7 @@ const AppSearchProvider = new Lang.Class({
|
|||||||
let app = this._appSys.lookup_app(result);
|
let app = this._appSys.lookup_app(result);
|
||||||
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) || _isTerminal(app);
|
let openNewWindow = modifiers & Clutter.ModifierType.CONTROL_MASK;
|
||||||
|
|
||||||
if (openNewWindow)
|
if (openNewWindow)
|
||||||
app.open_new_window(-1);
|
app.open_new_window(-1);
|
||||||
@ -932,9 +930,9 @@ const FolderView = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
createFolderIcon: function(size) {
|
createFolderIcon: function(size) {
|
||||||
let icon = new St.Widget({ layout_manager: new Clutter.BinLayout(),
|
let layout = new Clutter.TableLayout();
|
||||||
style_class: 'app-folder-icon',
|
let icon = new St.Widget({ layout_manager: layout,
|
||||||
width: size, height: size });
|
style_class: 'app-folder-icon' });
|
||||||
let subSize = Math.floor(FOLDER_SUBICON_FRACTION * size);
|
let subSize = Math.floor(FOLDER_SUBICON_FRACTION * size);
|
||||||
|
|
||||||
let aligns = [ Clutter.ActorAlign.START, Clutter.ActorAlign.END ];
|
let aligns = [ Clutter.ActorAlign.START, Clutter.ActorAlign.END ];
|
||||||
@ -944,7 +942,7 @@ const FolderView = new Lang.Class({
|
|||||||
x_expand: true, y_expand: true });
|
x_expand: true, y_expand: true });
|
||||||
bin.set_x_align(aligns[i % 2]);
|
bin.set_x_align(aligns[i % 2]);
|
||||||
bin.set_y_align(aligns[Math.floor(i / 2)]);
|
bin.set_y_align(aligns[Math.floor(i / 2)]);
|
||||||
icon.add_actor(bin);
|
layout.pack(bin, i % 2, Math.floor(i / 2));
|
||||||
}
|
}
|
||||||
|
|
||||||
return icon;
|
return icon;
|
||||||
@ -1403,9 +1401,6 @@ const AppIcon = new Lang.Class({
|
|||||||
if (button == 1) {
|
if (button == 1) {
|
||||||
this._onActivate(Clutter.get_current_event());
|
this._onActivate(Clutter.get_current_event());
|
||||||
} else if (button == 2) {
|
} else if (button == 2) {
|
||||||
// Last workspace is always empty
|
|
||||||
let launchWorkspace = global.screen.get_workspace_by_index(global.screen.n_workspaces - 1);
|
|
||||||
launchWorkspace.activate(global.get_current_time());
|
|
||||||
this.app.open_new_window(-1);
|
this.app.open_new_window(-1);
|
||||||
Main.overview.hide();
|
Main.overview.hide();
|
||||||
}
|
}
|
||||||
@ -1466,9 +1461,8 @@ const AppIcon = new Lang.Class({
|
|||||||
_onActivate: function (event) {
|
_onActivate: function (event) {
|
||||||
let modifiers = event.get_state();
|
let modifiers = event.get_state();
|
||||||
|
|
||||||
if ((modifiers & Clutter.ModifierType.CONTROL_MASK
|
if (modifiers & Clutter.ModifierType.CONTROL_MASK
|
||||||
&& this.app.state == Shell.AppState.RUNNING)
|
&& this.app.state == Shell.AppState.RUNNING) {
|
||||||
|| _isTerminal(this.app)) {
|
|
||||||
this.app.open_new_window(-1);
|
this.app.open_new_window(-1);
|
||||||
} else {
|
} else {
|
||||||
this.app.activate();
|
this.app.activate();
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
// -*- 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 Gio = imports.gi.Gio;
|
const Gio = imports.gi.Gio;
|
||||||
const GLib = imports.gi.GLib;
|
const GLib = imports.gi.GLib;
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
@ -28,6 +29,8 @@ const SCROLLBACK_HISTORY_LINES = 10;
|
|||||||
// See Notification._onEntryChanged
|
// See Notification._onEntryChanged
|
||||||
const COMPOSING_STOP_TIMEOUT = 5;
|
const COMPOSING_STOP_TIMEOUT = 5;
|
||||||
|
|
||||||
|
const CLOCK_FORMAT_KEY = 'clock-format';
|
||||||
|
|
||||||
const NotificationDirection = {
|
const NotificationDirection = {
|
||||||
SENT: 'chat-sent',
|
SENT: 'chat-sent',
|
||||||
RECEIVED: 'chat-received'
|
RECEIVED: 'chat-received'
|
||||||
@ -905,14 +908,14 @@ const ChatNotification = new Lang.Class({
|
|||||||
|
|
||||||
let group = props.group;
|
let group = props.group;
|
||||||
if (group != this._lastGroup) {
|
if (group != this._lastGroup) {
|
||||||
let style = 'chat-group-' + group;
|
|
||||||
this._lastGroup = group;
|
this._lastGroup = group;
|
||||||
this._lastGroupActor = new St.BoxLayout({ style_class: style,
|
let emptyLine = new St.Label({ style_class: 'chat-empty-line' });
|
||||||
vertical: true });
|
this.addActor(emptyLine);
|
||||||
this.addActor(this._lastGroupActor);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
this._lastGroupActor.add(body, props.childProps);
|
this._lastMessageBox = new St.BoxLayout({ vertical: false });
|
||||||
|
this._lastMessageBox.add(body, props.childProps);
|
||||||
|
this.addActor(this._lastMessageBox);
|
||||||
|
|
||||||
this.updated();
|
this.updated();
|
||||||
|
|
||||||
@ -941,32 +944,81 @@ const ChatNotification = new Lang.Class({
|
|||||||
|
|
||||||
let format;
|
let format;
|
||||||
|
|
||||||
// Show only the hour if date is on today
|
let desktopSettings = new Gio.Settings({ schema: 'org.gnome.desktop.interface' });
|
||||||
if(daysAgo < 1){
|
let clockFormat = desktopSettings.get_string(CLOCK_FORMAT_KEY);
|
||||||
format = "<b>%H:%M</b>";
|
|
||||||
}
|
|
||||||
// Show the word "Yesterday" and time if date is on yesterday
|
|
||||||
else if(daysAgo <2){
|
|
||||||
/* Translators: this is the word "Yesterday" followed by a time string. i.e. "Yesterday, 14:30"*/
|
|
||||||
// xgettext:no-c-format
|
|
||||||
format = _("<b>Yesterday</b>, <b>%H:%M</b>");
|
|
||||||
}
|
|
||||||
// Show a week day and time if date is in the last week
|
|
||||||
else if (daysAgo < 7) {
|
|
||||||
/* Translators: this is the week day name followed by a time string. i.e. "Monday, 14:30*/
|
|
||||||
// xgettext:no-c-format
|
|
||||||
format = _("<b>%A</b>, <b>%H:%M</b>");
|
|
||||||
|
|
||||||
} else if (date.getYear() == now.getYear()) {
|
switch (clockFormat) {
|
||||||
/* Translators: this is the month name and day number followed by a time string. i.e. "May 25, 14:30"*/
|
case '24h':
|
||||||
// xgettext:no-c-format
|
// Show only the time if date is on today
|
||||||
format = _("<b>%B</b> <b>%d</b>, <b>%H:%M</b>");
|
if(daysAgo < 1){
|
||||||
} else {
|
/* Translators: Time in 24h format */
|
||||||
/* Translators: this is the month name, day number, year number followed by a time string. i.e. "May 25 2012, 14:30"*/
|
format = _("%H\u2236%M");
|
||||||
// xgettext:no-c-format
|
}
|
||||||
format = _("<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> ");
|
// Show the word "Yesterday" and time if date is on yesterday
|
||||||
}
|
else if(daysAgo <2){
|
||||||
|
/* Translators: this is the word "Yesterday" followed by a
|
||||||
|
time string in 24h format. i.e. "Yesterday, 14:30" */
|
||||||
|
// xgettext:no-c-format
|
||||||
|
format = _("Yesterday, %H\u2236%M");
|
||||||
|
}
|
||||||
|
// Show a week day and time if date is in the last week
|
||||||
|
else if (daysAgo < 7) {
|
||||||
|
/* Translators: this is the week day name followed by a time
|
||||||
|
string in 24h format. i.e. "Monday, 14:30" */
|
||||||
|
// xgettext:no-c-format
|
||||||
|
format = _("%A, %H\u2236%M");
|
||||||
|
|
||||||
|
} else if (date.getYear() == now.getYear()) {
|
||||||
|
/* Translators: this is the month name and day number
|
||||||
|
followed by a time string in 24h format.
|
||||||
|
i.e. "May 25, 14:30" */
|
||||||
|
// xgettext:no-c-format
|
||||||
|
format = _("%B %d, %H\u2236%M");
|
||||||
|
} else {
|
||||||
|
/* Translators: this is the month name, day number, year
|
||||||
|
number followed by a time string in 24h format.
|
||||||
|
i.e. "May 25 2012, 14:30" */
|
||||||
|
// xgettext:no-c-format
|
||||||
|
format = _("%B %d %Y, %H\u2236%M");
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
/* explicit fall-through */
|
||||||
|
case '12h':
|
||||||
|
// Show only the time if date is on today
|
||||||
|
if(daysAgo < 1){
|
||||||
|
/* Translators: Time in 24h format */
|
||||||
|
format = _("%l\u2236%M %p");
|
||||||
|
}
|
||||||
|
// Show the word "Yesterday" and time if date is on yesterday
|
||||||
|
else if(daysAgo <2){
|
||||||
|
/* Translators: this is the word "Yesterday" followed by a
|
||||||
|
time string in 12h format. i.e. "Yesterday, 2:30 pm" */
|
||||||
|
// xgettext:no-c-format
|
||||||
|
format = _("Yesterday, %l\u2236%M %p");
|
||||||
|
}
|
||||||
|
// Show a week day and time if date is in the last week
|
||||||
|
else if (daysAgo < 7) {
|
||||||
|
/* Translators: this is the week day name followed by a time
|
||||||
|
string in 12h format. i.e. "Monday, 2:30 pm" */
|
||||||
|
// xgettext:no-c-format
|
||||||
|
format = _("%A, %l\u2236%M %p");
|
||||||
|
|
||||||
|
} else if (date.getYear() == now.getYear()) {
|
||||||
|
/* Translators: this is the month name and day number
|
||||||
|
followed by a time string in 12h format.
|
||||||
|
i.e. "May 25, 2:30 pm" */
|
||||||
|
// xgettext:no-c-format
|
||||||
|
format = _("%B %d, %l\u2236%M %p");
|
||||||
|
} else {
|
||||||
|
/* Translators: this is the month name, day number, year
|
||||||
|
number followed by a time string in 12h format.
|
||||||
|
i.e. "May 25 2012, 2:30 pm"*/
|
||||||
|
// xgettext:no-c-format
|
||||||
|
format = _("%B %d %Y, %l\u2236%M %p");
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
return date.toLocaleFormat(format);
|
return date.toLocaleFormat(format);
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -976,13 +1028,14 @@ const ChatNotification = new Lang.Class({
|
|||||||
let lastMessageTime = this._history[0].time;
|
let lastMessageTime = this._history[0].time;
|
||||||
let lastMessageDate = new Date(lastMessageTime * 1000);
|
let lastMessageDate = new Date(lastMessageTime * 1000);
|
||||||
|
|
||||||
let timeLabel = this._append({ body: this._formatTimestamp(lastMessageDate),
|
let timeLabel = new St.Label({ text: this._formatTimestamp(lastMessageDate),
|
||||||
group: 'meta',
|
style_class: 'chat-meta-message',
|
||||||
styles: ['chat-meta-message'],
|
x_expand: true,
|
||||||
childProps: { expand: true, x_fill: false,
|
y_expand: true,
|
||||||
x_align: St.Align.END },
|
x_align: Clutter.ActorAlign.END,
|
||||||
noTimestamp: true,
|
y_align: Clutter.ActorAlign.END });
|
||||||
timestamp: lastMessageTime });
|
|
||||||
|
this._lastMessageBox.add_actor(timeLabel);
|
||||||
|
|
||||||
this._filterMessages();
|
this._filterMessages();
|
||||||
|
|
||||||
|
@ -381,6 +381,8 @@ const DashActor = new Lang.Class({
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const baseIconSizes = [ 16, 22, 24, 32, 48, 64 ];
|
||||||
|
|
||||||
const Dash = new Lang.Class({
|
const Dash = new Lang.Class({
|
||||||
Name: 'Dash',
|
Name: 'Dash',
|
||||||
|
|
||||||
@ -632,25 +634,24 @@ const Dash = new Lang.Class({
|
|||||||
let minHeight, natHeight;
|
let minHeight, natHeight;
|
||||||
|
|
||||||
// Enforce the current icon size during the size request
|
// Enforce the current icon size during the size request
|
||||||
let [currentWidth, currentHeight] = firstIcon.icon.get_size();
|
firstIcon.setIconSize(this.iconSize);
|
||||||
|
|
||||||
firstIcon.icon.set_size(this.iconSize, this.iconSize);
|
|
||||||
[minHeight, natHeight] = firstButton.get_preferred_height(-1);
|
[minHeight, natHeight] = firstButton.get_preferred_height(-1);
|
||||||
|
|
||||||
firstIcon.icon.set_size(currentWidth, currentHeight);
|
let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor;
|
||||||
|
let iconSizes = baseIconSizes.map(function(s) {
|
||||||
|
return s * scaleFactor;
|
||||||
|
});
|
||||||
|
|
||||||
// Subtract icon padding and box spacing from the available height
|
// Subtract icon padding and box spacing from the available height
|
||||||
availHeight -= iconChildren.length * (natHeight - this.iconSize) +
|
availHeight -= iconChildren.length * (natHeight - this.iconSize * scaleFactor) +
|
||||||
(iconChildren.length - 1) * spacing;
|
(iconChildren.length - 1) * spacing;
|
||||||
|
|
||||||
let availSize = availHeight / iconChildren.length;
|
let availSize = availHeight / iconChildren.length;
|
||||||
|
|
||||||
let iconSizes = [ 16, 22, 24, 32, 48, 64 ];
|
let newIconSize = baseIconSizes[0];
|
||||||
|
|
||||||
let newIconSize = 16;
|
|
||||||
for (let i = 0; i < iconSizes.length; i++) {
|
for (let i = 0; i < iconSizes.length; i++) {
|
||||||
if (iconSizes[i] < availSize)
|
if (iconSizes[i] < availSize)
|
||||||
newIconSize = iconSizes[i];
|
newIconSize = baseIconSizes[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (newIconSize == this.iconSize)
|
if (newIconSize == this.iconSize)
|
||||||
|
@ -202,7 +202,7 @@ const DateMenuButton = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_getClockApp: function() {
|
_getClockApp: function() {
|
||||||
return Shell.AppSystem.get_default().lookup_app('gnome-clocks.desktop');
|
return Shell.AppSystem.get_default().lookup_app('org.gnome.clocks.desktop');
|
||||||
},
|
},
|
||||||
|
|
||||||
_onOpenCalendarActivate: function() {
|
_onOpenCalendarActivate: function() {
|
||||||
|
@ -25,9 +25,11 @@ const Gio = imports.gi.Gio;
|
|||||||
const GLib = imports.gi.GLib;
|
const GLib = imports.gi.GLib;
|
||||||
const Gtk = imports.gi.Gtk;
|
const Gtk = imports.gi.Gtk;
|
||||||
const Pango = imports.gi.Pango;
|
const Pango = imports.gi.Pango;
|
||||||
|
const Polkit = imports.gi.Polkit;
|
||||||
const St = imports.gi.St;
|
const St = imports.gi.St;
|
||||||
const Shell = imports.gi.Shell;
|
const Shell = imports.gi.Shell;
|
||||||
|
|
||||||
|
const CheckBox = imports.ui.checkBox;
|
||||||
const GnomeSession = imports.misc.gnomeSession;
|
const GnomeSession = imports.misc.gnomeSession;
|
||||||
const LoginManager = imports.misc.loginManager;
|
const LoginManager = imports.misc.loginManager;
|
||||||
const ModalDialog = imports.ui.modalDialog;
|
const ModalDialog = imports.ui.modalDialog;
|
||||||
@ -36,8 +38,10 @@ 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 = 32;
|
const _DIALOG_ICON_SIZE = 48;
|
||||||
|
|
||||||
const GSM_SESSION_MANAGER_LOGOUT_FORCE = 2;
|
const GSM_SESSION_MANAGER_LOGOUT_FORCE = 2;
|
||||||
|
|
||||||
@ -71,6 +75,7 @@ const logoutDialogContent = {
|
|||||||
"You will be logged out automatically in %d seconds.",
|
"You will be logged out automatically in %d seconds.",
|
||||||
seconds).format(seconds);
|
seconds).format(seconds);
|
||||||
},
|
},
|
||||||
|
showBatteryWarning: false,
|
||||||
confirmButtons: [{ signal: 'ConfirmedLogout',
|
confirmButtons: [{ signal: 'ConfirmedLogout',
|
||||||
label: C_("button", "Log Out") }],
|
label: C_("button", "Log Out") }],
|
||||||
iconStyleClass: 'end-session-dialog-logout-icon',
|
iconStyleClass: 'end-session-dialog-logout-icon',
|
||||||
@ -79,11 +84,14 @@ const logoutDialogContent = {
|
|||||||
|
|
||||||
const shutdownDialogContent = {
|
const shutdownDialogContent = {
|
||||||
subject: C_("title", "Power Off"),
|
subject: C_("title", "Power Off"),
|
||||||
|
subjectWithUpdates: C_("title", "Install Updates & Power Off"),
|
||||||
description: function(seconds) {
|
description: function(seconds) {
|
||||||
return ngettext("The system will power off automatically in %d second.",
|
return ngettext("The system will power off automatically in %d second.",
|
||||||
"The system will power off automatically in %d seconds.",
|
"The system will power off automatically in %d seconds.",
|
||||||
seconds).format(seconds);
|
seconds).format(seconds);
|
||||||
},
|
},
|
||||||
|
checkBoxText: C_("checkbox", "Install pending software updates"),
|
||||||
|
showBatteryWarning: true,
|
||||||
confirmButtons: [{ signal: 'ConfirmedReboot',
|
confirmButtons: [{ signal: 'ConfirmedReboot',
|
||||||
label: C_("button", "Restart") },
|
label: C_("button", "Restart") },
|
||||||
{ signal: 'ConfirmedShutdown',
|
{ signal: 'ConfirmedShutdown',
|
||||||
@ -100,6 +108,7 @@ const restartDialogContent = {
|
|||||||
"The system will restart automatically in %d seconds.",
|
"The system will restart automatically in %d seconds.",
|
||||||
seconds).format(seconds);
|
seconds).format(seconds);
|
||||||
},
|
},
|
||||||
|
showBatteryWarning: false,
|
||||||
confirmButtons: [{ signal: 'ConfirmedReboot',
|
confirmButtons: [{ signal: 'ConfirmedReboot',
|
||||||
label: C_("button", "Restart") }],
|
label: C_("button", "Restart") }],
|
||||||
iconName: 'view-refresh-symbolic',
|
iconName: 'view-refresh-symbolic',
|
||||||
@ -115,8 +124,11 @@ const restartInstallDialogContent = {
|
|||||||
"The system will automatically restart and install updates in %d seconds.",
|
"The system will automatically restart and install updates in %d seconds.",
|
||||||
seconds).format(seconds);
|
seconds).format(seconds);
|
||||||
},
|
},
|
||||||
|
showBatteryWarning: true,
|
||||||
confirmButtons: [{ signal: 'ConfirmedReboot',
|
confirmButtons: [{ signal: 'ConfirmedReboot',
|
||||||
label: C_("button", "Restart & Install") }],
|
label: C_("button", "Restart & Install") }],
|
||||||
|
unusedFutureButtonForTranslation: C_("button", "Install & Power Off"),
|
||||||
|
unusedFutureCheckBoxForTranslation: C_("checkbox", "Power off after updates are installed"),
|
||||||
iconName: 'view-refresh-symbolic',
|
iconName: 'view-refresh-symbolic',
|
||||||
iconStyleClass: 'end-session-dialog-shutdown-icon',
|
iconStyleClass: 'end-session-dialog-shutdown-icon',
|
||||||
showOtherSessions: true,
|
showOtherSessions: true,
|
||||||
@ -143,6 +155,14 @@ const LogindSessionIface = '<node> \
|
|||||||
|
|
||||||
const LogindSession = Gio.DBusProxy.makeProxyWrapper(LogindSessionIface);
|
const LogindSession = Gio.DBusProxy.makeProxyWrapper(LogindSessionIface);
|
||||||
|
|
||||||
|
const UPowerIface = '<node> \
|
||||||
|
<interface name="org.freedesktop.UPower"> \
|
||||||
|
<property name="OnBattery" type="b" access="read"/> \
|
||||||
|
</interface> \
|
||||||
|
</node>';
|
||||||
|
|
||||||
|
const UPowerProxy = Gio.DBusProxy.makeProxyWrapper(UPowerIface);
|
||||||
|
|
||||||
function findAppFromInhibitor(inhibitor) {
|
function findAppFromInhibitor(inhibitor) {
|
||||||
let desktopFile;
|
let desktopFile;
|
||||||
try {
|
try {
|
||||||
@ -195,6 +215,18 @@ function _setLabelText(label, text) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function _setCheckBoxLabel(checkBox, text) {
|
||||||
|
let label = checkBox.getLabelActor();
|
||||||
|
|
||||||
|
if (text) {
|
||||||
|
label.set_text(text);
|
||||||
|
checkBox.actor.show();
|
||||||
|
} else {
|
||||||
|
label.set_text('');
|
||||||
|
checkBox.actor.hide();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function init() {
|
function init() {
|
||||||
// This always returns the same singleton object
|
// This always returns the same singleton object
|
||||||
// By instantiating it initially, we register the
|
// By instantiating it initially, we register the
|
||||||
@ -214,6 +246,20 @@ const EndSessionDialog = new Lang.Class({
|
|||||||
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._updatesFile = Gio.File.new_for_path('/system-update');
|
||||||
|
this._preparedUpdateFile = Gio.File.new_for_path('/var/lib/PackageKit/prepared-update');
|
||||||
|
|
||||||
|
this._powerProxy = new UPowerProxy(Gio.DBus.system,
|
||||||
|
'org.freedesktop.UPower',
|
||||||
|
'/org/freedesktop/UPower',
|
||||||
|
Lang.bind(this, function(proxy, error) {
|
||||||
|
if (error) {
|
||||||
|
log(error.message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
this._powerProxy.connect('g-properties-changed',
|
||||||
|
Lang.bind(this, this._sync));
|
||||||
|
this._sync();
|
||||||
|
}));
|
||||||
|
|
||||||
this._secondsLeft = 0;
|
this._secondsLeft = 0;
|
||||||
this._totalSecondsToStayOpen = 0;
|
this._totalSecondsToStayOpen = 0;
|
||||||
@ -240,7 +286,8 @@ const EndSessionDialog = new Lang.Class({
|
|||||||
x_align: St.Align.END,
|
x_align: St.Align.END,
|
||||||
y_align: St.Align.START });
|
y_align: St.Align.START });
|
||||||
|
|
||||||
let messageLayout = new St.BoxLayout({ vertical: true });
|
let messageLayout = new St.BoxLayout({ vertical: true,
|
||||||
|
style_class: 'end-session-dialog-layout' });
|
||||||
mainContentLayout.add(messageLayout,
|
mainContentLayout.add(messageLayout,
|
||||||
{ y_align: St.Align.START });
|
{ y_align: St.Align.START });
|
||||||
|
|
||||||
@ -260,6 +307,16 @@ const EndSessionDialog = new Lang.Class({
|
|||||||
{ y_fill: true,
|
{ y_fill: true,
|
||||||
y_align: St.Align.START });
|
y_align: St.Align.START });
|
||||||
|
|
||||||
|
this._checkBox = new CheckBox.CheckBox();
|
||||||
|
this._checkBox.actor.connect('clicked', Lang.bind(this, this._sync));
|
||||||
|
messageLayout.add(this._checkBox.actor);
|
||||||
|
|
||||||
|
this._batteryWarning = new St.Label({ style_class: 'end-session-dialog-warning',
|
||||||
|
text: _("Running on battery power: please plug in before installing updates.") });
|
||||||
|
this._batteryWarning.clutter_text.ellipsize = Pango.EllipsizeMode.NONE;
|
||||||
|
this._batteryWarning.clutter_text.line_wrap = true;
|
||||||
|
messageLayout.add(this._batteryWarning);
|
||||||
|
|
||||||
this._scrollView = new St.ScrollView({ style_class: 'end-session-dialog-list' });
|
this._scrollView = new St.ScrollView({ style_class: 'end-session-dialog-list' });
|
||||||
this._scrollView.set_policy(Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC);
|
this._scrollView.set_policy(Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC);
|
||||||
this.contentLayout.add(this._scrollView,
|
this.contentLayout.add(this._scrollView,
|
||||||
@ -285,6 +342,12 @@ const EndSessionDialog = new Lang.Class({
|
|||||||
this._inhibitorSection.add_actor(this._sessionHeader);
|
this._inhibitorSection.add_actor(this._sessionHeader);
|
||||||
this._inhibitorSection.add_actor(this._sessionList);
|
this._inhibitorSection.add_actor(this._sessionList);
|
||||||
|
|
||||||
|
try {
|
||||||
|
this._updatesPermission = Polkit.Permission.new_sync("org.freedesktop.packagekit.trigger-offline-update", null, null);
|
||||||
|
} catch(e) {
|
||||||
|
log('No permission to trigger offline updates: %s'.format(e.toString()));
|
||||||
|
}
|
||||||
|
|
||||||
this._dbusImpl = Gio.DBusExportedObject.wrapJSObject(EndSessionDialogIface, this);
|
this._dbusImpl = Gio.DBusExportedObject.wrapJSObject(EndSessionDialogIface, this);
|
||||||
this._dbusImpl.export(Gio.DBus.session, '/org/gnome/SessionManager/EndSessionDialog');
|
this._dbusImpl.export(Gio.DBus.session, '/org/gnome/SessionManager/EndSessionDialog');
|
||||||
},
|
},
|
||||||
@ -299,13 +362,22 @@ const EndSessionDialog = new Lang.Class({
|
|||||||
if (!open)
|
if (!open)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (this._type == 2 && this._updatesFile.query_exists(null))
|
|
||||||
this._type = 3;
|
|
||||||
|
|
||||||
let dialogContent = DialogContent[this._type];
|
let dialogContent = DialogContent[this._type];
|
||||||
|
|
||||||
let subject = dialogContent.subject;
|
let subject = dialogContent.subject;
|
||||||
|
|
||||||
|
// Use different title when we are installing updates
|
||||||
|
if (dialogContent.subjectWithUpdates && this._checkBox.actor.checked)
|
||||||
|
subject = dialogContent.subjectWithUpdates;
|
||||||
|
|
||||||
|
if (dialogContent.showBatteryWarning) {
|
||||||
|
// Warn when running on battery power
|
||||||
|
if (this._powerProxy.OnBattery && this._checkBox.actor.checked)
|
||||||
|
this._batteryWarning.opacity = 255;
|
||||||
|
else
|
||||||
|
this._batteryWarning.opacity = 0;
|
||||||
|
}
|
||||||
|
|
||||||
let description;
|
let description;
|
||||||
let displayTime = _roundSecondsToInterval(this._totalSecondsToStayOpen,
|
let displayTime = _roundSecondsToInterval(this._totalSecondsToStayOpen,
|
||||||
this._secondsLeft,
|
this._secondsLeft,
|
||||||
@ -388,15 +460,75 @@ const EndSessionDialog = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_confirm: function(signal) {
|
_confirm: function(signal) {
|
||||||
this._fadeOutDialog();
|
let callback = Lang.bind(this, function() {
|
||||||
this._stopTimer();
|
this._fadeOutDialog();
|
||||||
this._dbusImpl.emit_signal(signal, null);
|
this._stopTimer();
|
||||||
|
this._dbusImpl.emit_signal(signal, null);
|
||||||
|
});
|
||||||
|
|
||||||
|
// Offline update not available; just emit the signal
|
||||||
|
if (!this._checkBox.actor.visible) {
|
||||||
|
callback();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Trigger the offline update as requested
|
||||||
|
if (this._checkBox.actor.checked) {
|
||||||
|
switch (signal) {
|
||||||
|
case "ConfirmedReboot":
|
||||||
|
this._triggerOfflineUpdateReboot(callback);
|
||||||
|
break;
|
||||||
|
case "ConfirmedShutdown":
|
||||||
|
// To actually trigger the offline update, we need to
|
||||||
|
// reboot to do the upgrade. When the upgrade is complete,
|
||||||
|
// the computer will shut down automatically.
|
||||||
|
signal = "ConfirmedReboot";
|
||||||
|
this._triggerOfflineUpdateShutdown(callback);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
callback();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
this._triggerOfflineUpdateCancel(callback);
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_onOpened: function() {
|
_onOpened: function() {
|
||||||
this._sync();
|
this._sync();
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_triggerOfflineUpdateReboot: function(callback) {
|
||||||
|
this._pkexecSpawn([TRIGGER_OFFLINE_UPDATE, 'reboot'], callback);
|
||||||
|
},
|
||||||
|
|
||||||
|
_triggerOfflineUpdateShutdown: function(callback) {
|
||||||
|
this._pkexecSpawn([TRIGGER_OFFLINE_UPDATE, 'power-off'], callback);
|
||||||
|
},
|
||||||
|
|
||||||
|
_triggerOfflineUpdateCancel: function(callback) {
|
||||||
|
this._pkexecSpawn([TRIGGER_OFFLINE_UPDATE, '--cancel'], callback);
|
||||||
|
},
|
||||||
|
|
||||||
|
_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();
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
_startTimer: function() {
|
_startTimer: function() {
|
||||||
let startTime = GLib.get_monotonic_time();
|
let startTime = GLib.get_monotonic_time();
|
||||||
this._secondsLeft = this._totalSecondsToStayOpen;
|
this._secondsLeft = this._totalSecondsToStayOpen;
|
||||||
@ -544,6 +676,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))
|
||||||
|
this._type = 3;
|
||||||
|
|
||||||
this._applications = [];
|
this._applications = [];
|
||||||
this._applicationList.destroy_all_children();
|
this._applicationList.destroy_all_children();
|
||||||
|
|
||||||
@ -556,6 +691,8 @@ const EndSessionDialog = new Lang.Class({
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let dialogContent = DialogContent[this._type];
|
||||||
|
|
||||||
for (let i = 0; i < inhibitorObjectPaths.length; i++) {
|
for (let i = 0; i < inhibitorObjectPaths.length; i++) {
|
||||||
let inhibitor = new GnomeSession.Inhibitor(inhibitorObjectPaths[i], Lang.bind(this, function(proxy, error) {
|
let inhibitor = new GnomeSession.Inhibitor(inhibitorObjectPaths[i], Lang.bind(this, function(proxy, error) {
|
||||||
this._onInhibitorLoaded(proxy);
|
this._onInhibitorLoaded(proxy);
|
||||||
@ -564,9 +701,23 @@ const EndSessionDialog = new Lang.Class({
|
|||||||
this._applications.push(inhibitor);
|
this._applications.push(inhibitor);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (DialogContent[type].showOtherSessions)
|
if (dialogContent.showOtherSessions)
|
||||||
this._loadSessions();
|
this._loadSessions();
|
||||||
|
|
||||||
|
let preparedUpdate = this._preparedUpdateFile.query_exists(null);
|
||||||
|
let updateAlreadyTriggered = this._updatesFile.query_exists(null);
|
||||||
|
let updatesAllowed = this._updatesPermission && this._updatesPermission.allowed;
|
||||||
|
|
||||||
|
_setCheckBoxLabel(this._checkBox, dialogContent.checkBoxText);
|
||||||
|
this._checkBox.actor.visible = (dialogContent.checkBoxText && preparedUpdate && updatesAllowed);
|
||||||
|
this._checkBox.actor.checked = (preparedUpdate && updateAlreadyTriggered);
|
||||||
|
|
||||||
|
// We show the warning either together with the checkbox, or when
|
||||||
|
// updates have already been triggered, but the user doesn't have
|
||||||
|
// enough permissions to cancel them.
|
||||||
|
this._batteryWarning.visible = (dialogContent.showBatteryWarning &&
|
||||||
|
(this._checkBox.actor.visible || preparedUpdate && updateAlreadyTriggered && !updatesAllowed));
|
||||||
|
|
||||||
this._updateButtons();
|
this._updateButtons();
|
||||||
|
|
||||||
if (!this.open(timestamp)) {
|
if (!this.open(timestamp)) {
|
||||||
|
@ -38,6 +38,7 @@ const connect = Lang.bind(_signals, _signals.connect);
|
|||||||
const disconnect = Lang.bind(_signals, _signals.disconnect);
|
const disconnect = Lang.bind(_signals, _signals.disconnect);
|
||||||
|
|
||||||
const ENABLED_EXTENSIONS_KEY = 'enabled-extensions';
|
const ENABLED_EXTENSIONS_KEY = 'enabled-extensions';
|
||||||
|
const EXTENSION_DISABLE_VERSION_CHECK_KEY = 'disable-extension-version-validation';
|
||||||
|
|
||||||
var initted = false;
|
var initted = false;
|
||||||
var enabled;
|
var enabled;
|
||||||
@ -156,7 +157,9 @@ function loadExtension(extension) {
|
|||||||
// Default to error, we set success as the last step
|
// Default to error, we set success as the last step
|
||||||
extension.state = ExtensionState.ERROR;
|
extension.state = ExtensionState.ERROR;
|
||||||
|
|
||||||
if (ExtensionUtils.isOutOfDate(extension)) {
|
let checkVersion = !global.settings.get_boolean(EXTENSION_DISABLE_VERSION_CHECK_KEY);
|
||||||
|
|
||||||
|
if (checkVersion && ExtensionUtils.isOutOfDate(extension)) {
|
||||||
extension.state = ExtensionState.OUT_OF_DATE;
|
extension.state = ExtensionState.OUT_OF_DATE;
|
||||||
} else {
|
} else {
|
||||||
let enabled = enabledExtensions.indexOf(extension.uuid) != -1;
|
let enabled = enabledExtensions.indexOf(extension.uuid) != -1;
|
||||||
@ -267,8 +270,19 @@ function onEnabledExtensionsChanged() {
|
|||||||
enabledExtensions = newEnabledExtensions;
|
enabledExtensions = newEnabledExtensions;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function _onVersionValidationChanged() {
|
||||||
|
if (Main.sessionMode.allowExtensions) {
|
||||||
|
enabledExtensions.forEach(function(uuid) {
|
||||||
|
if (ExtensionUtils.extensions[uuid])
|
||||||
|
reloadExtension(ExtensionUtils.extensions[uuid]);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function _loadExtensions() {
|
function _loadExtensions() {
|
||||||
global.settings.connect('changed::' + ENABLED_EXTENSIONS_KEY, onEnabledExtensionsChanged);
|
global.settings.connect('changed::' + ENABLED_EXTENSIONS_KEY, onEnabledExtensionsChanged);
|
||||||
|
global.settings.connect('changed::' + EXTENSION_DISABLE_VERSION_CHECK_KEY, _onVersionValidationChanged);
|
||||||
|
|
||||||
enabledExtensions = getEnabledExtensions();
|
enabledExtensions = getEnabledExtensions();
|
||||||
|
|
||||||
let finder = new ExtensionUtils.ExtensionFinder();
|
let finder = new ExtensionUtils.ExtensionFinder();
|
||||||
|
@ -34,7 +34,11 @@ const FocusCaretTracker = new Lang.Class({
|
|||||||
_init: function() {
|
_init: function() {
|
||||||
Atspi.init();
|
Atspi.init();
|
||||||
Atspi.set_timeout(250, 250);
|
Atspi.set_timeout(250, 250);
|
||||||
|
|
||||||
this._atspiListener = Atspi.EventListener.new(Lang.bind(this, this._onChanged));
|
this._atspiListener = Atspi.EventListener.new(Lang.bind(this, this._onChanged));
|
||||||
|
|
||||||
|
this._focusListenerRegistered = false;
|
||||||
|
this._caretListenerRegistered = false;
|
||||||
},
|
},
|
||||||
|
|
||||||
_onChanged: function(event) {
|
_onChanged: function(event) {
|
||||||
@ -45,21 +49,39 @@ const FocusCaretTracker = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
registerFocusListener: function() {
|
registerFocusListener: function() {
|
||||||
return this._atspiListener.register(STATECHANGED + ':focused') &&
|
if (this._focusListenerRegistered)
|
||||||
this._atspiListener.register(STATECHANGED + ':selected');
|
return;
|
||||||
|
|
||||||
|
// Ignore the return value, we get an exception if they fail
|
||||||
|
// And they should never fail
|
||||||
|
this._atspiListener.register(STATECHANGED + ':focused');
|
||||||
|
this._atspiListener.register(STATECHANGED + ':selected');
|
||||||
|
this._focusListenerRegistered = true;
|
||||||
},
|
},
|
||||||
|
|
||||||
registerCaretListener: function() {
|
registerCaretListener: function() {
|
||||||
return this._atspiListener.register(CARETMOVED);
|
if (this._caretListenerRegistered)
|
||||||
|
return;
|
||||||
|
|
||||||
|
this._atspiListener.register(CARETMOVED);
|
||||||
|
this._caretListenerRegistered = true;
|
||||||
},
|
},
|
||||||
|
|
||||||
deregisterFocusListener: function() {
|
deregisterFocusListener: function() {
|
||||||
return this._atspiListener.deregister(STATECHANGED + ':focused') &&
|
if (!this._focusListenerRegistered)
|
||||||
this._atspiListener.deregister(STATECHANGED + ':selected');
|
return;
|
||||||
|
|
||||||
|
this._atspiListener.deregister(STATECHANGED + ':focused');
|
||||||
|
this._atspiListener.deregister(STATECHANGED + ':selected');
|
||||||
|
this._focusListenerRegistered = false;
|
||||||
},
|
},
|
||||||
|
|
||||||
deregisterCaretListener: function() {
|
deregisterCaretListener: function() {
|
||||||
return this._atspiListener.deregister(CARETMOVED);
|
if (!this._caretListenerRegistered)
|
||||||
|
return;
|
||||||
|
|
||||||
|
this._atspiListener.deregister(CARETMOVED);
|
||||||
|
this._caretListenerRegistered = false;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
Signals.addSignalMethods(FocusCaretTracker.prototype);
|
Signals.addSignalMethods(FocusCaretTracker.prototype);
|
||||||
|
@ -143,11 +143,6 @@ const BaseIcon = new Lang.Class({
|
|||||||
this.icon = this.createIcon(this.iconSize);
|
this.icon = this.createIcon(this.iconSize);
|
||||||
|
|
||||||
this._iconBin.child = this.icon;
|
this._iconBin.child = this.icon;
|
||||||
|
|
||||||
// The icon returned by createIcon() might actually be smaller than
|
|
||||||
// the requested icon size (for instance StTextureCache does this
|
|
||||||
// for fallback icons), so set the size explicitly.
|
|
||||||
this._iconBin.set_size(this.iconSize, this.iconSize);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_onStyleChanged: function() {
|
_onStyleChanged: function() {
|
||||||
|
@ -834,6 +834,8 @@ const LayoutManager = new Lang.Class({
|
|||||||
Lang.bind(this, this._queueUpdateRegions));
|
Lang.bind(this, this._queueUpdateRegions));
|
||||||
actorData.allocationId = actor.connect('notify::allocation',
|
actorData.allocationId = actor.connect('notify::allocation',
|
||||||
Lang.bind(this, this._queueUpdateRegions));
|
Lang.bind(this, this._queueUpdateRegions));
|
||||||
|
actorData.destroyId = actor.connect('destroy',
|
||||||
|
Lang.bind(this, this._untrackActor));
|
||||||
// Note that destroying actor will unset its parent, so we don't
|
// Note that destroying actor will unset its parent, so we don't
|
||||||
// need to connect to 'destroy' too.
|
// need to connect to 'destroy' too.
|
||||||
|
|
||||||
@ -851,7 +853,7 @@ const LayoutManager = new Lang.Class({
|
|||||||
this._trackedActors.splice(i, 1);
|
this._trackedActors.splice(i, 1);
|
||||||
actor.disconnect(actorData.visibleId);
|
actor.disconnect(actorData.visibleId);
|
||||||
actor.disconnect(actorData.allocationId);
|
actor.disconnect(actorData.allocationId);
|
||||||
actor.disconnect(actorData.parentSetId);
|
actor.disconnect(actorData.destroyId);
|
||||||
|
|
||||||
this._queueUpdateRegions();
|
this._queueUpdateRegions();
|
||||||
},
|
},
|
||||||
|
@ -11,6 +11,7 @@ const Mainloop = imports.mainloop;
|
|||||||
const Meta = imports.gi.Meta;
|
const Meta = imports.gi.Meta;
|
||||||
const Signals = imports.signals;
|
const Signals = imports.signals;
|
||||||
|
|
||||||
|
const Background = imports.ui.background;
|
||||||
const FocusCaretTracker = imports.ui.focusCaretTracker;
|
const FocusCaretTracker = imports.ui.focusCaretTracker;
|
||||||
const Main = imports.ui.main;
|
const Main = imports.ui.main;
|
||||||
const MagnifierDBus = imports.ui.magnifierDBus;
|
const MagnifierDBus = imports.ui.magnifierDBus;
|
||||||
@ -57,20 +58,6 @@ const Magnifier = new Lang.Class({
|
|||||||
// Magnifier is a manager of ZoomRegions.
|
// Magnifier is a manager of ZoomRegions.
|
||||||
this._zoomRegions = [];
|
this._zoomRegions = [];
|
||||||
|
|
||||||
// Export to dbus.
|
|
||||||
magDBusService = new MagnifierDBus.ShellMagnifier();
|
|
||||||
|
|
||||||
let showAtLaunch = this._settingsInit();
|
|
||||||
this.setActive(showAtLaunch);
|
|
||||||
},
|
|
||||||
|
|
||||||
_initialize: function() {
|
|
||||||
if (this._initialized)
|
|
||||||
return;
|
|
||||||
this._initialized = true;
|
|
||||||
|
|
||||||
this._settingsInitLate();
|
|
||||||
|
|
||||||
// Create small clutter tree for the magnified mouse.
|
// Create small clutter tree for the magnified mouse.
|
||||||
let cursorTracker = Meta.CursorTracker.get_for_screen(global.screen);
|
let cursorTracker = Meta.CursorTracker.get_for_screen(global.screen);
|
||||||
this._mouseSprite = new Clutter.Texture();
|
this._mouseSprite = new Clutter.Texture();
|
||||||
@ -86,11 +73,15 @@ const Magnifier = new Lang.Class({
|
|||||||
|
|
||||||
let aZoomRegion = new ZoomRegion(this, this._cursorRoot);
|
let aZoomRegion = new ZoomRegion(this, this._cursorRoot);
|
||||||
this._zoomRegions.push(aZoomRegion);
|
this._zoomRegions.push(aZoomRegion);
|
||||||
this._settingsInitRegion(aZoomRegion);
|
let showAtLaunch = this._settingsInit(aZoomRegion);
|
||||||
aZoomRegion.scrollContentsTo(this.xMouse, this.yMouse);
|
aZoomRegion.scrollContentsTo(this.xMouse, this.yMouse);
|
||||||
|
|
||||||
cursorTracker.connect('cursor-changed', Lang.bind(this, this._updateMouseSprite));
|
cursorTracker.connect('cursor-changed', Lang.bind(this, this._updateMouseSprite));
|
||||||
this._cursorTracker = cursorTracker;
|
this._cursorTracker = cursorTracker;
|
||||||
|
|
||||||
|
// Export to dbus.
|
||||||
|
magDBusService = new MagnifierDBus.ShellMagnifier();
|
||||||
|
this.setActive(showAtLaunch);
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -115,20 +106,21 @@ const Magnifier = new Lang.Class({
|
|||||||
* @activate: Boolean to activate or de-activate the magnifier.
|
* @activate: Boolean to activate or de-activate the magnifier.
|
||||||
*/
|
*/
|
||||||
setActive: function(activate) {
|
setActive: function(activate) {
|
||||||
if (activate == this.isActive())
|
let isActive = this.isActive();
|
||||||
return;
|
|
||||||
|
|
||||||
if (activate)
|
|
||||||
this._initialize();
|
|
||||||
|
|
||||||
this._zoomRegions.forEach (function(zoomRegion, index, array) {
|
this._zoomRegions.forEach (function(zoomRegion, index, array) {
|
||||||
zoomRegion.setActive(activate);
|
zoomRegion.setActive(activate);
|
||||||
});
|
});
|
||||||
|
|
||||||
if (activate)
|
if (isActive != activate) {
|
||||||
this.startTrackingMouse();
|
if (activate) {
|
||||||
else
|
Meta.disable_unredirect_for_screen(global.screen);
|
||||||
this.stopTrackingMouse();
|
this.startTrackingMouse();
|
||||||
|
} else {
|
||||||
|
Meta.enable_unredirect_for_screen(global.screen);
|
||||||
|
this.stopTrackingMouse();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Make sure system mouse pointer is shown when all zoom regions are
|
// Make sure system mouse pointer is shown when all zoom regions are
|
||||||
// invisible.
|
// invisible.
|
||||||
@ -448,68 +440,64 @@ const Magnifier = new Lang.Class({
|
|||||||
this._mouseSprite.set_anchor_point(xHot, yHot);
|
this._mouseSprite.set_anchor_point(xHot, yHot);
|
||||||
},
|
},
|
||||||
|
|
||||||
_settingsInitRegion: function(zoomRegion) {
|
_settingsInit: function(zoomRegion) {
|
||||||
// Mag factor is accurate to two decimal places.
|
|
||||||
let aPref = parseFloat(this._settings.get_double(MAG_FACTOR_KEY).toFixed(2));
|
|
||||||
if (aPref != 0.0)
|
|
||||||
zoomRegion.setMagFactor(aPref, aPref);
|
|
||||||
|
|
||||||
aPref = this._settings.get_enum(SCREEN_POSITION_KEY);
|
|
||||||
if (aPref)
|
|
||||||
zoomRegion.setScreenPosition(aPref);
|
|
||||||
|
|
||||||
zoomRegion.setLensMode(this._settings.get_boolean(LENS_MODE_KEY));
|
|
||||||
zoomRegion.setClampScrollingAtEdges(!this._settings.get_boolean(CLAMP_MODE_KEY));
|
|
||||||
|
|
||||||
aPref = this._settings.get_enum(MOUSE_TRACKING_KEY);
|
|
||||||
if (aPref)
|
|
||||||
zoomRegion.setMouseTrackingMode(aPref);
|
|
||||||
|
|
||||||
aPref = this._settings.get_enum(FOCUS_TRACKING_KEY);
|
|
||||||
if (aPref)
|
|
||||||
zoomRegion.setFocusTrackingMode(aPref);
|
|
||||||
|
|
||||||
aPref = this._settings.get_enum(CARET_TRACKING_KEY);
|
|
||||||
if (aPref)
|
|
||||||
zoomRegion.setCaretTrackingMode(aPref);
|
|
||||||
|
|
||||||
aPref = this._settings.get_boolean(INVERT_LIGHTNESS_KEY);
|
|
||||||
if (aPref)
|
|
||||||
zoomRegion.setInvertLightness(aPref);
|
|
||||||
|
|
||||||
aPref = this._settings.get_double(COLOR_SATURATION_KEY);
|
|
||||||
if (aPref)
|
|
||||||
zoomRegion.setColorSaturation(aPref);
|
|
||||||
|
|
||||||
let bc = {};
|
|
||||||
bc.r = this._settings.get_double(BRIGHT_RED_KEY);
|
|
||||||
bc.g = this._settings.get_double(BRIGHT_GREEN_KEY);
|
|
||||||
bc.b = this._settings.get_double(BRIGHT_BLUE_KEY);
|
|
||||||
zoomRegion.setBrightness(bc);
|
|
||||||
|
|
||||||
bc.r = this._settings.get_double(CONTRAST_RED_KEY);
|
|
||||||
bc.g = this._settings.get_double(CONTRAST_GREEN_KEY);
|
|
||||||
bc.b = this._settings.get_double(CONTRAST_BLUE_KEY);
|
|
||||||
zoomRegion.setContrast(bc);
|
|
||||||
},
|
|
||||||
|
|
||||||
_settingsInit: function() {
|
|
||||||
this._appSettings = new Gio.Settings({ schema: APPLICATIONS_SCHEMA });
|
this._appSettings = new Gio.Settings({ schema: APPLICATIONS_SCHEMA });
|
||||||
this._settings = new Gio.Settings({ schema: MAGNIFIER_SCHEMA });
|
this._settings = new Gio.Settings({ schema: MAGNIFIER_SCHEMA });
|
||||||
|
|
||||||
this._appSettings.connect('changed::' + SHOW_KEY, Lang.bind(this, function() {
|
if (zoomRegion) {
|
||||||
let active = this._appSettings.get_boolean(SHOW_KEY);
|
// Mag factor is accurate to two decimal places.
|
||||||
this.setActive(active);
|
let aPref = parseFloat(this._settings.get_double(MAG_FACTOR_KEY).toFixed(2));
|
||||||
}));
|
if (aPref != 0.0)
|
||||||
|
zoomRegion.setMagFactor(aPref, aPref);
|
||||||
|
|
||||||
return this._appSettings.get_boolean(SHOW_KEY);
|
aPref = this._settings.get_enum(SCREEN_POSITION_KEY);
|
||||||
},
|
if (aPref)
|
||||||
|
zoomRegion.setScreenPosition(aPref);
|
||||||
|
|
||||||
|
zoomRegion.setLensMode(this._settings.get_boolean(LENS_MODE_KEY));
|
||||||
|
zoomRegion.setClampScrollingAtEdges(!this._settings.get_boolean(CLAMP_MODE_KEY));
|
||||||
|
|
||||||
|
aPref = this._settings.get_enum(MOUSE_TRACKING_KEY);
|
||||||
|
if (aPref)
|
||||||
|
zoomRegion.setMouseTrackingMode(aPref);
|
||||||
|
|
||||||
|
aPref = this._settings.get_enum(FOCUS_TRACKING_KEY);
|
||||||
|
if (aPref)
|
||||||
|
zoomRegion.setFocusTrackingMode(aPref);
|
||||||
|
|
||||||
|
aPref = this._settings.get_enum(CARET_TRACKING_KEY);
|
||||||
|
if (aPref)
|
||||||
|
zoomRegion.setCaretTrackingMode(aPref);
|
||||||
|
|
||||||
|
aPref = this._settings.get_boolean(INVERT_LIGHTNESS_KEY);
|
||||||
|
if (aPref)
|
||||||
|
zoomRegion.setInvertLightness(aPref);
|
||||||
|
|
||||||
|
aPref = this._settings.get_double(COLOR_SATURATION_KEY);
|
||||||
|
if (aPref)
|
||||||
|
zoomRegion.setColorSaturation(aPref);
|
||||||
|
|
||||||
|
let bc = {};
|
||||||
|
bc.r = this._settings.get_double(BRIGHT_RED_KEY);
|
||||||
|
bc.g = this._settings.get_double(BRIGHT_GREEN_KEY);
|
||||||
|
bc.b = this._settings.get_double(BRIGHT_BLUE_KEY);
|
||||||
|
zoomRegion.setBrightness(bc);
|
||||||
|
|
||||||
|
bc.r = this._settings.get_double(CONTRAST_RED_KEY);
|
||||||
|
bc.g = this._settings.get_double(CONTRAST_GREEN_KEY);
|
||||||
|
bc.b = this._settings.get_double(CONTRAST_BLUE_KEY);
|
||||||
|
zoomRegion.setContrast(bc);
|
||||||
|
}
|
||||||
|
|
||||||
_settingsInitLate: function() {
|
|
||||||
let showCrosshairs = this._settings.get_boolean(SHOW_CROSS_HAIRS_KEY);
|
let showCrosshairs = this._settings.get_boolean(SHOW_CROSS_HAIRS_KEY);
|
||||||
this.addCrosshairs();
|
this.addCrosshairs();
|
||||||
this.setCrosshairsVisible(showCrosshairs);
|
this.setCrosshairsVisible(showCrosshairs);
|
||||||
|
|
||||||
|
this._appSettings.connect('changed::' + SHOW_KEY,
|
||||||
|
Lang.bind(this, function() {
|
||||||
|
this.setActive(this._appSettings.get_boolean(SHOW_KEY));
|
||||||
|
}));
|
||||||
|
|
||||||
this._settings.connect('changed::' + SCREEN_POSITION_KEY,
|
this._settings.connect('changed::' + SCREEN_POSITION_KEY,
|
||||||
Lang.bind(this, this._updateScreenPosition));
|
Lang.bind(this, this._updateScreenPosition));
|
||||||
this._settings.connect('changed::' + MAG_FACTOR_KEY,
|
this._settings.connect('changed::' + MAG_FACTOR_KEY,
|
||||||
@ -573,6 +561,7 @@ const Magnifier = new Lang.Class({
|
|||||||
Lang.bind(this, function() {
|
Lang.bind(this, function() {
|
||||||
this.setCrosshairsClip(this._settings.get_boolean(CROSS_HAIRS_CLIP_KEY));
|
this.setCrosshairsClip(this._settings.get_boolean(CROSS_HAIRS_CLIP_KEY));
|
||||||
}));
|
}));
|
||||||
|
return this._appSettings.get_boolean(SHOW_KEY);
|
||||||
},
|
},
|
||||||
|
|
||||||
_updateScreenPosition: function() {
|
_updateScreenPosition: function() {
|
||||||
@ -731,8 +720,16 @@ const ZoomRegion = new Lang.Class({
|
|||||||
let component = event.source.get_component_iface();
|
let component = event.source.get_component_iface();
|
||||||
if (!component || event.detail1 != 1)
|
if (!component || event.detail1 != 1)
|
||||||
return;
|
return;
|
||||||
let extents = component.get_extents(Atspi.CoordType.SCREEN);
|
let extents;
|
||||||
[this._xFocus, this._yFocus] = [extents.x, extents.y]
|
try {
|
||||||
|
extents = component.get_extents(Atspi.CoordType.SCREEN);
|
||||||
|
} catch(e) {
|
||||||
|
log('Failed to read extents of focused component: ' + e.message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
[this._xFocus, this._yFocus] = [extents.x + (extents.width / 2),
|
||||||
|
extents.y + (extents.height / 2)];
|
||||||
this._centerFromFocusPosition();
|
this._centerFromFocusPosition();
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -740,7 +737,14 @@ const ZoomRegion = new Lang.Class({
|
|||||||
let text = event.source.get_text_iface();
|
let text = event.source.get_text_iface();
|
||||||
if (!text)
|
if (!text)
|
||||||
return;
|
return;
|
||||||
let extents = text.get_character_extents(text.get_caret_offset(), 0);
|
let extents;
|
||||||
|
try {
|
||||||
|
extents = text.get_character_extents(text.get_caret_offset(), 0);
|
||||||
|
} catch(e) {
|
||||||
|
log('Failed to read extents of text caret: ' + e.message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
[this._xCaret, this._yCaret] = [extents.x, extents.y];
|
[this._xCaret, this._yCaret] = [extents.x, extents.y];
|
||||||
this._centerFromCaretPosition();
|
this._centerFromCaretPosition();
|
||||||
},
|
},
|
||||||
@ -763,6 +767,9 @@ const ZoomRegion = new Lang.Class({
|
|||||||
} else {
|
} else {
|
||||||
this._destroyActors();
|
this._destroyActors();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this._syncCaretTracking();
|
||||||
|
this._syncFocusTracking();
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -822,10 +829,7 @@ const ZoomRegion = new Lang.Class({
|
|||||||
*/
|
*/
|
||||||
setFocusTrackingMode: function(mode) {
|
setFocusTrackingMode: function(mode) {
|
||||||
this._focusTrackingMode = mode;
|
this._focusTrackingMode = mode;
|
||||||
if (this._focusTrackingMode == GDesktopEnums.MagnifierFocusTrackingMode.NONE)
|
this._syncFocusTracking();
|
||||||
this._focusCaretTracker.deregisterFocusListener();
|
|
||||||
else
|
|
||||||
this._focusCaretTracker.registerFocusListener();
|
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -834,10 +838,27 @@ const ZoomRegion = new Lang.Class({
|
|||||||
*/
|
*/
|
||||||
setCaretTrackingMode: function(mode) {
|
setCaretTrackingMode: function(mode) {
|
||||||
this._caretTrackingMode = mode;
|
this._caretTrackingMode = mode;
|
||||||
if (this._caretTrackingMode == GDesktopEnums.MagnifierCaretTrackingMode.NONE)
|
this._syncCaretTracking();
|
||||||
this._focusCaretTracker.deregisterCaretListener();
|
},
|
||||||
|
|
||||||
|
_syncFocusTracking: function() {
|
||||||
|
let enabled = this._focusTrackingMode != GDesktopEnums.MagnifierFocusTrackingMode.NONE &&
|
||||||
|
this.isActive();
|
||||||
|
|
||||||
|
if (enabled)
|
||||||
|
this._focusCaretTracker.registerFocusListener();
|
||||||
else
|
else
|
||||||
|
this._focusCaretTracker.deregisterFocusListener();
|
||||||
|
},
|
||||||
|
|
||||||
|
_syncCaretTracking: function() {
|
||||||
|
let enabled = this._caretTrackingMode != GDesktopEnums.MagnifierCaretTrackingMode.NONE &&
|
||||||
|
this.isActive();
|
||||||
|
|
||||||
|
if (enabled)
|
||||||
this._focusCaretTracker.registerCaretListener();
|
this._focusCaretTracker.registerCaretListener();
|
||||||
|
else
|
||||||
|
this._focusCaretTracker.deregisterCaretListener();
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1178,13 +1199,17 @@ 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 Clutter.Actor({ background_color: Main.DEFAULT_BACKGROUND_COLOR,
|
||||||
|
layout_manager: new Clutter.BinLayout(),
|
||||||
width: global.screen_width,
|
width: global.screen_width,
|
||||||
height: global.screen_height });
|
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
|
||||||
// chrome, the windows, etc.
|
// chrome, the windows, etc.
|
||||||
this._uiGroupClone = new Clutter.Clone({ source: Main.uiGroup });
|
this._uiGroupClone = new Clutter.Clone({ source: Main.uiGroup,
|
||||||
|
clip_to_allocation: true });
|
||||||
mainGroup.add_actor(this._uiGroupClone);
|
mainGroup.add_actor(this._uiGroupClone);
|
||||||
|
|
||||||
// Add either the given mouseSourceActor to the ZoomRegion, or a clone of
|
// Add either the given mouseSourceActor to the ZoomRegion, or a clone of
|
||||||
|
@ -1162,32 +1162,10 @@ const SourceActor = new Lang.Class({
|
|||||||
}));
|
}));
|
||||||
this._actorDestroyed = false;
|
this._actorDestroyed = false;
|
||||||
|
|
||||||
this._counterLabel = new St.Label({ x_align: Clutter.ActorAlign.CENTER,
|
this._iconBin = new St.Bin({ x_fill: true,
|
||||||
x_expand: true,
|
|
||||||
y_align: Clutter.ActorAlign.CENTER,
|
|
||||||
y_expand: true });
|
|
||||||
|
|
||||||
this._counterBin = new St.Bin({ style_class: 'summary-source-counter',
|
|
||||||
child: this._counterLabel,
|
|
||||||
layout_manager: new Clutter.BinLayout() });
|
|
||||||
this._counterBin.hide();
|
|
||||||
|
|
||||||
this._counterBin.connect('style-changed', Lang.bind(this, function() {
|
|
||||||
let themeNode = this._counterBin.get_theme_node();
|
|
||||||
this._counterBin.translation_x = themeNode.get_length('-shell-counter-overlap-x');
|
|
||||||
this._counterBin.translation_y = themeNode.get_length('-shell-counter-overlap-y');
|
|
||||||
}));
|
|
||||||
|
|
||||||
this._iconBin = new St.Bin({ width: size,
|
|
||||||
height: size,
|
|
||||||
x_fill: true,
|
|
||||||
y_fill: true });
|
y_fill: true });
|
||||||
|
|
||||||
this.actor.add_actor(this._iconBin);
|
this.actor.add_actor(this._iconBin);
|
||||||
this.actor.add_actor(this._counterBin);
|
|
||||||
|
|
||||||
this._source.connect('count-updated', Lang.bind(this, this._updateCount));
|
|
||||||
this._updateCount();
|
|
||||||
|
|
||||||
this._source.connect('icon-updated', Lang.bind(this, this._updateIcon));
|
this._source.connect('icon-updated', Lang.bind(this, this._updateIcon));
|
||||||
this._updateIcon();
|
this._updateIcon();
|
||||||
@ -1211,6 +1189,48 @@ const SourceActor = new Lang.Class({
|
|||||||
_allocate: function(actor, box, flags) {
|
_allocate: function(actor, box, flags) {
|
||||||
// the iconBin should fill our entire box
|
// the iconBin should fill our entire box
|
||||||
this._iconBin.allocate(box, flags);
|
this._iconBin.allocate(box, flags);
|
||||||
|
},
|
||||||
|
|
||||||
|
_updateIcon: function() {
|
||||||
|
if (this._actorDestroyed)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (!this._iconSet)
|
||||||
|
this._iconBin.child = this._source.createIcon(this._size);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
const SourceActorWithLabel = new Lang.Class({
|
||||||
|
Name: 'SourceActorWithLabel',
|
||||||
|
Extends: SourceActor,
|
||||||
|
|
||||||
|
_init: function(source, size) {
|
||||||
|
this.parent(source, size);
|
||||||
|
|
||||||
|
this._counterLabel = new St.Label({ x_align: Clutter.ActorAlign.CENTER,
|
||||||
|
x_expand: true,
|
||||||
|
y_align: Clutter.ActorAlign.CENTER,
|
||||||
|
y_expand: true });
|
||||||
|
|
||||||
|
this._counterBin = new St.Bin({ style_class: 'summary-source-counter',
|
||||||
|
child: this._counterLabel,
|
||||||
|
layout_manager: new Clutter.BinLayout() });
|
||||||
|
this._counterBin.hide();
|
||||||
|
|
||||||
|
this._counterBin.connect('style-changed', Lang.bind(this, function() {
|
||||||
|
let themeNode = this._counterBin.get_theme_node();
|
||||||
|
this._counterBin.translation_x = themeNode.get_length('-shell-counter-overlap-x');
|
||||||
|
this._counterBin.translation_y = themeNode.get_length('-shell-counter-overlap-y');
|
||||||
|
}));
|
||||||
|
|
||||||
|
this.actor.add_actor(this._counterBin);
|
||||||
|
|
||||||
|
this._source.connect('count-updated', Lang.bind(this, this._updateCount));
|
||||||
|
this._updateCount();
|
||||||
|
},
|
||||||
|
|
||||||
|
_allocate: function(actor, box, flags) {
|
||||||
|
this.parent(actor, box, flags);
|
||||||
|
|
||||||
let childBox = new Clutter.ActorBox();
|
let childBox = new Clutter.ActorBox();
|
||||||
|
|
||||||
@ -1233,14 +1253,6 @@ const SourceActor = new Lang.Class({
|
|||||||
this._counterBin.allocate(childBox, flags);
|
this._counterBin.allocate(childBox, flags);
|
||||||
},
|
},
|
||||||
|
|
||||||
_updateIcon: function() {
|
|
||||||
if (this._actorDestroyed)
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (!this._iconSet)
|
|
||||||
this._iconBin.child = this._source.createIcon(this._size);
|
|
||||||
},
|
|
||||||
|
|
||||||
_updateCount: function() {
|
_updateCount: function() {
|
||||||
if (this._actorDestroyed)
|
if (this._actorDestroyed)
|
||||||
return;
|
return;
|
||||||
@ -1353,7 +1365,7 @@ const Source = new Lang.Class({
|
|||||||
if (this._mainIcon)
|
if (this._mainIcon)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
this._mainIcon = new SourceActor(this, this.SOURCE_ICON_SIZE);
|
this._mainIcon = new SourceActorWithLabel(this, this.SOURCE_ICON_SIZE);
|
||||||
},
|
},
|
||||||
|
|
||||||
// Unlike createIcon, this always returns the same actor;
|
// Unlike createIcon, this always returns the same actor;
|
||||||
|
@ -200,8 +200,9 @@ const OsdWindow = new Lang.Class({
|
|||||||
let scale = Math.min(scalew, scaleh);
|
let scale = Math.min(scalew, scaleh);
|
||||||
this._popupSize = 110 * Math.max(1, scale);
|
this._popupSize = 110 * Math.max(1, scale);
|
||||||
|
|
||||||
|
let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor;
|
||||||
|
this._icon.icon_size = this._popupSize / (2 * scaleFactor);
|
||||||
this._box.translation_y = monitor.height / 4;
|
this._box.translation_y = monitor.height / 4;
|
||||||
this._icon.icon_size = this._popupSize / 2;
|
|
||||||
this._box.style_changed();
|
this._box.style_changed();
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -217,7 +218,10 @@ const OsdWindow = new Lang.Class({
|
|||||||
let minWidth = this._popupSize - verticalPadding - leftBorder - rightBorder;
|
let minWidth = this._popupSize - verticalPadding - leftBorder - rightBorder;
|
||||||
let minHeight = this._popupSize - horizontalPadding - topBorder - bottomBorder;
|
let minHeight = this._popupSize - horizontalPadding - topBorder - bottomBorder;
|
||||||
|
|
||||||
this._box.style = 'min-height: %dpx;'.format(Math.max(minWidth, minHeight));
|
// minWidth/minHeight here are in real pixels,
|
||||||
|
// but the theme takes measures in unscaled dimensions
|
||||||
|
let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor;
|
||||||
|
this._box.style = 'min-height: %dpx;'.format(Math.max(minWidth, minHeight) / scaleFactor);
|
||||||
},
|
},
|
||||||
|
|
||||||
setMonitor: function(index) {
|
setMonitor: function(index) {
|
||||||
|
@ -493,8 +493,13 @@ const Overview = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
fadeOutDesktop: function() {
|
fadeOutDesktop: function() {
|
||||||
if (!this._desktopFade.get_n_children())
|
if (!this._desktopFade.get_n_children()) {
|
||||||
this._desktopFade.add_child(this._getDesktopClone());
|
let clone = this._getDesktopClone();
|
||||||
|
if (!clone)
|
||||||
|
return;
|
||||||
|
|
||||||
|
this._desktopFade.add_child(clone);
|
||||||
|
}
|
||||||
|
|
||||||
this._desktopFade.opacity = 255;
|
this._desktopFade.opacity = 255;
|
||||||
this._desktopFade.show();
|
this._desktopFade.show();
|
||||||
|
@ -213,7 +213,7 @@ const AppMenuButton = new Lang.Class({
|
|||||||
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._hbox.add_actor(this._label.actor);
|
||||||
this._arrow = PopupMenu.unicodeArrow(St.Side.BOTTOM);
|
this._arrow = PopupMenu.arrowIcon(St.Side.BOTTOM);
|
||||||
this._hbox.add_actor(this._arrow);
|
this._hbox.add_actor(this._arrow);
|
||||||
|
|
||||||
this._iconBottomClip = 0;
|
this._iconBottomClip = 0;
|
||||||
@ -812,7 +812,11 @@ const AggregateMenu = new Lang.Class({
|
|||||||
this._indicators = new St.BoxLayout({ style_class: 'panel-status-indicators-box' });
|
this._indicators = new St.BoxLayout({ style_class: 'panel-status-indicators-box' });
|
||||||
this.actor.add_child(this._indicators);
|
this.actor.add_child(this._indicators);
|
||||||
|
|
||||||
this._network = new imports.ui.status.network.NMApplet();
|
if (Config.HAVE_NETWORKMANAGER) {
|
||||||
|
this._network = new imports.ui.status.network.NMApplet();
|
||||||
|
} else {
|
||||||
|
this._network = null;
|
||||||
|
}
|
||||||
if (Config.HAVE_BLUETOOTH) {
|
if (Config.HAVE_BLUETOOTH) {
|
||||||
this._bluetooth = new imports.ui.status.bluetooth.Indicator();
|
this._bluetooth = new imports.ui.status.bluetooth.Indicator();
|
||||||
} else {
|
} else {
|
||||||
@ -829,22 +833,27 @@ const AggregateMenu = new Lang.Class({
|
|||||||
|
|
||||||
this._indicators.add_child(this._screencast.indicators);
|
this._indicators.add_child(this._screencast.indicators);
|
||||||
this._indicators.add_child(this._location.indicators);
|
this._indicators.add_child(this._location.indicators);
|
||||||
this._indicators.add_child(this._network.indicators);
|
if (this._network) {
|
||||||
|
this._indicators.add_child(this._network.indicators);
|
||||||
|
}
|
||||||
if (this._bluetooth) {
|
if (this._bluetooth) {
|
||||||
this._indicators.add_child(this._bluetooth.indicators);
|
this._indicators.add_child(this._bluetooth.indicators);
|
||||||
}
|
}
|
||||||
this._indicators.add_child(this._rfkill.indicators);
|
this._indicators.add_child(this._rfkill.indicators);
|
||||||
this._indicators.add_child(this._volume.indicators);
|
this._indicators.add_child(this._volume.indicators);
|
||||||
this._indicators.add_child(this._power.indicators);
|
this._indicators.add_child(this._power.indicators);
|
||||||
this._indicators.add_child(PopupMenu.unicodeArrow(St.Side.BOTTOM));
|
this._indicators.add_child(PopupMenu.arrowIcon(St.Side.BOTTOM));
|
||||||
|
|
||||||
this.menu.addMenuItem(this._volume.menu);
|
this.menu.addMenuItem(this._volume.menu);
|
||||||
this.menu.addMenuItem(this._brightness.menu);
|
this.menu.addMenuItem(this._brightness.menu);
|
||||||
this.menu.addMenuItem(new PopupMenu.PopupSeparatorMenuItem());
|
this.menu.addMenuItem(new PopupMenu.PopupSeparatorMenuItem());
|
||||||
this.menu.addMenuItem(this._network.menu);
|
if (this._network) {
|
||||||
|
this.menu.addMenuItem(this._network.menu);
|
||||||
|
}
|
||||||
if (this._bluetooth) {
|
if (this._bluetooth) {
|
||||||
this.menu.addMenuItem(this._bluetooth.menu);
|
this.menu.addMenuItem(this._bluetooth.menu);
|
||||||
}
|
}
|
||||||
|
this.menu.addMenuItem(this._location.menu);
|
||||||
this.menu.addMenuItem(this._rfkill.menu);
|
this.menu.addMenuItem(this._rfkill.menu);
|
||||||
this.menu.addMenuItem(this._power.menu);
|
this.menu.addMenuItem(this._power.menu);
|
||||||
this.menu.addMenuItem(new PopupMenu.PopupSeparatorMenuItem());
|
this.menu.addMenuItem(new PopupMenu.PopupSeparatorMenuItem());
|
||||||
|
@ -45,28 +45,35 @@ function isPopupMenuItemVisible(child) {
|
|||||||
/**
|
/**
|
||||||
* @side Side to which the arrow points.
|
* @side Side to which the arrow points.
|
||||||
*/
|
*/
|
||||||
function unicodeArrow(side) {
|
function arrowIcon(side) {
|
||||||
let arrowChar;
|
let rotation;
|
||||||
switch (side) {
|
switch (side) {
|
||||||
case St.Side.TOP:
|
case St.Side.TOP:
|
||||||
arrowChar = '\u25B4';
|
rotation = 180;
|
||||||
break;
|
break;
|
||||||
case St.Side.RIGHT:
|
case St.Side.RIGHT:
|
||||||
arrowChar = '\u25B8';
|
rotation = - 90;
|
||||||
break;
|
break;
|
||||||
case St.Side.BOTTOM:
|
case St.Side.BOTTOM:
|
||||||
arrowChar = '\u25BE';
|
rotation = 0;
|
||||||
break;
|
break;
|
||||||
case St.Side.LEFT:
|
case St.Side.LEFT:
|
||||||
arrowChar = '\u25C2';
|
rotation = 90;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return new St.Label({ text: arrowChar,
|
let gicon = new Gio.FileIcon({ file: Gio.File.new_for_path(global.datadir +
|
||||||
style_class: 'unicode-arrow',
|
'/theme/menu-arrow-symbolic.svg') });
|
||||||
accessible_role: Atk.Role.ARROW,
|
|
||||||
y_expand: true,
|
let arrow = new St.Icon({ style_class: 'popup-menu-arrow',
|
||||||
y_align: Clutter.ActorAlign.CENTER });
|
gicon: gicon,
|
||||||
|
accessible_role: Atk.Role.ARROW,
|
||||||
|
y_expand: true,
|
||||||
|
y_align: Clutter.ActorAlign.CENTER });
|
||||||
|
|
||||||
|
arrow.rotation_angle_z = rotation;
|
||||||
|
|
||||||
|
return arrow;
|
||||||
}
|
}
|
||||||
|
|
||||||
const PopupBaseMenuItem = new Lang.Class({
|
const PopupBaseMenuItem = new Lang.Class({
|
||||||
@ -111,6 +118,7 @@ const PopupBaseMenuItem = new Lang.Class({
|
|||||||
|
|
||||||
this.actor.connect('key-focus-in', Lang.bind(this, this._onKeyFocusIn));
|
this.actor.connect('key-focus-in', Lang.bind(this, this._onKeyFocusIn));
|
||||||
this.actor.connect('key-focus-out', Lang.bind(this, this._onKeyFocusOut));
|
this.actor.connect('key-focus-out', Lang.bind(this, this._onKeyFocusOut));
|
||||||
|
this.actor.connect('destroy', Lang.bind(this, this._onDestroy));
|
||||||
},
|
},
|
||||||
|
|
||||||
_getTopMenu: function() {
|
_getTopMenu: function() {
|
||||||
@ -192,6 +200,9 @@ const PopupBaseMenuItem = new Lang.Class({
|
|||||||
|
|
||||||
destroy: function() {
|
destroy: function() {
|
||||||
this.actor.destroy();
|
this.actor.destroy();
|
||||||
|
},
|
||||||
|
|
||||||
|
_onDestroy: function() {
|
||||||
this.emit('destroy');
|
this.emit('destroy');
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -868,14 +879,14 @@ const PopupSubMenu = new Lang.Class({
|
|||||||
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._arrow_rotation = this._arrow.rotation_angle_z;
|
this.actor._arrowRotation = this._arrow.rotation_angle_z;
|
||||||
Tweener.addTween(this.actor,
|
Tweener.addTween(this.actor,
|
||||||
{ _arrow_rotation: 90,
|
{ _arrowRotation: this.actor._arrowRotation + 90,
|
||||||
height: naturalHeight,
|
height: naturalHeight,
|
||||||
time: 0.25,
|
time: 0.25,
|
||||||
onUpdateScope: this,
|
onUpdateScope: this,
|
||||||
onUpdate: function() {
|
onUpdate: function() {
|
||||||
this._arrow.rotation_angle_z = this.actor._arrow_rotation;
|
this._arrow.rotation_angle_z = this.actor._arrowRotation;
|
||||||
},
|
},
|
||||||
onCompleteScope: this,
|
onCompleteScope: this,
|
||||||
onComplete: function() {
|
onComplete: function() {
|
||||||
@ -883,7 +894,7 @@ const PopupSubMenu = new Lang.Class({
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
this._arrow.rotation_angle_z = 90;
|
this._arrow.rotation_angle_z = this.actor._arrowRotation + 90;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -901,14 +912,14 @@ const PopupSubMenu = new Lang.Class({
|
|||||||
animate = false;
|
animate = false;
|
||||||
|
|
||||||
if (animate) {
|
if (animate) {
|
||||||
this.actor._arrow_rotation = this._arrow.rotation_angle_z;
|
this.actor._arrowRotation = this._arrow.rotation_angle_z;
|
||||||
Tweener.addTween(this.actor,
|
Tweener.addTween(this.actor,
|
||||||
{ _arrow_rotation: 0,
|
{ _arrowRotation: this.actor._arrowRotation - 90,
|
||||||
height: 0,
|
height: 0,
|
||||||
time: 0.25,
|
time: 0.25,
|
||||||
onUpdateScope: this,
|
onUpdateScope: this,
|
||||||
onUpdate: function() {
|
onUpdate: function() {
|
||||||
this._arrow.rotation_angle_z = this.actor._arrow_rotation;
|
this._arrow.rotation_angle_z = this.actor._arrowRotation;
|
||||||
},
|
},
|
||||||
onCompleteScope: this,
|
onCompleteScope: this,
|
||||||
onComplete: function() {
|
onComplete: function() {
|
||||||
@ -917,7 +928,7 @@ const PopupSubMenu = new Lang.Class({
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
this._arrow.rotation_angle_z = 0;
|
this._arrow.rotation_angle_z = this.actor._arrowRotation - 90;
|
||||||
this.actor.hide();
|
this.actor.hide();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@ -989,7 +1000,7 @@ const PopupSubMenuMenuItem = new Lang.Class({
|
|||||||
y_align: Clutter.ActorAlign.CENTER });
|
y_align: Clutter.ActorAlign.CENTER });
|
||||||
this.actor.add_child(this.status);
|
this.actor.add_child(this.status);
|
||||||
|
|
||||||
this._triangle = unicodeArrow(St.Side.RIGHT);
|
this._triangle = arrowIcon(St.Side.RIGHT);
|
||||||
this._triangle.pivot_point = new Clutter.Point({ x: 0.5, y: 0.6 });
|
this._triangle.pivot_point = new Clutter.Point({ x: 0.5, y: 0.6 });
|
||||||
|
|
||||||
this._triangleBin = new St.Widget({ y_expand: true,
|
this._triangleBin = new St.Widget({ y_expand: true,
|
||||||
|
@ -10,6 +10,8 @@ const FileUtils = imports.misc.fileUtils;
|
|||||||
const Main = imports.ui.main;
|
const Main = imports.ui.main;
|
||||||
const Params = imports.misc.params;
|
const Params = imports.misc.params;
|
||||||
|
|
||||||
|
const Config = imports.misc.config;
|
||||||
|
|
||||||
const DEFAULT_MODE = 'restrictive';
|
const DEFAULT_MODE = 'restrictive';
|
||||||
|
|
||||||
const _modes = {
|
const _modes = {
|
||||||
@ -92,8 +94,12 @@ const _modes = {
|
|||||||
isLocked: false,
|
isLocked: false,
|
||||||
isPrimary: true,
|
isPrimary: true,
|
||||||
unlockDialog: imports.ui.unlockDialog.UnlockDialog,
|
unlockDialog: imports.ui.unlockDialog.UnlockDialog,
|
||||||
components: ['networkAgent', 'polkitAgent', 'telepathyClient',
|
components: Config.HAVE_NETWORKMANAGER ?
|
||||||
|
['networkAgent', 'polkitAgent', 'telepathyClient',
|
||||||
|
'keyring', 'autorunManager', 'automountManager'] :
|
||||||
|
['polkitAgent', 'telepathyClient',
|
||||||
'keyring', 'autorunManager', 'automountManager'],
|
'keyring', 'autorunManager', 'automountManager'],
|
||||||
|
|
||||||
panel: {
|
panel: {
|
||||||
left: ['activities', 'appMenu'],
|
left: ['activities', 'appMenu'],
|
||||||
center: ['dateMenu'],
|
center: ['dateMenu'],
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
|
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
|
||||||
|
|
||||||
|
const Atk = imports.gi.Atk;
|
||||||
const Cairo = imports.cairo;
|
const Cairo = imports.cairo;
|
||||||
const Clutter = imports.gi.Clutter;
|
const Clutter = imports.gi.Clutter;
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
const St = imports.gi.St;
|
const St = imports.gi.St;
|
||||||
const Signals = imports.signals;
|
const Signals = imports.signals;
|
||||||
const Atk = imports.gi.Atk;
|
|
||||||
|
|
||||||
const SLIDER_SCROLL_STEP = 0.05; /* Slider scrolling step in % */
|
const SLIDER_SCROLL_STEP = 0.05; /* Slider scrolling step in % */
|
||||||
|
|
||||||
|
@ -44,7 +44,7 @@ const ATIndicator = new Lang.Class({
|
|||||||
this._hbox = new St.BoxLayout({ style_class: 'panel-status-menu-box' });
|
this._hbox = new St.BoxLayout({ style_class: 'panel-status-menu-box' });
|
||||||
this._hbox.add_child(new St.Icon({ style_class: 'system-status-icon',
|
this._hbox.add_child(new St.Icon({ style_class: 'system-status-icon',
|
||||||
icon_name: 'preferences-desktop-accessibility-symbolic' }));
|
icon_name: 'preferences-desktop-accessibility-symbolic' }));
|
||||||
this._hbox.add_child(PopupMenu.unicodeArrow(St.Side.BOTTOM));
|
this._hbox.add_child(PopupMenu.arrowIcon(St.Side.BOTTOM));
|
||||||
|
|
||||||
this.actor.add_child(this._hbox);
|
this.actor.add_child(this._hbox);
|
||||||
|
|
||||||
|
@ -38,7 +38,10 @@ const Indicator = new Lang.Class({
|
|||||||
log(error.message);
|
log(error.message);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this._sync();
|
||||||
}));
|
}));
|
||||||
|
this._proxy.connect('g-properties-changed', Lang.bind(this, this._sync));
|
||||||
|
|
||||||
// The Bluetooth menu only appears when Bluetooth is in use,
|
// The Bluetooth menu only appears when Bluetooth is in use,
|
||||||
// so just statically build it with a "Turn Off" menu item.
|
// so just statically build it with a "Turn Off" menu item.
|
||||||
@ -90,11 +93,12 @@ const Indicator = new Lang.Class({
|
|||||||
_sync: function() {
|
_sync: function() {
|
||||||
let nDevices = this._getNConnectedDevices();
|
let nDevices = this._getNConnectedDevices();
|
||||||
|
|
||||||
let on = nDevices > 0;
|
this._indicator.visible = nDevices > 0;
|
||||||
this._indicator.visible = on;
|
this._item.actor.visible = !this._proxy.BluetoothAirplaneMode;
|
||||||
this._item.actor.visible = on;
|
|
||||||
|
|
||||||
if (on)
|
if (nDevices > 0)
|
||||||
this._item.status.text = ngettext("%d Connected Device", "%d Connected Devices", nDevices).format(nDevices);
|
this._item.status.text = ngettext("%d Connected Device", "%d Connected Devices", nDevices).format(nDevices);
|
||||||
|
else
|
||||||
|
this._item.status.text = _("Not Connected");
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
@ -341,7 +341,7 @@ const InputSourceIndicator = new Lang.Class({
|
|||||||
|
|
||||||
this._hbox = new St.BoxLayout({ style_class: 'panel-status-menu-box' });
|
this._hbox = new St.BoxLayout({ style_class: 'panel-status-menu-box' });
|
||||||
this._hbox.add_child(this._container);
|
this._hbox.add_child(this._container);
|
||||||
this._hbox.add_child(PopupMenu.unicodeArrow(St.Side.BOTTOM));
|
this._hbox.add_child(PopupMenu.arrowIcon(St.Side.BOTTOM));
|
||||||
|
|
||||||
this.actor.add_child(this._hbox);
|
this.actor.add_child(this._hbox);
|
||||||
this.actor.add_style_class_name('panel-status-button');
|
this.actor.add_style_class_name('panel-status-button');
|
||||||
|
@ -1,18 +1,40 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
||||||
|
|
||||||
|
const GLib = imports.gi.GLib;
|
||||||
const Gio = imports.gi.Gio;
|
const Gio = imports.gi.Gio;
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
|
|
||||||
|
const Shell = imports.gi.Shell;
|
||||||
const PanelMenu = imports.ui.panelMenu;
|
const PanelMenu = imports.ui.panelMenu;
|
||||||
|
const PopupMenu = imports.ui.popupMenu;
|
||||||
|
|
||||||
|
const LOCATION_SCHEMA = 'org.gnome.shell.location';
|
||||||
|
const MAX_ACCURACY_LEVEL = 'max-accuracy-level';
|
||||||
|
|
||||||
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"/> \
|
||||||
|
<property name="AvailableAccuracyLevel" type="u" access="read"/> \
|
||||||
|
<method name="AddAgent"> \
|
||||||
|
<arg name="id" type="s" direction="in"/> \
|
||||||
|
</method> \
|
||||||
</interface> \
|
</interface> \
|
||||||
</node>';
|
</node>';
|
||||||
|
|
||||||
const GeoclueManager = Gio.DBusProxy.makeProxyWrapper(GeoclueIface);
|
const GeoclueManager = Gio.DBusProxy.makeProxyWrapper(GeoclueIface);
|
||||||
|
|
||||||
|
var AgentIface = '<node> \
|
||||||
|
<interface name="org.freedesktop.GeoClue2.Agent"> \
|
||||||
|
<property name="MaxAccuracyLevel" type="u" access="read"/> \
|
||||||
|
<method name="AuthorizeApp"> \
|
||||||
|
<arg name="desktop_id" type="s" direction="in"/> \
|
||||||
|
<arg name="req_accuracy_level" type="u" direction="in"/> \
|
||||||
|
<arg name="authorized" type="b" direction="out"/> \
|
||||||
|
<arg name="allowed_accuracy_level" type="u" direction="out"/> \
|
||||||
|
</method> \
|
||||||
|
</interface> \
|
||||||
|
</node>';
|
||||||
|
|
||||||
const Indicator = new Lang.Class({
|
const Indicator = new Lang.Class({
|
||||||
Name: 'LocationIndicator',
|
Name: 'LocationIndicator',
|
||||||
Extends: PanelMenu.SystemIndicator,
|
Extends: PanelMenu.SystemIndicator,
|
||||||
@ -20,18 +42,55 @@ const Indicator = new Lang.Class({
|
|||||||
_init: function() {
|
_init: function() {
|
||||||
this.parent();
|
this.parent();
|
||||||
|
|
||||||
|
this._settings = new Gio.Settings({ schema: LOCATION_SCHEMA });
|
||||||
|
this._settings.connect('changed::' + MAX_ACCURACY_LEVEL,
|
||||||
|
Lang.bind(this, this._onMaxAccuracyLevelChanged));
|
||||||
|
|
||||||
this._indicator = this._addIndicator();
|
this._indicator = this._addIndicator();
|
||||||
this._indicator.icon_name = 'find-location-symbolic';
|
this._indicator.icon_name = 'find-location-symbolic';
|
||||||
this._sync();
|
|
||||||
|
this._item = new PopupMenu.PopupSubMenuMenuItem(_("Location"), true);
|
||||||
|
this._item.icon.icon_name = 'find-location-symbolic';
|
||||||
|
|
||||||
|
var credentials = new Gio.Credentials();
|
||||||
|
var uid = credentials.get_unix_user();
|
||||||
|
this._agent = Gio.DBusExportedObject.wrapJSObject(AgentIface, this);
|
||||||
|
this._agent.export(Gio.DBus.system,
|
||||||
|
'/org/freedesktop/GeoClue2/Agent/' + uid);
|
||||||
|
|
||||||
|
this._item.status.text = _("On");
|
||||||
|
this._onOffAction = this._item.menu.addAction(_("Turn Off"), Lang.bind(this, this._onOnOffAction));
|
||||||
|
|
||||||
|
this.menu.addMenuItem(this._item);
|
||||||
|
|
||||||
this._watchId = Gio.bus_watch_name(Gio.BusType.SYSTEM,
|
this._watchId = Gio.bus_watch_name(Gio.BusType.SYSTEM,
|
||||||
'org.freedesktop.GeoClue2',
|
'org.freedesktop.GeoClue2',
|
||||||
0,
|
0,
|
||||||
Lang.bind(this, this._onGeoclueAppeared),
|
Lang.bind(this, this._connectToGeoclue),
|
||||||
Lang.bind(this, this._onGeoclueVanished));
|
Lang.bind(this, this._onGeoclueVanished));
|
||||||
|
this._onMaxAccuracyLevelChanged();
|
||||||
|
this._connectToGeoclue();
|
||||||
},
|
},
|
||||||
|
|
||||||
_sync: function() {
|
get MaxAccuracyLevel() {
|
||||||
|
return this._getMaxAccuracyLevel();
|
||||||
|
},
|
||||||
|
|
||||||
|
// We (and geoclue) have currently no way to reliably identifying apps so
|
||||||
|
// for now, lets just authorize all apps as long as they provide a valid
|
||||||
|
// desktop ID. We also ensure they don't get more accuracy than global max.
|
||||||
|
AuthorizeApp: function(desktop_id, reqAccuracyLevel) {
|
||||||
|
var appSystem = Shell.AppSystem.get_default();
|
||||||
|
var app = appSystem.lookup_app(desktop_id + ".desktop");
|
||||||
|
if (app == null) {
|
||||||
|
return [false, 0];
|
||||||
|
}
|
||||||
|
|
||||||
|
let allowedAccuracyLevel = clamp(reqAccuracyLevel, 0, this._getMaxAccuracyLevel());
|
||||||
|
return [true, allowedAccuracyLevel];
|
||||||
|
},
|
||||||
|
|
||||||
|
_syncIndicator: function() {
|
||||||
if (this._proxy == null) {
|
if (this._proxy == null) {
|
||||||
this._indicator.visible = false;
|
this._indicator.visible = false;
|
||||||
return;
|
return;
|
||||||
@ -40,19 +99,98 @@ const Indicator = new Lang.Class({
|
|||||||
this._indicator.visible = this._proxy.InUse;
|
this._indicator.visible = this._proxy.InUse;
|
||||||
},
|
},
|
||||||
|
|
||||||
_onGeoclueAppeared: function() {
|
_connectToGeoclue: function() {
|
||||||
// FIXME: This should be done async
|
if (this._proxy != null || this._connecting)
|
||||||
this._proxy = new GeoclueManager(Gio.DBus.system,
|
return false;
|
||||||
'org.freedesktop.GeoClue2',
|
|
||||||
'/org/freedesktop/GeoClue2/Manager');
|
|
||||||
this._proxy.connect('g-properties-changed', Lang.bind(this, this._sync));
|
|
||||||
|
|
||||||
this._sync();
|
this._connecting = true;
|
||||||
|
new GeoclueManager(Gio.DBus.system,
|
||||||
|
'org.freedesktop.GeoClue2',
|
||||||
|
'/org/freedesktop/GeoClue2/Manager',
|
||||||
|
Lang.bind(this, this._onProxyReady));
|
||||||
|
return true;
|
||||||
|
},
|
||||||
|
|
||||||
|
_onProxyReady: function(proxy, error) {
|
||||||
|
if (error != null) {
|
||||||
|
log(error.message);
|
||||||
|
this._connecting = false;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
this._proxy = proxy;
|
||||||
|
this._propertiesChangedId = this._proxy.connect('g-properties-changed',
|
||||||
|
Lang.bind(this, this._onGeocluePropsChanged));
|
||||||
|
|
||||||
|
this._updateMenu();
|
||||||
|
this._syncIndicator();
|
||||||
|
|
||||||
|
this._proxy.AddAgentRemote('gnome-shell', Lang.bind(this, this._onAgentRegistered));
|
||||||
|
},
|
||||||
|
|
||||||
|
_onAgentRegistered: function(result, error) {
|
||||||
|
this._connecting = false;
|
||||||
|
this._notifyMaxAccuracyLevel();
|
||||||
|
|
||||||
|
if (error != null)
|
||||||
|
log(error.message);
|
||||||
},
|
},
|
||||||
|
|
||||||
_onGeoclueVanished: function() {
|
_onGeoclueVanished: function() {
|
||||||
|
if (this._propertiesChangedId) {
|
||||||
|
this._proxy.disconnect(this._propertiesChangedId);
|
||||||
|
this._propertiesChangedId = 0;
|
||||||
|
}
|
||||||
this._proxy = null;
|
this._proxy = null;
|
||||||
|
|
||||||
this._sync();
|
this._syncIndicator();
|
||||||
|
},
|
||||||
|
|
||||||
|
_onOnOffAction: function() {
|
||||||
|
if (this._getMaxAccuracyLevel() == 0)
|
||||||
|
this._settings.set_enum(MAX_ACCURACY_LEVEL, this._availableAccuracyLevel);
|
||||||
|
else
|
||||||
|
this._settings.set_enum(MAX_ACCURACY_LEVEL, 0);
|
||||||
|
},
|
||||||
|
|
||||||
|
_onMaxAccuracyLevelChanged: function() {
|
||||||
|
if (this._getMaxAccuracyLevel() == 0) {
|
||||||
|
this._item.status.text = _("Off");
|
||||||
|
this._onOffAction.label.text = _("Turn On");
|
||||||
|
} else {
|
||||||
|
this._item.status.text = _("On");
|
||||||
|
this._onOffAction.label.text = _("Turn Off");
|
||||||
|
}
|
||||||
|
|
||||||
|
// Gotta ensure geoclue is up and we are registered as agent to it
|
||||||
|
// before we emit the notify for this property change.
|
||||||
|
if (!this._connectToGeoclue())
|
||||||
|
this._notifyMaxAccuracyLevel();
|
||||||
|
},
|
||||||
|
|
||||||
|
_getMaxAccuracyLevel: function() {
|
||||||
|
return this._settings.get_enum(MAX_ACCURACY_LEVEL);
|
||||||
|
},
|
||||||
|
|
||||||
|
_notifyMaxAccuracyLevel: function() {
|
||||||
|
let variant = new GLib.Variant('u', this._getMaxAccuracyLevel());
|
||||||
|
this._agent.emit_property_changed('MaxAccuracyLevel', variant);
|
||||||
|
},
|
||||||
|
|
||||||
|
_updateMenu: function() {
|
||||||
|
this._availableAccuracyLevel = this._proxy.AvailableAccuracyLevel;
|
||||||
|
this.menu.actor.visible = (this._availableAccuracyLevel != 0);
|
||||||
|
},
|
||||||
|
|
||||||
|
_onGeocluePropsChanged: function(proxy, properties) {
|
||||||
|
let unpacked = properties.deep_unpack();
|
||||||
|
if ("InUse" in unpacked)
|
||||||
|
this._syncIndicator();
|
||||||
|
if ("AvailableAccuracyLevel" in unpacked)
|
||||||
|
this._updateMenu();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
function clamp(value, min, max) {
|
||||||
|
return Math.max(min, Math.min(max, value));
|
||||||
|
}
|
||||||
|
@ -9,14 +9,17 @@ const NetworkManager = imports.gi.NetworkManager;
|
|||||||
const NMClient = imports.gi.NMClient;
|
const NMClient = imports.gi.NMClient;
|
||||||
const NMGtk = imports.gi.NMGtk;
|
const NMGtk = imports.gi.NMGtk;
|
||||||
const Signals = imports.signals;
|
const Signals = imports.signals;
|
||||||
|
const Shell = imports.gi.Shell;
|
||||||
const St = imports.gi.St;
|
const St = imports.gi.St;
|
||||||
|
|
||||||
|
const Animation = imports.ui.animation;
|
||||||
const Main = imports.ui.main;
|
const Main = imports.ui.main;
|
||||||
const PanelMenu = imports.ui.panelMenu;
|
const PanelMenu = imports.ui.panelMenu;
|
||||||
const PopupMenu = imports.ui.popupMenu;
|
const PopupMenu = imports.ui.popupMenu;
|
||||||
const MessageTray = imports.ui.messageTray;
|
const MessageTray = imports.ui.messageTray;
|
||||||
const ModalDialog = imports.ui.modalDialog;
|
const ModalDialog = imports.ui.modalDialog;
|
||||||
const ModemManager = imports.misc.modemManager;
|
const ModemManager = imports.misc.modemManager;
|
||||||
|
const Rfkill = imports.ui.status.rfkill;
|
||||||
const Util = imports.misc.util;
|
const Util = imports.misc.util;
|
||||||
|
|
||||||
const NMConnectionCategory = {
|
const NMConnectionCategory = {
|
||||||
@ -102,18 +105,34 @@ const NMConnectionItem = new Lang.Class({
|
|||||||
this._activeConnection = null;
|
this._activeConnection = null;
|
||||||
this._activeConnectionChangedId = 0;
|
this._activeConnectionChangedId = 0;
|
||||||
|
|
||||||
|
this._buildUI();
|
||||||
|
this._sync();
|
||||||
|
},
|
||||||
|
|
||||||
|
_buildUI: function() {
|
||||||
this.labelItem = new PopupMenu.PopupMenuItem('');
|
this.labelItem = new PopupMenu.PopupMenuItem('');
|
||||||
this.labelItem.connect('activate', Lang.bind(this, this._toggle));
|
this.labelItem.connect('activate', Lang.bind(this, this._toggle));
|
||||||
|
|
||||||
this.switchItem = new PopupMenu.PopupSwitchMenuItem(connection.get_id(), false);
|
this.radioItem = new PopupMenu.PopupMenuItem(this._connection.get_id(), false);
|
||||||
this.switchItem.connect('toggled', Lang.bind(this, this._toggle));
|
this.radioItem.connect('activate', Lang.bind(this, this._activate));
|
||||||
|
|
||||||
this._sync();
|
|
||||||
},
|
},
|
||||||
|
|
||||||
destroy: function() {
|
destroy: function() {
|
||||||
this.labelItem.destroy();
|
this.labelItem.destroy();
|
||||||
this.switchItem.destroy();
|
this.radioItem.destroy();
|
||||||
|
},
|
||||||
|
|
||||||
|
updateForConnection: function(connection) {
|
||||||
|
// connection should always be the same object
|
||||||
|
// (and object path) as this._connection, but
|
||||||
|
// this can be false if NetworkManager was restarted
|
||||||
|
// and picked up connections in a different order
|
||||||
|
// Just to be safe, we set it here again
|
||||||
|
|
||||||
|
this._connection = connection;
|
||||||
|
this.radioItem.label.text = connection.get_id();
|
||||||
|
this._sync();
|
||||||
|
this.emit('name-changed');
|
||||||
},
|
},
|
||||||
|
|
||||||
getName: function() {
|
getName: function() {
|
||||||
@ -129,9 +148,8 @@ const NMConnectionItem = new Lang.Class({
|
|||||||
|
|
||||||
_sync: function() {
|
_sync: function() {
|
||||||
let isActive = this.isActive();
|
let isActive = this.isActive();
|
||||||
this.labelItem.label.text = isActive ? _("Turn Off") : _("Connect");
|
this.labelItem.label.text = isActive ? _("Turn Off") : this._section.getConnectLabel();
|
||||||
this.switchItem.setToggleState(isActive);
|
this.radioItem.setOrnament(isActive ? PopupMenu.Ornament.DOT : PopupMenu.Ornament.NONE);
|
||||||
this.switchItem.setStatus(this._getStatus());
|
|
||||||
this.emit('icon-changed');
|
this.emit('icon-changed');
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -144,8 +162,11 @@ const NMConnectionItem = new Lang.Class({
|
|||||||
this._sync();
|
this._sync();
|
||||||
},
|
},
|
||||||
|
|
||||||
_getStatus: function() {
|
_activate: function() {
|
||||||
return null;
|
if (this._activeConnection == null)
|
||||||
|
this._section.activateConnection(this._connection);
|
||||||
|
|
||||||
|
this._sync();
|
||||||
},
|
},
|
||||||
|
|
||||||
_connectionStateChanged: function(ac, newstate, reason) {
|
_connectionStateChanged: function(ac, newstate, reason) {
|
||||||
@ -180,11 +201,11 @@ const NMConnectionSection = new Lang.Class({
|
|||||||
this._connections = [];
|
this._connections = [];
|
||||||
|
|
||||||
this._labelSection = new PopupMenu.PopupMenuSection();
|
this._labelSection = new PopupMenu.PopupMenuSection();
|
||||||
this._switchSection = new PopupMenu.PopupMenuSection();
|
this._radioSection = new PopupMenu.PopupMenuSection();
|
||||||
|
|
||||||
this.item = new PopupMenu.PopupSubMenuMenuItem('', true);
|
this.item = new PopupMenu.PopupSubMenuMenuItem('', true);
|
||||||
this.item.menu.addMenuItem(this._labelSection);
|
this.item.menu.addMenuItem(this._labelSection);
|
||||||
this.item.menu.addMenuItem(this._switchSection);
|
this.item.menu.addMenuItem(this._radioSection);
|
||||||
|
|
||||||
this.connect('icon-changed', Lang.bind(this, this._sync));
|
this.connect('icon-changed', Lang.bind(this, this._sync));
|
||||||
},
|
},
|
||||||
@ -196,7 +217,7 @@ const NMConnectionSection = new Lang.Class({
|
|||||||
_sync: function() {
|
_sync: function() {
|
||||||
let nItems = this._connectionItems.size;
|
let nItems = this._connectionItems.size;
|
||||||
|
|
||||||
this._switchSection.actor.visible = (nItems > 1);
|
this._radioSection.actor.visible = (nItems > 1);
|
||||||
this._labelSection.actor.visible = (nItems == 1);
|
this._labelSection.actor.visible = (nItems == 1);
|
||||||
|
|
||||||
this.item.status.text = this._getStatus();
|
this.item.status.text = this._getStatus();
|
||||||
@ -211,6 +232,10 @@ const NMConnectionSection = new Lang.Class({
|
|||||||
this.item.label.text = '';
|
this.item.label.text = '';
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_getMenuIcon: function() {
|
||||||
|
return this.getIndicatorIcon();
|
||||||
|
},
|
||||||
|
|
||||||
_getStatus: function() {
|
_getStatus: function() {
|
||||||
let values = this._connectionItems.values();
|
let values = this._connectionItems.values();
|
||||||
for (let item of values) {
|
for (let item of values) {
|
||||||
@ -221,8 +246,8 @@ const NMConnectionSection = new Lang.Class({
|
|||||||
return _("Off");
|
return _("Off");
|
||||||
},
|
},
|
||||||
|
|
||||||
_hasConnection: function(connection) {
|
getConnectLabel: function() {
|
||||||
return this._connectionItems.has(connection.get_uuid());
|
return _("Connect");
|
||||||
},
|
},
|
||||||
|
|
||||||
_connectionValid: function(connection) {
|
_connectionValid: function(connection) {
|
||||||
@ -230,10 +255,7 @@ const NMConnectionSection = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_connectionSortFunction: function(one, two) {
|
_connectionSortFunction: function(one, two) {
|
||||||
if (one._timestamp == two._timestamp)
|
return GLib.utf8_collate(one.get_id(), two.get_id());
|
||||||
return GLib.utf8_collate(one.get_id(), two.get_id());
|
|
||||||
|
|
||||||
return two._timestamp - one._timestamp;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_makeConnectionItem: function(connection) {
|
_makeConnectionItem: function(connection) {
|
||||||
@ -244,10 +266,20 @@ const NMConnectionSection = new Lang.Class({
|
|||||||
if (!this._connectionValid(connection))
|
if (!this._connectionValid(connection))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (this._hasConnection(connection))
|
// This function is called everytime connection is added or updated
|
||||||
return;
|
// In the usual case, we already added this connection and UUID
|
||||||
|
// didn't change. So we need to check if we already have an item,
|
||||||
|
// and update it for properties in the connection that changed
|
||||||
|
// (the only one we care about is the name)
|
||||||
|
// But it's also possible we didn't know about this connection
|
||||||
|
// (eg, during coldplug, or because it was updated and suddenly
|
||||||
|
// it's valid for this device), in which case we add a new item
|
||||||
|
|
||||||
this._addConnection(connection);
|
let item = this._connectionItems.get(connection.get_uuid());
|
||||||
|
if (item)
|
||||||
|
item.updateForConnection(connection);
|
||||||
|
else
|
||||||
|
this._addConnection(connection);
|
||||||
},
|
},
|
||||||
|
|
||||||
_addConnection: function(connection) {
|
_addConnection: function(connection) {
|
||||||
@ -261,10 +293,11 @@ const NMConnectionSection = new Lang.Class({
|
|||||||
item.connect('activation-failed', Lang.bind(this, function(item, reason) {
|
item.connect('activation-failed', Lang.bind(this, function(item, reason) {
|
||||||
this.emit('activation-failed', reason);
|
this.emit('activation-failed', reason);
|
||||||
}));
|
}));
|
||||||
|
item.connect('name-changed', Lang.bind(this, this._sync));
|
||||||
|
|
||||||
let pos = Util.insertSorted(this._connections, connection, Lang.bind(this, this._connectionSortFunction));
|
let pos = Util.insertSorted(this._connections, connection, Lang.bind(this, this._connectionSortFunction));
|
||||||
this._labelSection.addMenuItem(item.labelItem, pos);
|
this._labelSection.addMenuItem(item.labelItem, pos);
|
||||||
this._switchSection.addMenuItem(item.switchItem, pos);
|
this._radioSection.addMenuItem(item.radioItem, pos);
|
||||||
this._connectionItems.set(connection.get_uuid(), item);
|
this._connectionItems.set(connection.get_uuid(), item);
|
||||||
this._sync();
|
this._sync();
|
||||||
},
|
},
|
||||||
@ -292,11 +325,19 @@ const NMConnectionDevice = new Lang.Class({
|
|||||||
this._settings = settings;
|
this._settings = settings;
|
||||||
|
|
||||||
this._autoConnectItem = this.item.menu.addAction(_("Connect"), Lang.bind(this, this._autoConnect));
|
this._autoConnectItem = this.item.menu.addAction(_("Connect"), Lang.bind(this, this._autoConnect));
|
||||||
|
this._deactivateItem = this._radioSection.addAction(_("Turn Off"), Lang.bind(this, this.deactivateConnection));
|
||||||
|
|
||||||
this._stateChangedId = this._device.connect('state-changed', Lang.bind(this, this._deviceStateChanged));
|
this._stateChangedId = this._device.connect('state-changed', Lang.bind(this, this._deviceStateChanged));
|
||||||
this._activeConnectionChangedId = this._device.connect('notify::active-connection', Lang.bind(this, this._activeConnectionChanged));
|
this._activeConnectionChangedId = this._device.connect('notify::active-connection', Lang.bind(this, this._activeConnectionChanged));
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_canReachInternet: function() {
|
||||||
|
if (this._client.primary_connection != this._device.active_connection)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
return this._client.connectivity == NetworkManager.ConnectivityState.FULL;
|
||||||
|
},
|
||||||
|
|
||||||
_autoConnect: function() {
|
_autoConnect: function() {
|
||||||
let connection = new NetworkManager.Connection();
|
let connection = new NetworkManager.Connection();
|
||||||
this._client.add_and_activate_connection(connection, this._device, null, null);
|
this._client.add_and_activate_connection(connection, this._device, null, null);
|
||||||
@ -371,6 +412,7 @@ const NMConnectionDevice = new Lang.Class({
|
|||||||
_sync: function() {
|
_sync: function() {
|
||||||
let nItems = this._connectionItems.size;
|
let nItems = this._connectionItems.size;
|
||||||
this._autoConnectItem.actor.visible = (nItems == 0);
|
this._autoConnectItem.actor.visible = (nItems == 0);
|
||||||
|
this._deactivateItem.actor.visible = this._device.state > NetworkManager.DeviceState.DISCONNECTED;
|
||||||
this.parent();
|
this.parent();
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -430,33 +472,33 @@ const NMDeviceWired = new Lang.Class({
|
|||||||
this.item.menu.addMenuItem(createSettingsAction(_("Wired Settings"), device));
|
this.item.menu.addMenuItem(createSettingsAction(_("Wired Settings"), device));
|
||||||
},
|
},
|
||||||
|
|
||||||
_isConnected: function() {
|
_hasCarrier: function() {
|
||||||
if (!this._device.active_connection)
|
if (this._device instanceof NMClient.DeviceEthernet)
|
||||||
return false;
|
return this._device.carrier;
|
||||||
|
else
|
||||||
let state = this._device.active_connection.state;
|
return true;
|
||||||
return state >= NetworkManager.ActiveConnectionState.ACTIVATING;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_sync: function() {
|
_sync: function() {
|
||||||
this.item.actor.visible = this._isConnected();
|
this.item.actor.visible = this._hasCarrier();
|
||||||
this.parent();
|
this.parent();
|
||||||
},
|
},
|
||||||
|
|
||||||
_getMenuIcon: function() {
|
|
||||||
if (this._device.active_connection)
|
|
||||||
return this.getIndicatorIcon();
|
|
||||||
else
|
|
||||||
return 'network-wired-disconnected-symbolic';
|
|
||||||
},
|
|
||||||
|
|
||||||
getIndicatorIcon: function() {
|
getIndicatorIcon: function() {
|
||||||
let state = this._device.active_connection.state;
|
if (this._device.active_connection) {
|
||||||
if (state == NetworkManager.ActiveConnectionState.ACTIVATING)
|
let state = this._device.active_connection.state;
|
||||||
return 'network-wired-acquiring-symbolic';
|
|
||||||
else if (state == NetworkManager.ActiveConnectionState.ACTIVATED)
|
if (state == NetworkManager.ActiveConnectionState.ACTIVATING) {
|
||||||
return 'network-wired-symbolic';
|
return 'network-wired-acquiring-symbolic';
|
||||||
else
|
} else if (state == NetworkManager.ActiveConnectionState.ACTIVATED) {
|
||||||
|
if (this._canReachInternet())
|
||||||
|
return 'network-wired-symbolic';
|
||||||
|
else
|
||||||
|
return 'network-wired-no-route-symbolic';
|
||||||
|
} else {
|
||||||
|
return 'network-wired-disconnected-symbolic';
|
||||||
|
}
|
||||||
|
} else
|
||||||
return 'network-wired-disconnected-symbolic';
|
return 'network-wired-disconnected-symbolic';
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -523,28 +565,20 @@ const NMDeviceModem = new Lang.Class({
|
|||||||
return this.parent();
|
return this.parent();
|
||||||
},
|
},
|
||||||
|
|
||||||
_getMenuIcon: function() {
|
getIndicatorIcon: function() {
|
||||||
if (this._device.active_connection)
|
if (this._device.active_connection) {
|
||||||
return this.getIndicatorIcon();
|
if (this._device.active_connection.state == NetworkManager.ActiveConnectionState.ACTIVATING)
|
||||||
else
|
return 'network-cellular-acquiring-symbolic';
|
||||||
|
|
||||||
|
return this._getSignalIcon();
|
||||||
|
} else {
|
||||||
return 'network-cellular-signal-none-symbolic';
|
return 'network-cellular-signal-none-symbolic';
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_getSignalIcon: function() {
|
_getSignalIcon: function() {
|
||||||
return 'network-cellular-signal-' + signalToIcon(this._mobileDevice.signal_quality) + '-symbolic';
|
return 'network-cellular-signal-' + signalToIcon(this._mobileDevice.signal_quality) + '-symbolic';
|
||||||
},
|
},
|
||||||
|
|
||||||
getIndicatorIcon: function() {
|
|
||||||
if (this._device.active_connection.state == NetworkManager.ActiveConnectionState.ACTIVATING)
|
|
||||||
return 'network-cellular-acquiring-symbolic';
|
|
||||||
|
|
||||||
if (!this._mobileDevice) {
|
|
||||||
// this can happen for bluetooth in PAN mode
|
|
||||||
return 'network-cellular-connected-symbolic';
|
|
||||||
}
|
|
||||||
|
|
||||||
return this._getSignalIcon();
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
const NMDeviceBluetooth = new Lang.Class({
|
const NMDeviceBluetooth = new Lang.Class({
|
||||||
@ -558,21 +592,26 @@ const NMDeviceBluetooth = new Lang.Class({
|
|||||||
this.item.menu.addMenuItem(createSettingsAction(_("Mobile Broadband Settings"), device));
|
this.item.menu.addMenuItem(createSettingsAction(_("Mobile Broadband Settings"), device));
|
||||||
},
|
},
|
||||||
|
|
||||||
_getMenuIcon: function() {
|
_getDescription: function() {
|
||||||
if (this._device.active_connection)
|
return this._device.name;
|
||||||
return this.getIndicatorIcon();
|
},
|
||||||
else
|
|
||||||
return 'network-cellular-signal-none-symbolic';
|
getConnectLabel: function() {
|
||||||
|
return _("Use as Internet connection");
|
||||||
},
|
},
|
||||||
|
|
||||||
getIndicatorIcon: function() {
|
getIndicatorIcon: function() {
|
||||||
let state = this._device.active_connection.state;
|
if (this._device.active_connection) {
|
||||||
if (state == NetworkManager.ActiveConnectionState.ACTIVATING)
|
let state = this._device.active_connection.state;
|
||||||
return 'network-cellular-acquiring-symbolic';
|
if (state == NetworkManager.ActiveConnectionState.ACTIVATING)
|
||||||
else if (state == NetworkManager.ActiveConnectionState.ACTIVATED)
|
return 'network-cellular-acquiring-symbolic';
|
||||||
return 'network-cellular-connected-symbolic';
|
else if (state == NetworkManager.ActiveConnectionState.ACTIVATED)
|
||||||
else
|
return 'network-cellular-connected-symbolic';
|
||||||
|
else
|
||||||
|
return 'network-cellular-signal-none-symbolic';
|
||||||
|
} else {
|
||||||
return 'network-cellular-signal-none-symbolic';
|
return 'network-cellular-signal-none-symbolic';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -645,16 +684,26 @@ const NMWirelessDialog = new Lang.Class({
|
|||||||
Name: 'NMWirelessDialog',
|
Name: 'NMWirelessDialog',
|
||||||
Extends: ModalDialog.ModalDialog,
|
Extends: ModalDialog.ModalDialog,
|
||||||
|
|
||||||
_init: function(client, device) {
|
_init: function(client, device, settings) {
|
||||||
this.parent({ styleClass: 'nm-dialog' });
|
this.parent({ styleClass: 'nm-dialog' });
|
||||||
|
|
||||||
this._client = client;
|
this._client = client;
|
||||||
this._device = device;
|
this._device = device;
|
||||||
|
|
||||||
|
this._wirelessEnabledChangedId = this._client.connect('notify::wireless-enabled',
|
||||||
|
Lang.bind(this, this._syncView));
|
||||||
|
|
||||||
|
this._rfkill = Rfkill.getRfkillManager();
|
||||||
|
this._airplaneModeChangedId = this._rfkill.connect('airplane-mode-changed',
|
||||||
|
Lang.bind(this, this._syncView));
|
||||||
|
|
||||||
this._networks = [];
|
this._networks = [];
|
||||||
this._buildLayout();
|
this._buildLayout();
|
||||||
|
|
||||||
this._connections = device.get_available_connections();
|
let connections = settings.list_connections();
|
||||||
|
this._connections = connections.filter(Lang.bind(this, function(connection) {
|
||||||
|
return device.connection_valid(connection);
|
||||||
|
}));
|
||||||
|
|
||||||
this._apAddedId = device.connect('access-point-added', Lang.bind(this, this._accessPointAdded));
|
this._apAddedId = device.connect('access-point-added', Lang.bind(this, this._accessPointAdded));
|
||||||
this._apRemovedId = device.connect('access-point-removed', Lang.bind(this, this._accessPointRemoved));
|
this._apRemovedId = device.connect('access-point-removed', Lang.bind(this, this._accessPointRemoved));
|
||||||
@ -669,6 +718,12 @@ const NMWirelessDialog = new Lang.Class({
|
|||||||
this._selectedNetwork = null;
|
this._selectedNetwork = null;
|
||||||
this._activeApChanged();
|
this._activeApChanged();
|
||||||
this._updateSensitivity();
|
this._updateSensitivity();
|
||||||
|
this._syncView();
|
||||||
|
|
||||||
|
if (accessPoints.length == 0) {
|
||||||
|
/* If there are no visible access points, request a scan */
|
||||||
|
this._device.request_scan_simple(null);
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
destroy: function() {
|
destroy: function() {
|
||||||
@ -684,6 +739,14 @@ const NMWirelessDialog = new Lang.Class({
|
|||||||
GObject.Object.prototype.disconnect.call(this._device, this._activeApChangedId);
|
GObject.Object.prototype.disconnect.call(this._device, this._activeApChangedId);
|
||||||
this._activeApChangedId = 0;
|
this._activeApChangedId = 0;
|
||||||
}
|
}
|
||||||
|
if (this._wirelessEnabledChangedId) {
|
||||||
|
this._client.disconnect(this._wirelessEnabledChangedId);
|
||||||
|
this._wirelessEnabledChangedId = 0;
|
||||||
|
}
|
||||||
|
if (this._airplaneModeChangedId) {
|
||||||
|
this._rfkill.disconnect(this._airplaneModeChangedId);
|
||||||
|
this._airplaneModeChangedId = 0;
|
||||||
|
}
|
||||||
|
|
||||||
this.parent();
|
this.parent();
|
||||||
},
|
},
|
||||||
@ -705,13 +768,44 @@ const NMWirelessDialog = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_updateSensitivity: function() {
|
_updateSensitivity: function() {
|
||||||
let connectSensitive = this._selectedNetwork && (this._selectedNetwork != this._activeNetwork);
|
let connectSensitive = this._client.wireless_enabled && this._selectedNetwork && (this._selectedNetwork != this._activeNetwork);
|
||||||
this._connectButton.reactive = connectSensitive;
|
this._connectButton.reactive = connectSensitive;
|
||||||
this._connectButton.can_focus = connectSensitive;
|
this._connectButton.can_focus = connectSensitive;
|
||||||
},
|
},
|
||||||
|
|
||||||
_updateVisibility: function() {
|
_syncView: function() {
|
||||||
this._noNetworksLabel.visible = (this._networks.length == 0);
|
if (this._rfkill.airplaneMode) {
|
||||||
|
this._airplaneBox.show();
|
||||||
|
|
||||||
|
this._airplaneIcon.icon_name = 'airplane-mode-symbolic';
|
||||||
|
this._airplaneHeadline.text = _("Airplane Mode is On");
|
||||||
|
this._airplaneText.text = _("Wi-Fi is disabled when airplane mode is on.");
|
||||||
|
this._airplaneButton.label = _("Turn Off Airplane Mode");
|
||||||
|
|
||||||
|
this._airplaneButton.visible = !this._rfkill.hwAirplaneMode;
|
||||||
|
this._airplaneInactive.visible = this._rfkill.hwAirplaneMode;
|
||||||
|
this._noNetworksBox.hide();
|
||||||
|
} else if (!this._client.wireless_enabled) {
|
||||||
|
this._airplaneBox.show();
|
||||||
|
|
||||||
|
this._airplaneIcon.icon_name = 'dialog-information-symbolic';
|
||||||
|
this._airplaneHeadline.text = _("Wi-Fi is Off");
|
||||||
|
this._airplaneText.text = _("Wi-Fi needs to be turned on in order to connect to a network.");
|
||||||
|
this._airplaneButton.label = _("Turn On Wi-Fi");
|
||||||
|
|
||||||
|
this._airplaneButton.show();
|
||||||
|
this._airplaneInactive.hide();
|
||||||
|
this._noNetworksBox.hide();
|
||||||
|
} else {
|
||||||
|
this._airplaneBox.hide();
|
||||||
|
|
||||||
|
this._noNetworksBox.visible = (this._networks.length == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this._noNetworksBox.visible)
|
||||||
|
this._noNetworksSpinner.play();
|
||||||
|
else
|
||||||
|
this._noNetworksSpinner.stop();
|
||||||
},
|
},
|
||||||
|
|
||||||
_buildLayout: function() {
|
_buildLayout: function() {
|
||||||
@ -745,11 +839,43 @@ const NMWirelessDialog = new Lang.Class({
|
|||||||
this._scrollView.add_actor(this._itemBox);
|
this._scrollView.add_actor(this._itemBox);
|
||||||
this._stack.add_child(this._scrollView);
|
this._stack.add_child(this._scrollView);
|
||||||
|
|
||||||
this._noNetworksLabel = new St.Label({ style_class: 'no-networks-label',
|
this._noNetworksBox = new St.BoxLayout({ vertical: true,
|
||||||
|
style_class: 'no-networks-box',
|
||||||
|
x_align: Clutter.ActorAlign.CENTER,
|
||||||
|
y_align: Clutter.ActorAlign.CENTER });
|
||||||
|
|
||||||
|
this._noNetworksSpinner = new Animation.AnimatedIcon(global.datadir + '/theme/process-working.svg', 24, 24);
|
||||||
|
this._noNetworksBox.add_actor(this._noNetworksSpinner.actor);
|
||||||
|
this._noNetworksBox.add_actor(new St.Label({ style_class: 'no-networks-label',
|
||||||
|
text: _("No Networks") }));
|
||||||
|
this._stack.add_child(this._noNetworksBox);
|
||||||
|
|
||||||
|
this._airplaneBox = new St.BoxLayout({ vertical: true,
|
||||||
|
style_class: 'nm-dialog-airplane-box',
|
||||||
x_align: Clutter.ActorAlign.CENTER,
|
x_align: Clutter.ActorAlign.CENTER,
|
||||||
y_align: Clutter.ActorAlign.CENTER,
|
y_align: Clutter.ActorAlign.CENTER });
|
||||||
text: _("No Networks") });
|
this._airplaneIcon = new St.Icon({ icon_size: 48 });
|
||||||
this._stack.add_child(this._noNetworksLabel);
|
this._airplaneHeadline = new St.Label({ style_class: 'nm-dialog-airplane-headline' });
|
||||||
|
this._airplaneText = new St.Label({ style_class: 'nm-dialog-airplane-text' });
|
||||||
|
|
||||||
|
let airplaneSubStack = new St.Widget({ layout_manager: new Clutter.BinLayout });
|
||||||
|
this._airplaneButton = new St.Button({ style_class: 'modal-dialog-button' });
|
||||||
|
this._airplaneButton.connect('clicked', Lang.bind(this, function() {
|
||||||
|
if (this._rfkill.airplaneMode)
|
||||||
|
this._rfkill.airplaneMode = false;
|
||||||
|
else
|
||||||
|
this._client.wireless_enabled = true;
|
||||||
|
}));
|
||||||
|
airplaneSubStack.add_actor(this._airplaneButton);
|
||||||
|
this._airplaneInactive = new St.Label({ style_class: 'nm-dialog-airplane-text',
|
||||||
|
text: _("Use hardware switch to turn off") });
|
||||||
|
airplaneSubStack.add_actor(this._airplaneInactive);
|
||||||
|
|
||||||
|
this._airplaneBox.add(this._airplaneIcon, { x_align: St.Align.MIDDLE });
|
||||||
|
this._airplaneBox.add(this._airplaneHeadline, { x_align: St.Align.MIDDLE });
|
||||||
|
this._airplaneBox.add(this._airplaneText, { x_align: St.Align.MIDDLE });
|
||||||
|
this._airplaneBox.add(airplaneSubStack, { x_align: St.Align.MIDDLE });
|
||||||
|
this._stack.add_child(this._airplaneBox);
|
||||||
|
|
||||||
this.contentLayout.add(this._stack, { expand: true });
|
this.contentLayout.add(this._stack, { expand: true });
|
||||||
|
|
||||||
@ -942,7 +1068,7 @@ const NMWirelessDialog = new Lang.Class({
|
|||||||
this._itemBox.insert_child_at_index(network.item.actor, newPos);
|
this._itemBox.insert_child_at_index(network.item.actor, newPos);
|
||||||
}
|
}
|
||||||
|
|
||||||
this._updateVisibility();
|
this._syncView();
|
||||||
},
|
},
|
||||||
|
|
||||||
_accessPointRemoved: function(device, accessPoint) {
|
_accessPointRemoved: function(device, accessPoint) {
|
||||||
@ -957,14 +1083,14 @@ const NMWirelessDialog = new Lang.Class({
|
|||||||
network.accessPoints.splice(res.ap, 1);
|
network.accessPoints.splice(res.ap, 1);
|
||||||
|
|
||||||
if (network.accessPoints.length == 0) {
|
if (network.accessPoints.length == 0) {
|
||||||
network.item.destroy();
|
network.item.actor.destroy();
|
||||||
this._networks.splice(res.network, 1);
|
this._networks.splice(res.network, 1);
|
||||||
} else {
|
} else {
|
||||||
network.item.updateBestAP(network.accessPoints[0]);
|
network.item.updateBestAP(network.accessPoints[0]);
|
||||||
this._resortItems();
|
this._resortItems();
|
||||||
}
|
}
|
||||||
|
|
||||||
this._updateVisibility();
|
this._syncView();
|
||||||
},
|
},
|
||||||
|
|
||||||
_resortItems: function() {
|
_resortItems: function() {
|
||||||
@ -1004,9 +1130,10 @@ const NMDeviceWireless = new Lang.Class({
|
|||||||
Name: 'NMDeviceWireless',
|
Name: 'NMDeviceWireless',
|
||||||
category: NMConnectionCategory.WIRELESS,
|
category: NMConnectionCategory.WIRELESS,
|
||||||
|
|
||||||
_init: function(client, device) {
|
_init: function(client, device, settings) {
|
||||||
this._client = client;
|
this._client = client;
|
||||||
this._device = device;
|
this._device = device;
|
||||||
|
this._settings = settings;
|
||||||
|
|
||||||
this._description = '';
|
this._description = '';
|
||||||
|
|
||||||
@ -1074,7 +1201,7 @@ const NMDeviceWireless = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_showDialog: function() {
|
_showDialog: function() {
|
||||||
this._dialog = new NMWirelessDialog(this._client, this._device);
|
this._dialog = new NMWirelessDialog(this._client, this._device, this._settings);
|
||||||
this._dialog.connect('closed', Lang.bind(this, this._dialogClosed));
|
this._dialog.connect('closed', Lang.bind(this, this._dialogClosed));
|
||||||
this._dialog.open();
|
this._dialog.open();
|
||||||
},
|
},
|
||||||
@ -1121,7 +1248,12 @@ const NMDeviceWireless = new Lang.Class({
|
|||||||
_getStatus: function() {
|
_getStatus: function() {
|
||||||
let ap = this._device.active_access_point;
|
let ap = this._device.active_access_point;
|
||||||
|
|
||||||
if (ap)
|
if (this._isHotSpotMaster())
|
||||||
|
return _("Hotspot Active");
|
||||||
|
else if (this._device.state >= NetworkManager.DeviceState.PREPARE &&
|
||||||
|
this._device.state < NetworkManager.DeviceState.ACTIVATED)
|
||||||
|
return _("Connecting");
|
||||||
|
else if (ap)
|
||||||
return ssidToLabel(ap.get_ssid());
|
return ssidToLabel(ap.get_ssid());
|
||||||
else if (!this._client.wireless_hardware_enabled)
|
else if (!this._client.wireless_hardware_enabled)
|
||||||
return _("Hardware Disabled");
|
return _("Hardware Disabled");
|
||||||
@ -1140,20 +1272,52 @@ const NMDeviceWireless = new Lang.Class({
|
|||||||
return 'network-wireless-signal-none-symbolic';
|
return 'network-wireless-signal-none-symbolic';
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_canReachInternet: function() {
|
||||||
|
if (this._client.primary_connection != this._device.active_connection)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
return this._client.connectivity == NetworkManager.ConnectivityState.FULL;
|
||||||
|
},
|
||||||
|
|
||||||
|
_isHotSpotMaster: function() {
|
||||||
|
if (!this._device.active_connection)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
let connection = this._settings.get_connection_by_path(this._device.active_connection.connection);
|
||||||
|
if (!connection)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
let ip4config = connection.get_setting_ip4_config();
|
||||||
|
if (!ip4config)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
return ip4config.get_method() == NetworkManager.SETTING_IP4_CONFIG_METHOD_SHARED;
|
||||||
|
},
|
||||||
|
|
||||||
getIndicatorIcon: function() {
|
getIndicatorIcon: function() {
|
||||||
if (this._device.state >= NetworkManager.DeviceState.PREPARE &&
|
if (this._device.state < NetworkManager.DeviceState.PREPARE)
|
||||||
this._device.state < NetworkManager.DeviceState.ACTIVATED)
|
return 'network-wireless-disconnected-symbolic';
|
||||||
|
if (this._device.state < NetworkManager.DeviceState.ACTIVATED)
|
||||||
return 'network-wireless-acquiring-symbolic';
|
return 'network-wireless-acquiring-symbolic';
|
||||||
|
|
||||||
|
if (this._isHotSpotMaster())
|
||||||
|
return 'network-wireless-hotspot-symbolic';
|
||||||
|
|
||||||
let ap = this._device.active_access_point;
|
let ap = this._device.active_access_point;
|
||||||
if (!ap) {
|
if (!ap) {
|
||||||
if (this._device.mode != NM80211Mode.ADHOC)
|
if (this._device.mode != NM80211Mode.ADHOC)
|
||||||
log('An active wireless connection, in infrastructure mode, involves no access point?');
|
log('An active wireless connection, in infrastructure mode, involves no access point?');
|
||||||
|
|
||||||
return 'network-wireless-connected-symbolic';
|
if (this._canReachInternet())
|
||||||
|
return 'network-wireless-connected-symbolic';
|
||||||
|
else
|
||||||
|
return 'network-wireless-no-route-symbolic';
|
||||||
}
|
}
|
||||||
|
|
||||||
return 'network-wireless-signal-' + signalToIcon(ap.strength) + '-symbolic';
|
if (this._canReachInternet())
|
||||||
|
return 'network-wireless-signal-' + signalToIcon(ap.strength) + '-symbolic';
|
||||||
|
else
|
||||||
|
return 'network-wireless-no-route-symbolic';
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
Signals.addSignalMethods(NMDeviceWireless.prototype);
|
Signals.addSignalMethods(NMDeviceWireless.prototype);
|
||||||
@ -1169,6 +1333,22 @@ const NMVPNConnectionItem = new Lang.Class({
|
|||||||
return this._activeConnection.vpn_state != NetworkManager.VPNConnectionState.DISCONNECTED;
|
return this._activeConnection.vpn_state != NetworkManager.VPNConnectionState.DISCONNECTED;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_buildUI: function() {
|
||||||
|
this.labelItem = new PopupMenu.PopupMenuItem('');
|
||||||
|
this.labelItem.connect('activate', Lang.bind(this, this._toggle));
|
||||||
|
|
||||||
|
this.radioItem = new PopupMenu.PopupSwitchMenuItem(this._connection.get_id(), false);
|
||||||
|
this.radioItem.connect('toggled', Lang.bind(this, this._toggle));
|
||||||
|
},
|
||||||
|
|
||||||
|
_sync: function() {
|
||||||
|
let isActive = this.isActive();
|
||||||
|
this.labelItem.label.text = isActive ? _("Turn Off") : this._section.getConnectLabel();
|
||||||
|
this.radioItem.setToggleState(isActive);
|
||||||
|
this.radioItem.setStatus(this._getStatus());
|
||||||
|
this.emit('icon-changed');
|
||||||
|
},
|
||||||
|
|
||||||
_getStatus: function() {
|
_getStatus: function() {
|
||||||
if (this._activeConnection == null)
|
if (this._activeConnection == null)
|
||||||
return null;
|
return null;
|
||||||
@ -1238,15 +1418,39 @@ const NMVPNSection = new Lang.Class({
|
|||||||
|
|
||||||
_init: function(client) {
|
_init: function(client) {
|
||||||
this.parent(client);
|
this.parent(client);
|
||||||
|
|
||||||
|
this._vpnSettings = new PopupMenu.PopupMenuItem('');
|
||||||
|
this.item.menu.addMenuItem(this._vpnSettings);
|
||||||
|
this._vpnSettings.connect('activate', Lang.bind(this, this._onSettingsActivate));
|
||||||
|
|
||||||
this._sync();
|
this._sync();
|
||||||
},
|
},
|
||||||
|
|
||||||
_sync: function() {
|
_sync: function() {
|
||||||
let nItems = this._connectionItems.size;
|
let nItems = this._connectionItems.size;
|
||||||
this.item.actor.visible = (nItems > 0);
|
this.item.actor.visible = (nItems > 0);
|
||||||
|
|
||||||
|
if (nItems > 1)
|
||||||
|
this._vpnSettings.label.text = _("Network Settings");
|
||||||
|
else
|
||||||
|
this._vpnSettings.label.text = _("VPN Settings");
|
||||||
|
|
||||||
this.parent();
|
this.parent();
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_onSettingsActivate: function() {
|
||||||
|
let nItems = this._connectionItems.size;
|
||||||
|
if (nItems > 1) {
|
||||||
|
let appSys = Shell.AppSystem.get_default();
|
||||||
|
let app = appSys.lookup_app('gnome-network-panel.desktop');
|
||||||
|
app.launch(0, -1);
|
||||||
|
} else {
|
||||||
|
let connection = this._connections[0];
|
||||||
|
Util.spawnApp(['gnome-control-center', 'network', 'show-device',
|
||||||
|
connection.get_path()]);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
_getDescription: function() {
|
_getDescription: function() {
|
||||||
return _("VPN");
|
return _("VPN");
|
||||||
},
|
},
|
||||||
@ -1629,7 +1833,6 @@ const NMApplet = new Lang.Class({
|
|||||||
let connectionSettings = connection.get_setting_by_name(NetworkManager.SETTING_CONNECTION_SETTING_NAME);
|
let connectionSettings = connection.get_setting_by_name(NetworkManager.SETTING_CONNECTION_SETTING_NAME);
|
||||||
connection._type = connectionSettings.type;
|
connection._type = connectionSettings.type;
|
||||||
connection._section = this._ctypes[connection._type] || NMConnectionCategory.INVALID;
|
connection._section = this._ctypes[connection._type] || NMConnectionCategory.INVALID;
|
||||||
connection._timestamp = connectionSettings.timestamp;
|
|
||||||
|
|
||||||
let section = connection._section;
|
let section = connection._section;
|
||||||
|
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
const Gio = imports.gi.Gio;
|
const Gio = imports.gi.Gio;
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
|
const Signals = imports.signals;
|
||||||
|
|
||||||
const PanelMenu = imports.ui.panelMenu;
|
const PanelMenu = imports.ui.panelMenu;
|
||||||
const PopupMenu = imports.ui.popupMenu;
|
const PopupMenu = imports.ui.popupMenu;
|
||||||
@ -12,11 +13,55 @@ const OBJECT_PATH = '/org/gnome/SettingsDaemon/Rfkill';
|
|||||||
const RfkillManagerInterface = '<node> \
|
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" /> \
|
||||||
</interface> \
|
</interface> \
|
||||||
</node>';
|
</node>';
|
||||||
|
|
||||||
const RfkillManagerProxy = Gio.DBusProxy.makeProxyWrapper(RfkillManagerInterface);
|
const RfkillManagerProxy = Gio.DBusProxy.makeProxyWrapper(RfkillManagerInterface);
|
||||||
|
|
||||||
|
const RfkillManager = new Lang.Class({
|
||||||
|
Name: 'RfkillManager',
|
||||||
|
|
||||||
|
_init: function() {
|
||||||
|
this._proxy = new RfkillManagerProxy(Gio.DBus.session, BUS_NAME, OBJECT_PATH,
|
||||||
|
Lang.bind(this, function(proxy, error) {
|
||||||
|
if (error) {
|
||||||
|
log(error.message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
this._proxy.connect('g-properties-changed',
|
||||||
|
Lang.bind(this, this._changed));
|
||||||
|
this._changed();
|
||||||
|
}));
|
||||||
|
},
|
||||||
|
|
||||||
|
get airplaneMode() {
|
||||||
|
return this._proxy.AirplaneMode;
|
||||||
|
},
|
||||||
|
|
||||||
|
set airplaneMode(v) {
|
||||||
|
this._proxy.AirplaneMode = v;
|
||||||
|
},
|
||||||
|
|
||||||
|
get hwAirplaneMode() {
|
||||||
|
return this._proxy.HardwareAirplaneMode;
|
||||||
|
},
|
||||||
|
|
||||||
|
_changed: function() {
|
||||||
|
this.emit('airplane-mode-changed');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
Signals.addSignalMethods(RfkillManager.prototype);
|
||||||
|
|
||||||
|
var _manager;
|
||||||
|
function getRfkillManager() {
|
||||||
|
if (_manager != null)
|
||||||
|
return _manager;
|
||||||
|
|
||||||
|
_manager = new RfkillManager();
|
||||||
|
return _manager;
|
||||||
|
}
|
||||||
|
|
||||||
const Indicator = new Lang.Class({
|
const Indicator = new Lang.Class({
|
||||||
Name: 'RfkillIndicator',
|
Name: 'RfkillIndicator',
|
||||||
Extends: PanelMenu.SystemIndicator,
|
Extends: PanelMenu.SystemIndicator,
|
||||||
@ -24,16 +69,8 @@ const Indicator = new Lang.Class({
|
|||||||
_init: function() {
|
_init: function() {
|
||||||
this.parent();
|
this.parent();
|
||||||
|
|
||||||
this._proxy = new RfkillManagerProxy(Gio.DBus.session, BUS_NAME, OBJECT_PATH,
|
this._manager = getRfkillManager();
|
||||||
Lang.bind(this, function(proxy, error) {
|
this._manager.connect('airplane-mode-changed', Lang.bind(this, this._sync));
|
||||||
if (error) {
|
|
||||||
log(error.message);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
this._proxy.connect('g-properties-changed',
|
|
||||||
Lang.bind(this, this._sync));
|
|
||||||
this._sync();
|
|
||||||
}));
|
|
||||||
|
|
||||||
this._indicator = this._addIndicator();
|
this._indicator = this._addIndicator();
|
||||||
this._indicator.icon_name = 'airplane-mode-symbolic';
|
this._indicator.icon_name = 'airplane-mode-symbolic';
|
||||||
@ -45,7 +82,7 @@ const Indicator = new Lang.Class({
|
|||||||
this._item = new PopupMenu.PopupSubMenuMenuItem(_("Airplane Mode"), true);
|
this._item = new PopupMenu.PopupSubMenuMenuItem(_("Airplane Mode"), true);
|
||||||
this._item.icon.icon_name = 'airplane-mode-symbolic';
|
this._item.icon.icon_name = 'airplane-mode-symbolic';
|
||||||
this._item.status.text = _("On");
|
this._item.status.text = _("On");
|
||||||
this._item.menu.addAction(_("Turn Off"), Lang.bind(this, function() {
|
this._offItem = this._item.menu.addAction(_("Turn Off"), Lang.bind(this, function() {
|
||||||
this._proxy.AirplaneMode = false;
|
this._proxy.AirplaneMode = false;
|
||||||
}));
|
}));
|
||||||
this._item.menu.addSettingsAction(_("Network Settings"), 'gnome-network-panel.desktop');
|
this._item.menu.addSettingsAction(_("Network Settings"), 'gnome-network-panel.desktop');
|
||||||
@ -53,8 +90,18 @@ const Indicator = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_sync: function() {
|
_sync: function() {
|
||||||
let airplaneMode = this._proxy.AirplaneMode;
|
let airplaneMode = this._manager.airplaneMode;
|
||||||
|
let hwAirplaneMode = this._manager.hwAirplaneMode;
|
||||||
|
let changed = (airplaneMode != this._indicator.visible) ||
|
||||||
|
(hwAirplaneMode != this._offItem.actor.visible);
|
||||||
|
|
||||||
this._indicator.visible = airplaneMode;
|
this._indicator.visible = airplaneMode;
|
||||||
this._item.actor.visible = airplaneMode;
|
this._item.actor.visible = airplaneMode;
|
||||||
|
this._offItem.setSensitive(!hwAirplaneMode);
|
||||||
|
|
||||||
|
if (hwAirplaneMode)
|
||||||
|
this._offItem.label.text = _("Use hardware switch to turn off");
|
||||||
|
else
|
||||||
|
this._offItem.label.text = _("Turn Off");
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
@ -187,7 +187,6 @@ const ViewSelector = new Lang.Class({
|
|||||||
params = Params.parse(params, { a11yFocus: null });
|
params = Params.parse(params, { a11yFocus: null });
|
||||||
|
|
||||||
let page = new St.Bin({ child: actor,
|
let page = new St.Bin({ child: actor,
|
||||||
visible: false,
|
|
||||||
x_align: St.Align.START,
|
x_align: St.Align.START,
|
||||||
y_align: St.Align.START,
|
y_align: St.Align.START,
|
||||||
x_fill: true,
|
x_fill: true,
|
||||||
@ -212,7 +211,7 @@ const ViewSelector = new Lang.Class({
|
|||||||
oldPage.hide();
|
oldPage.hide();
|
||||||
|
|
||||||
this.emit('page-empty');
|
this.emit('page-empty');
|
||||||
this._activePage.navigate_focus(null, Gtk.DirectionType.TAB_FORWARD, false);
|
|
||||||
this._activePage.show();
|
this._activePage.show();
|
||||||
Tweener.addTween(this._activePage,
|
Tweener.addTween(this._activePage,
|
||||||
{ opacity: 255,
|
{ opacity: 255,
|
||||||
@ -283,6 +282,14 @@ const ViewSelector = new Lang.Class({
|
|||||||
return Clutter.EVENT_STOP;
|
return Clutter.EVENT_STOP;
|
||||||
} else if (this._shouldTriggerSearch(symbol)) {
|
} else if (this._shouldTriggerSearch(symbol)) {
|
||||||
this.startSearch(event);
|
this.startSearch(event);
|
||||||
|
} else if (!this._searchActive) {
|
||||||
|
if (symbol == Clutter.Tab || symbol == Clutter.Down) {
|
||||||
|
this._activePage.navigate_focus(null, Gtk.DirectionType.TAB_FORWARD, false);
|
||||||
|
return true;
|
||||||
|
} else if (symbol == Clutter.ISO_Left_Tab) {
|
||||||
|
this._activePage.navigate_focus(null, Gtk.DirectionType.TAB_BACKWARD, false);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return Clutter.EVENT_PROPAGATE;
|
return Clutter.EVENT_PROPAGATE;
|
||||||
},
|
},
|
||||||
|
@ -191,6 +191,7 @@ const WorkspaceTracker = new Lang.Class({
|
|||||||
tracker.connect('startup-sequence-changed', Lang.bind(this, this._queueCheckWorkspaces));
|
tracker.connect('startup-sequence-changed', Lang.bind(this, this._queueCheckWorkspaces));
|
||||||
|
|
||||||
global.screen.connect('notify::n-workspaces', Lang.bind(this, this._nWorkspacesChanged));
|
global.screen.connect('notify::n-workspaces', Lang.bind(this, this._nWorkspacesChanged));
|
||||||
|
global.window_manager.connect('switch-workspace', Lang.bind(this, this._queueCheckWorkspaces));
|
||||||
|
|
||||||
global.screen.connect('window-entered-monitor', Lang.bind(this, this._windowEnteredMonitor));
|
global.screen.connect('window-entered-monitor', Lang.bind(this, this._windowEnteredMonitor));
|
||||||
global.screen.connect('window-left-monitor', Lang.bind(this, this._windowLeftMonitor));
|
global.screen.connect('window-left-monitor', Lang.bind(this, this._windowLeftMonitor));
|
||||||
@ -249,13 +250,7 @@ const WorkspaceTracker = new Lang.Class({
|
|||||||
}
|
}
|
||||||
|
|
||||||
let activeWorkspaceIndex = global.screen.get_active_workspace_index();
|
let activeWorkspaceIndex = global.screen.get_active_workspace_index();
|
||||||
let removingCurrentWorkspace = (emptyWorkspaces[activeWorkspaceIndex] &&
|
emptyWorkspaces[activeWorkspaceIndex] = false;
|
||||||
activeWorkspaceIndex < emptyWorkspaces.length - 1);
|
|
||||||
|
|
||||||
if (removingCurrentWorkspace) {
|
|
||||||
// "Merge" the empty workspace we are removing with the one at the end
|
|
||||||
this._wm.blockAnimations();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Delete other empty workspaces; do it from the end to avoid index changes
|
// Delete other empty workspaces; do it from the end to avoid index changes
|
||||||
for (i = emptyWorkspaces.length - 2; i >= 0; i--) {
|
for (i = emptyWorkspaces.length - 2; i >= 0; i--) {
|
||||||
@ -263,11 +258,6 @@ const WorkspaceTracker = new Lang.Class({
|
|||||||
global.screen.remove_workspace(this._workspaces[i], global.get_current_time());
|
global.screen.remove_workspace(this._workspaces[i], global.get_current_time());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (removingCurrentWorkspace) {
|
|
||||||
global.screen.get_workspace_by_index(global.screen.n_workspaces - 1).activate(global.get_current_time());
|
|
||||||
this._wm.unblockAnimations();
|
|
||||||
}
|
|
||||||
|
|
||||||
this._checkWorkspacesId = 0;
|
this._checkWorkspacesId = 0;
|
||||||
return false;
|
return false;
|
||||||
},
|
},
|
||||||
@ -368,6 +358,93 @@ const WorkspaceTracker = new Lang.Class({
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const TilePreview = new Lang.Class({
|
||||||
|
Name: 'TilePreview',
|
||||||
|
|
||||||
|
_init: function() {
|
||||||
|
this.actor = new St.Widget();
|
||||||
|
global.window_group.add_actor(this.actor);
|
||||||
|
|
||||||
|
this._reset();
|
||||||
|
this._showing = false;
|
||||||
|
},
|
||||||
|
|
||||||
|
show: function(window, tileRect, monitorIndex) {
|
||||||
|
let windowActor = window.get_compositor_private();
|
||||||
|
if (!windowActor)
|
||||||
|
return;
|
||||||
|
|
||||||
|
global.window_group.set_child_below_sibling(this.actor, windowActor);
|
||||||
|
|
||||||
|
if (this._rect && this._rect.equal(tileRect))
|
||||||
|
return;
|
||||||
|
|
||||||
|
let changeMonitor = (this._monitorIndex == -1 ||
|
||||||
|
this._monitorIndex != monitorIndex);
|
||||||
|
|
||||||
|
this._monitorIndex = monitorIndex;
|
||||||
|
this._rect = tileRect;
|
||||||
|
|
||||||
|
let monitor = Main.layoutManager.monitors[monitorIndex];
|
||||||
|
|
||||||
|
this._updateStyle(monitor);
|
||||||
|
|
||||||
|
if (!this._showing || changeMonitor) {
|
||||||
|
let monitorRect = new Meta.Rectangle({ x: monitor.x,
|
||||||
|
y: monitor.y,
|
||||||
|
width: monitor.width,
|
||||||
|
height: monitor.height });
|
||||||
|
let [, rect] = window.get_outer_rect().intersect(monitorRect);
|
||||||
|
this.actor.set_size(rect.width, rect.height);
|
||||||
|
this.actor.set_position(rect.x, rect.y);
|
||||||
|
this.actor.opacity = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
this._showing = true;
|
||||||
|
this.actor.show();
|
||||||
|
Tweener.addTween(this.actor,
|
||||||
|
{ x: tileRect.x,
|
||||||
|
y: tileRect.y,
|
||||||
|
width: tileRect.width,
|
||||||
|
height: tileRect.height,
|
||||||
|
opacity: 255,
|
||||||
|
time: WINDOW_ANIMATION_TIME,
|
||||||
|
transition: 'easeOutQuad'
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
hide: function() {
|
||||||
|
if (!this._showing)
|
||||||
|
return;
|
||||||
|
|
||||||
|
this._showing = false;
|
||||||
|
Tweener.addTween(this.actor,
|
||||||
|
{ opacity: 0,
|
||||||
|
time: WINDOW_ANIMATION_TIME,
|
||||||
|
transition: 'easeOutQuad',
|
||||||
|
onComplete: Lang.bind(this, this._reset)
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
_reset: function() {
|
||||||
|
this.actor.hide();
|
||||||
|
this._rect = null;
|
||||||
|
this._monitorIndex = -1;
|
||||||
|
},
|
||||||
|
|
||||||
|
_updateStyle: function(monitor) {
|
||||||
|
let styles = ['tile-preview'];
|
||||||
|
if (this._monitorIndex == Main.layoutManager.primaryIndex)
|
||||||
|
styles.push('on-primary');
|
||||||
|
if (this._rect.x == monitor.x)
|
||||||
|
styles.push('tile-preview-left');
|
||||||
|
if (this._rect.x + this._rect.width == monitor.x + monitor.width)
|
||||||
|
styles.push('tile-preview-right');
|
||||||
|
|
||||||
|
this.actor.style_class = styles.join(' ');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
const WindowManager = new Lang.Class({
|
const WindowManager = new Lang.Class({
|
||||||
Name: 'WindowManager',
|
Name: 'WindowManager',
|
||||||
|
|
||||||
@ -398,6 +475,8 @@ const WindowManager = new Lang.Class({
|
|||||||
}));
|
}));
|
||||||
|
|
||||||
this._shellwm.connect('switch-workspace', Lang.bind(this, this._switchWorkspace));
|
this._shellwm.connect('switch-workspace', Lang.bind(this, this._switchWorkspace));
|
||||||
|
this._shellwm.connect('show-tile-preview', Lang.bind(this, this._showTilePreview));
|
||||||
|
this._shellwm.connect('hide-tile-preview', Lang.bind(this, this._hideTilePreview));
|
||||||
this._shellwm.connect('minimize', Lang.bind(this, this._minimizeWindow));
|
this._shellwm.connect('minimize', Lang.bind(this, this._minimizeWindow));
|
||||||
this._shellwm.connect('maximize', Lang.bind(this, this._maximizeWindow));
|
this._shellwm.connect('maximize', Lang.bind(this, this._maximizeWindow));
|
||||||
this._shellwm.connect('unmaximize', Lang.bind(this, this._unmaximizeWindow));
|
this._shellwm.connect('unmaximize', Lang.bind(this, this._unmaximizeWindow));
|
||||||
@ -407,6 +486,8 @@ const WindowManager = new Lang.Class({
|
|||||||
this._shellwm.connect('confirm-display-change', Lang.bind(this, this._confirmDisplayChange));
|
this._shellwm.connect('confirm-display-change', Lang.bind(this, this._confirmDisplayChange));
|
||||||
|
|
||||||
this._workspaceSwitcherPopup = null;
|
this._workspaceSwitcherPopup = null;
|
||||||
|
this._tilePreview = null;
|
||||||
|
|
||||||
this.setCustomKeybindingHandler('switch-to-workspace-left',
|
this.setCustomKeybindingHandler('switch-to-workspace-left',
|
||||||
Shell.KeyBindingMode.NORMAL |
|
Shell.KeyBindingMode.NORMAL |
|
||||||
Shell.KeyBindingMode.OVERVIEW,
|
Shell.KeyBindingMode.OVERVIEW,
|
||||||
@ -1056,6 +1137,18 @@ const WindowManager = new Lang.Class({
|
|||||||
shellwm.completed_switch_workspace();
|
shellwm.completed_switch_workspace();
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_showTilePreview: function(shellwm, window, tileRect, monitorIndex) {
|
||||||
|
if (!this._tilePreview)
|
||||||
|
this._tilePreview = new TilePreview();
|
||||||
|
this._tilePreview.show(window, tileRect, monitorIndex);
|
||||||
|
},
|
||||||
|
|
||||||
|
_hideTilePreview: function(shellwm) {
|
||||||
|
if (!this._tilePreview)
|
||||||
|
return;
|
||||||
|
this._tilePreview.hide();
|
||||||
|
},
|
||||||
|
|
||||||
_startAppSwitcher : function(display, screen, window, binding) {
|
_startAppSwitcher : function(display, screen, window, binding) {
|
||||||
/* prevent a corner case where both popups show up at once */
|
/* prevent a corner case where both popups show up at once */
|
||||||
if (this._workspaceSwitcherPopup != null)
|
if (this._workspaceSwitcherPopup != null)
|
||||||
|
@ -131,7 +131,7 @@ const WindowClone = new Lang.Class({
|
|||||||
this._dragSlot = [0, 0, 0, 0];
|
this._dragSlot = [0, 0, 0, 0];
|
||||||
this._stackAbove = null;
|
this._stackAbove = null;
|
||||||
|
|
||||||
this._windowClone._updateId = this.realWindow.connect('size-changed',
|
this._windowClone._updateId = this.metaWindow.connect('size-changed',
|
||||||
Lang.bind(this, this._onRealWindowSizeChanged));
|
Lang.bind(this, this._onRealWindowSizeChanged));
|
||||||
this._windowClone._destroyId = this.realWindow.connect('destroy', Lang.bind(this, function() {
|
this._windowClone._destroyId = this.realWindow.connect('destroy', Lang.bind(this, function() {
|
||||||
// First destroy the clone and then destroy everything
|
// First destroy the clone and then destroy everything
|
||||||
@ -199,7 +199,7 @@ const WindowClone = new Lang.Class({
|
|||||||
|
|
||||||
_doAddAttachedDialog: function(metaWin, realWin) {
|
_doAddAttachedDialog: function(metaWin, realWin) {
|
||||||
let clone = new Clutter.Clone({ source: realWin });
|
let clone = new Clutter.Clone({ source: realWin });
|
||||||
clone._updateId = realWin.connect('size-changed', Lang.bind(this, function() {
|
clone._updateId = metaWin.connect('size-changed', Lang.bind(this, function() {
|
||||||
this._computeBoundingBox();
|
this._computeBoundingBox();
|
||||||
this.emit('size-changed');
|
this.emit('size-changed');
|
||||||
}));
|
}));
|
||||||
@ -295,7 +295,7 @@ const WindowClone = new Lang.Class({
|
|||||||
else
|
else
|
||||||
realWindow = child.source;
|
realWindow = child.source;
|
||||||
|
|
||||||
realWindow.disconnect(child._updateId);
|
realWindow.meta_window.disconnect(child._updateId);
|
||||||
realWindow.disconnect(child._destroyId);
|
realWindow.disconnect(child._destroyId);
|
||||||
}));
|
}));
|
||||||
},
|
},
|
||||||
|
@ -68,7 +68,7 @@ const WindowClone = new Lang.Class({
|
|||||||
this.realWindow = realWindow;
|
this.realWindow = realWindow;
|
||||||
this.metaWindow = realWindow.meta_window;
|
this.metaWindow = realWindow.meta_window;
|
||||||
|
|
||||||
this.clone._updateId = this.realWindow.connect('position-changed',
|
this.clone._updateId = this.metaWindow.connect('position-changed',
|
||||||
Lang.bind(this, this._onPositionChanged));
|
Lang.bind(this, this._onPositionChanged));
|
||||||
this.clone._destroyId = this.realWindow.connect('destroy', Lang.bind(this, function() {
|
this.clone._destroyId = this.realWindow.connect('destroy', Lang.bind(this, function() {
|
||||||
// First destroy the clone and then destroy everything
|
// First destroy the clone and then destroy everything
|
||||||
@ -151,7 +151,7 @@ const WindowClone = new Lang.Class({
|
|||||||
let clone = new Clutter.Clone({ source: realDialog });
|
let clone = new Clutter.Clone({ source: realDialog });
|
||||||
this._updateDialogPosition(realDialog, clone);
|
this._updateDialogPosition(realDialog, clone);
|
||||||
|
|
||||||
clone._updateId = realDialog.connect('position-changed',
|
clone._updateId = metaDialog.connect('position-changed',
|
||||||
Lang.bind(this, this._updateDialogPosition, clone));
|
Lang.bind(this, this._updateDialogPosition, clone));
|
||||||
clone._destroyId = realDialog.connect('destroy', Lang.bind(this, function() {
|
clone._destroyId = realDialog.connect('destroy', Lang.bind(this, function() {
|
||||||
clone.destroy();
|
clone.destroy();
|
||||||
@ -176,7 +176,7 @@ const WindowClone = new Lang.Class({
|
|||||||
this.actor.get_children().forEach(function(child) {
|
this.actor.get_children().forEach(function(child) {
|
||||||
let realWindow = child.source;
|
let realWindow = child.source;
|
||||||
|
|
||||||
realWindow.disconnect(child._updateId);
|
realWindow.meta_window.disconnect(child._updateId);
|
||||||
realWindow.disconnect(child._destroyId);
|
realWindow.disconnect(child._destroyId);
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
@ -804,22 +804,25 @@ const ThumbnailsBox = new Lang.Class({
|
|||||||
[newWorkspaceIndex, this._dropPlaceholderPos] = [this._dropPlaceholderPos, -1];
|
[newWorkspaceIndex, this._dropPlaceholderPos] = [this._dropPlaceholderPos, -1];
|
||||||
|
|
||||||
// Nab all the windows below us.
|
// Nab all the windows below us.
|
||||||
let windows = global.get_window_actors().filter(function(win) {
|
let windows = global.get_window_actors().filter(function(winActor) {
|
||||||
// If the window is attached to an ancestor, we don't need/want to move it
|
// If the window is attached to an ancestor, we don't need/want to move it
|
||||||
if (!!win.meta_window.get_transient_for())
|
let window = winActor.meta_window;
|
||||||
|
|
||||||
|
if (window.get_transient_for() != null)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (isWindow)
|
if (isWindow)
|
||||||
return win.get_workspace() >= newWorkspaceIndex && win != source;
|
return window.get_workspace() >= newWorkspaceIndex && winActor != source;
|
||||||
else
|
else
|
||||||
return win.get_workspace() >= newWorkspaceIndex;
|
return window.get_workspace() >= newWorkspaceIndex;
|
||||||
});
|
});
|
||||||
|
|
||||||
this._spliceIndex = newWorkspaceIndex;
|
this._spliceIndex = newWorkspaceIndex;
|
||||||
|
|
||||||
// ... move them down one.
|
// ... move them down one.
|
||||||
windows.forEach(function(win) {
|
windows.forEach(function(winActor) {
|
||||||
win.meta_window.change_workspace_by_index(win.get_workspace() + 1, true);
|
let window = winActor.meta_window;
|
||||||
|
window.change_workspace_by_index(window.get_workspace() + 1, true);
|
||||||
});
|
});
|
||||||
|
|
||||||
if (isWindow)
|
if (isWindow)
|
||||||
|
@ -45,6 +45,7 @@ js/ui/status/accessibility.js
|
|||||||
js/ui/status/bluetooth.js
|
js/ui/status/bluetooth.js
|
||||||
js/ui/status/brightness.js
|
js/ui/status/brightness.js
|
||||||
js/ui/status/keyboard.js
|
js/ui/status/keyboard.js
|
||||||
|
js/ui/status/location.js
|
||||||
js/ui/status/network.js
|
js/ui/status/network.js
|
||||||
js/ui/status/power.js
|
js/ui/status/power.js
|
||||||
js/ui/status/rfkill.js
|
js/ui/status/rfkill.js
|
||||||
|
117
po/an.po
117
po/an.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-01-29 20:43+0000\n"
|
"POT-Creation-Date: 2014-02-08 10:22+0000\n"
|
||||||
"PO-Revision-Date: 2014-01-30 19:56+0100\n"
|
"PO-Revision-Date: 2014-02-08 19:31+0100\n"
|
||||||
"Last-Translator: Jorge Pérez Pérez <jorgtum@gmail.com>\n"
|
"Last-Translator: Jorge Pérez Pérez <jorgtum@gmail.com>\n"
|
||||||
"Language-Team: Aragonese <softaragones@googlegroups.com>\n"
|
"Language-Team: Aragonese <softaragones@googlegroups.com>\n"
|
||||||
"Language: an\n"
|
"Language: an\n"
|
||||||
@ -280,7 +280,7 @@ msgstr ""
|
|||||||
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
||||||
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
||||||
#: ../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:757
|
#: ../js/ui/status/network.js:857
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
msgstr "Cancelar"
|
msgstr "Cancelar"
|
||||||
|
|
||||||
@ -574,8 +574,8 @@ msgstr "Clau de paso:"
|
|||||||
msgid "Type again:"
|
msgid "Type again:"
|
||||||
msgstr "Escriba atra vegada:"
|
msgstr "Escriba atra vegada:"
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:132
|
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:227
|
||||||
#: ../js/ui/status/network.js:294 ../js/ui/status/network.js:760
|
#: ../js/ui/status/network.js:300 ../js/ui/status/network.js:860
|
||||||
msgid "Connect"
|
msgid "Connect"
|
||||||
msgstr "Connectar"
|
msgstr "Connectar"
|
||||||
|
|
||||||
@ -1077,7 +1077,7 @@ msgstr "Activau"
|
|||||||
#. 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:717 ../js/ui/status/network.js:518
|
#: ../js/ui/lookingGlass.js:717 ../js/ui/status/network.js:523
|
||||||
#: ../src/gvc/gvc-mixer-control.c:1830
|
#: ../src/gvc/gvc-mixer-control.c:1830
|
||||||
msgid "Disabled"
|
msgid "Disabled"
|
||||||
msgstr "Desactivau"
|
msgstr "Desactivau"
|
||||||
@ -1297,26 +1297,31 @@ msgstr "Contraste alto"
|
|||||||
msgid "Large Text"
|
msgid "Large Text"
|
||||||
msgstr "Texto gran"
|
msgstr "Texto gran"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:45
|
#: ../js/ui/status/bluetooth.js:48
|
||||||
msgid "Bluetooth"
|
msgid "Bluetooth"
|
||||||
msgstr "Bluetooth"
|
msgstr "Bluetooth"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:47 ../js/ui/status/network.js:132
|
#: ../js/ui/status/bluetooth.js:50 ../js/ui/status/network.js:134
|
||||||
#: ../js/ui/status/network.js:1108 ../js/ui/status/rfkill.js:48
|
#: ../js/ui/status/network.js:1209 ../js/ui/status/rfkill.js:85
|
||||||
|
#: ../js/ui/status/rfkill.js:105
|
||||||
msgid "Turn Off"
|
msgid "Turn Off"
|
||||||
msgstr "Desenchegar"
|
msgstr "Desenchegar"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:50
|
#: ../js/ui/status/bluetooth.js:53
|
||||||
msgid "Bluetooth Settings"
|
msgid "Bluetooth Settings"
|
||||||
msgstr "Cofiguracion de Bluetooth"
|
msgstr "Cofiguracion de Bluetooth"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:98
|
#: ../js/ui/status/bluetooth.js:100
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%d Connected Device"
|
msgid "%d Connected Device"
|
||||||
msgid_plural "%d Connected Devices"
|
msgid_plural "%d Connected Devices"
|
||||||
msgstr[0] "%d dispositivo connectau"
|
msgstr[0] "%d dispositivo connectau"
|
||||||
msgstr[1] "%d dispositivos connectaus"
|
msgstr[1] "%d dispositivos connectaus"
|
||||||
|
|
||||||
|
#: ../js/ui/status/bluetooth.js:102 ../js/ui/status/network.js:1232
|
||||||
|
msgid "Not Connected"
|
||||||
|
msgstr "No connectau"
|
||||||
|
|
||||||
#: ../js/ui/status/brightness.js:44
|
#: ../js/ui/status/brightness.js:44
|
||||||
msgid "Brightness"
|
msgid "Brightness"
|
||||||
msgstr "Brilo"
|
msgstr "Brilo"
|
||||||
@ -1325,103 +1330,133 @@ msgstr "Brilo"
|
|||||||
msgid "Show Keyboard Layout"
|
msgid "Show Keyboard Layout"
|
||||||
msgstr "Amostrar a distribución d'o teclau"
|
msgstr "Amostrar a distribución d'o teclau"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:71
|
#: ../js/ui/status/network.js:73
|
||||||
msgid "<unknown>"
|
msgid "<unknown>"
|
||||||
msgstr "<desconoxiu>"
|
msgstr "<desconoxiu>"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:221 ../js/ui/status/network.js:383
|
#: ../js/ui/status/network.js:223 ../js/ui/status/network.js:389
|
||||||
#: ../js/ui/status/network.js:1129
|
#: ../js/ui/status/network.js:1230
|
||||||
msgid "Off"
|
msgid "Off"
|
||||||
msgstr "DESENCHEGAU"
|
msgstr "DESENCHEGAU"
|
||||||
|
|
||||||
#. 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:389
|
#: ../js/ui/status/network.js:395
|
||||||
msgid "unmanaged"
|
msgid "unmanaged"
|
||||||
msgstr "no chestionada"
|
msgstr "no chestionada"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:391
|
#: ../js/ui/status/network.js:397
|
||||||
msgid "disconnecting..."
|
msgid "disconnecting..."
|
||||||
msgstr "deconectando…"
|
msgstr "deconectando…"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:397 ../js/ui/status/network.js:1183
|
#: ../js/ui/status/network.js:403 ../js/ui/status/network.js:1284
|
||||||
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:400 ../js/ui/status/network.js:1186
|
#: ../js/ui/status/network.js:406 ../js/ui/status/network.js:1287
|
||||||
msgid "authentication required"
|
msgid "authentication required"
|
||||||
msgstr "s'amenista autenticacion"
|
msgstr "s'amenista autenticacion"
|
||||||
|
|
||||||
#. 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:408
|
#: ../js/ui/status/network.js:414
|
||||||
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:412
|
#: ../js/ui/status/network.js:418
|
||||||
msgid "unavailable"
|
msgid "unavailable"
|
||||||
msgstr "no disponible"
|
msgstr "no disponible"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:414 ../js/ui/status/network.js:1188
|
#: ../js/ui/status/network.js:420 ../js/ui/status/network.js:1289
|
||||||
msgid "connection failed"
|
msgid "connection failed"
|
||||||
msgstr "falló a connexión"
|
msgstr "falló a connexión"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:430
|
#: ../js/ui/status/network.js:436
|
||||||
msgid "Wired Settings"
|
msgid "Wired Settings"
|
||||||
msgstr "Opcions inalambricas"
|
msgstr "Opcions inalambricas"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:472 ../js/ui/status/network.js:558
|
#: ../js/ui/status/network.js:477 ../js/ui/status/network.js:563
|
||||||
msgid "Mobile Broadband Settings"
|
msgid "Mobile Broadband Settings"
|
||||||
msgstr "Opcions de Banda ampla mobil"
|
msgstr "Opcions de Banda ampla mobil"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:514 ../js/ui/status/network.js:1127
|
#: ../js/ui/status/network.js:519 ../js/ui/status/network.js:1228
|
||||||
msgid "Hardware Disabled"
|
msgid "Hardware Disabled"
|
||||||
msgstr "Hardware desactivau"
|
msgstr "Hardware desactivau"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:725
|
#: ../js/ui/status/network.js:578
|
||||||
|
msgid "Use as Internet connection"
|
||||||
|
msgstr "Fer servir como una connexión a internet"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:755
|
||||||
|
msgid "Airplane Mode is On"
|
||||||
|
msgstr "O modo avión ye enchegau"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:756
|
||||||
|
msgid "Wi-Fi is disabled when airplane mode is on."
|
||||||
|
msgstr "O wi-Fi ye desactivau quan o modo avión ye enchegau."
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:757
|
||||||
|
msgid "Turn Off Airplane Mode"
|
||||||
|
msgstr "Desenchegar o modo avión"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:766
|
||||||
|
msgid "Wi-Fi is Off"
|
||||||
|
msgstr "O wi-fi ye desenchegau"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:767
|
||||||
|
msgid "Wi-Fi needs to be turned on in order to connect to a network."
|
||||||
|
msgstr "O wi-Fi ameniste estar enchegau ta connectar-se a un ret."
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:768
|
||||||
|
#, fuzzy
|
||||||
|
#| msgid "Turn On"
|
||||||
|
msgid "Turn On Wi-Fi"
|
||||||
|
msgstr "Enchegar"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:793
|
||||||
msgid "Wi-Fi Networks"
|
msgid "Wi-Fi Networks"
|
||||||
msgstr "Retz inalambricos"
|
msgstr "Retz inalambricos"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:727
|
#: ../js/ui/status/network.js:795
|
||||||
msgid "Select a network"
|
msgid "Select a network"
|
||||||
msgstr "Selecciona un ret"
|
msgstr "Selecciona un ret"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:751
|
#: ../js/ui/status/network.js:824
|
||||||
msgid "No Networks"
|
msgid "No Networks"
|
||||||
msgstr "No bi ha retz"
|
msgstr "No bi ha retz"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1014
|
#: ../js/ui/status/network.js:845 ../js/ui/status/rfkill.js:103
|
||||||
|
msgid "Use hardware switch to turn off"
|
||||||
|
msgstr "Fer servir o selector de hardware ta desenchegar-lo"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:1115
|
||||||
msgid "Select Network"
|
msgid "Select Network"
|
||||||
msgstr "Selecciona o ret"
|
msgstr "Selecciona o ret"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1020
|
#: ../js/ui/status/network.js:1121
|
||||||
msgid "Wi-Fi Settings"
|
msgid "Wi-Fi Settings"
|
||||||
msgstr "Opcions inalambricas"
|
msgstr "Opcions inalambricas"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1108
|
#: ../js/ui/status/network.js:1209
|
||||||
msgid "Turn On"
|
msgid "Turn On"
|
||||||
msgstr "Enchegar"
|
msgstr "Enchegar"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1131
|
#: ../js/ui/status/network.js:1352
|
||||||
msgid "Not Connected"
|
|
||||||
msgstr "No connectau"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1251
|
|
||||||
msgid "VPN"
|
msgid "VPN"
|
||||||
msgstr "VPN"
|
msgstr "VPN"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1394
|
#: ../js/ui/status/network.js:1495
|
||||||
msgid "Network Manager"
|
msgid "Network Manager"
|
||||||
msgstr "Chestor d'o rete"
|
msgstr "Chestor d'o rete"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1433
|
#: ../js/ui/status/network.js:1534
|
||||||
msgid "Connection failed"
|
msgid "Connection failed"
|
||||||
msgstr "Falló a connexión"
|
msgstr "Falló a connexión"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1434
|
#: ../js/ui/status/network.js:1535
|
||||||
msgid "Activation of network connection failed"
|
msgid "Activation of network connection failed"
|
||||||
msgstr "Falló l'activación d'a connexión de ret"
|
msgstr "Falló l'activación d'a connexión de ret"
|
||||||
|
|
||||||
@ -1455,15 +1490,15 @@ msgstr "SAI"
|
|||||||
msgid "Battery"
|
msgid "Battery"
|
||||||
msgstr "Batería"
|
msgstr "Batería"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:45
|
#: ../js/ui/status/rfkill.js:82
|
||||||
msgid "Airplane Mode"
|
msgid "Airplane Mode"
|
||||||
msgstr "Modo avión"
|
msgstr "Modo avión"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:47
|
#: ../js/ui/status/rfkill.js:84
|
||||||
msgid "On"
|
msgid "On"
|
||||||
msgstr "Enchegau"
|
msgstr "Enchegau"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:51
|
#: ../js/ui/status/rfkill.js:88
|
||||||
msgid "Network Settings"
|
msgid "Network Settings"
|
||||||
msgstr "Configuracion d'o rete"
|
msgstr "Configuracion d'o rete"
|
||||||
|
|
||||||
|
283
po/as.po
283
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-01-17 21:35+0000\n"
|
"POT-Creation-Date: 2014-02-11 08:31+0000\n"
|
||||||
"PO-Revision-Date: 2014-01-23 19:06+0630\n"
|
"PO-Revision-Date: 2014-02-11 18:44+0630\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"
|
||||||
@ -83,16 +83,10 @@ msgstr ""
|
|||||||
"দিয়ে।"
|
"দিয়ে।"
|
||||||
|
|
||||||
#: ../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
|
||||||
#| 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 "
|
||||||
@ -126,20 +120,17 @@ msgid "History for the looking glass dialog"
|
|||||||
msgstr "চোৱা কাঁচ ডাইলগৰ কাৰণে ইতিহাস"
|
msgstr "চোৱা কাঁচ ডাইলগৰ কাৰণে ইতিহাস"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:9
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:9
|
||||||
#| 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:10
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:10
|
||||||
#| 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."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"এই কি'য়ে এটা-ব্যৱহাৰকাৰী, এটা-অধিবেশন অৱস্থাবোৰত 'লগ আউট' মেনুআইটেম "
|
"এই কি'য়ে এটা-ব্যৱহাৰকাৰী, এটা-অধিবেশন অৱস্থাবোৰত 'লগ আউট' মেনুআইটেম "
|
||||||
"স্বচালিতভাৱে লুকুৱা অভাৰৰাইড কৰে।"
|
"স্বচালিতভাৱে "
|
||||||
|
"লুকুৱা অভাৰৰাইড কৰে।"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:11
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:11
|
||||||
msgid ""
|
msgid ""
|
||||||
@ -289,7 +280,7 @@ msgstr "উপৰত দিয়া কম্বোবাকচ ব্যৱহা
|
|||||||
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
||||||
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
||||||
#: ../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:724
|
#: ../js/ui/status/network.js:857
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
msgstr "বাতিল কৰক"
|
msgstr "বাতিল কৰক"
|
||||||
|
|
||||||
@ -347,31 +338,30 @@ 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/ui/appDisplay.js:540
|
#: ../js/ui/appDisplay.js:633
|
||||||
msgid "Frequently used applications will appear here"
|
msgid "Frequently used applications will appear here"
|
||||||
msgstr "সঘনে ব্যৱহাৰ কৰা এপ্লিকেচনসমূহ ইয়াত উপস্থিত হব"
|
msgstr "সঘনে ব্যৱহাৰ কৰা এপ্লিকেচনসমূহ ইয়াত উপস্থিত হব"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:660
|
#: ../js/ui/appDisplay.js:744
|
||||||
msgid "Frequent"
|
msgid "Frequent"
|
||||||
msgstr "সঘন"
|
msgstr "সঘন"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:667
|
#: ../js/ui/appDisplay.js:751
|
||||||
msgid "All"
|
msgid "All"
|
||||||
msgstr "সকলো"
|
msgstr "সকলো"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1498
|
#: ../js/ui/appDisplay.js:1558
|
||||||
msgid "New Window"
|
msgid "New Window"
|
||||||
msgstr "নতুন উইন্ডো"
|
msgstr "নতুন উইন্ডো"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1501 ../js/ui/dash.js:285
|
#: ../js/ui/appDisplay.js:1580 ../js/ui/dash.js:285
|
||||||
msgid "Remove from Favorites"
|
msgid "Remove from Favorites"
|
||||||
msgstr "পছন্দৰ পৰা আতৰাওক"
|
msgstr "পছন্দৰ পৰা আতৰাওক"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1502
|
#: ../js/ui/appDisplay.js:1586
|
||||||
msgid "Add to Favorites"
|
msgid "Add to Favorites"
|
||||||
msgstr "পছন্দলে যোগ কৰক"
|
msgstr "পছন্দলে যোগ কৰক"
|
||||||
|
|
||||||
@ -584,8 +574,8 @@ msgstr "পাছৱাৰ্ড:"
|
|||||||
msgid "Type again:"
|
msgid "Type again:"
|
||||||
msgstr "আকৌ টাইপ কৰক:"
|
msgstr "আকৌ টাইপ কৰক:"
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:131
|
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:227
|
||||||
#: ../js/ui/status/network.js:293 ../js/ui/status/network.js:727
|
#: ../js/ui/status/network.js:300 ../js/ui/status/network.js:860
|
||||||
msgid "Connect"
|
msgid "Connect"
|
||||||
msgstr "সংযোগ কৰক"
|
msgstr "সংযোগ কৰক"
|
||||||
|
|
||||||
@ -619,9 +609,6 @@ msgstr "বেতাঁৰ নেটৱাৰ্কৰ দ্বাৰা প্
|
|||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:312
|
#: ../js/ui/components/networkAgent.js:312
|
||||||
#, 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”."
|
||||||
@ -659,7 +646,6 @@ msgstr "মবাইল ব্ৰডবেণ্ড নেটৱাৰ্ক প
|
|||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:339
|
#: ../js/ui/components/networkAgent.js:339
|
||||||
#, 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” লে সংযোগ কৰিবলে এটা পাছৱাৰ্ডৰ প্ৰয়োজন।"
|
||||||
|
|
||||||
@ -708,35 +694,35 @@ msgid "Mute"
|
|||||||
msgstr "মোন কৰক"
|
msgstr "মোন কৰক"
|
||||||
|
|
||||||
#. Translators: this is the word "Yesterday" followed by a time string. i.e. "Yesterday, 14:30"*/
|
#. Translators: this is the word "Yesterday" followed by a time string. i.e. "Yesterday, 14:30"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:941
|
#: ../js/ui/components/telepathyClient.js:952
|
||||||
msgid "<b>Yesterday</b>, <b>%H:%M</b>"
|
msgid "<b>Yesterday</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>যোৱাকালী</b>, <b>%H:%M</b>"
|
msgstr "<b>যোৱাকালী</b>, <b>%H:%M</b>"
|
||||||
|
|
||||||
#. Translators: this is the week day name followed by a time string. i.e. "Monday, 14:30*/
|
#. Translators: this is the week day name followed by a time string. i.e. "Monday, 14:30*/
|
||||||
#: ../js/ui/components/telepathyClient.js:947
|
#: ../js/ui/components/telepathyClient.js:958
|
||||||
msgid "<b>%A</b>, <b>%H:%M</b>"
|
msgid "<b>%A</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>%A</b>, <b>%H:%M</b>"
|
msgstr "<b>%A</b>, <b>%H:%M</b>"
|
||||||
|
|
||||||
#. Translators: this is the month name and day number followed by a time string. i.e. "May 25, 14:30"*/
|
#. Translators: this is the month name and day number followed by a time string. i.e. "May 25, 14:30"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:952
|
#: ../js/ui/components/telepathyClient.js:963
|
||||||
msgid "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
msgid "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
msgstr "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
||||||
|
|
||||||
#. Translators: this is the month name, day number, year number followed by a time string. i.e. "May 25 2012, 14:30"*/
|
#. Translators: this is the month name, day number, year number followed by a time string. i.e. "May 25 2012, 14:30"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:956
|
#: ../js/ui/components/telepathyClient.js:967
|
||||||
msgid "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
msgid "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
||||||
msgstr "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
msgstr "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
||||||
|
|
||||||
#. 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:987
|
#: ../js/ui/components/telepathyClient.js:998
|
||||||
#, 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:1090
|
#: ../js/ui/components/telepathyClient.js:1101
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Invitation to %s"
|
msgid "Invitation to %s"
|
||||||
msgstr "%s লে নিমন্ত্ৰণ"
|
msgstr "%s লে নিমন্ত্ৰণ"
|
||||||
@ -744,38 +730,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:1098
|
#: ../js/ui/components/telepathyClient.js:1109
|
||||||
#, 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:1100
|
#: ../js/ui/components/telepathyClient.js:1111
|
||||||
#: ../js/ui/components/telepathyClient.js:1135
|
#: ../js/ui/components/telepathyClient.js:1146
|
||||||
#: ../js/ui/components/telepathyClient.js:1169
|
#: ../js/ui/components/telepathyClient.js:1180
|
||||||
#: ../js/ui/components/telepathyClient.js:1226
|
#: ../js/ui/components/telepathyClient.js:1237
|
||||||
msgid "Decline"
|
msgid "Decline"
|
||||||
msgstr "নাকচ কৰক"
|
msgstr "নাকচ কৰক"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1106
|
#: ../js/ui/components/telepathyClient.js:1117
|
||||||
#: ../js/ui/components/telepathyClient.js:1175
|
#: ../js/ui/components/telepathyClient.js:1186
|
||||||
#: ../js/ui/components/telepathyClient.js:1231
|
#: ../js/ui/components/telepathyClient.js:1242
|
||||||
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:1125
|
#: ../js/ui/components/telepathyClient.js:1136
|
||||||
#, 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:1128
|
#: ../js/ui/components/telepathyClient.js:1139
|
||||||
#, 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:1142
|
#: ../js/ui/components/telepathyClient.js:1153
|
||||||
msgid "Answer"
|
msgid "Answer"
|
||||||
msgstr "উত্তৰ দিয়ক"
|
msgstr "উত্তৰ দিয়ক"
|
||||||
|
|
||||||
@ -784,110 +770,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:1163
|
#: ../js/ui/components/telepathyClient.js:1174
|
||||||
#, 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:1192
|
#: ../js/ui/components/telepathyClient.js:1203
|
||||||
#, 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:1277
|
#: ../js/ui/components/telepathyClient.js:1288
|
||||||
msgid "Network error"
|
msgid "Network error"
|
||||||
msgstr "নেটৱাৰ্ক ত্ৰুটি"
|
msgstr "নেটৱাৰ্ক ত্ৰুটি"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1279
|
#: ../js/ui/components/telepathyClient.js:1290
|
||||||
msgid "Authentication failed"
|
msgid "Authentication failed"
|
||||||
msgstr "প্ৰমাণীকৰণ ব্যৰ্থ"
|
msgstr "প্ৰমাণীকৰণ ব্যৰ্থ"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1281
|
#: ../js/ui/components/telepathyClient.js:1292
|
||||||
msgid "Encryption error"
|
msgid "Encryption error"
|
||||||
msgstr "ইনক্ৰিপষণ ত্ৰুটি"
|
msgstr "ইনক্ৰিপষণ ত্ৰুটি"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1283
|
#: ../js/ui/components/telepathyClient.js:1294
|
||||||
msgid "Certificate not provided"
|
msgid "Certificate not provided"
|
||||||
msgstr "প্ৰমাণপত্ৰ প্ৰদান কৰা হোৱা নাই"
|
msgstr "প্ৰমাণপত্ৰ প্ৰদান কৰা হোৱা নাই"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1285
|
#: ../js/ui/components/telepathyClient.js:1296
|
||||||
msgid "Certificate untrusted"
|
msgid "Certificate untrusted"
|
||||||
msgstr "প্ৰমাণপত্ৰক ভৰষা কৰিব নোৱাৰি"
|
msgstr "প্ৰমাণপত্ৰক ভৰষা কৰিব নোৱাৰি"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1287
|
#: ../js/ui/components/telepathyClient.js:1298
|
||||||
msgid "Certificate expired"
|
msgid "Certificate expired"
|
||||||
msgstr "প্ৰমাণপত্ৰৰ অৱসান ঘটিছে"
|
msgstr "প্ৰমাণপত্ৰৰ অৱসান ঘটিছে"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1289
|
#: ../js/ui/components/telepathyClient.js:1300
|
||||||
msgid "Certificate not activated"
|
msgid "Certificate not activated"
|
||||||
msgstr "প্ৰমাণপত্ৰ সক্ৰিয় কৰা হোৱা নাই"
|
msgstr "প্ৰমাণপত্ৰ সক্ৰিয় কৰা হোৱা নাই"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1291
|
#: ../js/ui/components/telepathyClient.js:1302
|
||||||
msgid "Certificate hostname mismatch"
|
msgid "Certificate hostname mismatch"
|
||||||
msgstr "প্ৰমাণপত্ৰ হস্টনাম অমিল"
|
msgstr "প্ৰমাণপত্ৰ হস্টনাম অমিল"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1293
|
#: ../js/ui/components/telepathyClient.js:1304
|
||||||
msgid "Certificate fingerprint mismatch"
|
msgid "Certificate fingerprint mismatch"
|
||||||
msgstr "প্ৰমাণপত্ৰ ফিংগাৰপ্ৰিন্ট অমিল"
|
msgstr "প্ৰমাণপত্ৰ ফিংগাৰপ্ৰিন্ট অমিল"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1295
|
#: ../js/ui/components/telepathyClient.js:1306
|
||||||
msgid "Certificate self-signed"
|
msgid "Certificate self-signed"
|
||||||
msgstr "প্ৰমাণপত্ৰ স্ব-স্বাক্ষৰীত"
|
msgstr "প্ৰমাণপত্ৰ স্ব-স্বাক্ষৰীত"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1297
|
#: ../js/ui/components/telepathyClient.js:1308
|
||||||
msgid "Status is set to offline"
|
msgid "Status is set to offline"
|
||||||
msgstr "অৱস্থা অফলাইনলে সংহতি কৰা হৈছে"
|
msgstr "অৱস্থা অফলাইনলে সংহতি কৰা হৈছে"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1299
|
#: ../js/ui/components/telepathyClient.js:1310
|
||||||
msgid "Encryption is not available"
|
msgid "Encryption is not available"
|
||||||
msgstr "ইনক্ৰিপষণ উপলব্ধ নহয়"
|
msgstr "ইনক্ৰিপষণ উপলব্ধ নহয়"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1301
|
#: ../js/ui/components/telepathyClient.js:1312
|
||||||
msgid "Certificate is invalid"
|
msgid "Certificate is invalid"
|
||||||
msgstr "প্ৰমাণপত্ৰ অবৈধ"
|
msgstr "প্ৰমাণপত্ৰ অবৈধ"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1303
|
#: ../js/ui/components/telepathyClient.js:1314
|
||||||
msgid "Connection has been refused"
|
msgid "Connection has been refused"
|
||||||
msgstr "সংযোগ নাকচ কৰা হৈছে"
|
msgstr "সংযোগ নাকচ কৰা হৈছে"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1305
|
#: ../js/ui/components/telepathyClient.js:1316
|
||||||
msgid "Connection can't be established"
|
msgid "Connection can't be established"
|
||||||
msgstr "সংযোগ স্থাপন কৰিব নোৱাৰি"
|
msgstr "সংযোগ স্থাপন কৰিব নোৱাৰি"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1307
|
#: ../js/ui/components/telepathyClient.js:1318
|
||||||
msgid "Connection has been lost"
|
msgid "Connection has been lost"
|
||||||
msgstr "সংযোগ হেৰাইছে"
|
msgstr "সংযোগ হেৰাইছে"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1309
|
#: ../js/ui/components/telepathyClient.js:1320
|
||||||
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:1311
|
#: ../js/ui/components/telepathyClient.js:1322
|
||||||
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:1313
|
#: ../js/ui/components/telepathyClient.js:1324
|
||||||
msgid "The account already exists on the server"
|
msgid "The account already exists on the server"
|
||||||
msgstr "একাওন্ট ইতিমধ্যে চাৰ্ভাৰত উপস্থিত"
|
msgstr "একাওন্ট ইতিমধ্যে চাৰ্ভাৰত উপস্থিত"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1315
|
#: ../js/ui/components/telepathyClient.js:1326
|
||||||
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:1317
|
#: ../js/ui/components/telepathyClient.js:1328
|
||||||
msgid "Certificate has been revoked"
|
msgid "Certificate has been revoked"
|
||||||
msgstr "প্ৰমাণপত্ৰ প্ৰত্যাহাৰ কৰা হৈছে"
|
msgstr "প্ৰমাণপত্ৰ প্ৰত্যাহাৰ কৰা হৈছে"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1319
|
#: ../js/ui/components/telepathyClient.js:1330
|
||||||
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:1321
|
#: ../js/ui/components/telepathyClient.js:1332
|
||||||
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"
|
||||||
@ -896,22 +882,22 @@ msgstr ""
|
|||||||
"ক্ৰিপ্টোগ্ৰাফী "
|
"ক্ৰিপ্টোগ্ৰাফী "
|
||||||
"লাইব্ৰেৰীয়ে প্ৰণয়ন কৰা সীমাসমূহত অতিক্ৰম কৰে"
|
"লাইব্ৰেৰীয়ে প্ৰণয়ন কৰা সীমাসমূহত অতিক্ৰম কৰে"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1323
|
#: ../js/ui/components/telepathyClient.js:1334
|
||||||
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:1333
|
#: ../js/ui/components/telepathyClient.js:1344
|
||||||
#, 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:1338
|
#: ../js/ui/components/telepathyClient.js:1349
|
||||||
msgid "View account"
|
msgid "View account"
|
||||||
msgstr "একাওন্ট দৰ্শন কৰক"
|
msgstr "একাওন্ট দৰ্শন কৰক"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1370
|
#: ../js/ui/components/telepathyClient.js:1381
|
||||||
msgid "Unknown reason"
|
msgid "Unknown reason"
|
||||||
msgstr "অজ্ঞাত কাৰণ"
|
msgstr "অজ্ঞাত কাৰণ"
|
||||||
|
|
||||||
@ -1058,7 +1044,6 @@ 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 "extensions.gnome.org ৰ পৰা “%s” ক ডাউনল'ড আৰু ইনস্টল কৰিব নে?"
|
msgstr "extensions.gnome.org ৰ পৰা “%s” ক ডাউনল'ড আৰু ইনস্টল কৰিব নে?"
|
||||||
|
|
||||||
@ -1092,7 +1077,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:717 ../js/ui/status/network.js:470
|
#: ../js/ui/lookingGlass.js:717 ../js/ui/status/network.js:523
|
||||||
#: ../src/gvc/gvc-mixer-control.c:1830
|
#: ../src/gvc/gvc-mixer-control.c:1830
|
||||||
msgid "Disabled"
|
msgid "Disabled"
|
||||||
msgstr "অসামৰ্থবান কৰা আছে"
|
msgstr "অসামৰ্থবান কৰা আছে"
|
||||||
@ -1117,43 +1102,43 @@ msgstr "উৎস দৰ্শন কৰক"
|
|||||||
msgid "Web Page"
|
msgid "Web Page"
|
||||||
msgstr "ৱেব পৃষ্ঠা"
|
msgstr "ৱেব পৃষ্ঠা"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1309
|
#: ../js/ui/messageTray.js:1312
|
||||||
msgid "Open"
|
msgid "Open"
|
||||||
msgstr "খোলক"
|
msgstr "খোলক"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1316
|
#: ../js/ui/messageTray.js:1319
|
||||||
msgid "Remove"
|
msgid "Remove"
|
||||||
msgstr "আতৰাওক"
|
msgstr "আতৰাওক"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1613
|
#: ../js/ui/messageTray.js:1616
|
||||||
msgid "Notifications"
|
msgid "Notifications"
|
||||||
msgstr "অধিসূচনাসমূহ"
|
msgstr "অধিসূচনাসমূহ"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1620
|
#: ../js/ui/messageTray.js:1623
|
||||||
msgid "Clear Messages"
|
msgid "Clear Messages"
|
||||||
msgstr "বাৰ্তাসমূহ পৰিষ্কাৰ কৰক"
|
msgstr "বাৰ্তাসমূহ পৰিষ্কাৰ কৰক"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1639
|
#: ../js/ui/messageTray.js:1642
|
||||||
msgid "Notification Settings"
|
msgid "Notification Settings"
|
||||||
msgstr "অধিসূচনা সংহতিসমূহ"
|
msgstr "অধিসূচনা সংহতিসমূহ"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1692
|
#: ../js/ui/messageTray.js:1695
|
||||||
msgid "Tray Menu"
|
msgid "Tray Menu"
|
||||||
msgstr "ট্ৰে মেনু"
|
msgstr "ট্ৰে মেনু"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1909
|
#: ../js/ui/messageTray.js:1912
|
||||||
msgid "No Messages"
|
msgid "No Messages"
|
||||||
msgstr "কোনো বাৰ্তা নাই"
|
msgstr "কোনো বাৰ্তা নাই"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1947
|
#: ../js/ui/messageTray.js:1950
|
||||||
msgid "Message Tray"
|
msgid "Message Tray"
|
||||||
msgstr "বাৰ্তা ট্ৰে"
|
msgstr "বাৰ্তা ট্ৰে"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:2931
|
#: ../js/ui/messageTray.js:2934
|
||||||
msgid "System Information"
|
msgid "System Information"
|
||||||
msgstr "চিস্টেম তথ্য"
|
msgstr "চিস্টেম তথ্য"
|
||||||
|
|
||||||
#: ../js/ui/notificationDaemon.js:515 ../src/shell-app.c:397
|
#: ../js/ui/notificationDaemon.js:515 ../src/shell-app.c:399
|
||||||
msgctxt "program"
|
msgctxt "program"
|
||||||
msgid "Unknown"
|
msgid "Unknown"
|
||||||
msgstr "অজ্ঞাত"
|
msgstr "অজ্ঞাত"
|
||||||
@ -1191,7 +1176,7 @@ msgstr "প্ৰস্থান কৰক"
|
|||||||
msgid "Activities"
|
msgid "Activities"
|
||||||
msgstr "কাৰ্য্যসমূহ"
|
msgstr "কাৰ্য্যসমূহ"
|
||||||
|
|
||||||
#: ../js/ui/panel.js:903
|
#: ../js/ui/panel.js:905
|
||||||
msgid "Top Bar"
|
msgid "Top Bar"
|
||||||
msgstr "উপৰৰ বাৰ"
|
msgstr "উপৰৰ বাৰ"
|
||||||
|
|
||||||
@ -1220,19 +1205,19 @@ msgid_plural "%d new notifications"
|
|||||||
msgstr[0] "%d নতুন অধিসূচনা"
|
msgstr[0] "%d নতুন অধিসূচনা"
|
||||||
msgstr[1] "%d নতুন অধিসূচনাসমূহ"
|
msgstr[1] "%d নতুন অধিসূচনাসমূহ"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:472 ../js/ui/status/system.js:342
|
#: ../js/ui/screenShield.js:473 ../js/ui/status/system.js:342
|
||||||
msgid "Lock"
|
msgid "Lock"
|
||||||
msgstr "লক কৰক"
|
msgstr "লক কৰক"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:706
|
#: ../js/ui/screenShield.js:707
|
||||||
msgid "GNOME needs to lock the screen"
|
msgid "GNOME needs to lock the screen"
|
||||||
msgstr "GNOME এ পৰ্দা লক কৰিব লাগিব"
|
msgstr "GNOME এ পৰ্দা লক কৰিব লাগিব"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:833 ../js/ui/screenShield.js:1300
|
#: ../js/ui/screenShield.js:834 ../js/ui/screenShield.js:1301
|
||||||
msgid "Unable to lock"
|
msgid "Unable to lock"
|
||||||
msgstr "লক কৰিবলে অক্ষম"
|
msgstr "লক কৰিবলে অক্ষম"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:834 ../js/ui/screenShield.js:1301
|
#: ../js/ui/screenShield.js:835 ../js/ui/screenShield.js:1302
|
||||||
msgid "Lock was blocked by an application"
|
msgid "Lock was blocked by an application"
|
||||||
msgstr "লক কাৰ্য্য এটা এপ্লিকেচন দ্বাৰা প্ৰতিৰোধ কৰা হৈছিল"
|
msgstr "লক কাৰ্য্য এটা এপ্লিকেচন দ্বাৰা প্ৰতিৰোধ কৰা হৈছিল"
|
||||||
|
|
||||||
@ -1312,26 +1297,31 @@ msgstr "উচ্চ কন্ট্ৰাস্ট"
|
|||||||
msgid "Large Text"
|
msgid "Large Text"
|
||||||
msgstr "ডাঙৰ লিখনী"
|
msgstr "ডাঙৰ লিখনী"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:45
|
#: ../js/ui/status/bluetooth.js:48
|
||||||
msgid "Bluetooth"
|
msgid "Bluetooth"
|
||||||
msgstr "ব্লুটুথ"
|
msgstr "ব্লুটুথ"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:47 ../js/ui/status/network.js:131
|
#: ../js/ui/status/bluetooth.js:50 ../js/ui/status/network.js:134
|
||||||
#: ../js/ui/status/network.js:1081 ../js/ui/status/rfkill.js:48
|
#: ../js/ui/status/network.js:1209 ../js/ui/status/rfkill.js:85
|
||||||
|
#: ../js/ui/status/rfkill.js:105
|
||||||
msgid "Turn Off"
|
msgid "Turn Off"
|
||||||
msgstr "বন্ধ কৰক"
|
msgstr "বন্ধ কৰক"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:50
|
#: ../js/ui/status/bluetooth.js:53
|
||||||
msgid "Bluetooth Settings"
|
msgid "Bluetooth Settings"
|
||||||
msgstr "ব্লুটুথ সংহতিসমূহ"
|
msgstr "ব্লুটুথ সংহতিসমূহ"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:98
|
#: ../js/ui/status/bluetooth.js:100
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%d Connected Device"
|
msgid "%d Connected Device"
|
||||||
msgid_plural "%d Connected Devices"
|
msgid_plural "%d Connected Devices"
|
||||||
msgstr[0] "%d সংযুক্ত ডিভাইচ"
|
msgstr[0] "%d সংযুক্ত ডিভাইচ"
|
||||||
msgstr[1] "%d সংযুক্ত ডিভাইচসমূহ"
|
msgstr[1] "%d সংযুক্ত ডিভাইচসমূহ"
|
||||||
|
|
||||||
|
#: ../js/ui/status/bluetooth.js:102 ../js/ui/status/network.js:1232
|
||||||
|
msgid "Not Connected"
|
||||||
|
msgstr "সংযুক্ত নহয়"
|
||||||
|
|
||||||
#: ../js/ui/status/brightness.js:44
|
#: ../js/ui/status/brightness.js:44
|
||||||
msgid "Brightness"
|
msgid "Brightness"
|
||||||
msgstr "উজ্জ্বলতা"
|
msgstr "উজ্জ্বলতা"
|
||||||
@ -1340,103 +1330,136 @@ msgstr "উজ্জ্বলতা"
|
|||||||
msgid "Show Keyboard Layout"
|
msgid "Show Keyboard Layout"
|
||||||
msgstr "কিবৰ্ড বিন্যাস দেখুৱাওক"
|
msgstr "কিবৰ্ড বিন্যাস দেখুৱাওক"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:70
|
#: ../js/ui/status/network.js:73
|
||||||
msgid "<unknown>"
|
msgid "<unknown>"
|
||||||
msgstr "<unknown>"
|
msgstr "<unknown>"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:220 ../js/ui/status/network.js:377
|
#: ../js/ui/status/network.js:223 ../js/ui/status/network.js:389
|
||||||
#: ../js/ui/status/network.js:1102
|
#: ../js/ui/status/network.js:1230
|
||||||
msgid "Off"
|
msgid "Off"
|
||||||
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:383
|
#: ../js/ui/status/network.js:395
|
||||||
msgid "unmanaged"
|
msgid "unmanaged"
|
||||||
msgstr "অব্যৱস্থাপিত"
|
msgstr "অব্যৱস্থাপিত"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:385
|
#: ../js/ui/status/network.js:397
|
||||||
msgid "disconnecting..."
|
msgid "disconnecting..."
|
||||||
msgstr "বিচ্ছিনিত কৰা হৈছে..."
|
msgstr "বিচ্ছিনিত কৰা হৈছে..."
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:391 ../js/ui/status/network.js:1156
|
#: ../js/ui/status/network.js:403 ../js/ui/status/network.js:1284
|
||||||
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:394 ../js/ui/status/network.js:1159
|
#: ../js/ui/status/network.js:406 ../js/ui/status/network.js:1287
|
||||||
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:402
|
#: ../js/ui/status/network.js:414
|
||||||
msgid "firmware missing"
|
msgid "firmware missing"
|
||||||
msgstr "ফাৰ্মৱেৰ সন্ধানহীন"
|
msgstr "ফাৰ্মৱেৰ সন্ধানহীন"
|
||||||
|
|
||||||
#. 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:406
|
#: ../js/ui/status/network.js:418
|
||||||
msgid "unavailable"
|
msgid "unavailable"
|
||||||
msgstr "উপলব্ধ নাই"
|
msgstr "উপলব্ধ নাই"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:408 ../js/ui/status/network.js:1161
|
#: ../js/ui/status/network.js:420 ../js/ui/status/network.js:1289
|
||||||
msgid "connection failed"
|
msgid "connection failed"
|
||||||
msgstr "সংযোগ ব্যৰ্থ"
|
msgstr "সংযোগ ব্যৰ্থ"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:424 ../js/ui/status/network.js:510
|
#: ../js/ui/status/network.js:436
|
||||||
#| msgid "Mobile broadband"
|
#| msgid "Wi-Fi Settings"
|
||||||
|
msgid "Wired Settings"
|
||||||
|
msgstr "তাঁৰযুক্ত সংহতিসমূহ"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:477 ../js/ui/status/network.js:563
|
||||||
msgid "Mobile Broadband Settings"
|
msgid "Mobile Broadband Settings"
|
||||||
msgstr "মবাইল ব্ৰডবেণ্ড সংহতিসমূহ"
|
msgstr "মবাইল ব্ৰডবেণ্ড সংহতিসমূহ"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:466 ../js/ui/status/network.js:1100
|
#: ../js/ui/status/network.js:519 ../js/ui/status/network.js:1228
|
||||||
#| msgid "hardware disabled"
|
|
||||||
msgid "Hardware Disabled"
|
msgid "Hardware Disabled"
|
||||||
msgstr "হাৰ্ডৱেৰ অসামৰ্থবান কৰা আছে"
|
msgstr "হাৰ্ডৱেৰ অসামৰ্থবান কৰা আছে"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:692
|
#: ../js/ui/status/network.js:578
|
||||||
|
msgid "Use as Internet connection"
|
||||||
|
msgstr "ইন্টাৰনেট সংযোগ ৰূপে ব্যৱহাৰ কৰক"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:755
|
||||||
|
#| msgid "Airplane Mode"
|
||||||
|
msgid "Airplane Mode is On"
|
||||||
|
msgstr "বিমান অৱস্থা অন আছে"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:756
|
||||||
|
msgid "Wi-Fi is disabled when airplane mode is on."
|
||||||
|
msgstr "বিমান অৱস্থা অন থকা অৱস্থাত Wi-Fi অসামৰ্থবান থাকে।"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:757
|
||||||
|
#| msgid "Airplane Mode"
|
||||||
|
msgid "Turn Off Airplane Mode"
|
||||||
|
msgstr "বিমান অৱস্থা বন্ধ কৰক"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:766
|
||||||
|
#| msgid "Wi-Fi Settings"
|
||||||
|
msgid "Wi-Fi is Off"
|
||||||
|
msgstr "Wi-Fi অফ আছে"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:767
|
||||||
|
msgid "Wi-Fi needs to be turned on in order to connect to a network."
|
||||||
|
msgstr "এটা নেটৱাৰ্কৰ সৈতে সংযোগ কৰিবলে Wi-Fi অন কৰিব লাগিব।"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:768
|
||||||
|
#| msgid "Turn On"
|
||||||
|
msgid "Turn On Wi-Fi"
|
||||||
|
msgstr "Wi-Fi অন কৰক"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:793
|
||||||
msgid "Wi-Fi Networks"
|
msgid "Wi-Fi Networks"
|
||||||
msgstr "Wi-Fi নেটৱাৰ্কসমূহ"
|
msgstr "Wi-Fi নেটৱাৰ্কসমূহ"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:694
|
#: ../js/ui/status/network.js:795
|
||||||
msgid "Select a network"
|
msgid "Select a network"
|
||||||
msgstr "এটা নেটৱাৰ্ক বাছক"
|
msgstr "এটা নেটৱাৰ্ক বাছক"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:718
|
#: ../js/ui/status/network.js:824
|
||||||
msgid "No Networks"
|
msgid "No Networks"
|
||||||
msgstr "কোনো নেটৱাৰ্ক নাই"
|
msgstr "কোনো নেটৱাৰ্ক নাই"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:987
|
#: ../js/ui/status/network.js:845 ../js/ui/status/rfkill.js:103
|
||||||
|
msgid "Use hardware switch to turn off"
|
||||||
|
msgstr "বন্ধ কৰিবলে হাৰ্ডৱেৰ চুইচ ব্যৱহাৰ কৰক"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:1115
|
||||||
msgid "Select Network"
|
msgid "Select Network"
|
||||||
msgstr "নেটৱাৰ্ক বাছক"
|
msgstr "নেটৱাৰ্ক বাছক"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:993
|
#: ../js/ui/status/network.js:1121
|
||||||
#| msgid "Settings"
|
|
||||||
msgid "Wi-Fi Settings"
|
msgid "Wi-Fi Settings"
|
||||||
msgstr "Wi-Fi সংহতিসমূহ"
|
msgstr "Wi-Fi সংহতিসমূহ"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1081
|
#: ../js/ui/status/network.js:1209
|
||||||
msgid "Turn On"
|
msgid "Turn On"
|
||||||
msgstr "অন কৰক"
|
msgstr "অন কৰক"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1104
|
#: ../js/ui/status/network.js:1352
|
||||||
#| msgid "Connect"
|
|
||||||
msgid "Not Connected"
|
|
||||||
msgstr "সংযুক্ত নহয়"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1224
|
|
||||||
msgid "VPN"
|
msgid "VPN"
|
||||||
msgstr "VPN"
|
msgstr "VPN"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1364
|
#: ../js/ui/status/network.js:1495
|
||||||
msgid "Network Manager"
|
msgid "Network Manager"
|
||||||
msgstr "নেটৱাৰ্ক ব্যৱস্থাপক"
|
msgstr "নেটৱাৰ্ক ব্যৱস্থাপক"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1403
|
#: ../js/ui/status/network.js:1534
|
||||||
msgid "Connection failed"
|
msgid "Connection failed"
|
||||||
msgstr "সংযোগ ব্যৰ্থ"
|
msgstr "সংযোগ ব্যৰ্থ"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1404
|
#: ../js/ui/status/network.js:1535
|
||||||
msgid "Activation of network connection failed"
|
msgid "Activation of network connection failed"
|
||||||
msgstr "নেটৱাৰ্ক সংযোগ সক্ৰিয়কৰণ ব্যৰ্থ হল"
|
msgstr "নেটৱাৰ্ক সংযোগ সক্ৰিয়কৰণ ব্যৰ্থ হল"
|
||||||
|
|
||||||
@ -1470,15 +1493,15 @@ msgstr "UPS"
|
|||||||
msgid "Battery"
|
msgid "Battery"
|
||||||
msgstr "বেটাৰি"
|
msgstr "বেটাৰি"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:45
|
#: ../js/ui/status/rfkill.js:82
|
||||||
msgid "Airplane Mode"
|
msgid "Airplane Mode"
|
||||||
msgstr "বিমান অৱস্থা"
|
msgstr "বিমান অৱস্থা"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:47
|
#: ../js/ui/status/rfkill.js:84
|
||||||
msgid "On"
|
msgid "On"
|
||||||
msgstr "অন"
|
msgstr "অন"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:51
|
#: ../js/ui/status/rfkill.js:88
|
||||||
msgid "Network Settings"
|
msgid "Network Settings"
|
||||||
msgstr "নেটৱাৰ্ক সংহতিসমূহ"
|
msgstr "নেটৱাৰ্ক সংহতিসমূহ"
|
||||||
|
|
||||||
@ -1532,7 +1555,6 @@ 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” প্ৰস্তুত"
|
||||||
|
|
||||||
@ -1600,9 +1622,8 @@ msgstr "লগিন পৰ্দাৰ বাবে এটা বিশেষ
|
|||||||
msgid "List possible modes"
|
msgid "List possible modes"
|
||||||
msgstr "সম্ভাব্য অৱস্থাসমূহ তালিকাভুক্ত কৰক"
|
msgstr "সম্ভাব্য অৱস্থাসমূহ তালিকাভুক্ত কৰক"
|
||||||
|
|
||||||
#: ../src/shell-app.c:640
|
#: ../src/shell-app.c:642
|
||||||
#, c-format
|
#, c-format
|
||||||
#| msgid "Failed to launch '%s'"
|
|
||||||
msgid "Failed to launch “%s”"
|
msgid "Failed to launch “%s”"
|
||||||
msgstr "“%s” লঞ্চ কৰিবলে ব্যৰ্থ"
|
msgstr "“%s” লঞ্চ কৰিবলে ব্যৰ্থ"
|
||||||
|
|
||||||
|
288
po/cs.po
288
po/cs.po
@ -12,8 +12,8 @@ msgstr ""
|
|||||||
"Project-Id-Version: gnome-shell\n"
|
"Project-Id-Version: gnome-shell\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-01-17 21:35+0000\n"
|
"POT-Creation-Date: 2014-02-08 08:59+0000\n"
|
||||||
"PO-Revision-Date: 2014-01-18 12:21+0100\n"
|
"PO-Revision-Date: 2014-02-08 11:21+0100\n"
|
||||||
"Last-Translator: Marek Černocký <marek@manet.cz>\n"
|
"Last-Translator: Marek Černocký <marek@manet.cz>\n"
|
||||||
"Language-Team: Czech <gnome-cs-list@gnome.org>\n"
|
"Language-Team: Czech <gnome-cs-list@gnome.org>\n"
|
||||||
"Language: cs\n"
|
"Language: cs\n"
|
||||||
@ -258,6 +258,7 @@ msgid "Delay focus changes in mouse mode until the pointer stops moving"
|
|||||||
msgstr "Se změnou zaměření v režimu myši čekat na zastavení pohybu ukazatele"
|
msgstr "Se změnou zaměření v režimu myši čekat na zastavení pohybu ukazatele"
|
||||||
|
|
||||||
#: ../js/extensionPrefs/main.js:127
|
#: ../js/extensionPrefs/main.js:127
|
||||||
|
#, 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 ""
|
||||||
"Nastala chyba při načítání dialogového okna předvoleb pro rozšíření %s:"
|
"Nastala chyba při načítání dialogového okna předvoleb pro rozšíření %s:"
|
||||||
@ -274,7 +275,7 @@ msgstr ""
|
|||||||
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
||||||
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
||||||
#: ../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:724
|
#: ../js/ui/status/network.js:857
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
msgstr "Zrušit"
|
msgstr "Zrušit"
|
||||||
|
|
||||||
@ -301,6 +302,7 @@ msgid "Not listed?"
|
|||||||
msgstr "Nejste na seznamu?"
|
msgstr "Nejste na seznamu?"
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:598
|
#: ../js/gdm/loginDialog.js:598
|
||||||
|
#, javascript-format
|
||||||
msgid "(e.g., user or %s)"
|
msgid "(e.g., user or %s)"
|
||||||
msgstr "(např. uživatel nebo %s)"
|
msgstr "(např. uživatel nebo %s)"
|
||||||
|
|
||||||
@ -330,38 +332,41 @@ msgid "Could not parse command:"
|
|||||||
msgstr "Nelze analyzovat příkaz:"
|
msgstr "Nelze analyzovat příkaz:"
|
||||||
|
|
||||||
#: ../js/misc/util.js:156
|
#: ../js/misc/util.js:156
|
||||||
|
#, javascript-format
|
||||||
msgid "Execution of “%s” failed:"
|
msgid "Execution of “%s” failed:"
|
||||||
msgstr "Vykonání „%s“ selhalo:"
|
msgstr "Vykonání „%s“ selhalo:"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:540
|
#: ../js/ui/appDisplay.js:633
|
||||||
msgid "Frequently used applications will appear here"
|
msgid "Frequently used applications will appear here"
|
||||||
msgstr "Zde se objeví často používané aplikace"
|
msgstr "Zde se objeví často používané aplikace"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:660
|
#: ../js/ui/appDisplay.js:744
|
||||||
msgid "Frequent"
|
msgid "Frequent"
|
||||||
msgstr "Časté"
|
msgstr "Časté"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:667
|
#: ../js/ui/appDisplay.js:751
|
||||||
msgid "All"
|
msgid "All"
|
||||||
msgstr "Všechny"
|
msgstr "Všechny"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1498
|
#: ../js/ui/appDisplay.js:1558
|
||||||
msgid "New Window"
|
msgid "New Window"
|
||||||
msgstr "Nové okno"
|
msgstr "Nové okno"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1501 ../js/ui/dash.js:285
|
#: ../js/ui/appDisplay.js:1580 ../js/ui/dash.js:285
|
||||||
msgid "Remove from Favorites"
|
msgid "Remove from Favorites"
|
||||||
msgstr "Odstranit z oblíbených"
|
msgstr "Odstranit z oblíbených"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1502
|
#: ../js/ui/appDisplay.js:1586
|
||||||
msgid "Add to Favorites"
|
msgid "Add to Favorites"
|
||||||
msgstr "Přidat mezi oblíbené"
|
msgstr "Přidat mezi oblíbené"
|
||||||
|
|
||||||
#: ../js/ui/appFavorites.js:87
|
#: ../js/ui/appFavorites.js:87
|
||||||
|
#, javascript-format
|
||||||
msgid "%s has been added to your favorites."
|
msgid "%s has been added to your favorites."
|
||||||
msgstr "%s byl přidán mezi oblíbené."
|
msgstr "%s byl přidán mezi oblíbené."
|
||||||
|
|
||||||
#: ../js/ui/appFavorites.js:121
|
#: ../js/ui/appFavorites.js:121
|
||||||
|
#, javascript-format
|
||||||
msgid "%s has been removed from your favorites."
|
msgid "%s has been removed from your favorites."
|
||||||
msgstr "%s byl odstraněn z oblíbených."
|
msgstr "%s byl odstraněn z oblíbených."
|
||||||
|
|
||||||
@ -548,6 +553,7 @@ msgid "Removable Devices"
|
|||||||
msgstr "Výměnná zařízení"
|
msgstr "Výměnná zařízení"
|
||||||
|
|
||||||
#: ../js/ui/components/autorunManager.js:596
|
#: ../js/ui/components/autorunManager.js:596
|
||||||
|
#, javascript-format
|
||||||
msgid "Open with %s"
|
msgid "Open with %s"
|
||||||
msgstr "Otevřít s %s"
|
msgstr "Otevřít s %s"
|
||||||
|
|
||||||
@ -563,8 +569,8 @@ msgstr "Heslo:"
|
|||||||
msgid "Type again:"
|
msgid "Type again:"
|
||||||
msgstr "Napište znovu:"
|
msgstr "Napište znovu:"
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:131
|
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:227
|
||||||
#: ../js/ui/status/network.js:293 ../js/ui/status/network.js:727
|
#: ../js/ui/status/network.js:300 ../js/ui/status/network.js:860
|
||||||
msgid "Connect"
|
msgid "Connect"
|
||||||
msgstr "Připojit"
|
msgstr "Připojit"
|
||||||
|
|
||||||
@ -597,6 +603,7 @@ msgid "Authentication required by wireless network"
|
|||||||
msgstr "K bezdrátové síti je vyžadováno ověření"
|
msgstr "K bezdrátové síti je vyžadováno ověření"
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:312
|
#: ../js/ui/components/networkAgent.js:312
|
||||||
|
#, javascript-format
|
||||||
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”."
|
||||||
@ -606,7 +613,7 @@ msgstr ""
|
|||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:316
|
#: ../js/ui/components/networkAgent.js:316
|
||||||
msgid "Wired 802.1X authentication"
|
msgid "Wired 802.1X authentication"
|
||||||
msgstr "Ověření drátového připojení 802.1X"
|
msgstr "Ověření připojení po drátu 802.1X"
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:318
|
#: ../js/ui/components/networkAgent.js:318
|
||||||
msgid "Network name: "
|
msgid "Network name: "
|
||||||
@ -633,6 +640,7 @@ msgid "Mobile broadband network password"
|
|||||||
msgstr "Heslo k mobilní širokopásmové síti"
|
msgstr "Heslo k mobilní širokopásmové síti"
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:339
|
#: ../js/ui/components/networkAgent.js:339
|
||||||
|
#, javascript-format
|
||||||
msgid "A password is required to connect to “%s”."
|
msgid "A password is required to connect to “%s”."
|
||||||
msgstr "Pro připojení k „%s“ je vyžadováno heslo."
|
msgstr "Pro připojení k „%s“ je vyžadováno heslo."
|
||||||
|
|
||||||
@ -681,69 +689,74 @@ msgid "Mute"
|
|||||||
msgstr "Ztlumit"
|
msgstr "Ztlumit"
|
||||||
|
|
||||||
#. Translators: this is the word "Yesterday" followed by a time string. i.e. "Yesterday, 14:30"*/
|
#. Translators: this is the word "Yesterday" followed by a time string. i.e. "Yesterday, 14:30"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:941
|
#: ../js/ui/components/telepathyClient.js:952
|
||||||
msgid "<b>Yesterday</b>, <b>%H:%M</b>"
|
msgid "<b>Yesterday</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>Včera</b>, <b>%H.%M</b>"
|
msgstr "<b>Včera</b>, <b>%H.%M</b>"
|
||||||
|
|
||||||
#. Translators: this is the week day name followed by a time string. i.e. "Monday, 14:30*/
|
#. Translators: this is the week day name followed by a time string. i.e. "Monday, 14:30*/
|
||||||
#: ../js/ui/components/telepathyClient.js:947
|
#: ../js/ui/components/telepathyClient.js:958
|
||||||
msgid "<b>%A</b>, <b>%H:%M</b>"
|
msgid "<b>%A</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>%A</b>, <b>%H:%M</b>"
|
msgstr "<b>%A</b>, <b>%H:%M</b>"
|
||||||
|
|
||||||
#. Translators: this is the month name and day number followed by a time string. i.e. "May 25, 14:30"*/
|
#. Translators: this is the month name and day number followed by a time string. i.e. "May 25, 14:30"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:952
|
#: ../js/ui/components/telepathyClient.js:963
|
||||||
msgid "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
msgid "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>%d.</b> <b>%B</b>, <b>%H:%M</b>"
|
msgstr "<b>%d.</b> <b>%B</b>, <b>%H:%M</b>"
|
||||||
|
|
||||||
#. Translators: this is the month name, day number, year number followed by a time string. i.e. "May 25 2012, 14:30"*/
|
#. Translators: this is the month name, day number, year number followed by a time string. i.e. "May 25 2012, 14:30"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:956
|
#: ../js/ui/components/telepathyClient.js:967
|
||||||
msgid "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
msgid "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
||||||
msgstr "<b>%d.</b> <b>%B</b> <b>%Y</b>, <b>%H:%M</b> "
|
msgstr "<b>%d.</b> <b>%B</b> <b>%Y</b>, <b>%H:%M</b> "
|
||||||
|
|
||||||
#. 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:987
|
#: ../js/ui/components/telepathyClient.js:998
|
||||||
|
#, javascript-format
|
||||||
msgid "%s is now known as %s"
|
msgid "%s is now known as %s"
|
||||||
msgstr "%s je teď znám jako %s"
|
msgstr "%s je teď znám jako %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:1090
|
#: ../js/ui/components/telepathyClient.js:1101
|
||||||
|
#, javascript-format
|
||||||
msgid "Invitation to %s"
|
msgid "Invitation to %s"
|
||||||
msgstr "Pozvánka na připojení k %s"
|
msgstr "Pozvánka na připojení k %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:1098
|
#: ../js/ui/components/telepathyClient.js:1109
|
||||||
|
#, javascript-format
|
||||||
msgid "%s is inviting you to join %s"
|
msgid "%s is inviting you to join %s"
|
||||||
msgstr "%s vás zve do %s"
|
msgstr "%s vás zve do %s"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1100
|
#: ../js/ui/components/telepathyClient.js:1111
|
||||||
#: ../js/ui/components/telepathyClient.js:1135
|
#: ../js/ui/components/telepathyClient.js:1146
|
||||||
#: ../js/ui/components/telepathyClient.js:1169
|
#: ../js/ui/components/telepathyClient.js:1180
|
||||||
#: ../js/ui/components/telepathyClient.js:1226
|
#: ../js/ui/components/telepathyClient.js:1237
|
||||||
msgid "Decline"
|
msgid "Decline"
|
||||||
msgstr "Odmítnout"
|
msgstr "Odmítnout"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1106
|
#: ../js/ui/components/telepathyClient.js:1117
|
||||||
#: ../js/ui/components/telepathyClient.js:1175
|
#: ../js/ui/components/telepathyClient.js:1186
|
||||||
#: ../js/ui/components/telepathyClient.js:1231
|
#: ../js/ui/components/telepathyClient.js:1242
|
||||||
msgid "Accept"
|
msgid "Accept"
|
||||||
msgstr "Přijmout"
|
msgstr "Přijmout"
|
||||||
|
|
||||||
#. 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:1125
|
#: ../js/ui/components/telepathyClient.js:1136
|
||||||
|
#, javascript-format
|
||||||
msgid "Video call from %s"
|
msgid "Video call from %s"
|
||||||
msgstr "Videohovor od %s"
|
msgstr "Videohovor od %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:1128
|
#: ../js/ui/components/telepathyClient.js:1139
|
||||||
|
#, javascript-format
|
||||||
msgid "Call from %s"
|
msgid "Call from %s"
|
||||||
msgstr "Hovor od %s"
|
msgstr "Hovor od %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:1142
|
#: ../js/ui/components/telepathyClient.js:1153
|
||||||
msgid "Answer"
|
msgid "Answer"
|
||||||
msgstr "Zvednout"
|
msgstr "Zvednout"
|
||||||
|
|
||||||
@ -752,108 +765,110 @@ msgstr "Zvednout"
|
|||||||
#. * 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:1163
|
#: ../js/ui/components/telepathyClient.js:1174
|
||||||
|
#, javascript-format
|
||||||
msgid "%s is sending you %s"
|
msgid "%s is sending you %s"
|
||||||
msgstr "%s vám posílá %s"
|
msgstr "%s vám posílá %s"
|
||||||
|
|
||||||
#. To translators: The parameter is the contact's alias */
|
#. To translators: The parameter is the contact's alias */
|
||||||
#: ../js/ui/components/telepathyClient.js:1192
|
#: ../js/ui/components/telepathyClient.js:1203
|
||||||
|
#, 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 vás žádá o oprávnění vidět, že jste dostupní"
|
msgstr "%s vás žádá o oprávnění vidět, že jste dostupní"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1277
|
#: ../js/ui/components/telepathyClient.js:1288
|
||||||
msgid "Network error"
|
msgid "Network error"
|
||||||
msgstr "Chyba sítě"
|
msgstr "Chyba sítě"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1279
|
#: ../js/ui/components/telepathyClient.js:1290
|
||||||
msgid "Authentication failed"
|
msgid "Authentication failed"
|
||||||
msgstr "Ověření selhalo"
|
msgstr "Ověření selhalo"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1281
|
#: ../js/ui/components/telepathyClient.js:1292
|
||||||
msgid "Encryption error"
|
msgid "Encryption error"
|
||||||
msgstr "Chyba šifrování"
|
msgstr "Chyba šifrování"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1283
|
#: ../js/ui/components/telepathyClient.js:1294
|
||||||
msgid "Certificate not provided"
|
msgid "Certificate not provided"
|
||||||
msgstr "Certifikát neposkytnut"
|
msgstr "Certifikát neposkytnut"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1285
|
#: ../js/ui/components/telepathyClient.js:1296
|
||||||
msgid "Certificate untrusted"
|
msgid "Certificate untrusted"
|
||||||
msgstr "Nedůvěryhodný certifikát"
|
msgstr "Nedůvěryhodný certifikát"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1287
|
#: ../js/ui/components/telepathyClient.js:1298
|
||||||
msgid "Certificate expired"
|
msgid "Certificate expired"
|
||||||
msgstr "Platnost certifikátu vypršela"
|
msgstr "Platnost certifikátu vypršela"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1289
|
#: ../js/ui/components/telepathyClient.js:1300
|
||||||
msgid "Certificate not activated"
|
msgid "Certificate not activated"
|
||||||
msgstr "Certifikát není aktivován"
|
msgstr "Certifikát není aktivován"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1291
|
#: ../js/ui/components/telepathyClient.js:1302
|
||||||
msgid "Certificate hostname mismatch"
|
msgid "Certificate hostname mismatch"
|
||||||
msgstr "Název počítače certifikátu nesouhlasí"
|
msgstr "Název počítače certifikátu nesouhlasí"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1293
|
#: ../js/ui/components/telepathyClient.js:1304
|
||||||
msgid "Certificate fingerprint mismatch"
|
msgid "Certificate fingerprint mismatch"
|
||||||
msgstr "Otisk prstu certifikátu nesouhlasí"
|
msgstr "Otisk prstu certifikátu nesouhlasí"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1295
|
#: ../js/ui/components/telepathyClient.js:1306
|
||||||
msgid "Certificate self-signed"
|
msgid "Certificate self-signed"
|
||||||
msgstr "Certifikát je podepsán sám sebou"
|
msgstr "Certifikát je podepsán sám sebou"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1297
|
#: ../js/ui/components/telepathyClient.js:1308
|
||||||
msgid "Status is set to offline"
|
msgid "Status is set to offline"
|
||||||
msgstr "Stav nastaven na „Odhlášen“"
|
msgstr "Stav nastaven na „Odhlášen“"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1299
|
#: ../js/ui/components/telepathyClient.js:1310
|
||||||
msgid "Encryption is not available"
|
msgid "Encryption is not available"
|
||||||
msgstr "Šifrování není dostupné"
|
msgstr "Šifrování není dostupné"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1301
|
#: ../js/ui/components/telepathyClient.js:1312
|
||||||
msgid "Certificate is invalid"
|
msgid "Certificate is invalid"
|
||||||
msgstr "Certifikát je neplatný"
|
msgstr "Certifikát je neplatný"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1303
|
#: ../js/ui/components/telepathyClient.js:1314
|
||||||
msgid "Connection has been refused"
|
msgid "Connection has been refused"
|
||||||
msgstr "Spojení bylo odmítnuto"
|
msgstr "Spojení bylo odmítnuto"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1305
|
#: ../js/ui/components/telepathyClient.js:1316
|
||||||
msgid "Connection can't be established"
|
msgid "Connection can't be established"
|
||||||
msgstr "Spojení nemohlo bát navázáno"
|
msgstr "Spojení nemohlo bát navázáno"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1307
|
#: ../js/ui/components/telepathyClient.js:1318
|
||||||
msgid "Connection has been lost"
|
msgid "Connection has been lost"
|
||||||
msgstr "Spojení bylo ztraceno"
|
msgstr "Spojení bylo ztraceno"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1309
|
#: ../js/ui/components/telepathyClient.js:1320
|
||||||
msgid "This account is already connected to the server"
|
msgid "This account is already connected to the server"
|
||||||
msgstr "Tento účet je již připojen k serveru"
|
msgstr "Tento účet je již připojen k serveru"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1311
|
#: ../js/ui/components/telepathyClient.js:1322
|
||||||
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 "Spojení bylo nahrazeno novým spojením, které používá stejný zdroj"
|
msgstr "Spojení bylo nahrazeno novým spojením, které používá stejný zdroj"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1313
|
#: ../js/ui/components/telepathyClient.js:1324
|
||||||
msgid "The account already exists on the server"
|
msgid "The account already exists on the server"
|
||||||
msgstr "Takový účet již na serveru existuje"
|
msgstr "Takový účet již na serveru existuje"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1315
|
#: ../js/ui/components/telepathyClient.js:1326
|
||||||
msgid "Server is currently too busy to handle the connection"
|
msgid "Server is currently too busy to handle the connection"
|
||||||
msgstr "Server je právě příliš zaneprázdněn na to, aby obsloužil spojení"
|
msgstr "Server je právě příliš zaneprázdněn na to, aby obsloužil spojení"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1317
|
#: ../js/ui/components/telepathyClient.js:1328
|
||||||
msgid "Certificate has been revoked"
|
msgid "Certificate has been revoked"
|
||||||
msgstr "Certifikát byl odvolán"
|
msgstr "Certifikát byl odvolán"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1319
|
#: ../js/ui/components/telepathyClient.js:1330
|
||||||
msgid ""
|
msgid ""
|
||||||
"Certificate uses an insecure cipher algorithm or is cryptographically weak"
|
"Certificate uses an insecure cipher algorithm or is cryptographically weak"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Certifikát používá nepříliš bezpečný šifrovací algoritmus nebo je z "
|
"Certifikát používá nepříliš bezpečný šifrovací algoritmus nebo je z "
|
||||||
"kryptografického hlediska slabý"
|
"kryptografického hlediska slabý"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1321
|
#: ../js/ui/components/telepathyClient.js:1332
|
||||||
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"
|
||||||
@ -861,21 +876,22 @@ msgstr ""
|
|||||||
"Délka certifikátu serveru nebo délka zřetězených certifikátů serveru "
|
"Délka certifikátu serveru nebo délka zřetězených certifikátů serveru "
|
||||||
"přesáhla omezení dané kryptografickou knihovnou"
|
"přesáhla omezení dané kryptografickou knihovnou"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1323
|
#: ../js/ui/components/telepathyClient.js:1334
|
||||||
msgid "Internal error"
|
msgid "Internal error"
|
||||||
msgstr "Vnitřní chyba"
|
msgstr "Vnitřní chyba"
|
||||||
|
|
||||||
#. 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:1333
|
#: ../js/ui/components/telepathyClient.js:1344
|
||||||
|
#, javascript-format
|
||||||
msgid "Unable to connect to %s"
|
msgid "Unable to connect to %s"
|
||||||
msgstr "Nelze se připojit k „%s“"
|
msgstr "Nelze se připojit k „%s“"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1338
|
#: ../js/ui/components/telepathyClient.js:1349
|
||||||
msgid "View account"
|
msgid "View account"
|
||||||
msgstr "Zobrazit účet"
|
msgstr "Zobrazit účet"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1370
|
#: ../js/ui/components/telepathyClient.js:1381
|
||||||
msgid "Unknown reason"
|
msgid "Unknown reason"
|
||||||
msgstr "Neznámý důvod"
|
msgstr "Neznámý důvod"
|
||||||
|
|
||||||
@ -912,6 +928,7 @@ msgid "%A %B %e, %Y"
|
|||||||
msgstr "%A, %e. %B, %Y"
|
msgstr "%A, %e. %B, %Y"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:62
|
#: ../js/ui/endSessionDialog.js:62
|
||||||
|
#, javascript-format
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Log Out %s"
|
msgid "Log Out %s"
|
||||||
msgstr "Odhlásit uživatele %s"
|
msgstr "Odhlásit uživatele %s"
|
||||||
@ -922,6 +939,7 @@ msgid "Log Out"
|
|||||||
msgstr "Odhlášení"
|
msgstr "Odhlášení"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:65
|
#: ../js/ui/endSessionDialog.js:65
|
||||||
|
#, 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] "Uživatel %s bude automaticky odhlášen za %d sekundu."
|
msgstr[0] "Uživatel %s bude automaticky odhlášen za %d sekundu."
|
||||||
@ -929,6 +947,7 @@ msgstr[1] "Uživatel %s bude automaticky odhlášen za %d sekundy."
|
|||||||
msgstr[2] "Uživatel %s bude automaticky odhlášen za %d sekund."
|
msgstr[2] "Uživatel %s bude automaticky odhlášen za %d sekund."
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:70
|
#: ../js/ui/endSessionDialog.js:70
|
||||||
|
#, 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] "Budete automaticky odhlášeni za %d sekundu."
|
msgstr[0] "Budete automaticky odhlášeni za %d sekundu."
|
||||||
@ -946,6 +965,7 @@ msgid "Power Off"
|
|||||||
msgstr "Vypnutí"
|
msgstr "Vypnutí"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:83
|
#: ../js/ui/endSessionDialog.js:83
|
||||||
|
#, 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] "Systém bude automaticky vypnut za %d sekundu."
|
msgstr[0] "Systém bude automaticky vypnut za %d sekundu."
|
||||||
@ -968,6 +988,7 @@ msgid "Restart"
|
|||||||
msgstr "Restart"
|
msgstr "Restart"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:99
|
#: ../js/ui/endSessionDialog.js:99
|
||||||
|
#, 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] "Systém bude automaticky restartován za %d sekundu."
|
msgstr[0] "Systém bude automaticky restartován za %d sekundu."
|
||||||
@ -980,6 +1001,7 @@ msgid "Restart & Install Updates"
|
|||||||
msgstr "Restartovat a nainstalovat aktualizace"
|
msgstr "Restartovat a nainstalovat aktualizace"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:114
|
#: ../js/ui/endSessionDialog.js:114
|
||||||
|
#, 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 ""
|
||||||
"The system will automatically restart and install updates in %d seconds."
|
"The system will automatically restart and install updates in %d seconds."
|
||||||
@ -1008,11 +1030,13 @@ msgstr "Jsou přihlášeni jiní uživatelé."
|
|||||||
|
|
||||||
#. 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:486
|
#: ../js/ui/endSessionDialog.js:486
|
||||||
|
#, javascript-format
|
||||||
msgid "%s (remote)"
|
msgid "%s (remote)"
|
||||||
msgstr "%s (vzdálený)"
|
msgstr "%s (vzdálený)"
|
||||||
|
|
||||||
#. 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:489
|
#: ../js/ui/endSessionDialog.js:489
|
||||||
|
#, javascript-format
|
||||||
msgid "%s (console)"
|
msgid "%s (console)"
|
||||||
msgstr "%s (konzola)"
|
msgstr "%s (konzola)"
|
||||||
|
|
||||||
@ -1021,6 +1045,7 @@ msgid "Install"
|
|||||||
msgstr "Instalovat"
|
msgstr "Instalovat"
|
||||||
|
|
||||||
#: ../js/ui/extensionDownloader.js:204
|
#: ../js/ui/extensionDownloader.js:204
|
||||||
|
#, javascript-format
|
||||||
msgid "Download and install “%s” from extensions.gnome.org?"
|
msgid "Download and install “%s” from extensions.gnome.org?"
|
||||||
msgstr "Stáhnout a nainstalovat „%s“ z extensions.gnome.org?"
|
msgstr "Stáhnout a nainstalovat „%s“ z extensions.gnome.org?"
|
||||||
|
|
||||||
@ -1034,6 +1059,7 @@ msgstr "Nejsou nainstalována žádná rozšíření"
|
|||||||
|
|
||||||
#. Translators: argument is an extension UUID. */
|
#. Translators: argument is an extension UUID. */
|
||||||
#: ../js/ui/lookingGlass.js:695
|
#: ../js/ui/lookingGlass.js:695
|
||||||
|
#, javascript-format
|
||||||
msgid "%s has not emitted any errors."
|
msgid "%s has not emitted any errors."
|
||||||
msgstr "Rozšíření %s nevyvolalo žádné chyby."
|
msgstr "Rozšíření %s nevyvolalo žádné chyby."
|
||||||
|
|
||||||
@ -1053,7 +1079,7 @@ msgstr "Povoleno"
|
|||||||
#. 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:717 ../js/ui/status/network.js:470
|
#: ../js/ui/lookingGlass.js:717 ../js/ui/status/network.js:523
|
||||||
#: ../src/gvc/gvc-mixer-control.c:1830
|
#: ../src/gvc/gvc-mixer-control.c:1830
|
||||||
msgid "Disabled"
|
msgid "Disabled"
|
||||||
msgstr "Zakázáno"
|
msgstr "Zakázáno"
|
||||||
@ -1078,48 +1104,49 @@ msgstr "Zobrazit zdroj"
|
|||||||
msgid "Web Page"
|
msgid "Web Page"
|
||||||
msgstr "Webová stránka"
|
msgstr "Webová stránka"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1309
|
#: ../js/ui/messageTray.js:1312
|
||||||
msgid "Open"
|
msgid "Open"
|
||||||
msgstr "Otevřít"
|
msgstr "Otevřít"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1316
|
#: ../js/ui/messageTray.js:1319
|
||||||
msgid "Remove"
|
msgid "Remove"
|
||||||
msgstr "Odstranit"
|
msgstr "Odstranit"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1613
|
#: ../js/ui/messageTray.js:1616
|
||||||
msgid "Notifications"
|
msgid "Notifications"
|
||||||
msgstr "Upozornění"
|
msgstr "Upozornění"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1620
|
#: ../js/ui/messageTray.js:1623
|
||||||
msgid "Clear Messages"
|
msgid "Clear Messages"
|
||||||
msgstr "Vymazat zprávy"
|
msgstr "Vymazat zprávy"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1639
|
#: ../js/ui/messageTray.js:1642
|
||||||
msgid "Notification Settings"
|
msgid "Notification Settings"
|
||||||
msgstr "Nastavení upozornění"
|
msgstr "Nastavení upozornění"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1692
|
#: ../js/ui/messageTray.js:1695
|
||||||
msgid "Tray Menu"
|
msgid "Tray Menu"
|
||||||
msgstr "Nabídka lišty zpráv"
|
msgstr "Nabídka lišty zpráv"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1909
|
#: ../js/ui/messageTray.js:1912
|
||||||
msgid "No Messages"
|
msgid "No Messages"
|
||||||
msgstr "Žádné zprávy"
|
msgstr "Žádné zprávy"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1947
|
#: ../js/ui/messageTray.js:1950
|
||||||
msgid "Message Tray"
|
msgid "Message Tray"
|
||||||
msgstr "Lišta zpráv"
|
msgstr "Lišta zpráv"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:2931
|
#: ../js/ui/messageTray.js:2934
|
||||||
msgid "System Information"
|
msgid "System Information"
|
||||||
msgstr "Informace o systému"
|
msgstr "Informace o systému"
|
||||||
|
|
||||||
#: ../js/ui/notificationDaemon.js:515 ../src/shell-app.c:397
|
#: ../js/ui/notificationDaemon.js:515 ../src/shell-app.c:399
|
||||||
msgctxt "program"
|
msgctxt "program"
|
||||||
msgid "Unknown"
|
msgid "Unknown"
|
||||||
msgstr "Neznámé"
|
msgstr "Neznámé"
|
||||||
|
|
||||||
#: ../js/ui/overviewControls.js:483 ../js/ui/screenShield.js:151
|
#: ../js/ui/overviewControls.js:483 ../js/ui/screenShield.js:151
|
||||||
|
#, javascript-format
|
||||||
msgid "%d new message"
|
msgid "%d new message"
|
||||||
msgid_plural "%d new messages"
|
msgid_plural "%d new messages"
|
||||||
msgstr[0] "%d nová zpráva"
|
msgstr[0] "%d nová zpráva"
|
||||||
@ -1152,7 +1179,7 @@ msgstr "Ukončit"
|
|||||||
msgid "Activities"
|
msgid "Activities"
|
||||||
msgstr "Činnosti"
|
msgstr "Činnosti"
|
||||||
|
|
||||||
#: ../js/ui/panel.js:903
|
#: ../js/ui/panel.js:905
|
||||||
msgid "Top Bar"
|
msgid "Top Bar"
|
||||||
msgstr "Horní lišta"
|
msgstr "Horní lišta"
|
||||||
|
|
||||||
@ -1175,25 +1202,26 @@ msgid "%A, %B %d"
|
|||||||
msgstr "%A, %e. %B"
|
msgstr "%A, %e. %B"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:153
|
#: ../js/ui/screenShield.js:153
|
||||||
|
#, javascript-format
|
||||||
msgid "%d new notification"
|
msgid "%d new notification"
|
||||||
msgid_plural "%d new notifications"
|
msgid_plural "%d new notifications"
|
||||||
msgstr[0] "%d nové upozornění"
|
msgstr[0] "%d nové upozornění"
|
||||||
msgstr[1] "%d nová upozornění"
|
msgstr[1] "%d nová upozornění"
|
||||||
msgstr[2] "%d nových upozornění"
|
msgstr[2] "%d nových upozornění"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:472 ../js/ui/status/system.js:342
|
#: ../js/ui/screenShield.js:473 ../js/ui/status/system.js:342
|
||||||
msgid "Lock"
|
msgid "Lock"
|
||||||
msgstr "Uzamknout"
|
msgstr "Uzamknout"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:706
|
#: ../js/ui/screenShield.js:707
|
||||||
msgid "GNOME needs to lock the screen"
|
msgid "GNOME needs to lock the screen"
|
||||||
msgstr "GNOME potřebuje uzamknout obrazovku"
|
msgstr "GNOME potřebuje uzamknout obrazovku"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:833 ../js/ui/screenShield.js:1300
|
#: ../js/ui/screenShield.js:834 ../js/ui/screenShield.js:1301
|
||||||
msgid "Unable to lock"
|
msgid "Unable to lock"
|
||||||
msgstr "Nelze uzamknout obrazovku"
|
msgstr "Nelze uzamknout obrazovku"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:834 ../js/ui/screenShield.js:1301
|
#: ../js/ui/screenShield.js:835 ../js/ui/screenShield.js:1302
|
||||||
msgid "Lock was blocked by an application"
|
msgid "Lock was blocked by an application"
|
||||||
msgstr "Zamknutí bylo zablokováno některou z aplikací"
|
msgstr "Zamknutí bylo zablokováno některou z aplikací"
|
||||||
|
|
||||||
@ -1273,26 +1301,32 @@ msgstr "Vysoký kontrast"
|
|||||||
msgid "Large Text"
|
msgid "Large Text"
|
||||||
msgstr "Styl velkého textu"
|
msgstr "Styl velkého textu"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:45
|
#: ../js/ui/status/bluetooth.js:48
|
||||||
msgid "Bluetooth"
|
msgid "Bluetooth"
|
||||||
msgstr "Bluetooth"
|
msgstr "Bluetooth"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:47 ../js/ui/status/network.js:131
|
#: ../js/ui/status/bluetooth.js:50 ../js/ui/status/network.js:134
|
||||||
#: ../js/ui/status/network.js:1081 ../js/ui/status/rfkill.js:48
|
#: ../js/ui/status/network.js:1209 ../js/ui/status/rfkill.js:85
|
||||||
|
#: ../js/ui/status/rfkill.js:105
|
||||||
msgid "Turn Off"
|
msgid "Turn Off"
|
||||||
msgstr "Vypnout"
|
msgstr "Vypnout"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:50
|
#: ../js/ui/status/bluetooth.js:53
|
||||||
msgid "Bluetooth Settings"
|
msgid "Bluetooth Settings"
|
||||||
msgstr "Nastavení Bluetooth"
|
msgstr "Nastavení Bluetooth"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:98
|
#: ../js/ui/status/bluetooth.js:100
|
||||||
|
#, javascript-format
|
||||||
msgid "%d Connected Device"
|
msgid "%d Connected Device"
|
||||||
msgid_plural "%d Connected Devices"
|
msgid_plural "%d Connected Devices"
|
||||||
msgstr[0] "%d připojené zařízení"
|
msgstr[0] "%d připojené zařízení"
|
||||||
msgstr[1] "%d připojená zařízení"
|
msgstr[1] "%d připojená zařízení"
|
||||||
msgstr[2] "%d připojených zařízení"
|
msgstr[2] "%d připojených zařízení"
|
||||||
|
|
||||||
|
#: ../js/ui/status/bluetooth.js:102 ../js/ui/status/network.js:1232
|
||||||
|
msgid "Not Connected"
|
||||||
|
msgstr "Nepřipojeno"
|
||||||
|
|
||||||
#: ../js/ui/status/brightness.js:44
|
#: ../js/ui/status/brightness.js:44
|
||||||
msgid "Brightness"
|
msgid "Brightness"
|
||||||
msgstr "Jas"
|
msgstr "Jas"
|
||||||
@ -1301,99 +1335,131 @@ msgstr "Jas"
|
|||||||
msgid "Show Keyboard Layout"
|
msgid "Show Keyboard Layout"
|
||||||
msgstr "Zobrazit rozložení klávesnice"
|
msgstr "Zobrazit rozložení klávesnice"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:70
|
#: ../js/ui/status/network.js:73
|
||||||
msgid "<unknown>"
|
msgid "<unknown>"
|
||||||
msgstr "<neznámé>"
|
msgstr "<neznámé>"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:220 ../js/ui/status/network.js:377
|
#: ../js/ui/status/network.js:223 ../js/ui/status/network.js:389
|
||||||
#: ../js/ui/status/network.js:1102
|
#: ../js/ui/status/network.js:1230
|
||||||
msgid "Off"
|
msgid "Off"
|
||||||
msgstr "Vypnuto"
|
msgstr "Vypnuto"
|
||||||
|
|
||||||
#. 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:383
|
#: ../js/ui/status/network.js:395
|
||||||
msgid "unmanaged"
|
msgid "unmanaged"
|
||||||
msgstr "nespravováno"
|
msgstr "nespravováno"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:385
|
#: ../js/ui/status/network.js:397
|
||||||
msgid "disconnecting..."
|
msgid "disconnecting..."
|
||||||
msgstr "odpojování…"
|
msgstr "odpojování…"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:391 ../js/ui/status/network.js:1156
|
#: ../js/ui/status/network.js:403 ../js/ui/status/network.js:1284
|
||||||
msgid "connecting..."
|
msgid "connecting..."
|
||||||
msgstr "připojování…"
|
msgstr "připojování…"
|
||||||
|
|
||||||
#. 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:394 ../js/ui/status/network.js:1159
|
#: ../js/ui/status/network.js:406 ../js/ui/status/network.js:1287
|
||||||
msgid "authentication required"
|
msgid "authentication required"
|
||||||
msgstr "je vyžadováno ověření"
|
msgstr "je vyžadováno ověření"
|
||||||
|
|
||||||
#. 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:402
|
#: ../js/ui/status/network.js:414
|
||||||
msgid "firmware missing"
|
msgid "firmware missing"
|
||||||
msgstr "nedostupný firmware"
|
msgstr "nedostupný 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:406
|
#: ../js/ui/status/network.js:418
|
||||||
msgid "unavailable"
|
msgid "unavailable"
|
||||||
msgstr "nedostupné"
|
msgstr "nedostupné"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:408 ../js/ui/status/network.js:1161
|
#: ../js/ui/status/network.js:420 ../js/ui/status/network.js:1289
|
||||||
msgid "connection failed"
|
msgid "connection failed"
|
||||||
msgstr "připojení selhalo"
|
msgstr "připojení selhalo"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:424 ../js/ui/status/network.js:510
|
#: ../js/ui/status/network.js:436
|
||||||
|
msgid "Wired Settings"
|
||||||
|
msgstr "Nastavení připojení po drátu"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:477 ../js/ui/status/network.js:563
|
||||||
msgid "Mobile Broadband Settings"
|
msgid "Mobile Broadband Settings"
|
||||||
msgstr "Nastavení mobilní širokopásmové sítě"
|
msgstr "Nastavení mobilní širokopásmové sítě"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:466 ../js/ui/status/network.js:1100
|
#: ../js/ui/status/network.js:519 ../js/ui/status/network.js:1228
|
||||||
msgid "Hardware Disabled"
|
msgid "Hardware Disabled"
|
||||||
msgstr "Hardware zakázán"
|
msgstr "Hardware zakázán"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:692
|
#: ../js/ui/status/network.js:578
|
||||||
|
msgid "Use as Internet connection"
|
||||||
|
msgstr "Použít jako připojení k Internetu"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:755
|
||||||
|
msgid "Airplane Mode is On"
|
||||||
|
msgstr "Režim „letadlo“ je zapnutý"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:756
|
||||||
|
msgid "Wi-Fi is disabled when airplane mode is on."
|
||||||
|
msgstr "Když je zapnutý režim „letadlo“, je WiFi zakázána."
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:757
|
||||||
|
msgid "Turn Off Airplane Mode"
|
||||||
|
msgstr "Vypnout režim „letadlo“"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:766
|
||||||
|
msgid "Wi-Fi is Off"
|
||||||
|
msgstr "WiFi je vypnutá"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:767
|
||||||
|
msgid "Wi-Fi needs to be turned on in order to connect to a network."
|
||||||
|
msgstr "Abyste se připojili k síti, je zapotřebí zapnout WiFi."
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:768
|
||||||
|
msgid "Turn On Wi-Fi"
|
||||||
|
msgstr "Zapnout WiFi"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:793
|
||||||
msgid "Wi-Fi Networks"
|
msgid "Wi-Fi Networks"
|
||||||
msgstr "Sítě WiFi"
|
msgstr "Sítě WiFi"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:694
|
#: ../js/ui/status/network.js:795
|
||||||
msgid "Select a network"
|
msgid "Select a network"
|
||||||
msgstr "Vyberte síť"
|
msgstr "Vyberte síť"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:718
|
#: ../js/ui/status/network.js:824
|
||||||
msgid "No Networks"
|
msgid "No Networks"
|
||||||
msgstr "Žádné sítě"
|
msgstr "Žádné sítě"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:987
|
#: ../js/ui/status/network.js:845 ../js/ui/status/rfkill.js:103
|
||||||
|
msgid "Use hardware switch to turn off"
|
||||||
|
msgstr "K vypnutí použijte fyzický vypínač"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:1115
|
||||||
msgid "Select Network"
|
msgid "Select Network"
|
||||||
msgstr "Vybrat síť"
|
msgstr "Vybrat síť"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:993
|
#: ../js/ui/status/network.js:1121
|
||||||
msgid "Wi-Fi Settings"
|
msgid "Wi-Fi Settings"
|
||||||
msgstr "Nastavení WiFi"
|
msgstr "Nastavení WiFi"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1081
|
#: ../js/ui/status/network.js:1209
|
||||||
msgid "Turn On"
|
msgid "Turn On"
|
||||||
msgstr "Zapnout"
|
msgstr "Zapnout"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1104
|
#: ../js/ui/status/network.js:1352
|
||||||
msgid "Not Connected"
|
|
||||||
msgstr "Nepřipojeno"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1224
|
|
||||||
msgid "VPN"
|
msgid "VPN"
|
||||||
msgstr "VPN"
|
msgstr "VPN"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1364
|
#: ../js/ui/status/network.js:1495
|
||||||
msgid "Network Manager"
|
msgid "Network Manager"
|
||||||
msgstr "Network Manager"
|
msgstr "Network Manager"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1403
|
#: ../js/ui/status/network.js:1534
|
||||||
msgid "Connection failed"
|
msgid "Connection failed"
|
||||||
msgstr "Připojení selhalo"
|
msgstr "Připojení selhalo"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1404
|
#: ../js/ui/status/network.js:1535
|
||||||
msgid "Activation of network connection failed"
|
msgid "Activation of network connection failed"
|
||||||
msgstr "Aktivace síťového připojení selhala"
|
msgstr "Aktivace síťového připojení selhala"
|
||||||
|
|
||||||
@ -1410,10 +1476,12 @@ msgid "Estimating…"
|
|||||||
msgstr "Odhaduje se…"
|
msgstr "Odhaduje se…"
|
||||||
|
|
||||||
#: ../js/ui/status/power.js:86
|
#: ../js/ui/status/power.js:86
|
||||||
|
#, javascript-format
|
||||||
msgid "%d∶%02d Remaining (%d%%)"
|
msgid "%d∶%02d Remaining (%d%%)"
|
||||||
msgstr "Zbývá %d∶%02d (%d %%)"
|
msgstr "Zbývá %d∶%02d (%d %%)"
|
||||||
|
|
||||||
#: ../js/ui/status/power.js:91
|
#: ../js/ui/status/power.js:91
|
||||||
|
#, javascript-format
|
||||||
msgid "%d∶%02d Until Full (%d%%)"
|
msgid "%d∶%02d Until Full (%d%%)"
|
||||||
msgstr "%d∶%02d do nabití (%d %%)"
|
msgstr "%d∶%02d do nabití (%d %%)"
|
||||||
|
|
||||||
@ -1425,15 +1493,15 @@ msgstr "Záložní zdroj"
|
|||||||
msgid "Battery"
|
msgid "Battery"
|
||||||
msgstr "Baterie"
|
msgstr "Baterie"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:45
|
#: ../js/ui/status/rfkill.js:82
|
||||||
msgid "Airplane Mode"
|
msgid "Airplane Mode"
|
||||||
msgstr "Režim „letadlo“"
|
msgstr "Režim „letadlo“"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:47
|
#: ../js/ui/status/rfkill.js:84
|
||||||
msgid "On"
|
msgid "On"
|
||||||
msgstr "Zapnuto"
|
msgstr "Zapnuto"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:51
|
#: ../js/ui/status/rfkill.js:88
|
||||||
msgid "Network Settings"
|
msgid "Network Settings"
|
||||||
msgstr "Nastavení sítě"
|
msgstr "Nastavení sítě"
|
||||||
|
|
||||||
@ -1486,6 +1554,7 @@ msgid "Search"
|
|||||||
msgstr "Hledat"
|
msgstr "Hledat"
|
||||||
|
|
||||||
#: ../js/ui/windowAttentionHandler.js:19
|
#: ../js/ui/windowAttentionHandler.js:19
|
||||||
|
#, javascript-format
|
||||||
msgid "“%s” is ready"
|
msgid "“%s” is ready"
|
||||||
msgstr "Připraveno „%s“"
|
msgstr "Připraveno „%s“"
|
||||||
|
|
||||||
@ -1505,6 +1574,7 @@ msgid "Keep Changes"
|
|||||||
msgstr "Zachovat"
|
msgstr "Zachovat"
|
||||||
|
|
||||||
#: ../js/ui/windowManager.js:97
|
#: ../js/ui/windowManager.js:97
|
||||||
|
#, 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] "Nastavení se obnoví na původní za %d sekundu"
|
msgstr[0] "Nastavení se obnoví na původní za %d sekundu"
|
||||||
@ -1555,7 +1625,7 @@ msgstr "Použít pro přihlašovací obrazovku zadaný režim, např. „gdm“.
|
|||||||
msgid "List possible modes"
|
msgid "List possible modes"
|
||||||
msgstr "Vypsat možné režimy"
|
msgstr "Vypsat možné režimy"
|
||||||
|
|
||||||
#: ../src/shell-app.c:640
|
#: ../src/shell-app.c:642
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to launch “%s”"
|
msgid "Failed to launch “%s”"
|
||||||
msgstr "Nelze spustit „%s“"
|
msgstr "Nelze spustit „%s“"
|
||||||
|
313
po/el.po
313
po/el.po
@ -7,16 +7,16 @@ msgstr ""
|
|||||||
"Project-Id-Version: gnome-shell.po.master\n"
|
"Project-Id-Version: gnome-shell.po.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-01-10 21:15+0000\n"
|
"POT-Creation-Date: 2014-01-29 20:43+0000\n"
|
||||||
"PO-Revision-Date: 2014-01-11 14:55+0300\n"
|
"PO-Revision-Date: 2014-01-30 20:22+0300\n"
|
||||||
"Last-Translator: Dimitris Spingos (Δημήτρης Σπίγγος) <dmtrs32@gmail.com>\n"
|
"Last-Translator: Dimitris Spingos (Δημήτρης Σπίγγος) <dmtrs32@gmail.com>\n"
|
||||||
"Language-Team: www.gnome.gr\n"
|
"Language-Team: team@lists.gnome.gr\n"
|
||||||
"Language: el\n"
|
"Language: el\n"
|
||||||
"MIME-Version: 1.0\n"
|
"MIME-Version: 1.0\n"
|
||||||
"Content-Type: text/plain; charset=UTF-8\n"
|
"Content-Type: text/plain; charset=UTF-8\n"
|
||||||
"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-Generator: Virtaal 0.7.1\n"
|
"X-Generator: Virtaal 0.7.0\n"
|
||||||
"X-DamnedLies-Scope: partial\n"
|
"X-DamnedLies-Scope: partial\n"
|
||||||
"X-Poedit-SourceCharset: utf-8\n"
|
"X-Poedit-SourceCharset: utf-8\n"
|
||||||
"X-Project-Style: gnome\n"
|
"X-Project-Style: gnome\n"
|
||||||
@ -111,30 +111,18 @@ msgstr ""
|
|||||||
"περιοχή αγαπημένων."
|
"περιοχή αγαπημένων."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:7
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:7
|
||||||
msgid "List of categories that should be displayed as folders"
|
|
||||||
msgstr "Η λίστα των κατηγοριών που πρέπει να εμφανίζονται ως φάκελοι"
|
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:8
|
|
||||||
msgid ""
|
|
||||||
"Each category name in this list will be represented as folder in the "
|
|
||||||
"application view, rather than being displayed inline in the main view."
|
|
||||||
msgstr ""
|
|
||||||
"Το όνομα κάθε κατηγορίας σε αυτή τη λίστα θα αναπαριστάται ως φάκελος στην "
|
|
||||||
"προβολή εφαρμογής, αντί να εμφανίζεται ενσωματωμένο στην κύρια προβολή."
|
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:9
|
|
||||||
msgid "History for command (Alt-F2) dialog"
|
msgid "History for command (Alt-F2) dialog"
|
||||||
msgstr "Ιστορικό του διαλόγου εντολών (Alt-F2)"
|
msgstr "Ιστορικό του διαλόγου εντολών (Alt-F2)"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:10
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:8
|
||||||
msgid "History for the looking glass dialog"
|
msgid "History for the looking glass dialog"
|
||||||
msgstr "Ιστορικό του διαλόγου καθρέπτη"
|
msgstr "Ιστορικό του διαλόγου καθρέπτη"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:11
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:9
|
||||||
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:12
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:10
|
||||||
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."
|
||||||
@ -142,14 +130,14 @@ msgstr ""
|
|||||||
"Αυτό το κλειδί υπερισχύει της αυτόματης απόκρυψης του στοιχείου μενού "
|
"Αυτό το κλειδί υπερισχύει της αυτόματης απόκρυψης του στοιχείου μενού "
|
||||||
"'Αποσύνδεση' σε μεμονωμένο χρήστη, σε καταστάσεις μεμονωμένης συνεδρίας."
|
"'Αποσύνδεση' σε μεμονωμένο χρήστη, σε καταστάσεις μεμονωμένης συνεδρίας."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:13
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:11
|
||||||
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:14
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:12
|
||||||
msgid ""
|
msgid ""
|
||||||
"The shell will request a password when an encrypted device or a remote "
|
"The shell will request a password when an encrypted device or a remote "
|
||||||
"filesystem is mounted. If the password can be saved for future use a "
|
"filesystem is mounted. If the password can be saved for future use a "
|
||||||
@ -162,71 +150,71 @@ msgstr ""
|
|||||||
"μην απαιτείται ο κωδικός πρόσβασης'. Αυτό το κλειδί ορίζει την προεπιλεγμένη "
|
"μην απαιτείται ο κωδικός πρόσβασης'. Αυτό το κλειδί ορίζει την προεπιλεγμένη "
|
||||||
"κατάσταση του πλαισίου ελέγχου."
|
"κατάσταση του πλαισίου ελέγχου."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:15
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:13
|
||||||
msgid "Show the week date in the calendar"
|
msgid "Show the week date in the calendar"
|
||||||
msgstr "Εμφάνιση του αριθμού εβδομάδας στο ημερολόγιο"
|
msgstr "Εμφάνιση του αριθμού εβδομάδας στο ημερολόγιο"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:16
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:14
|
||||||
msgid "If true, display the ISO week date in the calendar."
|
msgid "If true, display the ISO week date in the calendar."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Αν αληθές, εμφανίζει τον αριθμό εβδομάδας σύμφωνα με το ISO στο ημερολόγιο."
|
"Αν αληθές, εμφανίζει τον αριθμό εβδομάδας σύμφωνα με το ISO στο ημερολόγιο."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:17
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:15
|
||||||
msgid "Keybinding to open the application menu"
|
msgid "Keybinding to open the application menu"
|
||||||
msgstr "Συνδυασμός πλήκτρων για το άνοιγμα του μενού εφαρμογών"
|
msgstr "Συνδυασμός πλήκτρων για το άνοιγμα του μενού εφαρμογών"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:18
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:16
|
||||||
msgid "Keybinding to open the application menu."
|
msgid "Keybinding to open the application menu."
|
||||||
msgstr "Συνδυασμός πλήκτρων για το άνοιγμα του μενού εφαρμογών."
|
msgstr "Συνδυασμός πλήκτρων για το άνοιγμα του μενού εφαρμογών."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:19
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:17
|
||||||
msgid "Keybinding to open the \"Show Applications\" view"
|
msgid "Keybinding to open the \"Show Applications\" view"
|
||||||
msgstr "Συνδυασμός πλήκτρων για το άνοιγμα της προβολής \"Εμφάνιση εφαρμογών\""
|
msgstr "Συνδυασμός πλήκτρων για το άνοιγμα της προβολής \"Εμφάνιση εφαρμογών\""
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:20
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:18
|
||||||
msgid ""
|
msgid ""
|
||||||
"Keybinding to open the \"Show Applications\" view of the Activities Overview."
|
"Keybinding to open the \"Show Applications\" view of the Activities Overview."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Ο συνδυασμός πλήκτρων για το άνοιγμα της προβολής \"Εμφάνιση εφαρμογών\" της "
|
"Ο συνδυασμός πλήκτρων για το άνοιγμα της προβολής \"Εμφάνιση εφαρμογών\" της "
|
||||||
"επισκόπησης ενεργειών."
|
"επισκόπησης ενεργειών."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:21
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:19
|
||||||
msgid "Keybinding to open the overview"
|
msgid "Keybinding to open the overview"
|
||||||
msgstr "Συνδυασμός πλήκτρων για το άνοιγμα της επισκόπησης"
|
msgstr "Συνδυασμός πλήκτρων για το άνοιγμα της επισκόπησης"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:22
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:20
|
||||||
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:23
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:21
|
||||||
msgid "Keybinding to toggle the visibility of the message tray"
|
msgid "Keybinding to toggle the visibility of the message tray"
|
||||||
msgstr "Συνδυασμός πλήκτρων για εναλλαγή ορατότητας της περιοχής ειδοποιήσεων"
|
msgstr "Συνδυασμός πλήκτρων για εναλλαγή ορατότητας της περιοχής ειδοποιήσεων"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:24
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:22
|
||||||
msgid "Keybinding to toggle the visibility of the message tray."
|
msgid "Keybinding to toggle the visibility of the message tray."
|
||||||
msgstr "Συνδυασμός πλήκτρων για εναλλαγή ορατότητας της περιοχής ειδοποιήσεων."
|
msgstr "Συνδυασμός πλήκτρων για εναλλαγή ορατότητας της περιοχής ειδοποιήσεων."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:25
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:23
|
||||||
msgid "Keybinding to focus the active notification"
|
msgid "Keybinding to focus the active notification"
|
||||||
msgstr "Συνδυασμός πλήκτρων για εστίαση της ενεργής ειδοποίησης"
|
msgstr "Συνδυασμός πλήκτρων για εστίαση της ενεργής ειδοποίησης"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:26
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:24
|
||||||
msgid "Keybinding to focus the active notification."
|
msgid "Keybinding to focus the active notification."
|
||||||
msgstr "Συνδυασμός πλήκτρων για εστίαση της ενεργής ειδοποίησης."
|
msgstr "Συνδυασμός πλήκτρων για εστίαση της ενεργής ειδοποίησης."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:27
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:25
|
||||||
msgid "Which keyboard to use"
|
msgid "Which keyboard to use"
|
||||||
msgstr "Ποιο πληκτρολόγιο θα χρησιμοποιηθεί"
|
msgstr "Ποιο πληκτρολόγιο θα χρησιμοποιηθεί"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:28
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:26
|
||||||
msgid "The type of keyboard to use."
|
msgid "The type of keyboard to use."
|
||||||
msgstr "Ο τύπος του πληκτρολογίου που θα χρησιμοποιηθεί."
|
msgstr "Ο τύπος του πληκτρολογίου που θα χρησιμοποιηθεί."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:29
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:27
|
||||||
msgid "The application icon mode."
|
msgid "The application icon mode."
|
||||||
msgstr "Η κατάσταση εικονιδίου εφαρμογής."
|
msgstr "Η κατάσταση εικονιδίου εφαρμογής."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:30
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:28
|
||||||
msgid ""
|
msgid ""
|
||||||
"Configures how the windows are shown in the switcher. Valid possibilities "
|
"Configures how the windows are shown in the switcher. Valid possibilities "
|
||||||
"are 'thumbnail-only' (shows a thumbnail of the window), 'app-icon-"
|
"are 'thumbnail-only' (shows a thumbnail of the window), 'app-icon-"
|
||||||
@ -237,22 +225,22 @@ msgstr ""
|
|||||||
"παραθύρου), 'app-icon-only' (εμφανίζει μόνο το εικονίδιο της εφαρμογής) ή "
|
"παραθύρου), 'app-icon-only' (εμφανίζει μόνο το εικονίδιο της εφαρμογής) ή "
|
||||||
"'both' - και τα δύο."
|
"'both' - και τα δύο."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:31
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:29
|
||||||
msgid "Attach modal dialog to the parent window"
|
msgid "Attach modal dialog to the parent window"
|
||||||
msgstr "Προσάρτηση αποκλειστικού διαλόγου στο γονικό παράθυρο"
|
msgstr "Προσάρτηση αποκλειστικού διαλόγου στο γονικό παράθυρο"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:32
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:30
|
||||||
msgid ""
|
msgid ""
|
||||||
"This key overrides the key in org.gnome.mutter when running GNOME Shell."
|
"This key overrides the key in org.gnome.mutter when running GNOME Shell."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Αυτό το κλειδί υπερισχύει του κλειδιού στο org.gnome.mutter όταν εκτελείται "
|
"Αυτό το κλειδί υπερισχύει του κλειδιού στο org.gnome.mutter όταν εκτελείται "
|
||||||
"το GNOME Shell."
|
"το GNOME Shell."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:33
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:31
|
||||||
msgid "Arrangement of buttons on the titlebar"
|
msgid "Arrangement of buttons on the titlebar"
|
||||||
msgstr "Διάταξη των κουμπιών στη γραμμή τίτλου"
|
msgstr "Διάταξη των κουμπιών στη γραμμή τίτλου"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:34
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:32
|
||||||
msgid ""
|
msgid ""
|
||||||
"This key overrides the key in org.gnome.desktop.wm.preferences when running "
|
"This key overrides the key in org.gnome.desktop.wm.preferences when running "
|
||||||
"GNOME Shell."
|
"GNOME Shell."
|
||||||
@ -260,21 +248,21 @@ msgstr ""
|
|||||||
"Αυτό το κλειδί υπερισχύει του κλειδιού στο org.gnome.desktop.wm.preferences "
|
"Αυτό το κλειδί υπερισχύει του κλειδιού στο org.gnome.desktop.wm.preferences "
|
||||||
"όταν εκτελείται το GNOME Shell."
|
"όταν εκτελείται το GNOME Shell."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:35
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:33
|
||||||
msgid "Enable edge tiling when dropping windows on screen edges"
|
msgid "Enable edge tiling when dropping windows on screen edges"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Ενεργοποίηση της προσάρτηση άκρων, όταν αφήνετε παράθυρα στις άκρες της "
|
"Ενεργοποίηση της προσάρτηση άκρων, όταν αφήνετε παράθυρα στις άκρες της "
|
||||||
"οθόνης"
|
"οθόνης"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:36
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:34
|
||||||
msgid "Workspaces are managed dynamically"
|
msgid "Workspaces are managed dynamically"
|
||||||
msgstr "Οι χώροι εργασίας διαχειρίζονται δυναμικά"
|
msgstr "Οι χώροι εργασίας διαχειρίζονται δυναμικά"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:37
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:35
|
||||||
msgid "Workspaces only on primary monitor"
|
msgid "Workspaces only on primary monitor"
|
||||||
msgstr "Χώροι εργασίας μόνο στην κύρια οθόνη"
|
msgstr "Χώροι εργασίας μόνο στην κύρια οθόνη"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:38
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:36
|
||||||
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 ""
|
||||||
"Καθυστέρηση εστίασης αλλαγών στην κατάσταση ποντικιού μέχρι να σταματήσει να "
|
"Καθυστέρηση εστίασης αλλαγών στην κατάσταση ποντικιού μέχρι να σταματήσει να "
|
||||||
@ -300,7 +288,7 @@ msgstr ""
|
|||||||
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
||||||
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
||||||
#: ../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:726
|
#: ../js/ui/status/network.js:757
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
msgstr "Ακύρωση"
|
msgstr "Ακύρωση"
|
||||||
|
|
||||||
@ -358,30 +346,30 @@ 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:"
|
||||||
msgstr "Η εκτέλεση του '%s' απέτυχε:"
|
msgstr "Η εκτέλεση του “%s” απέτυχε:"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:600
|
#: ../js/ui/appDisplay.js:633
|
||||||
msgid "Frequently used applications will appear here"
|
msgid "Frequently used applications will appear here"
|
||||||
msgstr "Οι συχνά χρησιμοποιούμενες εφαρμογές θα εμφανιστούν εδώ"
|
msgstr "Οι συχνά χρησιμοποιούμενες εφαρμογές θα εμφανιστούν εδώ"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:719
|
#: ../js/ui/appDisplay.js:744
|
||||||
msgid "Frequent"
|
msgid "Frequent"
|
||||||
msgstr "Συχνά"
|
msgstr "Συχνά"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:726
|
#: ../js/ui/appDisplay.js:751
|
||||||
msgid "All"
|
msgid "All"
|
||||||
msgstr "Όλα"
|
msgstr "Όλα"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1546
|
#: ../js/ui/appDisplay.js:1558
|
||||||
msgid "New Window"
|
msgid "New Window"
|
||||||
msgstr "Νέο παράθυρο"
|
msgstr "Νέο παράθυρο"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1549 ../js/ui/dash.js:285
|
#: ../js/ui/appDisplay.js:1580 ../js/ui/dash.js:285
|
||||||
msgid "Remove from Favorites"
|
msgid "Remove from Favorites"
|
||||||
msgstr "Αφαίρεση από τα αγαπημένα"
|
msgstr "Αφαίρεση από τα αγαπημένα"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1550
|
#: ../js/ui/appDisplay.js:1586
|
||||||
msgid "Add to Favorites"
|
msgid "Add to Favorites"
|
||||||
msgstr "Προσθήκη στα αγαπημένα"
|
msgstr "Προσθήκη στα αγαπημένα"
|
||||||
|
|
||||||
@ -595,7 +583,7 @@ msgid "Type again:"
|
|||||||
msgstr "Πληκτρολογήστε ξανά:"
|
msgstr "Πληκτρολογήστε ξανά:"
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:132
|
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:132
|
||||||
#: ../js/ui/status/network.js:295 ../js/ui/status/network.js:729
|
#: ../js/ui/status/network.js:294 ../js/ui/status/network.js:760
|
||||||
msgid "Connect"
|
msgid "Connect"
|
||||||
msgstr "Σύνδεση"
|
msgstr "Σύνδεση"
|
||||||
|
|
||||||
@ -631,10 +619,10 @@ msgstr "Απαιτείται πιστοποίηση από το ασύρματο
|
|||||||
#, javascript-format
|
#, javascript-format
|
||||||
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 ""
|
msgstr ""
|
||||||
"Κωδικοί ή κλειδιά κρυπτογράφησης απαιτούνται για πρόσβαση στο ασύρματο "
|
"Κωδικοί πρόσβασης ή κλειδιά κρυπτογράφησης απαιτούνται για πρόσβαση στο "
|
||||||
"δίκτυο '%s'."
|
"ασύρματο δίκτυο “%s”."
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:316
|
#: ../js/ui/components/networkAgent.js:316
|
||||||
msgid "Wired 802.1X authentication"
|
msgid "Wired 802.1X authentication"
|
||||||
@ -666,8 +654,8 @@ msgstr "Κωδικός δικτύου κινητής ευρυζωνικής σύ
|
|||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:339
|
#: ../js/ui/components/networkAgent.js:339
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "A password is required to connect to '%s'."
|
msgid "A password is required to connect to “%s”."
|
||||||
msgstr "Απαιτείται κωδικός για σύνδεση στο '%s'."
|
msgstr "Απαιτείται κωδικός πρόσβασης για σύνδεση στο “%s”."
|
||||||
|
|
||||||
#: ../js/ui/components/polkitAgent.js:54
|
#: ../js/ui/components/polkitAgent.js:54
|
||||||
msgid "Authentication Required"
|
msgid "Authentication Required"
|
||||||
@ -714,35 +702,35 @@ msgid "Mute"
|
|||||||
msgstr "Σίγαση"
|
msgstr "Σίγαση"
|
||||||
|
|
||||||
#. Translators: this is the word "Yesterday" followed by a time string. i.e. "Yesterday, 14:30"*/
|
#. Translators: this is the word "Yesterday" followed by a time string. i.e. "Yesterday, 14:30"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:941
|
#: ../js/ui/components/telepathyClient.js:952
|
||||||
msgid "<b>Yesterday</b>, <b>%H:%M</b>"
|
msgid "<b>Yesterday</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>Χθες</b>, <b>%Ω:%Λ</b>"
|
msgstr "<b>Χθες</b>, <b>%Ω:%Λ</b>"
|
||||||
|
|
||||||
#. Translators: this is the week day name followed by a time string. i.e. "Monday, 14:30*/
|
#. Translators: this is the week day name followed by a time string. i.e. "Monday, 14:30*/
|
||||||
#: ../js/ui/components/telepathyClient.js:947
|
#: ../js/ui/components/telepathyClient.js:958
|
||||||
msgid "<b>%A</b>, <b>%H:%M</b>"
|
msgid "<b>%A</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>%ΗΗΗΗ</b>, <b>%Ω:%Λ</b>"
|
msgstr "<b>%ΗΗΗΗ</b>, <b>%Ω:%Λ</b>"
|
||||||
|
|
||||||
#. Translators: this is the month name and day number followed by a time string. i.e. "May 25, 14:30"*/
|
#. Translators: this is the month name and day number followed by a time string. i.e. "May 25, 14:30"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:952
|
#: ../js/ui/components/telepathyClient.js:963
|
||||||
msgid "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
msgid "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>%Η</b> <b>%ΜΜΜΜ</b>, <b>%Ω:%Λ</b>"
|
msgstr "<b>%Η</b> <b>%ΜΜΜΜ</b>, <b>%Ω:%Λ</b>"
|
||||||
|
|
||||||
#. Translators: this is the month name, day number, year number followed by a time string. i.e. "May 25 2012, 14:30"*/
|
#. Translators: this is the month name, day number, year number followed by a time string. i.e. "May 25 2012, 14:30"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:956
|
#: ../js/ui/components/telepathyClient.js:967
|
||||||
msgid "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
msgid "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
||||||
msgstr "<b>%Η</b> <b>%ΜΜΜΜ</b> <b>%ΕΕΕΕ</b>, <b>%Ω:%Λ</b> "
|
msgstr "<b>%Η</b> <b>%ΜΜΜΜ</b> <b>%ΕΕΕΕ</b>, <b>%Ω:%Λ</b> "
|
||||||
|
|
||||||
#. 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:987
|
#: ../js/ui/components/telepathyClient.js:998
|
||||||
#, 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:1090
|
#: ../js/ui/components/telepathyClient.js:1101
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Invitation to %s"
|
msgid "Invitation to %s"
|
||||||
msgstr "Πρόσκληση στο %s"
|
msgstr "Πρόσκληση στο %s"
|
||||||
@ -750,38 +738,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:1098
|
#: ../js/ui/components/telepathyClient.js:1109
|
||||||
#, 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:1100
|
#: ../js/ui/components/telepathyClient.js:1111
|
||||||
#: ../js/ui/components/telepathyClient.js:1135
|
#: ../js/ui/components/telepathyClient.js:1146
|
||||||
#: ../js/ui/components/telepathyClient.js:1169
|
#: ../js/ui/components/telepathyClient.js:1180
|
||||||
#: ../js/ui/components/telepathyClient.js:1226
|
#: ../js/ui/components/telepathyClient.js:1237
|
||||||
msgid "Decline"
|
msgid "Decline"
|
||||||
msgstr "Απόρριψη"
|
msgstr "Απόρριψη"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1106
|
#: ../js/ui/components/telepathyClient.js:1117
|
||||||
#: ../js/ui/components/telepathyClient.js:1175
|
#: ../js/ui/components/telepathyClient.js:1186
|
||||||
#: ../js/ui/components/telepathyClient.js:1231
|
#: ../js/ui/components/telepathyClient.js:1242
|
||||||
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:1125
|
#: ../js/ui/components/telepathyClient.js:1136
|
||||||
#, 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:1128
|
#: ../js/ui/components/telepathyClient.js:1139
|
||||||
#, 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:1142
|
#: ../js/ui/components/telepathyClient.js:1153
|
||||||
msgid "Answer"
|
msgid "Answer"
|
||||||
msgstr "Απάντηση"
|
msgstr "Απάντηση"
|
||||||
|
|
||||||
@ -790,112 +778,112 @@ 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:1163
|
#: ../js/ui/components/telepathyClient.js:1174
|
||||||
#, 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:1192
|
#: ../js/ui/components/telepathyClient.js:1203
|
||||||
#, 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:1277
|
#: ../js/ui/components/telepathyClient.js:1288
|
||||||
msgid "Network error"
|
msgid "Network error"
|
||||||
msgstr "Σφάλμα δικτύου"
|
msgstr "Σφάλμα δικτύου"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1279
|
#: ../js/ui/components/telepathyClient.js:1290
|
||||||
msgid "Authentication failed"
|
msgid "Authentication failed"
|
||||||
msgstr "Η πιστοποίηση απέτυχε"
|
msgstr "Η πιστοποίηση απέτυχε"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1281
|
#: ../js/ui/components/telepathyClient.js:1292
|
||||||
msgid "Encryption error"
|
msgid "Encryption error"
|
||||||
msgstr "Σφάλμα κρυπτογράφησης"
|
msgstr "Σφάλμα κρυπτογράφησης"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1283
|
#: ../js/ui/components/telepathyClient.js:1294
|
||||||
msgid "Certificate not provided"
|
msgid "Certificate not provided"
|
||||||
msgstr "Δεν υπάρχει πιστοποιητικό"
|
msgstr "Δεν υπάρχει πιστοποιητικό"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1285
|
#: ../js/ui/components/telepathyClient.js:1296
|
||||||
msgid "Certificate untrusted"
|
msgid "Certificate untrusted"
|
||||||
msgstr "Μη έμπιστο πιστοποιητικό"
|
msgstr "Μη έμπιστο πιστοποιητικό"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1287
|
#: ../js/ui/components/telepathyClient.js:1298
|
||||||
msgid "Certificate expired"
|
msgid "Certificate expired"
|
||||||
msgstr "Ληγμένο πιστοποιητικό"
|
msgstr "Ληγμένο πιστοποιητικό"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1289
|
#: ../js/ui/components/telepathyClient.js:1300
|
||||||
msgid "Certificate not activated"
|
msgid "Certificate not activated"
|
||||||
msgstr "Το πιστοποιητικό δεν ενεργοποιήθηκε"
|
msgstr "Το πιστοποιητικό δεν ενεργοποιήθηκε"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1291
|
#: ../js/ui/components/telepathyClient.js:1302
|
||||||
msgid "Certificate hostname mismatch"
|
msgid "Certificate hostname mismatch"
|
||||||
msgstr "Αναντιστοιχία ονόματος κεντρικού υπολογιστή στο πιστοποιητικό"
|
msgstr "Αναντιστοιχία ονόματος κεντρικού υπολογιστή στο πιστοποιητικό"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1293
|
#: ../js/ui/components/telepathyClient.js:1304
|
||||||
msgid "Certificate fingerprint mismatch"
|
msgid "Certificate fingerprint mismatch"
|
||||||
msgstr "Αναντιστοιχία αποτυπώματος πιστοποιητικού"
|
msgstr "Αναντιστοιχία αποτυπώματος πιστοποιητικού"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1295
|
#: ../js/ui/components/telepathyClient.js:1306
|
||||||
msgid "Certificate self-signed"
|
msgid "Certificate self-signed"
|
||||||
msgstr "Αυτο-υπογεγραμμένο πιστοποιητικό"
|
msgstr "Αυτο-υπογεγραμμένο πιστοποιητικό"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1297
|
#: ../js/ui/components/telepathyClient.js:1308
|
||||||
msgid "Status is set to offline"
|
msgid "Status is set to offline"
|
||||||
msgstr "Η κατάσταση έχει ορισθεί σε εκτός σύνδεσης"
|
msgstr "Η κατάσταση έχει ορισθεί σε εκτός σύνδεσης"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1299
|
#: ../js/ui/components/telepathyClient.js:1310
|
||||||
msgid "Encryption is not available"
|
msgid "Encryption is not available"
|
||||||
msgstr "Δεν υπάρχει διαθέσιμη κρυπτογράφηση"
|
msgstr "Δεν υπάρχει διαθέσιμη κρυπτογράφηση"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1301
|
#: ../js/ui/components/telepathyClient.js:1312
|
||||||
msgid "Certificate is invalid"
|
msgid "Certificate is invalid"
|
||||||
msgstr "Το πιστοποιητικό είναι άκυρο"
|
msgstr "Το πιστοποιητικό είναι άκυρο"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1303
|
#: ../js/ui/components/telepathyClient.js:1314
|
||||||
msgid "Connection has been refused"
|
msgid "Connection has been refused"
|
||||||
msgstr "Άρνηση σύνδεσης"
|
msgstr "Άρνηση σύνδεσης"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1305
|
#: ../js/ui/components/telepathyClient.js:1316
|
||||||
msgid "Connection can't be established"
|
msgid "Connection can't be established"
|
||||||
msgstr "Δεν είναι δυνατή η σύνδεση"
|
msgstr "Δεν είναι δυνατή η σύνδεση"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1307
|
#: ../js/ui/components/telepathyClient.js:1318
|
||||||
msgid "Connection has been lost"
|
msgid "Connection has been lost"
|
||||||
msgstr "Η σύνδεση χάθηκε"
|
msgstr "Η σύνδεση χάθηκε"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1309
|
#: ../js/ui/components/telepathyClient.js:1320
|
||||||
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:1311
|
#: ../js/ui/components/telepathyClient.js:1322
|
||||||
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:1313
|
#: ../js/ui/components/telepathyClient.js:1324
|
||||||
msgid "The account already exists on the server"
|
msgid "The account already exists on the server"
|
||||||
msgstr "Ο λογαριασμός υπάρχει ήδη στον εξυπηρετητή"
|
msgstr "Ο λογαριασμός υπάρχει ήδη στον εξυπηρετητή"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1315
|
#: ../js/ui/components/telepathyClient.js:1326
|
||||||
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:1317
|
#: ../js/ui/components/telepathyClient.js:1328
|
||||||
msgid "Certificate has been revoked"
|
msgid "Certificate has been revoked"
|
||||||
msgstr "Το πιστοποιητικό έχει ανακληθεί"
|
msgstr "Το πιστοποιητικό έχει ανακληθεί"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1319
|
#: ../js/ui/components/telepathyClient.js:1330
|
||||||
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:1321
|
#: ../js/ui/components/telepathyClient.js:1332
|
||||||
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"
|
||||||
@ -904,22 +892,22 @@ msgstr ""
|
|||||||
"πιστοποιητικού του εξυπηρετητή υπερβαίνει τα όρια που επιτρέπει η βιβλιοθήκη "
|
"πιστοποιητικού του εξυπηρετητή υπερβαίνει τα όρια που επιτρέπει η βιβλιοθήκη "
|
||||||
"κρυπτογραφίας"
|
"κρυπτογραφίας"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1323
|
#: ../js/ui/components/telepathyClient.js:1334
|
||||||
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:1333
|
#: ../js/ui/components/telepathyClient.js:1344
|
||||||
#, 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:1338
|
#: ../js/ui/components/telepathyClient.js:1349
|
||||||
msgid "View account"
|
msgid "View account"
|
||||||
msgstr "Προβολή λογαριασμού"
|
msgstr "Προβολή λογαριασμού"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1370
|
#: ../js/ui/components/telepathyClient.js:1381
|
||||||
msgid "Unknown reason"
|
msgid "Unknown reason"
|
||||||
msgstr "Άγνωστος λόγος"
|
msgstr "Άγνωστος λόγος"
|
||||||
|
|
||||||
@ -1067,8 +1055,8 @@ 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?"
|
||||||
msgstr "Λήψη και εγκατάσταση '%s' από το extensions.gnome.org;"
|
msgstr "Λήψη και εγκατάσταση του “%s” από το extensions.gnome.org;"
|
||||||
|
|
||||||
#: ../js/ui/keyboard.js:641 ../js/ui/status/keyboard.js:335
|
#: ../js/ui/keyboard.js:641 ../js/ui/status/keyboard.js:335
|
||||||
msgid "Keyboard"
|
msgid "Keyboard"
|
||||||
@ -1100,7 +1088,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:717 ../js/ui/status/network.js:472
|
#: ../js/ui/lookingGlass.js:717 ../js/ui/status/network.js:518
|
||||||
#: ../src/gvc/gvc-mixer-control.c:1830
|
#: ../src/gvc/gvc-mixer-control.c:1830
|
||||||
msgid "Disabled"
|
msgid "Disabled"
|
||||||
msgstr "Απενεργοποιημένο"
|
msgstr "Απενεργοποιημένο"
|
||||||
@ -1125,48 +1113,48 @@ msgstr "Προβολή πηγής"
|
|||||||
msgid "Web Page"
|
msgid "Web Page"
|
||||||
msgstr "Ιστοσελίδα"
|
msgstr "Ιστοσελίδα"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1310
|
#: ../js/ui/messageTray.js:1312
|
||||||
msgid "Open"
|
msgid "Open"
|
||||||
msgstr "Άνοιγμα"
|
msgstr "Άνοιγμα"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1317
|
#: ../js/ui/messageTray.js:1319
|
||||||
msgid "Remove"
|
msgid "Remove"
|
||||||
msgstr "Αφαίρεση"
|
msgstr "Αφαίρεση"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1614
|
#: ../js/ui/messageTray.js:1616
|
||||||
msgid "Notifications"
|
msgid "Notifications"
|
||||||
msgstr "Ειδοποιήσεις"
|
msgstr "Ειδοποιήσεις"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1621
|
#: ../js/ui/messageTray.js:1623
|
||||||
msgid "Clear Messages"
|
msgid "Clear Messages"
|
||||||
msgstr "Καθαρισμός μηνυμάτων"
|
msgstr "Καθαρισμός μηνυμάτων"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1640
|
#: ../js/ui/messageTray.js:1642
|
||||||
msgid "Notification Settings"
|
msgid "Notification Settings"
|
||||||
msgstr "Ρυθμίσεις ειδοποιήσεων"
|
msgstr "Ρυθμίσεις ειδοποιήσεων"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1693
|
#: ../js/ui/messageTray.js:1695
|
||||||
msgid "Tray Menu"
|
msgid "Tray Menu"
|
||||||
msgstr "Μενού περιοχής ειδοποιήσεων"
|
msgstr "Μενού περιοχής ειδοποιήσεων"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1910
|
#: ../js/ui/messageTray.js:1912
|
||||||
msgid "No Messages"
|
msgid "No Messages"
|
||||||
msgstr "Κανένα μήνυμα"
|
msgstr "Κανένα μήνυμα"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1948
|
#: ../js/ui/messageTray.js:1950
|
||||||
msgid "Message Tray"
|
msgid "Message Tray"
|
||||||
msgstr "Περιοχή ειδοποιήσεων μηνυμάτων"
|
msgstr "Περιοχή ειδοποιήσεων μηνυμάτων"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:2931
|
#: ../js/ui/messageTray.js:2934
|
||||||
msgid "System Information"
|
msgid "System Information"
|
||||||
msgstr "Πληροφορίες συστήματος"
|
msgstr "Πληροφορίες συστήματος"
|
||||||
|
|
||||||
#: ../js/ui/notificationDaemon.js:515 ../src/shell-app.c:397
|
#: ../js/ui/notificationDaemon.js:515 ../src/shell-app.c:399
|
||||||
msgctxt "program"
|
msgctxt "program"
|
||||||
msgid "Unknown"
|
msgid "Unknown"
|
||||||
msgstr "Άγνωστο"
|
msgstr "Άγνωστο"
|
||||||
|
|
||||||
#: ../js/ui/overviewControls.js:483 ../js/ui/screenShield.js:153
|
#: ../js/ui/overviewControls.js:483 ../js/ui/screenShield.js:151
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%d new message"
|
msgid "%d new message"
|
||||||
msgid_plural "%d new messages"
|
msgid_plural "%d new messages"
|
||||||
@ -1199,7 +1187,7 @@ msgstr "Έξοδος"
|
|||||||
msgid "Activities"
|
msgid "Activities"
|
||||||
msgstr "Δραστηριότητες"
|
msgstr "Δραστηριότητες"
|
||||||
|
|
||||||
#: ../js/ui/panel.js:903
|
#: ../js/ui/panel.js:905
|
||||||
msgid "Top Bar"
|
msgid "Top Bar"
|
||||||
msgstr "Πάνω μπάρα"
|
msgstr "Πάνω μπάρα"
|
||||||
|
|
||||||
@ -1217,30 +1205,30 @@ msgstr "Κλείσιμο"
|
|||||||
|
|
||||||
#. 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:89
|
#: ../js/ui/screenShield.js:88
|
||||||
msgid "%A, %B %d"
|
msgid "%A, %B %d"
|
||||||
msgstr "%A, %B %d"
|
msgstr "%A, %B %d"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:155
|
#: ../js/ui/screenShield.js:153
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%d new notification"
|
msgid "%d new notification"
|
||||||
msgid_plural "%d new notifications"
|
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:342
|
#: ../js/ui/screenShield.js:473 ../js/ui/status/system.js:342
|
||||||
msgid "Lock"
|
msgid "Lock"
|
||||||
msgstr "Κλείδωμα"
|
msgstr "Κλείδωμα"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:708
|
#: ../js/ui/screenShield.js:707
|
||||||
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:1302
|
#: ../js/ui/screenShield.js:834 ../js/ui/screenShield.js:1301
|
||||||
msgid "Unable to lock"
|
msgid "Unable to lock"
|
||||||
msgstr "Αδυναμία κλειδώματος"
|
msgstr "Αδυναμία κλειδώματος"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:836 ../js/ui/screenShield.js:1303
|
#: ../js/ui/screenShield.js:835 ../js/ui/screenShield.js:1302
|
||||||
msgid "Lock was blocked by an application"
|
msgid "Lock was blocked by an application"
|
||||||
msgstr "Το κλείδωμα εμποδίστηκε από μια εφαρμογή"
|
msgstr "Το κλείδωμα εμποδίστηκε από μια εφαρμογή"
|
||||||
|
|
||||||
@ -1325,7 +1313,7 @@ msgid "Bluetooth"
|
|||||||
msgstr "Bluetooth"
|
msgstr "Bluetooth"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:47 ../js/ui/status/network.js:132
|
#: ../js/ui/status/bluetooth.js:47 ../js/ui/status/network.js:132
|
||||||
#: ../js/ui/status/network.js:1083 ../js/ui/status/rfkill.js:48
|
#: ../js/ui/status/network.js:1108 ../js/ui/status/rfkill.js:48
|
||||||
msgid "Turn Off"
|
msgid "Turn Off"
|
||||||
msgstr "Σβήσιμο"
|
msgstr "Σβήσιμο"
|
||||||
|
|
||||||
@ -1352,95 +1340,99 @@ msgstr "Εμφάνιση διάταξης πληκτρολογίου"
|
|||||||
msgid "<unknown>"
|
msgid "<unknown>"
|
||||||
msgstr "<άγνωστο>"
|
msgstr "<άγνωστο>"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:222 ../js/ui/status/network.js:379
|
#: ../js/ui/status/network.js:221 ../js/ui/status/network.js:383
|
||||||
#: ../js/ui/status/network.js:1104
|
#: ../js/ui/status/network.js:1129
|
||||||
msgid "Off"
|
msgid "Off"
|
||||||
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:385
|
#: ../js/ui/status/network.js:389
|
||||||
msgid "unmanaged"
|
msgid "unmanaged"
|
||||||
msgstr "μη διαχειριζόμενες"
|
msgstr "μη διαχειριζόμενες"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:387
|
#: ../js/ui/status/network.js:391
|
||||||
msgid "disconnecting..."
|
msgid "disconnecting..."
|
||||||
msgstr "αποσύνδεση..."
|
msgstr "αποσύνδεση..."
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:393 ../js/ui/status/network.js:1158
|
#: ../js/ui/status/network.js:397 ../js/ui/status/network.js:1183
|
||||||
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:396 ../js/ui/status/network.js:1161
|
#: ../js/ui/status/network.js:400 ../js/ui/status/network.js:1186
|
||||||
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:404
|
#: ../js/ui/status/network.js:408
|
||||||
msgid "firmware missing"
|
msgid "firmware missing"
|
||||||
msgstr "έλλειψη firmware"
|
msgstr "έλλειψη 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:408
|
#: ../js/ui/status/network.js:412
|
||||||
msgid "unavailable"
|
msgid "unavailable"
|
||||||
msgstr "μη διαθέσιμο"
|
msgstr "μη διαθέσιμο"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:410 ../js/ui/status/network.js:1163
|
#: ../js/ui/status/network.js:414 ../js/ui/status/network.js:1188
|
||||||
msgid "connection failed"
|
msgid "connection failed"
|
||||||
msgstr "αποτυχία σύνδεσης"
|
msgstr "αποτυχία σύνδεσης"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:426 ../js/ui/status/network.js:512
|
#: ../js/ui/status/network.js:430
|
||||||
|
msgid "Wired Settings"
|
||||||
|
msgstr "Ενσύρματες ρυθμίσεις"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:472 ../js/ui/status/network.js:558
|
||||||
msgid "Mobile Broadband Settings"
|
msgid "Mobile Broadband Settings"
|
||||||
msgstr "Ρυθμίσεις Κινήτης Ευρυζωνικής"
|
msgstr "Ρυθμίσεις Κινήτης Ευρυζωνικής"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:468 ../js/ui/status/network.js:1102
|
#: ../js/ui/status/network.js:514 ../js/ui/status/network.js:1127
|
||||||
msgid "Hardware Disabled"
|
msgid "Hardware Disabled"
|
||||||
msgstr "Το Υλικό Απενεργοποιήθηκε"
|
msgstr "Το Υλικό Απενεργοποιήθηκε"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:694
|
#: ../js/ui/status/network.js:725
|
||||||
msgid "Wi-Fi Networks"
|
msgid "Wi-Fi Networks"
|
||||||
msgstr "Δίκτυα Wi-Fi"
|
msgstr "Δίκτυα Wi-Fi"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:696
|
#: ../js/ui/status/network.js:727
|
||||||
msgid "Select a network"
|
msgid "Select a network"
|
||||||
msgstr "Επιλογή δικτύου"
|
msgstr "Επιλογή δικτύου"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:720
|
#: ../js/ui/status/network.js:751
|
||||||
msgid "No Networks"
|
msgid "No Networks"
|
||||||
msgstr "Χωρίς δίκτυα"
|
msgstr "Χωρίς δίκτυα"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:989
|
#: ../js/ui/status/network.js:1014
|
||||||
msgid "Select Network"
|
msgid "Select Network"
|
||||||
msgstr "Επιλογή δικτύου"
|
msgstr "Επιλογή δικτύου"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:995
|
#: ../js/ui/status/network.js:1020
|
||||||
msgid "Wi-Fi Settings"
|
msgid "Wi-Fi Settings"
|
||||||
msgstr "Ρυθμίσεις Wi-Fi"
|
msgstr "Ρυθμίσεις Wi-Fi"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1083
|
#: ../js/ui/status/network.js:1108
|
||||||
msgid "Turn On"
|
msgid "Turn On"
|
||||||
msgstr "Ενεργοποίηση"
|
msgstr "Ενεργοποίηση"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1106
|
#: ../js/ui/status/network.js:1131
|
||||||
msgid "Not Connected"
|
msgid "Not Connected"
|
||||||
msgstr "Χωρίς σύνδεση"
|
msgstr "Χωρίς σύνδεση"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1226
|
#: ../js/ui/status/network.js:1251
|
||||||
msgid "VPN"
|
msgid "VPN"
|
||||||
msgstr "VPN"
|
msgstr "VPN"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1366
|
#: ../js/ui/status/network.js:1394
|
||||||
msgid "Network Manager"
|
msgid "Network Manager"
|
||||||
msgstr "Διαχειριστής δικτύου"
|
msgstr "Διαχειριστής δικτύου"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1405
|
#: ../js/ui/status/network.js:1433
|
||||||
msgid "Connection failed"
|
msgid "Connection failed"
|
||||||
msgstr "Αποτυχία σύνδεσης"
|
msgstr "Αποτυχία σύνδεσης"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1406
|
#: ../js/ui/status/network.js:1434
|
||||||
msgid "Activation of network connection failed"
|
msgid "Activation of network connection failed"
|
||||||
msgstr "Απέτυχε η ενεργοποίηση της σύνδεσης δικτύου"
|
msgstr "Απέτυχε η ενεργοποίηση της σύνδεσης δικτύου"
|
||||||
|
|
||||||
@ -1536,8 +1528,8 @@ msgstr "Αναζήτηση"
|
|||||||
|
|
||||||
#: ../js/ui/windowAttentionHandler.js:19
|
#: ../js/ui/windowAttentionHandler.js:19
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "'%s' is ready"
|
msgid "“%s” is ready"
|
||||||
msgstr "Το '%s' είναι έτοιμο"
|
msgstr "Το “%s” είναι έτοιμο"
|
||||||
|
|
||||||
#: ../js/ui/windowManager.js:56
|
#: ../js/ui/windowManager.js:56
|
||||||
msgid "Do you want to keep these display settings?"
|
msgid "Do you want to keep these display settings?"
|
||||||
@ -1606,10 +1598,10 @@ msgstr ""
|
|||||||
msgid "List possible modes"
|
msgid "List possible modes"
|
||||||
msgstr "Λίστα πιθανών καταστάσεων λειτουργίας"
|
msgstr "Λίστα πιθανών καταστάσεων λειτουργίας"
|
||||||
|
|
||||||
#: ../src/shell-app.c:640
|
#: ../src/shell-app.c:642
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to launch '%s'"
|
msgid "Failed to launch “%s”"
|
||||||
msgstr "Αποτυχία εκκίνησης '%s'"
|
msgstr "Αποτυχία εκκίνησης του “%s”"
|
||||||
|
|
||||||
#: ../src/shell-keyring-prompt.c:714
|
#: ../src/shell-keyring-prompt.c:714
|
||||||
msgid "Passwords do not match."
|
msgid "Passwords do not match."
|
||||||
@ -1623,6 +1615,17 @@ msgstr "Ο κωδικός δεν μπορεί να είναι κενός"
|
|||||||
msgid "Authentication dialog was dismissed by the user"
|
msgid "Authentication dialog was dismissed by the user"
|
||||||
msgstr "Το παράθυρο πιστοποίησης έκλεισε από τον χρήστη"
|
msgstr "Το παράθυρο πιστοποίησης έκλεισε από τον χρήστη"
|
||||||
|
|
||||||
|
#~ msgid "List of categories that should be displayed as folders"
|
||||||
|
#~ msgstr "Η λίστα των κατηγοριών που πρέπει να εμφανίζονται ως φάκελοι"
|
||||||
|
|
||||||
|
#~ msgid ""
|
||||||
|
#~ "Each category name in this list will be represented as folder in the "
|
||||||
|
#~ "application view, rather than being displayed inline in the main view."
|
||||||
|
#~ msgstr ""
|
||||||
|
#~ "Το όνομα κάθε κατηγορίας σε αυτή τη λίστα θα αναπαριστάται ως φάκελος "
|
||||||
|
#~ "στην προβολή εφαρμογής, αντί να εμφανίζεται ενσωματωμένο στην κύρια "
|
||||||
|
#~ "προβολή."
|
||||||
|
|
||||||
#~ msgid "Authorization request from %s"
|
#~ msgid "Authorization request from %s"
|
||||||
#~ msgstr "Αίτηση εξουσιοδότησης από %s"
|
#~ msgstr "Αίτηση εξουσιοδότησης από %s"
|
||||||
|
|
||||||
|
243
po/es.po
243
po/es.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-01-19 15:04+0000\n"
|
"POT-Creation-Date: 2014-02-07 08:57+0000\n"
|
||||||
"PO-Revision-Date: 2014-01-20 12:32+0100\n"
|
"PO-Revision-Date: 2014-02-07 10:54+0100\n"
|
||||||
"Last-Translator: Daniel Mustieles <daniel.mustieles@gmail.com>\n"
|
"Last-Translator: Daniel Mustieles <daniel.mustieles@gmail.com>\n"
|
||||||
"Language-Team: Español <gnome-es-list@gnome.org>\n"
|
"Language-Team: Español <gnome-es-list@gnome.org>\n"
|
||||||
"Language: es\n"
|
"Language: es\n"
|
||||||
@ -279,7 +279,7 @@ msgstr ""
|
|||||||
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
||||||
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
||||||
#: ../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:724
|
#: ../js/ui/status/network.js:857
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
msgstr "Cancelar"
|
msgstr "Cancelar"
|
||||||
|
|
||||||
@ -335,31 +335,30 @@ msgid "Could not parse command:"
|
|||||||
msgstr "No se pudo analizar el comando:"
|
msgstr "No se pudo analizar el comando:"
|
||||||
|
|
||||||
#: ../js/misc/util.js:156
|
#: ../js/misc/util.js:156
|
||||||
#| msgid "Execution of '%s' failed:"
|
|
||||||
msgid "Execution of “%s” failed:"
|
msgid "Execution of “%s” failed:"
|
||||||
msgstr "Falló la ejecución de «%s»:"
|
msgstr "Falló la ejecución de «%s»:"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:543
|
#: ../js/ui/appDisplay.js:633
|
||||||
msgid "Frequently used applications will appear here"
|
msgid "Frequently used applications will appear here"
|
||||||
msgstr "Las aplicaciones usadas frecuentemente aparecerán aquí"
|
msgstr "Las aplicaciones usadas frecuentemente aparecerán aquí"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:663
|
#: ../js/ui/appDisplay.js:744
|
||||||
msgid "Frequent"
|
msgid "Frequent"
|
||||||
msgstr "Frecuentes"
|
msgstr "Frecuentes"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:670
|
#: ../js/ui/appDisplay.js:751
|
||||||
msgid "All"
|
msgid "All"
|
||||||
msgstr "Todas"
|
msgstr "Todas"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1501
|
#: ../js/ui/appDisplay.js:1558
|
||||||
msgid "New Window"
|
msgid "New Window"
|
||||||
msgstr "Ventana nueva"
|
msgstr "Ventana nueva"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1504 ../js/ui/dash.js:285
|
#: ../js/ui/appDisplay.js:1580 ../js/ui/dash.js:285
|
||||||
msgid "Remove from Favorites"
|
msgid "Remove from Favorites"
|
||||||
msgstr "Quitar de los favoritos"
|
msgstr "Quitar de los favoritos"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1505
|
#: ../js/ui/appDisplay.js:1586
|
||||||
msgid "Add to Favorites"
|
msgid "Add to Favorites"
|
||||||
msgstr "Añadir a los favoritos"
|
msgstr "Añadir a los favoritos"
|
||||||
|
|
||||||
@ -569,8 +568,8 @@ msgstr "Contraseña:"
|
|||||||
msgid "Type again:"
|
msgid "Type again:"
|
||||||
msgstr "Escriba de nuevo:"
|
msgstr "Escriba de nuevo:"
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:131
|
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:227
|
||||||
#: ../js/ui/status/network.js:293 ../js/ui/status/network.js:727
|
#: ../js/ui/status/network.js:300 ../js/ui/status/network.js:860
|
||||||
msgid "Connect"
|
msgid "Connect"
|
||||||
msgstr "Conectar"
|
msgstr "Conectar"
|
||||||
|
|
||||||
@ -603,9 +602,6 @@ msgid "Authentication required by wireless network"
|
|||||||
msgstr "La red inalámbrica requiere autenticación"
|
msgstr "La red inalámbrica requiere autenticación"
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:312
|
#: ../js/ui/components/networkAgent.js:312
|
||||||
#| 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”."
|
||||||
@ -642,7 +638,6 @@ msgid "Mobile broadband network password"
|
|||||||
msgstr "Contraseña de la red de banda ancha móvil"
|
msgstr "Contraseña de la red de banda ancha móvil"
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:339
|
#: ../js/ui/components/networkAgent.js:339
|
||||||
#| 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 "Se requiere una contraseña para conectarse a «%s»."
|
msgstr "Se requiere una contraseña para conectarse a «%s»."
|
||||||
|
|
||||||
@ -691,69 +686,69 @@ msgid "Mute"
|
|||||||
msgstr "Silenciar"
|
msgstr "Silenciar"
|
||||||
|
|
||||||
#. Translators: this is the word "Yesterday" followed by a time string. i.e. "Yesterday, 14:30"*/
|
#. Translators: this is the word "Yesterday" followed by a time string. i.e. "Yesterday, 14:30"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:941
|
#: ../js/ui/components/telepathyClient.js:952
|
||||||
msgid "<b>Yesterday</b>, <b>%H:%M</b>"
|
msgid "<b>Yesterday</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>Ayer</b>, <b>%H:%M</b>"
|
msgstr "<b>Ayer</b>, <b>%H:%M</b>"
|
||||||
|
|
||||||
#. Translators: this is the week day name followed by a time string. i.e. "Monday, 14:30*/
|
#. Translators: this is the week day name followed by a time string. i.e. "Monday, 14:30*/
|
||||||
#: ../js/ui/components/telepathyClient.js:947
|
#: ../js/ui/components/telepathyClient.js:958
|
||||||
msgid "<b>%A</b>, <b>%H:%M</b>"
|
msgid "<b>%A</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>%A</b>, <b>%H:%M</b>"
|
msgstr "<b>%A</b>, <b>%H:%M</b>"
|
||||||
|
|
||||||
#. Translators: this is the month name and day number followed by a time string. i.e. "May 25, 14:30"*/
|
#. Translators: this is the month name and day number followed by a time string. i.e. "May 25, 14:30"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:952
|
#: ../js/ui/components/telepathyClient.js:963
|
||||||
msgid "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
msgid "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>%d</b> de <b>%B</b>, <b>%H:%M</b>"
|
msgstr "<b>%d</b> de <b>%B</b>, <b>%H:%M</b>"
|
||||||
|
|
||||||
#. Translators: this is the month name, day number, year number followed by a time string. i.e. "May 25 2012, 14:30"*/
|
#. Translators: this is the month name, day number, year number followed by a time string. i.e. "May 25 2012, 14:30"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:956
|
#: ../js/ui/components/telepathyClient.js:967
|
||||||
msgid "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
msgid "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
||||||
msgstr "<b>%d</b> de <b>%B</b> <b>%Y</b>, <b>%H:%M</b> "
|
msgstr "<b>%d</b> de <b>%B</b> <b>%Y</b>, <b>%H:%M</b> "
|
||||||
|
|
||||||
#. 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:987
|
#: ../js/ui/components/telepathyClient.js:998
|
||||||
msgid "%s is now known as %s"
|
msgid "%s is now known as %s"
|
||||||
msgstr "Ahora %s se llama %s"
|
msgstr "Ahora %s se llama %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:1090
|
#: ../js/ui/components/telepathyClient.js:1101
|
||||||
msgid "Invitation to %s"
|
msgid "Invitation to %s"
|
||||||
msgstr "Invitación a %s"
|
msgstr "Invitación 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:1098
|
#: ../js/ui/components/telepathyClient.js:1109
|
||||||
msgid "%s is inviting you to join %s"
|
msgid "%s is inviting you to join %s"
|
||||||
msgstr "%s le está invitando a unirse a %s"
|
msgstr "%s le está invitando a unirse a %s"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1100
|
#: ../js/ui/components/telepathyClient.js:1111
|
||||||
#: ../js/ui/components/telepathyClient.js:1135
|
#: ../js/ui/components/telepathyClient.js:1146
|
||||||
#: ../js/ui/components/telepathyClient.js:1169
|
#: ../js/ui/components/telepathyClient.js:1180
|
||||||
#: ../js/ui/components/telepathyClient.js:1226
|
#: ../js/ui/components/telepathyClient.js:1237
|
||||||
msgid "Decline"
|
msgid "Decline"
|
||||||
msgstr "Rechazar"
|
msgstr "Rechazar"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1106
|
#: ../js/ui/components/telepathyClient.js:1117
|
||||||
#: ../js/ui/components/telepathyClient.js:1175
|
#: ../js/ui/components/telepathyClient.js:1186
|
||||||
#: ../js/ui/components/telepathyClient.js:1231
|
#: ../js/ui/components/telepathyClient.js:1242
|
||||||
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:1125
|
#: ../js/ui/components/telepathyClient.js:1136
|
||||||
msgid "Video call from %s"
|
msgid "Video call from %s"
|
||||||
msgstr "Videollamada de %s"
|
msgstr "Videollamada 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:1128
|
#: ../js/ui/components/telepathyClient.js:1139
|
||||||
msgid "Call from %s"
|
msgid "Call from %s"
|
||||||
msgstr "Llamada de %s"
|
msgstr "Llamada 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:1142
|
#: ../js/ui/components/telepathyClient.js:1153
|
||||||
msgid "Answer"
|
msgid "Answer"
|
||||||
msgstr "Responder"
|
msgstr "Responder"
|
||||||
|
|
||||||
@ -762,110 +757,110 @@ msgstr "Responder"
|
|||||||
#. * 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:1163
|
#: ../js/ui/components/telepathyClient.js:1174
|
||||||
msgid "%s is sending you %s"
|
msgid "%s is sending you %s"
|
||||||
msgstr "%s le está enviando %s"
|
msgstr "%s le está enviando %s"
|
||||||
|
|
||||||
#. To translators: The parameter is the contact's alias */
|
#. To translators: The parameter is the contact's alias */
|
||||||
#: ../js/ui/components/telepathyClient.js:1192
|
#: ../js/ui/components/telepathyClient.js:1203
|
||||||
msgid "%s would like permission to see when you are online"
|
msgid "%s would like permission to see when you are online"
|
||||||
msgstr "%s solicita permiso para ver cuándo está en línea"
|
msgstr "%s solicita permiso para ver cuándo está en línea"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1277
|
#: ../js/ui/components/telepathyClient.js:1288
|
||||||
msgid "Network error"
|
msgid "Network error"
|
||||||
msgstr "Error de la red"
|
msgstr "Error de la red"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1279
|
#: ../js/ui/components/telepathyClient.js:1290
|
||||||
msgid "Authentication failed"
|
msgid "Authentication failed"
|
||||||
msgstr "Falló la autenticación"
|
msgstr "Falló la autenticación"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1281
|
#: ../js/ui/components/telepathyClient.js:1292
|
||||||
msgid "Encryption error"
|
msgid "Encryption error"
|
||||||
msgstr "Error de cifrado"
|
msgstr "Error de cifrado"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1283
|
#: ../js/ui/components/telepathyClient.js:1294
|
||||||
msgid "Certificate not provided"
|
msgid "Certificate not provided"
|
||||||
msgstr "Certificado no proporcionado"
|
msgstr "Certificado no proporcionado"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1285
|
#: ../js/ui/components/telepathyClient.js:1296
|
||||||
msgid "Certificate untrusted"
|
msgid "Certificate untrusted"
|
||||||
msgstr "No se confía en el certificado"
|
msgstr "No se confía en el certificado"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1287
|
#: ../js/ui/components/telepathyClient.js:1298
|
||||||
msgid "Certificate expired"
|
msgid "Certificate expired"
|
||||||
msgstr "Certificado caducado"
|
msgstr "Certificado caducado"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1289
|
#: ../js/ui/components/telepathyClient.js:1300
|
||||||
msgid "Certificate not activated"
|
msgid "Certificate not activated"
|
||||||
msgstr "Certificado no activado"
|
msgstr "Certificado no activado"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1291
|
#: ../js/ui/components/telepathyClient.js:1302
|
||||||
msgid "Certificate hostname mismatch"
|
msgid "Certificate hostname mismatch"
|
||||||
msgstr "El nombre del servidor dle certificado no coincide"
|
msgstr "El nombre del servidor dle certificado no coincide"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1293
|
#: ../js/ui/components/telepathyClient.js:1304
|
||||||
msgid "Certificate fingerprint mismatch"
|
msgid "Certificate fingerprint mismatch"
|
||||||
msgstr "La huella del certificado no coincide"
|
msgstr "La huella del certificado no coincide"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1295
|
#: ../js/ui/components/telepathyClient.js:1306
|
||||||
msgid "Certificate self-signed"
|
msgid "Certificate self-signed"
|
||||||
msgstr "Certificado autofirmado"
|
msgstr "Certificado autofirmado"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1297
|
#: ../js/ui/components/telepathyClient.js:1308
|
||||||
msgid "Status is set to offline"
|
msgid "Status is set to offline"
|
||||||
msgstr "El estado está establecido a «desconectado»"
|
msgstr "El estado está establecido a «desconectado»"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1299
|
#: ../js/ui/components/telepathyClient.js:1310
|
||||||
msgid "Encryption is not available"
|
msgid "Encryption is not available"
|
||||||
msgstr "El cifrado no está disponible"
|
msgstr "El cifrado no está disponible"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1301
|
#: ../js/ui/components/telepathyClient.js:1312
|
||||||
msgid "Certificate is invalid"
|
msgid "Certificate is invalid"
|
||||||
msgstr "El certificado no es válido"
|
msgstr "El certificado no es válido"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1303
|
#: ../js/ui/components/telepathyClient.js:1314
|
||||||
msgid "Connection has been refused"
|
msgid "Connection has been refused"
|
||||||
msgstr "Se ha rechazado la conexión"
|
msgstr "Se ha rechazado la conexión"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1305
|
#: ../js/ui/components/telepathyClient.js:1316
|
||||||
msgid "Connection can't be established"
|
msgid "Connection can't be established"
|
||||||
msgstr "No se puede establecer la conexión"
|
msgstr "No se puede establecer la conexión"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1307
|
#: ../js/ui/components/telepathyClient.js:1318
|
||||||
msgid "Connection has been lost"
|
msgid "Connection has been lost"
|
||||||
msgstr "Se ha perdido la conexión"
|
msgstr "Se ha perdido la conexión"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1309
|
#: ../js/ui/components/telepathyClient.js:1320
|
||||||
msgid "This account is already connected to the server"
|
msgid "This account is already connected to the server"
|
||||||
msgstr "Esta cuenta ya está conectada al servidor"
|
msgstr "Esta cuenta ya está conectada al servidor"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1311
|
#: ../js/ui/components/telepathyClient.js:1322
|
||||||
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 ""
|
||||||
"Se ha sustituido la conexión por una nueva conexión usando el mismo recurso"
|
"Se ha sustituido la conexión por una nueva conexión usando el mismo recurso"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1313
|
#: ../js/ui/components/telepathyClient.js:1324
|
||||||
msgid "The account already exists on the server"
|
msgid "The account already exists on the server"
|
||||||
msgstr "La cuenta ya existe en el servidor"
|
msgstr "La cuenta ya existe en el servidor"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1315
|
#: ../js/ui/components/telepathyClient.js:1326
|
||||||
msgid "Server is currently too busy to handle the connection"
|
msgid "Server is currently too busy to handle the connection"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Actualmente el servidor está muy ocupado intentando gestionar la conexión"
|
"Actualmente el servidor está muy ocupado intentando gestionar la conexión"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1317
|
#: ../js/ui/components/telepathyClient.js:1328
|
||||||
msgid "Certificate has been revoked"
|
msgid "Certificate has been revoked"
|
||||||
msgstr "Se ha revocado el certificado"
|
msgstr "Se ha revocado el certificado"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1319
|
#: ../js/ui/components/telepathyClient.js:1330
|
||||||
msgid ""
|
msgid ""
|
||||||
"Certificate uses an insecure cipher algorithm or is cryptographically weak"
|
"Certificate uses an insecure cipher algorithm or is cryptographically weak"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"El certificado usa un algoritmo de cifrado inseguro o es criptográficamente "
|
"El certificado usa un algoritmo de cifrado inseguro o es criptográficamente "
|
||||||
"débil"
|
"débil"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1321
|
#: ../js/ui/components/telepathyClient.js:1332
|
||||||
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"
|
||||||
@ -874,21 +869,21 @@ msgstr ""
|
|||||||
"certificado del servidor exceden los límites impuestos por la biblioteca de "
|
"certificado del servidor exceden los límites impuestos por la biblioteca de "
|
||||||
"criptografía"
|
"criptografía"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1323
|
#: ../js/ui/components/telepathyClient.js:1334
|
||||||
msgid "Internal error"
|
msgid "Internal error"
|
||||||
msgstr "Error interno"
|
msgstr "Error 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:1333
|
#: ../js/ui/components/telepathyClient.js:1344
|
||||||
msgid "Unable to connect to %s"
|
msgid "Unable to connect to %s"
|
||||||
msgstr "No se pudo conectar a %s"
|
msgstr "No se pudo conectar a %s"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1338
|
#: ../js/ui/components/telepathyClient.js:1349
|
||||||
msgid "View account"
|
msgid "View account"
|
||||||
msgstr "Ver cuenta"
|
msgstr "Ver cuenta"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1370
|
#: ../js/ui/components/telepathyClient.js:1381
|
||||||
msgid "Unknown reason"
|
msgid "Unknown reason"
|
||||||
msgstr "Razón desconocida"
|
msgstr "Razón desconocida"
|
||||||
|
|
||||||
@ -1026,7 +1021,6 @@ msgid "Install"
|
|||||||
msgstr "Instalar"
|
msgstr "Instalar"
|
||||||
|
|
||||||
#: ../js/ui/extensionDownloader.js:204
|
#: ../js/ui/extensionDownloader.js:204
|
||||||
#| 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 "¿Descargar e instalar «%s» desde extensions.gnome.org?"
|
msgstr "¿Descargar e instalar «%s» desde extensions.gnome.org?"
|
||||||
|
|
||||||
@ -1059,7 +1053,7 @@ msgstr "Activado"
|
|||||||
#. 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:717 ../js/ui/status/network.js:470
|
#: ../js/ui/lookingGlass.js:717 ../js/ui/status/network.js:523
|
||||||
#: ../src/gvc/gvc-mixer-control.c:1830
|
#: ../src/gvc/gvc-mixer-control.c:1830
|
||||||
msgid "Disabled"
|
msgid "Disabled"
|
||||||
msgstr "Desactivado"
|
msgstr "Desactivado"
|
||||||
@ -1120,7 +1114,7 @@ msgstr "Bandeja de mensajes"
|
|||||||
msgid "System Information"
|
msgid "System Information"
|
||||||
msgstr "Información del sistema"
|
msgstr "Información del sistema"
|
||||||
|
|
||||||
#: ../js/ui/notificationDaemon.js:515 ../src/shell-app.c:397
|
#: ../js/ui/notificationDaemon.js:515 ../src/shell-app.c:399
|
||||||
msgctxt "program"
|
msgctxt "program"
|
||||||
msgid "Unknown"
|
msgid "Unknown"
|
||||||
msgstr "Desconocido"
|
msgstr "Desconocido"
|
||||||
@ -1157,7 +1151,7 @@ msgstr "Salir"
|
|||||||
msgid "Activities"
|
msgid "Activities"
|
||||||
msgstr "Actividades"
|
msgstr "Actividades"
|
||||||
|
|
||||||
#: ../js/ui/panel.js:903
|
#: ../js/ui/panel.js:905
|
||||||
msgid "Top Bar"
|
msgid "Top Bar"
|
||||||
msgstr "Barra superior"
|
msgstr "Barra superior"
|
||||||
|
|
||||||
@ -1185,19 +1179,19 @@ msgid_plural "%d new notifications"
|
|||||||
msgstr[0] "%d notificación nueva"
|
msgstr[0] "%d notificación nueva"
|
||||||
msgstr[1] "%d notificaciones nuevas"
|
msgstr[1] "%d notificaciones nuevas"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:472 ../js/ui/status/system.js:342
|
#: ../js/ui/screenShield.js:473 ../js/ui/status/system.js:342
|
||||||
msgid "Lock"
|
msgid "Lock"
|
||||||
msgstr "Bloquear"
|
msgstr "Bloquear"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:706
|
#: ../js/ui/screenShield.js:707
|
||||||
msgid "GNOME needs to lock the screen"
|
msgid "GNOME needs to lock the screen"
|
||||||
msgstr "GNOME necesita bloquear la pantalla"
|
msgstr "GNOME necesita bloquear la pantalla"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:833 ../js/ui/screenShield.js:1300
|
#: ../js/ui/screenShield.js:834 ../js/ui/screenShield.js:1301
|
||||||
msgid "Unable to lock"
|
msgid "Unable to lock"
|
||||||
msgstr "No se pudo bloquear"
|
msgstr "No se pudo bloquear"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:834 ../js/ui/screenShield.js:1301
|
#: ../js/ui/screenShield.js:835 ../js/ui/screenShield.js:1302
|
||||||
msgid "Lock was blocked by an application"
|
msgid "Lock was blocked by an application"
|
||||||
msgstr "Una aplicación impidió el bloqueo"
|
msgstr "Una aplicación impidió el bloqueo"
|
||||||
|
|
||||||
@ -1277,25 +1271,30 @@ msgstr "Contraste alto"
|
|||||||
msgid "Large Text"
|
msgid "Large Text"
|
||||||
msgstr "Texto grande"
|
msgstr "Texto grande"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:45
|
#: ../js/ui/status/bluetooth.js:48
|
||||||
msgid "Bluetooth"
|
msgid "Bluetooth"
|
||||||
msgstr "Bluetooth"
|
msgstr "Bluetooth"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:47 ../js/ui/status/network.js:131
|
#: ../js/ui/status/bluetooth.js:50 ../js/ui/status/network.js:134
|
||||||
#: ../js/ui/status/network.js:1081 ../js/ui/status/rfkill.js:48
|
#: ../js/ui/status/network.js:1209 ../js/ui/status/rfkill.js:85
|
||||||
|
#: ../js/ui/status/rfkill.js:105
|
||||||
msgid "Turn Off"
|
msgid "Turn Off"
|
||||||
msgstr "Apagar"
|
msgstr "Apagar"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:50
|
#: ../js/ui/status/bluetooth.js:53
|
||||||
msgid "Bluetooth Settings"
|
msgid "Bluetooth Settings"
|
||||||
msgstr "Configuración de Bluetooth"
|
msgstr "Configuración de Bluetooth"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:98
|
#: ../js/ui/status/bluetooth.js:100
|
||||||
msgid "%d Connected Device"
|
msgid "%d Connected Device"
|
||||||
msgid_plural "%d Connected Devices"
|
msgid_plural "%d Connected Devices"
|
||||||
msgstr[0] "%d dispositivo conectado"
|
msgstr[0] "%d dispositivo conectado"
|
||||||
msgstr[1] "%d dispositivos conectados"
|
msgstr[1] "%d dispositivos conectados"
|
||||||
|
|
||||||
|
#: ../js/ui/status/bluetooth.js:102 ../js/ui/status/network.js:1232
|
||||||
|
msgid "Not Connected"
|
||||||
|
msgstr "No conectado"
|
||||||
|
|
||||||
#: ../js/ui/status/brightness.js:44
|
#: ../js/ui/status/brightness.js:44
|
||||||
msgid "Brightness"
|
msgid "Brightness"
|
||||||
msgstr "Brillo"
|
msgstr "Brillo"
|
||||||
@ -1304,99 +1303,131 @@ msgstr "Brillo"
|
|||||||
msgid "Show Keyboard Layout"
|
msgid "Show Keyboard Layout"
|
||||||
msgstr "Mostrar la distribución del teclado"
|
msgstr "Mostrar la distribución del teclado"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:70
|
#: ../js/ui/status/network.js:73
|
||||||
msgid "<unknown>"
|
msgid "<unknown>"
|
||||||
msgstr "<desconocido>"
|
msgstr "<desconocido>"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:220 ../js/ui/status/network.js:377
|
#: ../js/ui/status/network.js:223 ../js/ui/status/network.js:389
|
||||||
#: ../js/ui/status/network.js:1102
|
#: ../js/ui/status/network.js:1230
|
||||||
msgid "Off"
|
msgid "Off"
|
||||||
msgstr "Desconectado"
|
msgstr "Desconectado"
|
||||||
|
|
||||||
#. 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:383
|
#: ../js/ui/status/network.js:395
|
||||||
msgid "unmanaged"
|
msgid "unmanaged"
|
||||||
msgstr "no gestionada"
|
msgstr "no gestionada"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:385
|
#: ../js/ui/status/network.js:397
|
||||||
msgid "disconnecting..."
|
msgid "disconnecting..."
|
||||||
msgstr "deconectando…"
|
msgstr "deconectando…"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:391 ../js/ui/status/network.js:1156
|
#: ../js/ui/status/network.js:403 ../js/ui/status/network.js:1284
|
||||||
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:394 ../js/ui/status/network.js:1159
|
#: ../js/ui/status/network.js:406 ../js/ui/status/network.js:1287
|
||||||
msgid "authentication required"
|
msgid "authentication required"
|
||||||
msgstr "se necesita autenticación"
|
msgstr "se necesita 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:402
|
#: ../js/ui/status/network.js:414
|
||||||
msgid "firmware missing"
|
msgid "firmware missing"
|
||||||
msgstr "falta el «firmware»"
|
msgstr "falta el «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:406
|
#: ../js/ui/status/network.js:418
|
||||||
msgid "unavailable"
|
msgid "unavailable"
|
||||||
msgstr "no disponible"
|
msgstr "no disponible"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:408 ../js/ui/status/network.js:1161
|
#: ../js/ui/status/network.js:420 ../js/ui/status/network.js:1289
|
||||||
msgid "connection failed"
|
msgid "connection failed"
|
||||||
msgstr "falló la conexión"
|
msgstr "falló la conexión"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:424 ../js/ui/status/network.js:510
|
#: ../js/ui/status/network.js:436
|
||||||
|
msgid "Wired Settings"
|
||||||
|
msgstr "Configuración de Wi-Fi"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:477 ../js/ui/status/network.js:563
|
||||||
msgid "Mobile Broadband Settings"
|
msgid "Mobile Broadband Settings"
|
||||||
msgstr "Configuración de banda ancha móvil"
|
msgstr "Configuración de banda ancha móvil"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:466 ../js/ui/status/network.js:1100
|
#: ../js/ui/status/network.js:519 ../js/ui/status/network.js:1228
|
||||||
msgid "Hardware Disabled"
|
msgid "Hardware Disabled"
|
||||||
msgstr "Hardware desactivado"
|
msgstr "Hardware desactivado"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:692
|
#: ../js/ui/status/network.js:578
|
||||||
|
msgid "Use as Internet connection"
|
||||||
|
msgstr "Usar como conexión a Internet"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:755
|
||||||
|
msgid "Airplane Mode is On"
|
||||||
|
msgstr "El modo avión está activado"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:756
|
||||||
|
msgid "Wi-Fi is disabled when airplane mode is on."
|
||||||
|
msgstr "La Wi-Fi se desactiva cuando se activa el modo avión."
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:757
|
||||||
|
msgid "Turn Off Airplane Mode"
|
||||||
|
msgstr "Apagar el modo avión"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:766
|
||||||
|
msgid "Wi-Fi is Off"
|
||||||
|
msgstr "La Wi-Fi está desactivada"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:767
|
||||||
|
msgid "Wi-Fi needs to be turned on in order to connect to a network."
|
||||||
|
msgstr "Se debe activar la Wi-Fi para poder conectarse a la red."
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:768
|
||||||
|
msgid "Turn On Wi-Fi"
|
||||||
|
msgstr "Activar la Wi-Fi"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:793
|
||||||
msgid "Wi-Fi Networks"
|
msgid "Wi-Fi Networks"
|
||||||
msgstr "Redes Wi-Fi"
|
msgstr "Redes Wi-Fi"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:694
|
#: ../js/ui/status/network.js:795
|
||||||
msgid "Select a network"
|
msgid "Select a network"
|
||||||
msgstr "Seleccionar una red"
|
msgstr "Seleccionar una red"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:718
|
#: ../js/ui/status/network.js:824
|
||||||
msgid "No Networks"
|
msgid "No Networks"
|
||||||
msgstr "No hay redes"
|
msgstr "No hay redes"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:987
|
#: ../js/ui/status/network.js:845 ../js/ui/status/rfkill.js:103
|
||||||
|
msgid "Use hardware switch to turn off"
|
||||||
|
msgstr "Usar el interruptor hardware para apagar"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:1115
|
||||||
msgid "Select Network"
|
msgid "Select Network"
|
||||||
msgstr "Seleccionar red"
|
msgstr "Seleccionar red"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:993
|
#: ../js/ui/status/network.js:1121
|
||||||
msgid "Wi-Fi Settings"
|
msgid "Wi-Fi Settings"
|
||||||
msgstr "Configuración de Wi-Fi"
|
msgstr "Configuración de Wi-Fi"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1081
|
#: ../js/ui/status/network.js:1209
|
||||||
msgid "Turn On"
|
msgid "Turn On"
|
||||||
msgstr "Enceder"
|
msgstr "Enceder"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1104
|
#: ../js/ui/status/network.js:1352
|
||||||
msgid "Not Connected"
|
|
||||||
msgstr "No conectado"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1224
|
|
||||||
msgid "VPN"
|
msgid "VPN"
|
||||||
msgstr "VPN"
|
msgstr "VPN"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1364
|
#: ../js/ui/status/network.js:1495
|
||||||
msgid "Network Manager"
|
msgid "Network Manager"
|
||||||
msgstr "Gestor de la red"
|
msgstr "Gestor de la red"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1403
|
#: ../js/ui/status/network.js:1534
|
||||||
msgid "Connection failed"
|
msgid "Connection failed"
|
||||||
msgstr "Falló la conexión"
|
msgstr "Falló la conexión"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1404
|
#: ../js/ui/status/network.js:1535
|
||||||
msgid "Activation of network connection failed"
|
msgid "Activation of network connection failed"
|
||||||
msgstr "Falló la activación de la conexión de red"
|
msgstr "Falló la activación de la conexión de red"
|
||||||
|
|
||||||
@ -1428,15 +1459,15 @@ msgstr "SAI"
|
|||||||
msgid "Battery"
|
msgid "Battery"
|
||||||
msgstr "Batería"
|
msgstr "Batería"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:45
|
#: ../js/ui/status/rfkill.js:82
|
||||||
msgid "Airplane Mode"
|
msgid "Airplane Mode"
|
||||||
msgstr "Modo avión"
|
msgstr "Modo avión"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:47
|
#: ../js/ui/status/rfkill.js:84
|
||||||
msgid "On"
|
msgid "On"
|
||||||
msgstr "Encender"
|
msgstr "Encender"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:51
|
#: ../js/ui/status/rfkill.js:88
|
||||||
msgid "Network Settings"
|
msgid "Network Settings"
|
||||||
msgstr "Configuración de la red"
|
msgstr "Configuración de la red"
|
||||||
|
|
||||||
@ -1489,7 +1520,6 @@ msgid "Search"
|
|||||||
msgstr "Buscar"
|
msgstr "Buscar"
|
||||||
|
|
||||||
#: ../js/ui/windowAttentionHandler.js:19
|
#: ../js/ui/windowAttentionHandler.js:19
|
||||||
#| msgid "'%s' is ready"
|
|
||||||
msgid "“%s” is ready"
|
msgid "“%s” is ready"
|
||||||
msgstr "«%s» está preparado"
|
msgstr "«%s» está preparado"
|
||||||
|
|
||||||
@ -1558,9 +1588,8 @@ msgstr ""
|
|||||||
msgid "List possible modes"
|
msgid "List possible modes"
|
||||||
msgstr "Listar los modos posibles"
|
msgstr "Listar los modos posibles"
|
||||||
|
|
||||||
#: ../src/shell-app.c:640
|
#: ../src/shell-app.c:642
|
||||||
#, c-format
|
#, c-format
|
||||||
#| msgid "Failed to launch '%s'"
|
|
||||||
msgid "Failed to launch “%s”"
|
msgid "Failed to launch “%s”"
|
||||||
msgstr "Falló al lanzar «%s»"
|
msgstr "Falló al lanzar «%s»"
|
||||||
|
|
||||||
|
239
po/gl.po
239
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-01-20 23:09+0100\n"
|
"POT-Creation-Date: 2014-02-07 00:57+0100\n"
|
||||||
"PO-Revision-Date: 2014-01-20 23:10+0200\n"
|
"PO-Revision-Date: 2014-02-07 00:59+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"
|
||||||
@ -278,7 +278,7 @@ msgstr ""
|
|||||||
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
||||||
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
||||||
#: ../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:724
|
#: ../js/ui/status/network.js:857
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
msgstr "Cancelar"
|
msgstr "Cancelar"
|
||||||
|
|
||||||
@ -354,27 +354,27 @@ 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»:"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:543
|
#: ../js/ui/appDisplay.js:633
|
||||||
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:663
|
#: ../js/ui/appDisplay.js:744
|
||||||
msgid "Frequent"
|
msgid "Frequent"
|
||||||
msgstr "Frecuentes"
|
msgstr "Frecuentes"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:670
|
#: ../js/ui/appDisplay.js:751
|
||||||
msgid "All"
|
msgid "All"
|
||||||
msgstr "Todos"
|
msgstr "Todos"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1499
|
#: ../js/ui/appDisplay.js:1558
|
||||||
msgid "New Window"
|
msgid "New Window"
|
||||||
msgstr "Xanela nova"
|
msgstr "Xanela nova"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1521 ../js/ui/dash.js:285
|
#: ../js/ui/appDisplay.js:1580 ../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:1527
|
#: ../js/ui/appDisplay.js:1586
|
||||||
msgid "Add to Favorites"
|
msgid "Add to Favorites"
|
||||||
msgstr "Engadir aos favoritos"
|
msgstr "Engadir aos favoritos"
|
||||||
|
|
||||||
@ -583,8 +583,8 @@ msgstr "Contrasinal:"
|
|||||||
msgid "Type again:"
|
msgid "Type again:"
|
||||||
msgstr "Escriba de novo:"
|
msgstr "Escriba de novo:"
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:131
|
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:227
|
||||||
#: ../js/ui/status/network.js:293 ../js/ui/status/network.js:727
|
#: ../js/ui/status/network.js:300 ../js/ui/status/network.js:860
|
||||||
msgid "Connect"
|
msgid "Connect"
|
||||||
msgstr "Conectar"
|
msgstr "Conectar"
|
||||||
|
|
||||||
@ -624,8 +624,8 @@ 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 ""
|
||||||
"Requírense contrasinais ou chaves de cifrado para acceder á rede sen fíos «%"
|
"Requírense contrasinais ou chaves de cifrado para acceder á rede sen fíos "
|
||||||
"s»."
|
"«%s»."
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:316
|
#: ../js/ui/components/networkAgent.js:316
|
||||||
msgid "Wired 802.1X authentication"
|
msgid "Wired 802.1X authentication"
|
||||||
@ -709,39 +709,39 @@ msgid "Mute"
|
|||||||
msgstr "Silenciar"
|
msgstr "Silenciar"
|
||||||
|
|
||||||
#. Translators: this is the word "Yesterday" followed by a time string. i.e. "Yesterday, 14:30"
|
#. Translators: this is the word "Yesterday" followed by a time string. i.e. "Yesterday, 14:30"
|
||||||
#: ../js/ui/components/telepathyClient.js:941
|
#: ../js/ui/components/telepathyClient.js:952
|
||||||
#, no-c-format
|
#, no-c-format
|
||||||
msgid "<b>Yesterday</b>, <b>%H:%M</b>"
|
msgid "<b>Yesterday</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>Onte</b>, <b>%H:%M</b>"
|
msgstr "<b>Onte</b>, <b>%H:%M</b>"
|
||||||
|
|
||||||
#. Translators: this is the week day name followed by a time string. i.e. "Monday, 14:30
|
#. Translators: this is the week day name followed by a time string. i.e. "Monday, 14:30
|
||||||
#: ../js/ui/components/telepathyClient.js:947
|
#: ../js/ui/components/telepathyClient.js:958
|
||||||
#, no-c-format
|
#, no-c-format
|
||||||
msgid "<b>%A</b>, <b>%H:%M</b>"
|
msgid "<b>%A</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>%H:%M</b> do <b>%A</b>"
|
msgstr "<b>%H:%M</b> do <b>%A</b>"
|
||||||
|
|
||||||
#. Translators: this is the month name and day number followed by a time string. i.e. "May 25, 14:30"
|
#. Translators: this is the month name and day number followed by a time string. i.e. "May 25, 14:30"
|
||||||
#: ../js/ui/components/telepathyClient.js:952
|
#: ../js/ui/components/telepathyClient.js:963
|
||||||
#, no-c-format
|
#, no-c-format
|
||||||
msgid "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
msgid "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
msgstr "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
||||||
|
|
||||||
#. Translators: this is the month name, day number, year number followed by a time string. i.e. "May 25 2012, 14:30"
|
#. Translators: this is the month name, day number, year number followed by a time string. i.e. "May 25 2012, 14:30"
|
||||||
#: ../js/ui/components/telepathyClient.js:956
|
#: ../js/ui/components/telepathyClient.js:967
|
||||||
#, no-c-format
|
#, no-c-format
|
||||||
msgid "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
msgid "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
||||||
msgstr "<b>%d</b> de <b>%B</b> de <b>%Y</b>, <b>%H:%M</b> "
|
msgstr "<b>%d</b> de <b>%B</b> de <b>%Y</b>, <b>%H:%M</b> "
|
||||||
|
|
||||||
#. 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:987
|
#: ../js/ui/components/telepathyClient.js:998
|
||||||
#, c-format
|
#, c-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:1090
|
#: ../js/ui/components/telepathyClient.js:1101
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Invitation to %s"
|
msgid "Invitation to %s"
|
||||||
msgstr "Convite a %s"
|
msgstr "Convite a %s"
|
||||||
@ -749,38 +749,38 @@ 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:1098
|
#: ../js/ui/components/telepathyClient.js:1109
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%s is inviting you to join %s"
|
msgid "%s is inviting you to join %s"
|
||||||
msgstr "%s estalle convidando a unirse a %s"
|
msgstr "%s estalle convidando a unirse a %s"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1100
|
#: ../js/ui/components/telepathyClient.js:1111
|
||||||
#: ../js/ui/components/telepathyClient.js:1135
|
#: ../js/ui/components/telepathyClient.js:1146
|
||||||
#: ../js/ui/components/telepathyClient.js:1169
|
#: ../js/ui/components/telepathyClient.js:1180
|
||||||
#: ../js/ui/components/telepathyClient.js:1226
|
#: ../js/ui/components/telepathyClient.js:1237
|
||||||
msgid "Decline"
|
msgid "Decline"
|
||||||
msgstr "Rexeitar"
|
msgstr "Rexeitar"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1106
|
#: ../js/ui/components/telepathyClient.js:1117
|
||||||
#: ../js/ui/components/telepathyClient.js:1175
|
#: ../js/ui/components/telepathyClient.js:1186
|
||||||
#: ../js/ui/components/telepathyClient.js:1231
|
#: ../js/ui/components/telepathyClient.js:1242
|
||||||
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:1125
|
#: ../js/ui/components/telepathyClient.js:1136
|
||||||
#, c-format
|
#, c-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:1128
|
#: ../js/ui/components/telepathyClient.js:1139
|
||||||
#, c-format
|
#, c-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:1142
|
#: ../js/ui/components/telepathyClient.js:1153
|
||||||
msgid "Answer"
|
msgid "Answer"
|
||||||
msgstr "Responder"
|
msgstr "Responder"
|
||||||
|
|
||||||
@ -789,112 +789,112 @@ msgstr "Responder"
|
|||||||
#. * 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:1163
|
#: ../js/ui/components/telepathyClient.js:1174
|
||||||
#, c-format
|
#, c-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:1192
|
#: ../js/ui/components/telepathyClient.js:1203
|
||||||
#, c-format
|
#, c-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 solicítalle permiso para ver cando está en liña"
|
msgstr "%s solicítalle permiso para ver cando está en liña"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1277
|
#: ../js/ui/components/telepathyClient.js:1288
|
||||||
msgid "Network error"
|
msgid "Network error"
|
||||||
msgstr "Erro da rede"
|
msgstr "Erro da rede"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1279
|
#: ../js/ui/components/telepathyClient.js:1290
|
||||||
msgid "Authentication failed"
|
msgid "Authentication failed"
|
||||||
msgstr "Fallou a autenticación"
|
msgstr "Fallou a autenticación"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1281
|
#: ../js/ui/components/telepathyClient.js:1292
|
||||||
msgid "Encryption error"
|
msgid "Encryption error"
|
||||||
msgstr "Erro de cifrado"
|
msgstr "Erro de cifrado"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1283
|
#: ../js/ui/components/telepathyClient.js:1294
|
||||||
msgid "Certificate not provided"
|
msgid "Certificate not provided"
|
||||||
msgstr "Certificado non fornecido"
|
msgstr "Certificado non fornecido"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1285
|
#: ../js/ui/components/telepathyClient.js:1296
|
||||||
msgid "Certificate untrusted"
|
msgid "Certificate untrusted"
|
||||||
msgstr "Non se confía no certificado"
|
msgstr "Non se confía no certificado"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1287
|
#: ../js/ui/components/telepathyClient.js:1298
|
||||||
msgid "Certificate expired"
|
msgid "Certificate expired"
|
||||||
msgstr "Certificado caducado"
|
msgstr "Certificado caducado"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1289
|
#: ../js/ui/components/telepathyClient.js:1300
|
||||||
msgid "Certificate not activated"
|
msgid "Certificate not activated"
|
||||||
msgstr "Certificado non activado"
|
msgstr "Certificado non activado"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1291
|
#: ../js/ui/components/telepathyClient.js:1302
|
||||||
msgid "Certificate hostname mismatch"
|
msgid "Certificate hostname mismatch"
|
||||||
msgstr "O nome do servidor do certificado non coincide"
|
msgstr "O nome do servidor do certificado non coincide"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1293
|
#: ../js/ui/components/telepathyClient.js:1304
|
||||||
msgid "Certificate fingerprint mismatch"
|
msgid "Certificate fingerprint mismatch"
|
||||||
msgstr "A pegada do certificado non coincide"
|
msgstr "A pegada do certificado non coincide"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1295
|
#: ../js/ui/components/telepathyClient.js:1306
|
||||||
msgid "Certificate self-signed"
|
msgid "Certificate self-signed"
|
||||||
msgstr "Certificado autoasinado"
|
msgstr "Certificado autoasinado"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1297
|
#: ../js/ui/components/telepathyClient.js:1308
|
||||||
msgid "Status is set to offline"
|
msgid "Status is set to offline"
|
||||||
msgstr "O estado está definido a «desconectado»"
|
msgstr "O estado está definido a «desconectado»"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1299
|
#: ../js/ui/components/telepathyClient.js:1310
|
||||||
msgid "Encryption is not available"
|
msgid "Encryption is not available"
|
||||||
msgstr "O cifrado non está dispoñíbel"
|
msgstr "O cifrado non está dispoñíbel"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1301
|
#: ../js/ui/components/telepathyClient.js:1312
|
||||||
msgid "Certificate is invalid"
|
msgid "Certificate is invalid"
|
||||||
msgstr "O certificado non é válido"
|
msgstr "O certificado non é válido"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1303
|
#: ../js/ui/components/telepathyClient.js:1314
|
||||||
msgid "Connection has been refused"
|
msgid "Connection has been refused"
|
||||||
msgstr "Rexeitouse a conexión"
|
msgstr "Rexeitouse a conexión"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1305
|
#: ../js/ui/components/telepathyClient.js:1316
|
||||||
msgid "Connection can't be established"
|
msgid "Connection can't be established"
|
||||||
msgstr "Non é posíbel estabelecer a conexión"
|
msgstr "Non é posíbel estabelecer a conexión"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1307
|
#: ../js/ui/components/telepathyClient.js:1318
|
||||||
msgid "Connection has been lost"
|
msgid "Connection has been lost"
|
||||||
msgstr "Perdeuse a conexión"
|
msgstr "Perdeuse a conexión"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1309
|
#: ../js/ui/components/telepathyClient.js:1320
|
||||||
msgid "This account is already connected to the server"
|
msgid "This account is already connected to the server"
|
||||||
msgstr "Esta cuenta xa está conectada ao servidor"
|
msgstr "Esta cuenta xa está conectada ao servidor"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1311
|
#: ../js/ui/components/telepathyClient.js:1322
|
||||||
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 ""
|
||||||
"Substituíuse a conexión por unha nova conexión empregando o mesmo recurso"
|
"Substituíuse a conexión por unha nova conexión empregando o mesmo recurso"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1313
|
#: ../js/ui/components/telepathyClient.js:1324
|
||||||
msgid "The account already exists on the server"
|
msgid "The account already exists on the server"
|
||||||
msgstr "Esta conta xa existe no servidor"
|
msgstr "Esta conta xa existe no servidor"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1315
|
#: ../js/ui/components/telepathyClient.js:1326
|
||||||
msgid "Server is currently too busy to handle the connection"
|
msgid "Server is currently too busy to handle the connection"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Nestes intres o servidor está moi ocupado tentando xestionar a conexión"
|
"Nestes intres o servidor está moi ocupado tentando xestionar a conexión"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1317
|
#: ../js/ui/components/telepathyClient.js:1328
|
||||||
msgid "Certificate has been revoked"
|
msgid "Certificate has been revoked"
|
||||||
msgstr "Revogouse o certificado"
|
msgstr "Revogouse o certificado"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1319
|
#: ../js/ui/components/telepathyClient.js:1330
|
||||||
msgid ""
|
msgid ""
|
||||||
"Certificate uses an insecure cipher algorithm or is cryptographically weak"
|
"Certificate uses an insecure cipher algorithm or is cryptographically weak"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"O certificado usa un algoritmo de cifrado inseguro ou é criptográficamente "
|
"O certificado usa un algoritmo de cifrado inseguro ou é criptográficamente "
|
||||||
"débil"
|
"débil"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1321
|
#: ../js/ui/components/telepathyClient.js:1332
|
||||||
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"
|
||||||
@ -903,22 +903,22 @@ msgstr ""
|
|||||||
"certificado do servidor excede os límites impostos pola biblioteca de "
|
"certificado do servidor excede os límites impostos pola biblioteca de "
|
||||||
"criptografía."
|
"criptografía."
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1323
|
#: ../js/ui/components/telepathyClient.js:1334
|
||||||
msgid "Internal error"
|
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:1333
|
#: ../js/ui/components/telepathyClient.js:1344
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Unable to connect to %s"
|
msgid "Unable to connect to %s"
|
||||||
msgstr "Non foi posíbel conectarse a %s"
|
msgstr "Non foi posíbel conectarse a %s"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1338
|
#: ../js/ui/components/telepathyClient.js:1349
|
||||||
msgid "View account"
|
msgid "View account"
|
||||||
msgstr "Ver conta"
|
msgstr "Ver conta"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1370
|
#: ../js/ui/components/telepathyClient.js:1381
|
||||||
msgid "Unknown reason"
|
msgid "Unknown reason"
|
||||||
msgstr "Razón descoñecida"
|
msgstr "Razón descoñecida"
|
||||||
|
|
||||||
@ -1100,7 +1100,7 @@ msgstr "Activado"
|
|||||||
#. 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:717 ../js/ui/status/network.js:470
|
#: ../js/ui/lookingGlass.js:717 ../js/ui/status/network.js:523
|
||||||
#: ../src/gvc/gvc-mixer-control.c:1830
|
#: ../src/gvc/gvc-mixer-control.c:1830
|
||||||
msgid "Disabled"
|
msgid "Disabled"
|
||||||
msgstr "Desactivado"
|
msgstr "Desactivado"
|
||||||
@ -1161,7 +1161,7 @@ msgstr "Bandexa de mensaxes"
|
|||||||
msgid "System Information"
|
msgid "System Information"
|
||||||
msgstr "Información do sistema"
|
msgstr "Información do sistema"
|
||||||
|
|
||||||
#: ../js/ui/notificationDaemon.js:515 ../src/shell-app.c:397
|
#: ../js/ui/notificationDaemon.js:515 ../src/shell-app.c:399
|
||||||
msgctxt "program"
|
msgctxt "program"
|
||||||
msgid "Unknown"
|
msgid "Unknown"
|
||||||
msgstr "Descoñecido"
|
msgstr "Descoñecido"
|
||||||
@ -1199,7 +1199,7 @@ msgstr "Saír"
|
|||||||
msgid "Activities"
|
msgid "Activities"
|
||||||
msgstr "Actividades"
|
msgstr "Actividades"
|
||||||
|
|
||||||
#: ../js/ui/panel.js:903
|
#: ../js/ui/panel.js:905
|
||||||
msgid "Top Bar"
|
msgid "Top Bar"
|
||||||
msgstr "Barra superior"
|
msgstr "Barra superior"
|
||||||
|
|
||||||
@ -1233,11 +1233,11 @@ msgid_plural "%d new notifications"
|
|||||||
msgstr[0] "%d notificación nova"
|
msgstr[0] "%d notificación nova"
|
||||||
msgstr[1] "%d notificacións novas"
|
msgstr[1] "%d notificacións novas"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:472 ../js/ui/status/system.js:342
|
#: ../js/ui/screenShield.js:473 ../js/ui/status/system.js:342
|
||||||
msgid "Lock"
|
msgid "Lock"
|
||||||
msgstr "Bloquear"
|
msgstr "Bloquear"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:706
|
#: ../js/ui/screenShield.js:707
|
||||||
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"
|
||||||
|
|
||||||
@ -1248,11 +1248,11 @@ msgstr "GNOME precisa bloquear a pantalla"
|
|||||||
#.
|
#.
|
||||||
#. XXX: another option is to kick the user into the gdm login
|
#. XXX: another option is to kick the user into the gdm login
|
||||||
#. screen, where we're not affected by grabs
|
#. screen, where we're not affected by grabs
|
||||||
#: ../js/ui/screenShield.js:833 ../js/ui/screenShield.js:1300
|
#: ../js/ui/screenShield.js:834 ../js/ui/screenShield.js:1301
|
||||||
msgid "Unable to lock"
|
msgid "Unable to lock"
|
||||||
msgstr "Non foi posíbel bloquear"
|
msgstr "Non foi posíbel bloquear"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:834 ../js/ui/screenShield.js:1301
|
#: ../js/ui/screenShield.js:835 ../js/ui/screenShield.js:1302
|
||||||
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"
|
||||||
|
|
||||||
@ -1334,26 +1334,31 @@ msgstr "Texto grande"
|
|||||||
|
|
||||||
#. The Bluetooth menu only appears when Bluetooth is in use,
|
#. The Bluetooth menu only appears when Bluetooth is in use,
|
||||||
#. so just statically build it with a "Turn Off" menu item.
|
#. so just statically build it with a "Turn Off" menu item.
|
||||||
#: ../js/ui/status/bluetooth.js:45
|
#: ../js/ui/status/bluetooth.js:48
|
||||||
msgid "Bluetooth"
|
msgid "Bluetooth"
|
||||||
msgstr "Bluetooth"
|
msgstr "Bluetooth"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:47 ../js/ui/status/network.js:131
|
#: ../js/ui/status/bluetooth.js:50 ../js/ui/status/network.js:134
|
||||||
#: ../js/ui/status/network.js:1081 ../js/ui/status/rfkill.js:48
|
#: ../js/ui/status/network.js:1209 ../js/ui/status/rfkill.js:85
|
||||||
|
#: ../js/ui/status/rfkill.js:105
|
||||||
msgid "Turn Off"
|
msgid "Turn Off"
|
||||||
msgstr "Apagar"
|
msgstr "Apagar"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:50
|
#: ../js/ui/status/bluetooth.js:53
|
||||||
msgid "Bluetooth Settings"
|
msgid "Bluetooth Settings"
|
||||||
msgstr "Preferencias do Bluetooth"
|
msgstr "Preferencias do Bluetooth"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:98
|
#: ../js/ui/status/bluetooth.js:100
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%d Connected Device"
|
msgid "%d Connected Device"
|
||||||
msgid_plural "%d Connected Devices"
|
msgid_plural "%d Connected Devices"
|
||||||
msgstr[0] "%d dispositivo conectado"
|
msgstr[0] "%d dispositivo conectado"
|
||||||
msgstr[1] "%d dispositivos conectados"
|
msgstr[1] "%d dispositivos conectados"
|
||||||
|
|
||||||
|
#: ../js/ui/status/bluetooth.js:102 ../js/ui/status/network.js:1232
|
||||||
|
msgid "Not Connected"
|
||||||
|
msgstr "Non conectado"
|
||||||
|
|
||||||
#: ../js/ui/status/brightness.js:44
|
#: ../js/ui/status/brightness.js:44
|
||||||
msgid "Brightness"
|
msgid "Brightness"
|
||||||
msgstr "Brillo"
|
msgstr "Brillo"
|
||||||
@ -1362,99 +1367,131 @@ msgstr "Brillo"
|
|||||||
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/network.js:70
|
#: ../js/ui/status/network.js:73
|
||||||
msgid "<unknown>"
|
msgid "<unknown>"
|
||||||
msgstr "<descoñecido>"
|
msgstr "<descoñecido>"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:220 ../js/ui/status/network.js:377
|
#: ../js/ui/status/network.js:223 ../js/ui/status/network.js:389
|
||||||
#: ../js/ui/status/network.js:1102
|
#: ../js/ui/status/network.js:1230
|
||||||
msgid "Off"
|
msgid "Off"
|
||||||
msgstr "Desactivar"
|
msgstr "Desactivar"
|
||||||
|
|
||||||
#. 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:383
|
#: ../js/ui/status/network.js:395
|
||||||
msgid "unmanaged"
|
msgid "unmanaged"
|
||||||
msgstr "non xestionada"
|
msgstr "non xestionada"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:385
|
#: ../js/ui/status/network.js:397
|
||||||
msgid "disconnecting..."
|
msgid "disconnecting..."
|
||||||
msgstr "desconectando…"
|
msgstr "desconectando…"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:391 ../js/ui/status/network.js:1156
|
#: ../js/ui/status/network.js:403 ../js/ui/status/network.js:1284
|
||||||
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:394 ../js/ui/status/network.js:1159
|
#: ../js/ui/status/network.js:406 ../js/ui/status/network.js:1287
|
||||||
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:402
|
#: ../js/ui/status/network.js:414
|
||||||
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:406
|
#: ../js/ui/status/network.js:418
|
||||||
msgid "unavailable"
|
msgid "unavailable"
|
||||||
msgstr "non dispoñíbel"
|
msgstr "non dispoñíbel"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:408 ../js/ui/status/network.js:1161
|
#: ../js/ui/status/network.js:420 ../js/ui/status/network.js:1289
|
||||||
msgid "connection failed"
|
msgid "connection failed"
|
||||||
msgstr "conexión fallada"
|
msgstr "conexión fallada"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:424 ../js/ui/status/network.js:510
|
#: ../js/ui/status/network.js:436
|
||||||
|
msgid "Wired Settings"
|
||||||
|
msgstr "Preferencias da rede con fíos"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:477 ../js/ui/status/network.js:563
|
||||||
msgid "Mobile Broadband Settings"
|
msgid "Mobile Broadband Settings"
|
||||||
msgstr "Preferencias da banda larga móbil"
|
msgstr "Preferencias da banda larga móbil"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:466 ../js/ui/status/network.js:1100
|
#: ../js/ui/status/network.js:519 ../js/ui/status/network.js:1228
|
||||||
msgid "Hardware Disabled"
|
msgid "Hardware Disabled"
|
||||||
msgstr "Hardware desactivado"
|
msgstr "Hardware desactivado"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:692
|
#: ../js/ui/status/network.js:578
|
||||||
|
msgid "Use as Internet connection"
|
||||||
|
msgstr "Usar como conexión a Internet"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:755
|
||||||
|
msgid "Airplane Mode is On"
|
||||||
|
msgstr "Modo avión activado"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:756
|
||||||
|
msgid "Wi-Fi is disabled when airplane mode is on."
|
||||||
|
msgstr "A Wifi está desactivada cando o modo avión está activo."
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:757
|
||||||
|
msgid "Turn Off Airplane Mode"
|
||||||
|
msgstr "Desactivar o modo avión"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:766
|
||||||
|
msgid "Wi-Fi is Off"
|
||||||
|
msgstr "Wifi desactivada"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:767
|
||||||
|
msgid "Wi-Fi needs to be turned on in order to connect to a network."
|
||||||
|
msgstr "A Wifi precisa activarse para poder conectarse á rede."
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:768
|
||||||
|
msgid "Turn On Wi-Fi"
|
||||||
|
msgstr "Activar Wifi"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:793
|
||||||
msgid "Wi-Fi Networks"
|
msgid "Wi-Fi Networks"
|
||||||
msgstr "Redes WiFi"
|
msgstr "Redes WiFi"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:694
|
#: ../js/ui/status/network.js:795
|
||||||
msgid "Select a network"
|
msgid "Select a network"
|
||||||
msgstr "Seleccione unha rede"
|
msgstr "Seleccione unha rede"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:718
|
#: ../js/ui/status/network.js:824
|
||||||
msgid "No Networks"
|
msgid "No Networks"
|
||||||
msgstr "Sen redes"
|
msgstr "Sen redes"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:987
|
#: ../js/ui/status/network.js:845 ../js/ui/status/rfkill.js:103
|
||||||
|
msgid "Use hardware switch to turn off"
|
||||||
|
msgstr "Usar interruptor hardware para apagar"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:1115
|
||||||
msgid "Select Network"
|
msgid "Select Network"
|
||||||
msgstr "Seleccione unha rede"
|
msgstr "Seleccione unha rede"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:993
|
#: ../js/ui/status/network.js:1121
|
||||||
msgid "Wi-Fi Settings"
|
msgid "Wi-Fi Settings"
|
||||||
msgstr "Preferencias da WiFi"
|
msgstr "Preferencias da WiFi"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1081
|
#: ../js/ui/status/network.js:1209
|
||||||
msgid "Turn On"
|
msgid "Turn On"
|
||||||
msgstr "Activar"
|
msgstr "Activar"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1104
|
#: ../js/ui/status/network.js:1352
|
||||||
msgid "Not Connected"
|
|
||||||
msgstr "Non conectado"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1224
|
|
||||||
msgid "VPN"
|
msgid "VPN"
|
||||||
msgstr "VPN"
|
msgstr "VPN"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1364
|
#: ../js/ui/status/network.js:1495
|
||||||
msgid "Network Manager"
|
msgid "Network Manager"
|
||||||
msgstr "Xestor da rede"
|
msgstr "Xestor da rede"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1403
|
#: ../js/ui/status/network.js:1534
|
||||||
msgid "Connection failed"
|
msgid "Connection failed"
|
||||||
msgstr "Produciuse un fallo na conexión"
|
msgstr "Produciuse un fallo na conexión"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1404
|
#: ../js/ui/status/network.js:1535
|
||||||
msgid "Activation of network connection failed"
|
msgid "Activation of network connection failed"
|
||||||
msgstr "Produciuse un fallo na activación da conexión de rede"
|
msgstr "Produciuse un fallo na activación da conexión de rede"
|
||||||
|
|
||||||
@ -1495,15 +1532,15 @@ msgstr "Batería"
|
|||||||
#. The menu only appears when airplane mode is on, so just
|
#. The menu only appears when airplane mode is on, so just
|
||||||
#. statically build it as if it was on, rather than dynamically
|
#. statically build it as if it was on, rather than dynamically
|
||||||
#. changing the menu contents.
|
#. changing the menu contents.
|
||||||
#: ../js/ui/status/rfkill.js:45
|
#: ../js/ui/status/rfkill.js:82
|
||||||
msgid "Airplane Mode"
|
msgid "Airplane Mode"
|
||||||
msgstr "Modo avión"
|
msgstr "Modo avión"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:47
|
#: ../js/ui/status/rfkill.js:84
|
||||||
msgid "On"
|
msgid "On"
|
||||||
msgstr "Activado"
|
msgstr "Activado"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:51
|
#: ../js/ui/status/rfkill.js:88
|
||||||
msgid "Network Settings"
|
msgid "Network Settings"
|
||||||
msgstr "Preferencias da rede"
|
msgstr "Preferencias da rede"
|
||||||
|
|
||||||
@ -1626,7 +1663,7 @@ msgstr ""
|
|||||||
msgid "List possible modes"
|
msgid "List possible modes"
|
||||||
msgstr "Listar os modos posíbeis"
|
msgstr "Listar os modos posíbeis"
|
||||||
|
|
||||||
#: ../src/shell-app.c:640
|
#: ../src/shell-app.c:642
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to launch “%s”"
|
msgid "Failed to launch “%s”"
|
||||||
msgstr "Produciuse un erro ao iniciar «%s»"
|
msgstr "Produciuse un erro ao iniciar «%s»"
|
||||||
|
182
po/he.po
182
po/he.po
@ -9,8 +9,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-01-29 22:33+0200\n"
|
"POT-Creation-Date: 2014-02-15 20:15+0200\n"
|
||||||
"PO-Revision-Date: 2014-01-29 22:38+0200\n"
|
"PO-Revision-Date: 2014-02-15 20:16+0200\n"
|
||||||
"Last-Translator: Yosef Or Boczko <yoseforb@gmail.com>\n"
|
"Last-Translator: Yosef Or Boczko <yoseforb@gmail.com>\n"
|
||||||
"Language-Team: עברית <>\n"
|
"Language-Team: עברית <>\n"
|
||||||
"Language: he\n"
|
"Language: he\n"
|
||||||
@ -271,7 +271,7 @@ msgstr "יש לבחור את ההרחבה להגדרה באמצעות תיבת
|
|||||||
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
||||||
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
||||||
#: ../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:757
|
#: ../js/ui/status/network.js:857
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
msgstr "ביטול"
|
msgstr "ביטול"
|
||||||
|
|
||||||
@ -328,31 +328,31 @@ msgid "Could not parse command:"
|
|||||||
msgstr "לא ניתן לפענח את הפקודה:"
|
msgstr "לא ניתן לפענח את הפקודה:"
|
||||||
|
|
||||||
#: ../js/misc/util.js:156
|
#: ../js/misc/util.js:156
|
||||||
#, c-format
|
#, javascript-format
|
||||||
msgid "Execution of “%s” failed:"
|
msgid "Execution of “%s” failed:"
|
||||||
msgstr "ההרצה של „%s” נכשלה:"
|
msgstr "ההרצה של „%s” נכשלה:"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:633
|
#: ../js/ui/appDisplay.js:625
|
||||||
msgid "Frequently used applications will appear here"
|
msgid "Frequently used applications will appear here"
|
||||||
msgstr "יישומים בשימוש תדיר יופיעו כאן"
|
msgstr "יישומים בשימוש תדיר יופיעו כאן"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:744
|
#: ../js/ui/appDisplay.js:736
|
||||||
msgid "Frequent"
|
msgid "Frequent"
|
||||||
msgstr "תדיר"
|
msgstr "תדיר"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:751
|
#: ../js/ui/appDisplay.js:743
|
||||||
msgid "All"
|
msgid "All"
|
||||||
msgstr "הכול"
|
msgstr "הכול"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1558
|
#: ../js/ui/appDisplay.js:1546
|
||||||
msgid "New Window"
|
msgid "New Window"
|
||||||
msgstr "חלון חדש"
|
msgstr "חלון חדש"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1580 ../js/ui/dash.js:285
|
#: ../js/ui/appDisplay.js:1568 ../js/ui/dash.js:285
|
||||||
msgid "Remove from Favorites"
|
msgid "Remove from Favorites"
|
||||||
msgstr "הסרה מהמועדפים"
|
msgstr "הסרה מהמועדפים"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1586
|
#: ../js/ui/appDisplay.js:1574
|
||||||
msgid "Add to Favorites"
|
msgid "Add to Favorites"
|
||||||
msgstr "הוספה למועדפים"
|
msgstr "הוספה למועדפים"
|
||||||
|
|
||||||
@ -493,7 +493,7 @@ msgstr "ש׳"
|
|||||||
|
|
||||||
#: ../js/ui/calendar.js:390
|
#: ../js/ui/calendar.js:390
|
||||||
msgid "calendar:MY"
|
msgid "calendar:MY"
|
||||||
msgstr ""
|
msgstr "calendar:YM"
|
||||||
|
|
||||||
#: ../js/ui/calendar.js:446
|
#: ../js/ui/calendar.js:446
|
||||||
msgid "Previous month"
|
msgid "Previous month"
|
||||||
@ -565,8 +565,8 @@ msgstr "ססמה:"
|
|||||||
msgid "Type again:"
|
msgid "Type again:"
|
||||||
msgstr "נא להקליד שוב:"
|
msgstr "נא להקליד שוב:"
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:132
|
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:227
|
||||||
#: ../js/ui/status/network.js:294 ../js/ui/status/network.js:760
|
#: ../js/ui/status/network.js:300 ../js/ui/status/network.js:860
|
||||||
msgid "Connect"
|
msgid "Connect"
|
||||||
msgstr "התחברות"
|
msgstr "התחברות"
|
||||||
|
|
||||||
@ -599,7 +599,7 @@ msgid "Authentication required by wireless network"
|
|||||||
msgstr "הרשת האלחוטית דורשת אימות"
|
msgstr "הרשת האלחוטית דורשת אימות"
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:312
|
#: ../js/ui/components/networkAgent.js:312
|
||||||
#, c-format
|
#, javascript-format
|
||||||
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”."
|
||||||
@ -634,7 +634,7 @@ msgid "Mobile broadband network password"
|
|||||||
msgstr "ססמת רשת הפס הרחב הניידת"
|
msgstr "ססמת רשת הפס הרחב הניידת"
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:339
|
#: ../js/ui/components/networkAgent.js:339
|
||||||
#, c-format
|
#, javascript-format
|
||||||
msgid "A password is required to connect to “%s”."
|
msgid "A password is required to connect to “%s”."
|
||||||
msgstr "נדרשת ססמה כדי להתחבר אל „%s”"
|
msgstr "נדרשת ססמה כדי להתחבר אל „%s”"
|
||||||
|
|
||||||
@ -1025,7 +1025,7 @@ msgid "Install"
|
|||||||
msgstr "התקנה"
|
msgstr "התקנה"
|
||||||
|
|
||||||
#: ../js/ui/extensionDownloader.js:204
|
#: ../js/ui/extensionDownloader.js:204
|
||||||
#, c-format
|
#, javascript-format
|
||||||
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?"
|
||||||
|
|
||||||
@ -1059,7 +1059,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:717 ../js/ui/status/network.js:518
|
#: ../js/ui/lookingGlass.js:717 ../js/ui/status/network.js:523
|
||||||
#: ../src/gvc/gvc-mixer-control.c:1830
|
#: ../src/gvc/gvc-mixer-control.c:1830
|
||||||
msgid "Disabled"
|
msgid "Disabled"
|
||||||
msgstr "מנוטרל"
|
msgstr "מנוטרל"
|
||||||
@ -1159,7 +1159,7 @@ msgstr "יציאה"
|
|||||||
msgid "Activities"
|
msgid "Activities"
|
||||||
msgstr "פעילויות"
|
msgstr "פעילויות"
|
||||||
|
|
||||||
#: ../js/ui/panel.js:905
|
#: ../js/ui/panel.js:914
|
||||||
msgid "Top Bar"
|
msgid "Top Bar"
|
||||||
msgstr "הסרגל העליון"
|
msgstr "הסרגל העליון"
|
||||||
|
|
||||||
@ -1281,27 +1281,32 @@ msgstr "ניגודיות גבוהה"
|
|||||||
msgid "Large Text"
|
msgid "Large Text"
|
||||||
msgstr "טקסט גדול"
|
msgstr "טקסט גדול"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:45
|
#: ../js/ui/status/bluetooth.js:48
|
||||||
msgid "Bluetooth"
|
msgid "Bluetooth"
|
||||||
msgstr "Bluetooth"
|
msgstr "Bluetooth"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:47 ../js/ui/status/network.js:132
|
#: ../js/ui/status/bluetooth.js:50 ../js/ui/status/location.js:55
|
||||||
#: ../js/ui/status/network.js:1108 ../js/ui/status/rfkill.js:48
|
#: ../js/ui/status/network.js:134 ../js/ui/status/network.js:1209
|
||||||
|
#: ../js/ui/status/rfkill.js:85 ../js/ui/status/rfkill.js:105
|
||||||
msgid "Turn Off"
|
msgid "Turn Off"
|
||||||
msgstr "כיבוי"
|
msgstr "כיבוי"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:50
|
#: ../js/ui/status/bluetooth.js:53
|
||||||
msgid "Bluetooth Settings"
|
msgid "Bluetooth Settings"
|
||||||
msgstr "הגדרות Bluetooth"
|
msgstr "הגדרות Bluetooth"
|
||||||
|
|
||||||
# javascript-format
|
# javascript-format
|
||||||
#: ../js/ui/status/bluetooth.js:98
|
#: ../js/ui/status/bluetooth.js:100
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%d Connected Device"
|
msgid "%d Connected Device"
|
||||||
msgid_plural "%d Connected Devices"
|
msgid_plural "%d Connected Devices"
|
||||||
msgstr[0] "התקן אחד מחובר"
|
msgstr[0] "התקן אחד מחובר"
|
||||||
msgstr[1] "%d התקנים מחוברים"
|
msgstr[1] "%d התקנים מחוברים"
|
||||||
|
|
||||||
|
#: ../js/ui/status/bluetooth.js:102 ../js/ui/status/network.js:1232
|
||||||
|
msgid "Not Connected"
|
||||||
|
msgstr "לא מחובר"
|
||||||
|
|
||||||
#: ../js/ui/status/brightness.js:44
|
#: ../js/ui/status/brightness.js:44
|
||||||
msgid "Brightness"
|
msgid "Brightness"
|
||||||
msgstr "בהירות"
|
msgstr "בהירות"
|
||||||
@ -1310,103 +1315,140 @@ msgstr "בהירות"
|
|||||||
msgid "Show Keyboard Layout"
|
msgid "Show Keyboard Layout"
|
||||||
msgstr "הצגת פריסת המקלדת"
|
msgstr "הצגת פריסת המקלדת"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:71
|
#: ../js/ui/status/location.js:45
|
||||||
msgid "<unknown>"
|
msgid "Location"
|
||||||
msgstr "<לא ידוע>"
|
msgstr "מיקום"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:221 ../js/ui/status/network.js:383
|
#: ../js/ui/status/location.js:54 ../js/ui/status/location.js:160
|
||||||
#: ../js/ui/status/network.js:1129
|
#: ../js/ui/status/rfkill.js:84
|
||||||
|
msgid "On"
|
||||||
|
msgstr "פועל"
|
||||||
|
|
||||||
|
#: ../js/ui/status/location.js:157 ../js/ui/status/network.js:223
|
||||||
|
#: ../js/ui/status/network.js:389 ../js/ui/status/network.js:1230
|
||||||
msgid "Off"
|
msgid "Off"
|
||||||
msgstr "כבוימנותק"
|
msgstr "כבוימנותק"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:73
|
||||||
|
msgid "<unknown>"
|
||||||
|
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:389
|
#: ../js/ui/status/network.js:395
|
||||||
msgid "unmanaged"
|
msgid "unmanaged"
|
||||||
msgstr "לא מנוהל"
|
msgstr "לא מנוהל"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:391
|
#: ../js/ui/status/network.js:397
|
||||||
msgid "disconnecting..."
|
msgid "disconnecting..."
|
||||||
msgstr "בהליכי ניתוק..."
|
msgstr "בהליכי ניתוק..."
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:397 ../js/ui/status/network.js:1183
|
#: ../js/ui/status/network.js:403 ../js/ui/status/network.js:1284
|
||||||
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:400 ../js/ui/status/network.js:1186
|
#: ../js/ui/status/network.js:406 ../js/ui/status/network.js:1287
|
||||||
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:408
|
#: ../js/ui/status/network.js:414
|
||||||
msgid "firmware missing"
|
msgid "firmware missing"
|
||||||
msgstr "הקושחה חסרה"
|
msgstr "הקושחה חסרה"
|
||||||
|
|
||||||
#. 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:412
|
#: ../js/ui/status/network.js:418
|
||||||
msgid "unavailable"
|
msgid "unavailable"
|
||||||
msgstr "לא זמין"
|
msgstr "לא זמין"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:414 ../js/ui/status/network.js:1188
|
#: ../js/ui/status/network.js:420 ../js/ui/status/network.js:1289
|
||||||
msgid "connection failed"
|
msgid "connection failed"
|
||||||
msgstr "החיבור נכשל"
|
msgstr "החיבור נכשל"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:430
|
#: ../js/ui/status/network.js:436
|
||||||
msgid "Wired Settings"
|
msgid "Wired Settings"
|
||||||
msgstr "הגדרות רשת קווית"
|
msgstr "הגדרות רשת קווית"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:472 ../js/ui/status/network.js:558
|
#: ../js/ui/status/network.js:477 ../js/ui/status/network.js:563
|
||||||
msgid "Mobile Broadband Settings"
|
msgid "Mobile Broadband Settings"
|
||||||
msgstr "הגדרות פס־רחב נייד"
|
msgstr "הגדרות פס־רחב נייד"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:514 ../js/ui/status/network.js:1127
|
#: ../js/ui/status/network.js:519 ../js/ui/status/network.js:1228
|
||||||
msgid "Hardware Disabled"
|
msgid "Hardware Disabled"
|
||||||
msgstr "מנוטרל חומרתית"
|
msgstr "מנוטרל חומרתית"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:725
|
#: ../js/ui/status/network.js:578
|
||||||
|
msgid "Use as Internet connection"
|
||||||
|
msgstr "שימוש כחיבור לאינטרנט"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:755
|
||||||
|
msgid "Airplane Mode is On"
|
||||||
|
msgstr "מצב טיסה מופעל"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:756
|
||||||
|
msgid "Wi-Fi is disabled when airplane mode is on."
|
||||||
|
msgstr "רשת אלחוטית מושבתת כאשר מצב טיסה מופעל."
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:757
|
||||||
|
msgid "Turn Off Airplane Mode"
|
||||||
|
msgstr "כיבוי מצב טיסה"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:766
|
||||||
|
msgid "Wi-Fi is Off"
|
||||||
|
msgstr "רשת אלחוטית כבויה"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:767
|
||||||
|
msgid "Wi-Fi needs to be turned on in order to connect to a network."
|
||||||
|
msgstr "רשת אלחוטית צריכה להיות מופעלת על מנת להתחבר לרשת."
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:768
|
||||||
|
msgid "Turn On Wi-Fi"
|
||||||
|
msgstr "הפעלת רשת אלחוטית"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:793
|
||||||
msgid "Wi-Fi Networks"
|
msgid "Wi-Fi Networks"
|
||||||
msgstr "רשתות אלחוטיות"
|
msgstr "רשתות אלחוטיות"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:727
|
#: ../js/ui/status/network.js:795
|
||||||
msgid "Select a network"
|
msgid "Select a network"
|
||||||
msgstr "בחירת רשת"
|
msgstr "בחירת רשת"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:751
|
#: ../js/ui/status/network.js:824
|
||||||
msgid "No Networks"
|
msgid "No Networks"
|
||||||
msgstr "אין רשתות"
|
msgstr "אין רשתות"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1014
|
#: ../js/ui/status/network.js:845 ../js/ui/status/rfkill.js:103
|
||||||
|
msgid "Use hardware switch to turn off"
|
||||||
|
msgstr "שימוש במתג של החומרה לכיבוי"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:1115
|
||||||
msgid "Select Network"
|
msgid "Select Network"
|
||||||
msgstr "בחירת רשת"
|
msgstr "בחירת רשת"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1020
|
#: ../js/ui/status/network.js:1121
|
||||||
msgid "Wi-Fi Settings"
|
msgid "Wi-Fi Settings"
|
||||||
msgstr "הגדרות רשת אלחוטית"
|
msgstr "הגדרות רשת אלחוטית"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1108
|
#: ../js/ui/status/network.js:1209
|
||||||
msgid "Turn On"
|
msgid "Turn On"
|
||||||
msgstr "הפעלה"
|
msgstr "הפעלה"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1131
|
#: ../js/ui/status/network.js:1352
|
||||||
msgid "Not Connected"
|
|
||||||
msgstr "לא מחובר"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1251
|
|
||||||
msgid "VPN"
|
msgid "VPN"
|
||||||
msgstr "VPN"
|
msgstr "VPN"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1394
|
#: ../js/ui/status/network.js:1495
|
||||||
msgid "Network Manager"
|
msgid "Network Manager"
|
||||||
msgstr "מנהל הרשתות"
|
msgstr "מנהל הרשתות"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1433
|
#: ../js/ui/status/network.js:1534
|
||||||
msgid "Connection failed"
|
msgid "Connection failed"
|
||||||
msgstr "ההתחברות נכשל"
|
msgstr "ההתחברות נכשל"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1434
|
#: ../js/ui/status/network.js:1535
|
||||||
msgid "Activation of network connection failed"
|
msgid "Activation of network connection failed"
|
||||||
msgstr "הפעלת חיבור הרשת נכשלה"
|
msgstr "הפעלת חיבור הרשת נכשלה"
|
||||||
|
|
||||||
@ -1440,15 +1482,11 @@ msgstr "אל־פסק"
|
|||||||
msgid "Battery"
|
msgid "Battery"
|
||||||
msgstr "סוללה"
|
msgstr "סוללה"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:45
|
#: ../js/ui/status/rfkill.js:82
|
||||||
msgid "Airplane Mode"
|
msgid "Airplane Mode"
|
||||||
msgstr "מצב טיסה"
|
msgstr "מצב טיסה"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:47
|
#: ../js/ui/status/rfkill.js:88
|
||||||
msgid "On"
|
|
||||||
msgstr "פועל"
|
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:51
|
|
||||||
msgid "Network Settings"
|
msgid "Network Settings"
|
||||||
msgstr "הגדרות הרשת"
|
msgstr "הגדרות הרשת"
|
||||||
|
|
||||||
@ -1462,7 +1500,7 @@ msgstr "יציאה"
|
|||||||
|
|
||||||
#: ../js/ui/status/system.js:338
|
#: ../js/ui/status/system.js:338
|
||||||
msgid "Orientation Lock"
|
msgid "Orientation Lock"
|
||||||
msgstr ""
|
msgstr "נעילת כיוון"
|
||||||
|
|
||||||
#: ../js/ui/status/system.js:346
|
#: ../js/ui/status/system.js:346
|
||||||
msgid "Suspend"
|
msgid "Suspend"
|
||||||
@ -1501,7 +1539,7 @@ msgid "Search"
|
|||||||
msgstr "חיפוש"
|
msgstr "חיפוש"
|
||||||
|
|
||||||
#: ../js/ui/windowAttentionHandler.js:19
|
#: ../js/ui/windowAttentionHandler.js:19
|
||||||
#, c-format
|
#, javascript-format
|
||||||
msgid "“%s” is ready"
|
msgid "“%s” is ready"
|
||||||
msgstr "„%s” מוכן"
|
msgstr "„%s” מוכן"
|
||||||
|
|
||||||
@ -1554,19 +1592,19 @@ msgstr[1] "%u קלטים"
|
|||||||
msgid "System Sounds"
|
msgid "System Sounds"
|
||||||
msgstr "צלילי מערכת"
|
msgstr "צלילי מערכת"
|
||||||
|
|
||||||
#: ../src/main.c:347
|
#: ../src/main.c:349
|
||||||
msgid "Print version"
|
msgid "Print version"
|
||||||
msgstr "Print version"
|
msgstr "Print version"
|
||||||
|
|
||||||
#: ../src/main.c:353
|
#: ../src/main.c:355
|
||||||
msgid "Mode used by GDM for login screen"
|
msgid "Mode used by GDM for login screen"
|
||||||
msgstr "המצב בו GDM יעשה שימוש לצורך מסך הכניסה"
|
msgstr "המצב בו GDM יעשה שימוש לצורך מסך הכניסה"
|
||||||
|
|
||||||
#: ../src/main.c:359
|
#: ../src/main.c:361
|
||||||
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:365
|
#: ../src/main.c:367
|
||||||
msgid "List possible modes"
|
msgid "List possible modes"
|
||||||
msgstr "הצגת המצבים האפשריים"
|
msgstr "הצגת המצבים האפשריים"
|
||||||
|
|
||||||
@ -1587,6 +1625,14 @@ msgstr "הססמה לא יכולה להישאר ריקה"
|
|||||||
msgid "Authentication dialog was dismissed by the user"
|
msgid "Authentication dialog was dismissed by the user"
|
||||||
msgstr "המשתמש בחר להתעלם מתיבת דו־שיח האימות"
|
msgstr "המשתמש בחר להתעלם מתיבת דו־שיח האימות"
|
||||||
|
|
||||||
|
#~ msgctxt "event list time"
|
||||||
|
#~ msgid "%H\\u2236%M"
|
||||||
|
#~ msgstr "%H\\u2236%M"
|
||||||
|
|
||||||
|
#~ msgctxt "event list time"
|
||||||
|
#~ msgid "%l\\u2236%M\\u2009%p"
|
||||||
|
#~ msgstr "%l\\u2236%M\\u2009%p"
|
||||||
|
|
||||||
#~ msgid "List of categories that should be displayed as folders"
|
#~ msgid "List of categories that should be displayed as folders"
|
||||||
#~ msgstr "List of categories that should be displayed as folders"
|
#~ msgstr "List of categories that should be displayed as folders"
|
||||||
|
|
||||||
@ -1653,14 +1699,6 @@ msgstr "המשתמש בחר להתעלם מתיבת דו־שיח האימות"
|
|||||||
#~ msgid "%s the Oracle says"
|
#~ msgid "%s the Oracle says"
|
||||||
#~ msgstr "%s, כה אמרה האוראקל"
|
#~ msgstr "%s, כה אמרה האוראקל"
|
||||||
|
|
||||||
#~ msgctxt "event list time"
|
|
||||||
#~ msgid "%H\\u2236%M"
|
|
||||||
#~ msgstr "%H\\u2236%M"
|
|
||||||
|
|
||||||
#~ msgctxt "event list time"
|
|
||||||
#~ msgid "%l\\u2236%M\\u2009%p"
|
|
||||||
#~ msgstr "%l\\u2236%M\\u2009%p"
|
|
||||||
|
|
||||||
#~ msgid "Screenshots"
|
#~ msgid "Screenshots"
|
||||||
#~ msgstr "צילומי מסך"
|
#~ msgstr "צילומי מסך"
|
||||||
|
|
||||||
|
374
po/id.po
374
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-01-03 21:13+0000\n"
|
"POT-Creation-Date: 2014-02-04 08:57+0000\n"
|
||||||
"PO-Revision-Date: 2014-01-04 10:24+0700\n"
|
"PO-Revision-Date: 2014-02-04 21:15+0700\n"
|
||||||
"Last-Translator: Andika Triwidada <andika@gmail.com>\n"
|
"Last-Translator: Andika Triwidada <andika@gmail.com>\n"
|
||||||
"Language-Team: Indonesian <gnome@i15n.org>\n"
|
"Language-Team: Indonesian <gnome@i15n.org>\n"
|
||||||
"Language: id\n"
|
"Language: id\n"
|
||||||
@ -20,7 +20,7 @@ msgstr ""
|
|||||||
"Content-Transfer-Encoding: 8bit\n"
|
"Content-Transfer-Encoding: 8bit\n"
|
||||||
"Plural-Forms: nplurals=1; plural=0;\n"
|
"Plural-Forms: nplurals=1; plural=0;\n"
|
||||||
"X-Poedit-SourceCharset: UTF-8\n"
|
"X-Poedit-SourceCharset: UTF-8\n"
|
||||||
"X-Generator: Poedit 1.5.7\n"
|
"X-Generator: Poedit 1.6.3\n"
|
||||||
|
|
||||||
#: ../data/50-gnome-shell-system.xml.in.h:1
|
#: ../data/50-gnome-shell-system.xml.in.h:1
|
||||||
msgid "System"
|
msgid "System"
|
||||||
@ -83,20 +83,20 @@ msgstr ""
|
|||||||
"dialog Alt-F2."
|
"dialog 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"
|
||||||
msgstr "Uuid ekstensi yang hendak diaktifkan"
|
msgstr "UUID ekstensi yang akan difungsikan"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:4
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:4
|
||||||
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 "
|
||||||
"list. You can also manipulate this list with the EnableExtension and "
|
"list. You can also manipulate this list with the EnableExtension and "
|
||||||
"DisableExtension DBus methods on org.gnome.Shell."
|
"DisableExtension D-Bus methods on org.gnome.Shell."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Ekstensi GNOME Shell memiliki properti uuid; kunci ini berisikan ekstensi "
|
"Ekstensi GNOME Shell memiliki properti UUID; kunci ini memuat daftar "
|
||||||
"yang seharusnya dimuat. Ekstensi yang ingin dimuat harus berada di dalam "
|
"ekstensi yang mesti dimuat. Sebarang ekstensi yang ingin dimuat perlu berada "
|
||||||
"daftar tersebut. Anda juga bisa memanipulasi daftar ini dengan metode DBus "
|
"dalam daftar ini. Anda juga dapat memanipulasi daftar ini dengan metoda D-"
|
||||||
"EnableExtension dan DisableExtension pada org.gnome.Shell."
|
"Bus EnableExtension dan DisableExtension pada org.gnome.Shell."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:5
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:5
|
||||||
msgid "List of desktop file IDs for favorite applications"
|
msgid "List of desktop file IDs for favorite applications"
|
||||||
@ -111,45 +111,33 @@ msgstr ""
|
|||||||
"area favorit."
|
"area favorit."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:7
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:7
|
||||||
msgid "List of categories that should be displayed as folders"
|
|
||||||
msgstr "Daftar kategori yang mesti ditampilkan sebagai folder"
|
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:8
|
|
||||||
msgid ""
|
|
||||||
"Each category name in this list will be represented as folder in the "
|
|
||||||
"application view, rather than being displayed inline in the main view."
|
|
||||||
msgstr ""
|
|
||||||
"Setiap nama kategori dalam daftar ini akan diwakili oleh folder dalam "
|
|
||||||
"tilikan aplikasi, bukan ditampilkan dalam tilikan utama."
|
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:9
|
|
||||||
msgid "History for command (Alt-F2) dialog"
|
msgid "History for command (Alt-F2) dialog"
|
||||||
msgstr "Riwayat dialog perintah (Alt-F2)"
|
msgstr "Riwayat dialog perintah (Alt-F2)"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:10
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:8
|
||||||
msgid "History for the looking glass dialog"
|
msgid "History for the looking glass dialog"
|
||||||
msgstr "Riwayat untuk dialog yang berpenampilan gelas kaca"
|
msgstr "Riwayat untuk dialog yang berpenampilan gelas kaca"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:11
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:9
|
||||||
msgid "Always show the 'Log out' menuitem in the user menu."
|
msgid "Always show the 'Log out' menu item in the user menu."
|
||||||
msgstr "Selalku tampilkan butir menu 'Log keluar' dalam menu pengguna."
|
msgstr "Selalu tampilkan butir menu 'Log keluar' dalam menu pengguna."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:12
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:10
|
||||||
msgid ""
|
msgid ""
|
||||||
"This key overrides the automatic hiding of the 'Log out' menuitem 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 ""
|
||||||
"Kunci ini menimpa penyembunyian otomatis dari butir menu 'Log keluar' dalam "
|
"Kunci ini menimpa penyembunyian otomatis butir menu 'Log keluar' dalam "
|
||||||
"situasi pengguna tunggal, sesi tunggal."
|
"situasi pengguna-tunggal, sesi-tunggal."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:13
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:11
|
||||||
msgid ""
|
msgid ""
|
||||||
"Whether to remember password for mounting encrypted or remote filesystems"
|
"Whether to remember password for mounting encrypted or remote filesystems"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Apakah mengingat sandi untuk mengait sistem berkas terenkripsi atau jarak "
|
"Apakah mengingat sandi untuk mengait sistem berkas terenkripsi atau jarak "
|
||||||
"jauh"
|
"jauh"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:14
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:12
|
||||||
msgid ""
|
msgid ""
|
||||||
"The shell will request a password when an encrypted device or a remote "
|
"The shell will request a password when an encrypted device or a remote "
|
||||||
"filesystem is mounted. If the password can be saved for future use a "
|
"filesystem is mounted. If the password can be saved for future use a "
|
||||||
@ -161,70 +149,70 @@ msgstr ""
|
|||||||
"dimasa depan, suatu kotak contreng 'Ingat Sandi' akan tampil. Kunci ini "
|
"dimasa depan, suatu kotak contreng 'Ingat Sandi' akan tampil. Kunci ini "
|
||||||
"menata keadaan baku dari kontak contreng."
|
"menata keadaan baku dari kontak contreng."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:15
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:13
|
||||||
msgid "Show the week date in the calendar"
|
msgid "Show the week date in the calendar"
|
||||||
msgstr "Menampilkan tanggal pada kalender"
|
msgstr "Menampilkan tanggal pada kalender"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:16
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:14
|
||||||
msgid "If true, display the ISO week date in the calendar."
|
msgid "If true, display the ISO week date in the calendar."
|
||||||
msgstr "Jika \"true\", menampilkan tanggal berformat ISO pada kalender."
|
msgstr "Jika \"true\", menampilkan tanggal berformat ISO pada kalender."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:17
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:15
|
||||||
msgid "Keybinding to open the application menu"
|
msgid "Keybinding to open the application menu"
|
||||||
msgstr "Kombinasi tombol untuk membuka menu aplikasi"
|
msgstr "Kombinasi tombol untuk membuka menu aplikasi"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:18
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:16
|
||||||
msgid "Keybinding to open the application menu."
|
msgid "Keybinding to open the application menu."
|
||||||
msgstr "Kombinasi tombol untuk membuka menu aplikasi."
|
msgstr "Kombinasi tombol untuk membuka menu aplikasi."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:19
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:17
|
||||||
msgid "Keybinding to open the \"Show Applications\" view"
|
msgid "Keybinding to open the \"Show Applications\" view"
|
||||||
msgstr "Kombinasi tombol untuk membuka tilikan \"Tampilkan Aplikasi\""
|
msgstr "Kombinasi tombol untuk membuka tilikan \"Tampilkan Aplikasi\""
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:20
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:18
|
||||||
msgid ""
|
msgid ""
|
||||||
"Keybinding to open the \"Show Applications\" view of the Activities Overview."
|
"Keybinding to open the \"Show Applications\" view of the Activities Overview."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Kombinasi tombol untuk membuka tilikan Ringkasan Aktivitas \"Tampilkan "
|
"Kombinasi tombol untuk membuka tilikan Ringkasan Aktivitas \"Tampilkan "
|
||||||
"Aplikasi\"."
|
"Aplikasi\"."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:21
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:19
|
||||||
msgid "Keybinding to open the overview"
|
msgid "Keybinding to open the overview"
|
||||||
msgstr "Kombinasi tombol untuk membuka ringkasan"
|
msgstr "Kombinasi tombol untuk membuka ringkasan"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:22
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:20
|
||||||
msgid "Keybinding to open the Activities Overview."
|
msgid "Keybinding to open the Activities Overview."
|
||||||
msgstr "Kombinasi tombol untuk membuka Ringkasan Aktivitas."
|
msgstr "Kombinasi tombol untuk membuka Ringkasan Aktivitas."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:23
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:21
|
||||||
msgid "Keybinding to toggle the visibility of the message tray"
|
msgid "Keybinding to toggle the visibility of the message tray"
|
||||||
msgstr "Kombinasi tombol untuk kenampakan baki pesan"
|
msgstr "Kombinasi tombol untuk kenampakan baki pesan"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:24
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:22
|
||||||
msgid "Keybinding to toggle the visibility of the message tray."
|
msgid "Keybinding to toggle the visibility of the message tray."
|
||||||
msgstr "Kombinasi tombol untuk kenampakan baki pesan."
|
msgstr "Kombinasi tombol untuk kenampakan baki pesan."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:25
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:23
|
||||||
msgid "Keybinding to focus the active notification"
|
msgid "Keybinding to focus the active notification"
|
||||||
msgstr "Kombinasi tombol untuk fokus pada pemberitahuan yang aktif"
|
msgstr "Kombinasi tombol untuk fokus pada pemberitahuan yang aktif"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:26
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:24
|
||||||
msgid "Keybinding to focus the active notification."
|
msgid "Keybinding to focus the active notification."
|
||||||
msgstr "Kombinasi tombol untuk fokus pada pemberitahuan yang aktif."
|
msgstr "Kombinasi tombol untuk fokus pada pemberitahuan yang aktif."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:27
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:25
|
||||||
msgid "Which keyboard to use"
|
msgid "Which keyboard to use"
|
||||||
msgstr "Papan tik mana yang akan dipakai"
|
msgstr "Papan tik mana yang akan dipakai"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:28
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:26
|
||||||
msgid "The type of keyboard to use."
|
msgid "The type of keyboard to use."
|
||||||
msgstr "Jenis papan tik yang akan dipakai."
|
msgstr "Jenis papan tik yang akan dipakai."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:29
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:27
|
||||||
msgid "The application icon mode."
|
msgid "The application icon mode."
|
||||||
msgstr "Mode ikon aplikasi."
|
msgstr "Mode ikon aplikasi."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:30
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:28
|
||||||
msgid ""
|
msgid ""
|
||||||
"Configures how the windows are shown in the switcher. Valid possibilities "
|
"Configures how the windows are shown in the switcher. Valid possibilities "
|
||||||
"are 'thumbnail-only' (shows a thumbnail of the window), 'app-icon-"
|
"are 'thumbnail-only' (shows a thumbnail of the window), 'app-icon-"
|
||||||
@ -234,22 +222,22 @@ msgstr ""
|
|||||||
"adalah 'thumbnail-only' (menampilkan gambar mini dari jendela), 'app-icon-"
|
"adalah 'thumbnail-only' (menampilkan gambar mini dari jendela), 'app-icon-"
|
||||||
"only' (hanya menampilkan ikon aplikasi), atau 'both' (keduanya)."
|
"only' (hanya menampilkan ikon aplikasi), atau 'both' (keduanya)."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:31
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:29
|
||||||
msgid "Attach modal dialog to the parent window"
|
msgid "Attach modal dialog to the parent window"
|
||||||
msgstr "Mencantolkan dialog modal ke jendela induk"
|
msgstr "Mencantolkan dialog modal ke jendela induk"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:32
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:30
|
||||||
msgid ""
|
msgid ""
|
||||||
"This key overrides the key in org.gnome.mutter when running GNOME Shell."
|
"This key overrides the key in org.gnome.mutter when running GNOME Shell."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Kunci ini menimpa kunci dalam org.gnome.mutter ketika menjalankan GNOME "
|
"Kunci ini menimpa kunci dalam org.gnome.mutter ketika menjalankan GNOME "
|
||||||
"Shell."
|
"Shell."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:33
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:31
|
||||||
msgid "Arrangement of buttons on the titlebar"
|
msgid "Arrangement of buttons on the titlebar"
|
||||||
msgstr "Pengaturan tombol pada bilah judul"
|
msgstr "Pengaturan tombol pada bilah judul"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:34
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:32
|
||||||
msgid ""
|
msgid ""
|
||||||
"This key overrides the key in org.gnome.desktop.wm.preferences when running "
|
"This key overrides the key in org.gnome.desktop.wm.preferences when running "
|
||||||
"GNOME Shell."
|
"GNOME Shell."
|
||||||
@ -257,20 +245,20 @@ msgstr ""
|
|||||||
"Kunci ini menimpa kunci dalam org.gnome.desktop.wm.preferences ketika "
|
"Kunci ini menimpa kunci dalam org.gnome.desktop.wm.preferences ketika "
|
||||||
"menjalankan GNOME Shell."
|
"menjalankan GNOME Shell."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:35
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:33
|
||||||
msgid "Enable edge tiling when dropping windows on screen edges"
|
msgid "Enable edge tiling when dropping windows on screen edges"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Memfungsikan pengubinan tepi ketika menjatuhkan jendela pada tepi layar"
|
"Memfungsikan pengubinan tepi ketika menjatuhkan jendela pada tepi layar"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:36
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:34
|
||||||
msgid "Workspaces are managed dynamically"
|
msgid "Workspaces are managed dynamically"
|
||||||
msgstr "Ruang kerja dikelola secara dinamis"
|
msgstr "Ruang kerja dikelola secara dinamis"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:37
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:35
|
||||||
msgid "Workspaces only on primary monitor"
|
msgid "Workspaces only on primary monitor"
|
||||||
msgstr "Ruang kerja hanya pada monitor primer"
|
msgstr "Ruang kerja hanya pada monitor primer"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:38
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:36
|
||||||
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 ""
|
||||||
"Tunda perubahan fokus dalam mode tetikus sampai penunjuk berhenti bergerak"
|
"Tunda perubahan fokus dalam mode tetikus sampai penunjuk berhenti bergerak"
|
||||||
@ -289,9 +277,9 @@ msgid "Select an extension to configure using the combobox above."
|
|||||||
msgstr "Pilih ekstensi yang ingin dikonfigurasi pada kotak di atas."
|
msgstr "Pilih ekstensi yang ingin dikonfigurasi pada kotak di atas."
|
||||||
|
|
||||||
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
||||||
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:359
|
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
||||||
#: ../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:726
|
#: ../js/ui/status/network.js:757
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
msgstr "Batal"
|
msgstr "Batal"
|
||||||
|
|
||||||
@ -309,25 +297,25 @@ msgctxt "button"
|
|||||||
msgid "Sign In"
|
msgid "Sign In"
|
||||||
msgstr "Masuk"
|
msgstr "Masuk"
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:272
|
#: ../js/gdm/loginDialog.js:270
|
||||||
msgid "Choose Session"
|
msgid "Choose Session"
|
||||||
msgstr "Pilih Sesi"
|
msgstr "Pilih Sesi"
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:432
|
#: ../js/gdm/loginDialog.js:430
|
||||||
msgid "Not listed?"
|
msgid "Not listed?"
|
||||||
msgstr "Tak masuk daftar?"
|
msgstr "Tak masuk daftar?"
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:600
|
#: ../js/gdm/loginDialog.js:598
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "(e.g., user or %s)"
|
msgid "(e.g., user or %s)"
|
||||||
msgstr "(cth., pengguna dari %s)"
|
msgstr "(cth., pengguna dari %s)"
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:605 ../js/ui/components/networkAgent.js:262
|
#: ../js/gdm/loginDialog.js:603 ../js/ui/components/networkAgent.js:262
|
||||||
#: ../js/ui/components/networkAgent.js:280
|
#: ../js/ui/components/networkAgent.js:280
|
||||||
msgid "Username: "
|
msgid "Username: "
|
||||||
msgstr "Nama pengguna: "
|
msgstr "Nama pengguna: "
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:870
|
#: ../js/gdm/loginDialog.js:868
|
||||||
msgid "Login Window"
|
msgid "Login Window"
|
||||||
msgstr "Jendela Log Masuk"
|
msgstr "Jendela Log Masuk"
|
||||||
|
|
||||||
@ -349,30 +337,30 @@ msgstr "Tidak dapat mengurai perintah:"
|
|||||||
|
|
||||||
#: ../js/misc/util.js:156
|
#: ../js/misc/util.js:156
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Execution of '%s' failed:"
|
msgid "Execution of “%s” failed:"
|
||||||
msgstr "Eksekusi '%s' gagal:"
|
msgstr "Eksekusi \"%s\" gagal:"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:596
|
#: ../js/ui/appDisplay.js:633
|
||||||
msgid "Frequently used applications will appear here"
|
msgid "Frequently used applications will appear here"
|
||||||
msgstr "Aplikasi yang sering dipakai akan muncul di sini"
|
msgstr "Aplikasi yang sering dipakai akan muncul di sini"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:715
|
#: ../js/ui/appDisplay.js:744
|
||||||
msgid "Frequent"
|
msgid "Frequent"
|
||||||
msgstr "Sering"
|
msgstr "Sering"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:722
|
#: ../js/ui/appDisplay.js:751
|
||||||
msgid "All"
|
msgid "All"
|
||||||
msgstr "Semua"
|
msgstr "Semua"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1541
|
#: ../js/ui/appDisplay.js:1558
|
||||||
msgid "New Window"
|
msgid "New Window"
|
||||||
msgstr "Jendela Baru"
|
msgstr "Jendela Baru"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1544 ../js/ui/dash.js:285
|
#: ../js/ui/appDisplay.js:1580 ../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:1545
|
#: ../js/ui/appDisplay.js:1586
|
||||||
msgid "Add to Favorites"
|
msgid "Add to Favorites"
|
||||||
msgstr "Tambah ke Favorit"
|
msgstr "Tambah ke Favorit"
|
||||||
|
|
||||||
@ -586,7 +574,7 @@ msgid "Type again:"
|
|||||||
msgstr "Ketik lagi:"
|
msgstr "Ketik lagi:"
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:132
|
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:132
|
||||||
#: ../js/ui/status/network.js:295 ../js/ui/status/network.js:729
|
#: ../js/ui/status/network.js:294 ../js/ui/status/network.js:760
|
||||||
msgid "Connect"
|
msgid "Connect"
|
||||||
msgstr "Sambung"
|
msgstr "Sambung"
|
||||||
|
|
||||||
@ -622,10 +610,10 @@ msgstr "Otentikasi dibutuhkan oleh jaringan nirkabel"
|
|||||||
#, javascript-format
|
#, javascript-format
|
||||||
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 ""
|
msgstr ""
|
||||||
"Sandi atau kunci penyandian diperlukan untuk mengakses jaringan nirkabel "
|
"Sandi atau kunci enkripsi diperlukan untuk mengakses jaringan nirkabel \"%s"
|
||||||
"'%s'."
|
"\"."
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:316
|
#: ../js/ui/components/networkAgent.js:316
|
||||||
msgid "Wired 802.1X authentication"
|
msgid "Wired 802.1X authentication"
|
||||||
@ -657,8 +645,8 @@ msgstr "Sandi jaringan data seluler"
|
|||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:339
|
#: ../js/ui/components/networkAgent.js:339
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "A password is required to connect to '%s'."
|
msgid "A password is required to connect to “%s”."
|
||||||
msgstr "Sebuah kata sandi dibutuhkan untuk menyambung ke '%s'."
|
msgstr "Perlu suatu sandi untuk menyambung ke \"%s\"."
|
||||||
|
|
||||||
#: ../js/ui/components/polkitAgent.js:54
|
#: ../js/ui/components/polkitAgent.js:54
|
||||||
msgid "Authentication Required"
|
msgid "Authentication Required"
|
||||||
@ -705,35 +693,35 @@ msgid "Mute"
|
|||||||
msgstr "Bisu"
|
msgstr "Bisu"
|
||||||
|
|
||||||
#. Translators: this is the word "Yesterday" followed by a time string. i.e. "Yesterday, 14:30"*/
|
#. Translators: this is the word "Yesterday" followed by a time string. i.e. "Yesterday, 14:30"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:941
|
#: ../js/ui/components/telepathyClient.js:952
|
||||||
msgid "<b>Yesterday</b>, <b>%H:%M</b>"
|
msgid "<b>Yesterday</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>Kemarin</b>, <b>%H:%M</b>"
|
msgstr "<b>Kemarin</b>, <b>%H:%M</b>"
|
||||||
|
|
||||||
#. Translators: this is the week day name followed by a time string. i.e. "Monday, 14:30*/
|
#. Translators: this is the week day name followed by a time string. i.e. "Monday, 14:30*/
|
||||||
#: ../js/ui/components/telepathyClient.js:947
|
#: ../js/ui/components/telepathyClient.js:958
|
||||||
msgid "<b>%A</b>, <b>%H:%M</b>"
|
msgid "<b>%A</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>%A</b>, <b>%H:%M</b>"
|
msgstr "<b>%A</b>, <b>%H:%M</b>"
|
||||||
|
|
||||||
#. Translators: this is the month name and day number followed by a time string. i.e. "May 25, 14:30"*/
|
#. Translators: this is the month name and day number followed by a time string. i.e. "May 25, 14:30"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:952
|
#: ../js/ui/components/telepathyClient.js:963
|
||||||
msgid "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
msgid "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>%d</b> <b>%B</b>, <b>%H:%M</b>"
|
msgstr "<b>%d</b> <b>%B</b>, <b>%H:%M</b>"
|
||||||
|
|
||||||
#. Translators: this is the month name, day number, year number followed by a time string. i.e. "May 25 2012, 14:30"*/
|
#. Translators: this is the month name, day number, year number followed by a time string. i.e. "May 25 2012, 14:30"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:956
|
#: ../js/ui/components/telepathyClient.js:967
|
||||||
msgid "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
msgid "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
||||||
msgstr "<b>%d</b> <b>%B</b> <b>%Y</b>, <b>%H:%M</b> "
|
msgstr "<b>%d</b> <b>%B</b> <b>%Y</b>, <b>%H:%M</b> "
|
||||||
|
|
||||||
#. 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:987
|
#: ../js/ui/components/telepathyClient.js:998
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s is now known as %s"
|
msgid "%s is now known as %s"
|
||||||
msgstr "%s sekarang dikenal sebagai %s"
|
msgstr "%s sekarang dikenal sebagai %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:1090
|
#: ../js/ui/components/telepathyClient.js:1101
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Invitation to %s"
|
msgid "Invitation to %s"
|
||||||
msgstr "Undangan ke %s"
|
msgstr "Undangan ke %s"
|
||||||
@ -741,38 +729,38 @@ msgstr "Undangan ke %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:1098
|
#: ../js/ui/components/telepathyClient.js:1109
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s is inviting you to join %s"
|
msgid "%s is inviting you to join %s"
|
||||||
msgstr "%s mengundang Anda untuk bergabung dengan %s"
|
msgstr "%s mengundang Anda untuk bergabung dengan %s"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1100
|
#: ../js/ui/components/telepathyClient.js:1111
|
||||||
#: ../js/ui/components/telepathyClient.js:1135
|
#: ../js/ui/components/telepathyClient.js:1146
|
||||||
#: ../js/ui/components/telepathyClient.js:1169
|
#: ../js/ui/components/telepathyClient.js:1180
|
||||||
#: ../js/ui/components/telepathyClient.js:1226
|
#: ../js/ui/components/telepathyClient.js:1237
|
||||||
msgid "Decline"
|
msgid "Decline"
|
||||||
msgstr "Tolak"
|
msgstr "Tolak"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1106
|
#: ../js/ui/components/telepathyClient.js:1117
|
||||||
#: ../js/ui/components/telepathyClient.js:1175
|
#: ../js/ui/components/telepathyClient.js:1186
|
||||||
#: ../js/ui/components/telepathyClient.js:1231
|
#: ../js/ui/components/telepathyClient.js:1242
|
||||||
msgid "Accept"
|
msgid "Accept"
|
||||||
msgstr "Terima"
|
msgstr "Terima"
|
||||||
|
|
||||||
#. 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:1125
|
#: ../js/ui/components/telepathyClient.js:1136
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Video call from %s"
|
msgid "Video call from %s"
|
||||||
msgstr "Panggilan video dari %s"
|
msgstr "Panggilan video dari %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:1128
|
#: ../js/ui/components/telepathyClient.js:1139
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Call from %s"
|
msgid "Call from %s"
|
||||||
msgstr "Panggilan dari %s"
|
msgstr "Panggilan dari %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:1142
|
#: ../js/ui/components/telepathyClient.js:1153
|
||||||
msgid "Answer"
|
msgid "Answer"
|
||||||
msgstr "Jawab"
|
msgstr "Jawab"
|
||||||
|
|
||||||
@ -781,111 +769,111 @@ msgstr "Jawab"
|
|||||||
#. * 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:1163
|
#: ../js/ui/components/telepathyClient.js:1174
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s is sending you %s"
|
msgid "%s is sending you %s"
|
||||||
msgstr "%s sedang mengirimi Anda %s"
|
msgstr "%s sedang mengirimi Anda %s"
|
||||||
|
|
||||||
#. To translators: The parameter is the contact's alias */
|
#. To translators: The parameter is the contact's alias */
|
||||||
#: ../js/ui/components/telepathyClient.js:1192
|
#: ../js/ui/components/telepathyClient.js:1203
|
||||||
#, 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 ingin minta ijin melihat Anda ketika Anda daring"
|
msgstr "%s ingin minta ijin melihat Anda ketika Anda daring"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1277
|
#: ../js/ui/components/telepathyClient.js:1288
|
||||||
msgid "Network error"
|
msgid "Network error"
|
||||||
msgstr "Galat jaringan"
|
msgstr "Galat jaringan"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1279
|
#: ../js/ui/components/telepathyClient.js:1290
|
||||||
msgid "Authentication failed"
|
msgid "Authentication failed"
|
||||||
msgstr "Otentikasi gagal"
|
msgstr "Otentikasi gagal"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1281
|
#: ../js/ui/components/telepathyClient.js:1292
|
||||||
msgid "Encryption error"
|
msgid "Encryption error"
|
||||||
msgstr "Galat enkripsi"
|
msgstr "Galat enkripsi"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1283
|
#: ../js/ui/components/telepathyClient.js:1294
|
||||||
msgid "Certificate not provided"
|
msgid "Certificate not provided"
|
||||||
msgstr "Sertifikat tidak disediakan"
|
msgstr "Sertifikat tidak disediakan"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1285
|
#: ../js/ui/components/telepathyClient.js:1296
|
||||||
msgid "Certificate untrusted"
|
msgid "Certificate untrusted"
|
||||||
msgstr "Sertifikat tidak dipercaya"
|
msgstr "Sertifikat tidak dipercaya"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1287
|
#: ../js/ui/components/telepathyClient.js:1298
|
||||||
msgid "Certificate expired"
|
msgid "Certificate expired"
|
||||||
msgstr "Sertifikat kadaluarsa"
|
msgstr "Sertifikat kadaluarsa"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1289
|
#: ../js/ui/components/telepathyClient.js:1300
|
||||||
msgid "Certificate not activated"
|
msgid "Certificate not activated"
|
||||||
msgstr "Sertifikat tidak diaktifkan"
|
msgstr "Sertifikat tidak diaktifkan"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1291
|
#: ../js/ui/components/telepathyClient.js:1302
|
||||||
msgid "Certificate hostname mismatch"
|
msgid "Certificate hostname mismatch"
|
||||||
msgstr "Nama host sertifikat tidak cocok"
|
msgstr "Nama host sertifikat tidak cocok"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1293
|
#: ../js/ui/components/telepathyClient.js:1304
|
||||||
msgid "Certificate fingerprint mismatch"
|
msgid "Certificate fingerprint mismatch"
|
||||||
msgstr "Sidik jari sertifikat tidak cocok"
|
msgstr "Sidik jari sertifikat tidak cocok"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1295
|
#: ../js/ui/components/telepathyClient.js:1306
|
||||||
msgid "Certificate self-signed"
|
msgid "Certificate self-signed"
|
||||||
msgstr "Sertifikat ditandatangani sendiri"
|
msgstr "Sertifikat ditandatangani sendiri"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1297
|
#: ../js/ui/components/telepathyClient.js:1308
|
||||||
msgid "Status is set to offline"
|
msgid "Status is set to offline"
|
||||||
msgstr "Status diatur ke luring"
|
msgstr "Status diatur ke luring"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1299
|
#: ../js/ui/components/telepathyClient.js:1310
|
||||||
msgid "Encryption is not available"
|
msgid "Encryption is not available"
|
||||||
msgstr "Enkripsi tidak tersedia"
|
msgstr "Enkripsi tidak tersedia"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1301
|
#: ../js/ui/components/telepathyClient.js:1312
|
||||||
msgid "Certificate is invalid"
|
msgid "Certificate is invalid"
|
||||||
msgstr "Sertifikat tidak valid"
|
msgstr "Sertifikat tidak valid"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1303
|
#: ../js/ui/components/telepathyClient.js:1314
|
||||||
msgid "Connection has been refused"
|
msgid "Connection has been refused"
|
||||||
msgstr "Koneksi telah ditolak"
|
msgstr "Koneksi telah ditolak"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1305
|
#: ../js/ui/components/telepathyClient.js:1316
|
||||||
msgid "Connection can't be established"
|
msgid "Connection can't be established"
|
||||||
msgstr "Koneksi tak dapat dijalin"
|
msgstr "Koneksi tak dapat dijalin"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1307
|
#: ../js/ui/components/telepathyClient.js:1318
|
||||||
msgid "Connection has been lost"
|
msgid "Connection has been lost"
|
||||||
msgstr "Koneksi telah terputus"
|
msgstr "Koneksi telah terputus"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1309
|
#: ../js/ui/components/telepathyClient.js:1320
|
||||||
msgid "This account is already connected to the server"
|
msgid "This account is already connected to the server"
|
||||||
msgstr "Akun ini telah tersambung pada server"
|
msgstr "Akun ini telah tersambung pada server"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1311
|
#: ../js/ui/components/telepathyClient.js:1322
|
||||||
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 ""
|
||||||
"Koneksi telah digantikan oleh koneksi baru memakai sumberdaya yang sama"
|
"Koneksi telah digantikan oleh koneksi baru memakai sumberdaya yang sama"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1313
|
#: ../js/ui/components/telepathyClient.js:1324
|
||||||
msgid "The account already exists on the server"
|
msgid "The account already exists on the server"
|
||||||
msgstr "Akun ini sudah ada di server"
|
msgstr "Akun ini sudah ada di server"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1315
|
#: ../js/ui/components/telepathyClient.js:1326
|
||||||
msgid "Server is currently too busy to handle the connection"
|
msgid "Server is currently too busy to handle the connection"
|
||||||
msgstr "Server kini terlalu sibuk untuk menangani koneksi"
|
msgstr "Server kini terlalu sibuk untuk menangani koneksi"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1317
|
#: ../js/ui/components/telepathyClient.js:1328
|
||||||
msgid "Certificate has been revoked"
|
msgid "Certificate has been revoked"
|
||||||
msgstr "Sertifikat telah dicabut"
|
msgstr "Sertifikat telah dicabut"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1319
|
#: ../js/ui/components/telepathyClient.js:1330
|
||||||
msgid ""
|
msgid ""
|
||||||
"Certificate uses an insecure cipher algorithm or is cryptographically weak"
|
"Certificate uses an insecure cipher algorithm or is cryptographically weak"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Sertifikat memakai algorima cipher yang tak aman atau lemah secara "
|
"Sertifikat memakai algorima cipher yang tak aman atau lemah secara "
|
||||||
"kriptografi"
|
"kriptografi"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1321
|
#: ../js/ui/components/telepathyClient.js:1332
|
||||||
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"
|
||||||
@ -893,22 +881,22 @@ msgstr ""
|
|||||||
"Panjang sertifikat server, atau kedalaman rantai sertifikat server, "
|
"Panjang sertifikat server, atau kedalaman rantai sertifikat server, "
|
||||||
"melampaui batas yang diberlakukan oleh pustaka kriptografi"
|
"melampaui batas yang diberlakukan oleh pustaka kriptografi"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1323
|
#: ../js/ui/components/telepathyClient.js:1334
|
||||||
msgid "Internal error"
|
msgid "Internal error"
|
||||||
msgstr "Galat internal"
|
msgstr "Galat internal"
|
||||||
|
|
||||||
#. 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:1333
|
#: ../js/ui/components/telepathyClient.js:1344
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Unable to connect to %s"
|
msgid "Unable to connect to %s"
|
||||||
msgstr "Tak bisa menyambung ke %s"
|
msgstr "Tak bisa menyambung ke %s"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1338
|
#: ../js/ui/components/telepathyClient.js:1349
|
||||||
msgid "View account"
|
msgid "View account"
|
||||||
msgstr "Tilik akun"
|
msgstr "Tilik akun"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1370
|
#: ../js/ui/components/telepathyClient.js:1381
|
||||||
msgid "Unknown reason"
|
msgid "Unknown reason"
|
||||||
msgstr "Alasan yang tidak diketahui"
|
msgstr "Alasan yang tidak diketahui"
|
||||||
|
|
||||||
@ -943,72 +931,72 @@ 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:64
|
#: ../js/ui/endSessionDialog.js:62
|
||||||
#, 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:65
|
#: ../js/ui/endSessionDialog.js:63
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Log Out"
|
msgid "Log Out"
|
||||||
msgstr "Keluar"
|
msgstr "Keluar"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:67
|
#: ../js/ui/endSessionDialog.js:65
|
||||||
#, 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:72
|
#: ../js/ui/endSessionDialog.js:70
|
||||||
#, 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:77
|
#: ../js/ui/endSessionDialog.js:75
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Log Out"
|
msgid "Log Out"
|
||||||
msgstr "Keluar"
|
msgstr "Keluar"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:83
|
#: ../js/ui/endSessionDialog.js:81
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Power Off"
|
msgid "Power Off"
|
||||||
msgstr "Matikan"
|
msgstr "Matikan"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:85
|
#: ../js/ui/endSessionDialog.js:83
|
||||||
#, 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:90 ../js/ui/endSessionDialog.js:106
|
#: ../js/ui/endSessionDialog.js:88 ../js/ui/endSessionDialog.js:104
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Restart"
|
msgid "Restart"
|
||||||
msgstr "Nyalakan Ulang"
|
msgstr "Nyalakan Ulang"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:92
|
#: ../js/ui/endSessionDialog.js:90
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Power Off"
|
msgid "Power Off"
|
||||||
msgstr "Matikan"
|
msgstr "Matikan"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:99
|
#: ../js/ui/endSessionDialog.js:97
|
||||||
msgctxt "title"
|
msgctxt "title"
|
||||||
msgid "Restart"
|
msgid "Restart"
|
||||||
msgstr "Nyalakan Ulang"
|
msgstr "Nyalakan Ulang"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:101
|
#: ../js/ui/endSessionDialog.js:99
|
||||||
#, 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:114
|
#: ../js/ui/endSessionDialog.js:112
|
||||||
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:116
|
#: ../js/ui/endSessionDialog.js:114
|
||||||
#, 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 ""
|
||||||
@ -1017,27 +1005,27 @@ 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:121
|
#: ../js/ui/endSessionDialog.js:119
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Restart & Install"
|
msgid "Restart & Install"
|
||||||
msgstr "Start Ulang & Pasang"
|
msgstr "Start Ulang & Pasang"
|
||||||
|
|
||||||
#: ../js/ui/endSessionDialog.js:277
|
#: ../js/ui/endSessionDialog.js:275
|
||||||
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:284
|
#: ../js/ui/endSessionDialog.js:282
|
||||||
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:488
|
#: ../js/ui/endSessionDialog.js:486
|
||||||
#, 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:491
|
#: ../js/ui/endSessionDialog.js:489
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s (console)"
|
msgid "%s (console)"
|
||||||
msgstr "%s (konsol)"
|
msgstr "%s (konsol)"
|
||||||
@ -1048,8 +1036,8 @@ msgstr "Pasang"
|
|||||||
|
|
||||||
#: ../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?"
|
||||||
msgstr "Unduh dan pasang '%s' dari extensions.gnome.org?"
|
msgstr "Unduh dan pasang \"%s\" dari extensions.gnome.org?"
|
||||||
|
|
||||||
#: ../js/ui/keyboard.js:641 ../js/ui/status/keyboard.js:335
|
#: ../js/ui/keyboard.js:641 ../js/ui/status/keyboard.js:335
|
||||||
msgid "Keyboard"
|
msgid "Keyboard"
|
||||||
@ -1081,7 +1069,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:717 ../js/ui/status/network.js:472
|
#: ../js/ui/lookingGlass.js:717 ../js/ui/status/network.js:518
|
||||||
#: ../src/gvc/gvc-mixer-control.c:1830
|
#: ../src/gvc/gvc-mixer-control.c:1830
|
||||||
msgid "Disabled"
|
msgid "Disabled"
|
||||||
msgstr "Dinonaktifkan"
|
msgstr "Dinonaktifkan"
|
||||||
@ -1106,48 +1094,48 @@ msgstr "Tilik Sumber"
|
|||||||
msgid "Web Page"
|
msgid "Web Page"
|
||||||
msgstr "Halaman Web"
|
msgstr "Halaman Web"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1310
|
#: ../js/ui/messageTray.js:1312
|
||||||
msgid "Open"
|
msgid "Open"
|
||||||
msgstr "Buka"
|
msgstr "Buka"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1317
|
#: ../js/ui/messageTray.js:1319
|
||||||
msgid "Remove"
|
msgid "Remove"
|
||||||
msgstr "Hapus"
|
msgstr "Hapus"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1614
|
#: ../js/ui/messageTray.js:1616
|
||||||
msgid "Notifications"
|
msgid "Notifications"
|
||||||
msgstr "Pemberitahuan"
|
msgstr "Pemberitahuan"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1621
|
#: ../js/ui/messageTray.js:1623
|
||||||
msgid "Clear Messages"
|
msgid "Clear Messages"
|
||||||
msgstr "Bersihkan Pesan"
|
msgstr "Bersihkan Pesan"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1640
|
#: ../js/ui/messageTray.js:1642
|
||||||
msgid "Notification Settings"
|
msgid "Notification Settings"
|
||||||
msgstr "Pengaturan Pemberitahuan"
|
msgstr "Pengaturan Pemberitahuan"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1693
|
#: ../js/ui/messageTray.js:1695
|
||||||
msgid "Tray Menu"
|
msgid "Tray Menu"
|
||||||
msgstr "Menu Baki"
|
msgstr "Menu Baki"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1910
|
#: ../js/ui/messageTray.js:1912
|
||||||
msgid "No Messages"
|
msgid "No Messages"
|
||||||
msgstr "Tiada Pesan"
|
msgstr "Tiada Pesan"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1948
|
#: ../js/ui/messageTray.js:1950
|
||||||
msgid "Message Tray"
|
msgid "Message Tray"
|
||||||
msgstr "Baki Pesan"
|
msgstr "Baki Pesan"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:2931
|
#: ../js/ui/messageTray.js:2934
|
||||||
msgid "System Information"
|
msgid "System Information"
|
||||||
msgstr "Informasi Sistem"
|
msgstr "Informasi Sistem"
|
||||||
|
|
||||||
#: ../js/ui/notificationDaemon.js:515 ../src/shell-app.c:397
|
#: ../js/ui/notificationDaemon.js:515 ../src/shell-app.c:399
|
||||||
msgctxt "program"
|
msgctxt "program"
|
||||||
msgid "Unknown"
|
msgid "Unknown"
|
||||||
msgstr "Tak dikenal"
|
msgstr "Tak dikenal"
|
||||||
|
|
||||||
#: ../js/ui/overviewControls.js:483 ../js/ui/screenShield.js:153
|
#: ../js/ui/overviewControls.js:483 ../js/ui/screenShield.js:151
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%d new message"
|
msgid "%d new message"
|
||||||
msgid_plural "%d new messages"
|
msgid_plural "%d new messages"
|
||||||
@ -1179,7 +1167,7 @@ msgstr "Keluar"
|
|||||||
msgid "Activities"
|
msgid "Activities"
|
||||||
msgstr "Aktivitas"
|
msgstr "Aktivitas"
|
||||||
|
|
||||||
#: ../js/ui/panel.js:903
|
#: ../js/ui/panel.js:905
|
||||||
msgid "Top Bar"
|
msgid "Top Bar"
|
||||||
msgstr "Bar Atas"
|
msgstr "Bar Atas"
|
||||||
|
|
||||||
@ -1198,29 +1186,29 @@ msgstr "Tutup"
|
|||||||
|
|
||||||
#. 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:89
|
#: ../js/ui/screenShield.js:88
|
||||||
msgid "%A, %B %d"
|
msgid "%A, %B %d"
|
||||||
msgstr "%A, %d %B"
|
msgstr "%A, %d %B"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:155
|
#: ../js/ui/screenShield.js:153
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%d new notification"
|
msgid "%d new notification"
|
||||||
msgid_plural "%d new notifications"
|
msgid_plural "%d new notifications"
|
||||||
msgstr[0] "%d pemberitahuan baru"
|
msgstr[0] "%d pemberitahuan baru"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:474 ../js/ui/status/system.js:342
|
#: ../js/ui/screenShield.js:473 ../js/ui/status/system.js:342
|
||||||
msgid "Lock"
|
msgid "Lock"
|
||||||
msgstr "Kunci"
|
msgstr "Kunci"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:708
|
#: ../js/ui/screenShield.js:707
|
||||||
msgid "GNOME needs to lock the screen"
|
msgid "GNOME needs to lock the screen"
|
||||||
msgstr "GNOME perlu mengunci layar"
|
msgstr "GNOME perlu mengunci layar"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:835 ../js/ui/screenShield.js:1302
|
#: ../js/ui/screenShield.js:834 ../js/ui/screenShield.js:1301
|
||||||
msgid "Unable to lock"
|
msgid "Unable to lock"
|
||||||
msgstr "Tak bisa mengunci"
|
msgstr "Tak bisa mengunci"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:836 ../js/ui/screenShield.js:1303
|
#: ../js/ui/screenShield.js:835 ../js/ui/screenShield.js:1302
|
||||||
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"
|
||||||
|
|
||||||
@ -1305,7 +1293,7 @@ msgid "Bluetooth"
|
|||||||
msgstr "Bluetooth"
|
msgstr "Bluetooth"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:47 ../js/ui/status/network.js:132
|
#: ../js/ui/status/bluetooth.js:47 ../js/ui/status/network.js:132
|
||||||
#: ../js/ui/status/network.js:1083 ../js/ui/status/rfkill.js:48
|
#: ../js/ui/status/network.js:1108 ../js/ui/status/rfkill.js:48
|
||||||
msgid "Turn Off"
|
msgid "Turn Off"
|
||||||
msgstr "Matikan"
|
msgstr "Matikan"
|
||||||
|
|
||||||
@ -1331,95 +1319,99 @@ msgstr "Tampilkan Tata Letak Papan Tik"
|
|||||||
msgid "<unknown>"
|
msgid "<unknown>"
|
||||||
msgstr "<tak dikenal>"
|
msgstr "<tak dikenal>"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:222 ../js/ui/status/network.js:379
|
#: ../js/ui/status/network.js:221 ../js/ui/status/network.js:383
|
||||||
#: ../js/ui/status/network.js:1104
|
#: ../js/ui/status/network.js:1129
|
||||||
msgid "Off"
|
msgid "Off"
|
||||||
msgstr "Mati"
|
msgstr "Mati"
|
||||||
|
|
||||||
#. 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:385
|
#: ../js/ui/status/network.js:389
|
||||||
msgid "unmanaged"
|
msgid "unmanaged"
|
||||||
msgstr "tak dikelola"
|
msgstr "tak dikelola"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:387
|
#: ../js/ui/status/network.js:391
|
||||||
msgid "disconnecting..."
|
msgid "disconnecting..."
|
||||||
msgstr "memutus..."
|
msgstr "memutus..."
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:393 ../js/ui/status/network.js:1158
|
#: ../js/ui/status/network.js:397 ../js/ui/status/network.js:1183
|
||||||
msgid "connecting..."
|
msgid "connecting..."
|
||||||
msgstr "menghubungi..."
|
msgstr "menghubungi..."
|
||||||
|
|
||||||
#. 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:396 ../js/ui/status/network.js:1161
|
#: ../js/ui/status/network.js:400 ../js/ui/status/network.js:1186
|
||||||
msgid "authentication required"
|
msgid "authentication required"
|
||||||
msgstr "diperlukan otentikasi"
|
msgstr "diperlukan otentikasi"
|
||||||
|
|
||||||
#. 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:404
|
#: ../js/ui/status/network.js:408
|
||||||
msgid "firmware missing"
|
msgid "firmware missing"
|
||||||
msgstr "firmware hilang"
|
msgstr "firmware hilang"
|
||||||
|
|
||||||
#. 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:408
|
#: ../js/ui/status/network.js:412
|
||||||
msgid "unavailable"
|
msgid "unavailable"
|
||||||
msgstr "tidak tersedia"
|
msgstr "tidak tersedia"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:410 ../js/ui/status/network.js:1163
|
#: ../js/ui/status/network.js:414 ../js/ui/status/network.js:1188
|
||||||
msgid "connection failed"
|
msgid "connection failed"
|
||||||
msgstr "koneksi gagal"
|
msgstr "koneksi gagal"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:426 ../js/ui/status/network.js:512
|
#: ../js/ui/status/network.js:430
|
||||||
|
msgid "Wired Settings"
|
||||||
|
msgstr "Pengaturan Kabel"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:472 ../js/ui/status/network.js:558
|
||||||
msgid "Mobile Broadband Settings"
|
msgid "Mobile Broadband Settings"
|
||||||
msgstr "Pengaturan Data Seluler"
|
msgstr "Pengaturan Data Seluler"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:468 ../js/ui/status/network.js:1102
|
#: ../js/ui/status/network.js:514 ../js/ui/status/network.js:1127
|
||||||
msgid "Hardware Disabled"
|
msgid "Hardware Disabled"
|
||||||
msgstr "Perangkat Keras Dinonaktifkan"
|
msgstr "Perangkat Keras Dinonaktifkan"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:694
|
#: ../js/ui/status/network.js:725
|
||||||
msgid "Wi-Fi Networks"
|
msgid "Wi-Fi Networks"
|
||||||
msgstr "Jaringan Wi-Fi"
|
msgstr "Jaringan Wi-Fi"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:696
|
#: ../js/ui/status/network.js:727
|
||||||
msgid "Select a network"
|
msgid "Select a network"
|
||||||
msgstr "Pilih jaringan"
|
msgstr "Pilih jaringan"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:720
|
#: ../js/ui/status/network.js:751
|
||||||
msgid "No Networks"
|
msgid "No Networks"
|
||||||
msgstr "Tiada Jaringan"
|
msgstr "Tiada Jaringan"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:989
|
#: ../js/ui/status/network.js:1014
|
||||||
msgid "Select Network"
|
msgid "Select Network"
|
||||||
msgstr "Pilih Jaringan"
|
msgstr "Pilih Jaringan"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:995
|
#: ../js/ui/status/network.js:1020
|
||||||
msgid "Wi-Fi Settings"
|
msgid "Wi-Fi Settings"
|
||||||
msgstr "Pengaturan Wi-Fi"
|
msgstr "Pengaturan Wi-Fi"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1083
|
#: ../js/ui/status/network.js:1108
|
||||||
msgid "Turn On"
|
msgid "Turn On"
|
||||||
msgstr "Nyalakan"
|
msgstr "Nyalakan"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1106
|
#: ../js/ui/status/network.js:1131
|
||||||
msgid "Not Connected"
|
msgid "Not Connected"
|
||||||
msgstr "Tak Tersambung"
|
msgstr "Tak Tersambung"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1226
|
#: ../js/ui/status/network.js:1251
|
||||||
msgid "VPN"
|
msgid "VPN"
|
||||||
msgstr "VPN"
|
msgstr "VPN"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1366
|
#: ../js/ui/status/network.js:1394
|
||||||
msgid "Network Manager"
|
msgid "Network Manager"
|
||||||
msgstr "Manajer Jaringan"
|
msgstr "Manajer Jaringan"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1405
|
#: ../js/ui/status/network.js:1433
|
||||||
msgid "Connection failed"
|
msgid "Connection failed"
|
||||||
msgstr "Koneksi gagal"
|
msgstr "Koneksi gagal"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1406
|
#: ../js/ui/status/network.js:1434
|
||||||
msgid "Activation of network connection failed"
|
msgid "Activation of network connection failed"
|
||||||
msgstr "Aktivasi koneksi jaringan gagal"
|
msgstr "Aktivasi koneksi jaringan gagal"
|
||||||
|
|
||||||
@ -1515,8 +1507,8 @@ msgstr "Cari"
|
|||||||
|
|
||||||
#: ../js/ui/windowAttentionHandler.js:19
|
#: ../js/ui/windowAttentionHandler.js:19
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "'%s' is ready"
|
msgid "“%s” is ready"
|
||||||
msgstr "'%s' telah siap"
|
msgstr "'%s' siap"
|
||||||
|
|
||||||
#: ../js/ui/windowManager.js:56
|
#: ../js/ui/windowManager.js:56
|
||||||
msgid "Do you want to keep these display settings?"
|
msgid "Do you want to keep these display settings?"
|
||||||
@ -1579,10 +1571,10 @@ msgstr "Menggunakan mode tertentu, mis. \"gdm\" untuk layar masuk"
|
|||||||
msgid "List possible modes"
|
msgid "List possible modes"
|
||||||
msgstr "Menampilkan mode yang mungkin"
|
msgstr "Menampilkan mode yang mungkin"
|
||||||
|
|
||||||
#: ../src/shell-app.c:640
|
#: ../src/shell-app.c:642
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to launch '%s'"
|
msgid "Failed to launch “%s”"
|
||||||
msgstr "Gagal meluncurkan '%s'"
|
msgstr "Gagal meluncurkan \"%s\""
|
||||||
|
|
||||||
#: ../src/shell-keyring-prompt.c:714
|
#: ../src/shell-keyring-prompt.c:714
|
||||||
msgid "Passwords do not match."
|
msgid "Passwords do not match."
|
||||||
|
475
po/nb.po
475
po/nb.po
@ -2,14 +2,14 @@
|
|||||||
# Copyright (C) 2009 THE PACKAGE'S COPYRIGHT HOLDER
|
# Copyright (C) 2009 THE PACKAGE'S COPYRIGHT HOLDER
|
||||||
# This file is distributed under the same license as the gnome-shell package.
|
# This file is distributed under the same license as the gnome-shell package.
|
||||||
#
|
#
|
||||||
# Kjartan Maraas <kmaraas@gnome.org>, 2009-2013.
|
# Kjartan Maraas <kmaraas@gnome.org>, 2009-2014.
|
||||||
# Torstein Adolf Winterseth <kvikende@fsfe.org>, 2010.
|
# Torstein Adolf Winterseth <kvikende@fsfe.org>, 2010.
|
||||||
msgid ""
|
msgid ""
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: gnome-shell 3.11.x\n"
|
"Project-Id-Version: gnome-shell 3.11.x\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2014-01-21 19:59+0100\n"
|
"POT-Creation-Date: 2014-02-19 19:43+0100\n"
|
||||||
"PO-Revision-Date: 2014-01-21 20:03+0100\n"
|
"PO-Revision-Date: 2014-02-19 19:45+0100\n"
|
||||||
"Last-Translator: Kjartan Maraas <kmaraas@gnome.org>\n"
|
"Last-Translator: Kjartan Maraas <kmaraas@gnome.org>\n"
|
||||||
"Language-Team: Norwegian bokmål <i18n-nb@lister.ping.uio.no>\n"
|
"Language-Team: Norwegian bokmål <i18n-nb@lister.ping.uio.no>\n"
|
||||||
"Language: \n"
|
"Language: \n"
|
||||||
@ -86,13 +86,28 @@ msgid ""
|
|||||||
"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 "
|
||||||
"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 "GNOME Shell-utvidelser har en UUID-egenskap. Denne nøkkelen lister utvidelser som skal lastes. Alle utvidelser som ønsker å bli lastet må være i denne listen. Du kan også manipulere denne listen med DBus-metodene EnablExtension og DisableExtension på org.gnome.Shell."
|
msgstr ""
|
||||||
|
"GNOME Shell-utvidelser har en UUID-egenskap. Denne nøkkelen lister "
|
||||||
|
"utvidelser som skal lastes. Alle utvidelser som ønsker å bli lastet må være "
|
||||||
|
"i denne listen. Du kan også manipulere denne listen med DBus-metodene "
|
||||||
|
"EnablExtension og DisableExtension på org.gnome.Shell."
|
||||||
|
|
||||||
#: ../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"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:6
|
||||||
|
msgid ""
|
||||||
|
"GNOME Shell will only load extensions that claim to support the current "
|
||||||
|
"running version. Enabling this option will disable this check and try to "
|
||||||
|
"load all extensions regardless of the versions they claim to support."
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
#: ../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"
|
||||||
msgstr "Liste av skrivebordfil-ider for favorittprogrammer"
|
msgstr "Liste av skrivebordfil-ider for favorittprogrammer"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:6
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:8
|
||||||
msgid ""
|
msgid ""
|
||||||
"The applications corresponding to these identifiers will be displayed in the "
|
"The applications corresponding to these identifiers will be displayed in the "
|
||||||
"favorites area."
|
"favorites area."
|
||||||
@ -100,30 +115,30 @@ msgstr ""
|
|||||||
"Programmene som passer til disse identifikatorene vil bli vist i "
|
"Programmene som passer til disse identifikatorene vil bli vist i "
|
||||||
"favorittområdet."
|
"favorittområdet."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:7
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:9
|
||||||
msgid "History for command (Alt-F2) dialog"
|
msgid "History for command (Alt-F2) dialog"
|
||||||
msgstr "Historikk for kommandodialog (Alt-F2)"
|
msgstr "Historikk for kommandodialog (Alt-F2)"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:8
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:10
|
||||||
msgid "History for the looking glass dialog"
|
msgid "History for the looking glass dialog"
|
||||||
msgstr "Historikk for forstørrelsesglass-dialogen"
|
msgstr "Historikk for forstørrelsesglass-dialogen"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:9
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:11
|
||||||
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 "Alltid vis menyoppføringen «Logg ut» i brukermenyen."
|
msgstr "Alltid vis menyoppføringen «Logg ut» i brukermenyen."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:10
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:12
|
||||||
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."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:11
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:13
|
||||||
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:12
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:14
|
||||||
msgid ""
|
msgid ""
|
||||||
"The shell will request a password when an encrypted device or a remote "
|
"The shell will request a password when an encrypted device or a remote "
|
||||||
"filesystem is mounted. If the password can be saved for future use a "
|
"filesystem is mounted. If the password can be saved for future use a "
|
||||||
@ -131,90 +146,104 @@ msgid ""
|
|||||||
"state of the checkbox."
|
"state of the checkbox."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:13
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:15
|
||||||
msgid "Show the week date in the calendar"
|
msgid "Show the week date in the calendar"
|
||||||
msgstr "Vis dato for uken i kalender"
|
msgstr "Vis dato for uken i kalender"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:14
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:16
|
||||||
msgid "If true, display the ISO week date in the calendar."
|
msgid "If true, display the ISO week date in the calendar."
|
||||||
msgstr "Viser ISO-ukedato i kalenderen hvis «true»."
|
msgstr "Viser ISO-ukedato i kalenderen hvis «true»."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:15
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:17
|
||||||
msgid "Keybinding to open the application menu"
|
msgid "Keybinding to open the application menu"
|
||||||
msgstr "Tastaturbinding som åpner programmenyen"
|
msgstr "Tastaturbinding som åpner programmenyen"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:16
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:18
|
||||||
msgid "Keybinding to open the application menu."
|
msgid "Keybinding to open the application menu."
|
||||||
msgstr "Tastaturbinding som åpner programmenyen."
|
msgstr "Tastaturbinding som åpner programmenyen."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:17
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:19
|
||||||
msgid "Keybinding to open the \"Show Applications\" view"
|
msgid "Keybinding to open the \"Show Applications\" view"
|
||||||
msgstr "Tastaturbinding som åpner visningen «Vis programmer»"
|
msgstr "Tastaturbinding som åpner visningen «Vis programmer»"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:18
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:20
|
||||||
msgid ""
|
msgid ""
|
||||||
"Keybinding to open the \"Show Applications\" view of the Activities Overview."
|
"Keybinding to open the \"Show Applications\" view of the Activities Overview."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Tastaturbinding som åpner visningen «Vis programmer» i aktivitetsoversikten."
|
"Tastaturbinding som åpner visningen «Vis programmer» i aktivitetsoversikten."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:19
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:21
|
||||||
msgid "Keybinding to open the overview"
|
msgid "Keybinding to open the overview"
|
||||||
msgstr "Tastaturbinding som åpner oversikten"
|
msgstr "Tastaturbinding som åpner oversikten"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:20
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:22
|
||||||
msgid "Keybinding to open the Activities Overview."
|
msgid "Keybinding to open the Activities Overview."
|
||||||
msgstr "Tastaturbinding som åpner aktivitetsoversikten."
|
msgstr "Tastaturbinding som åpner aktivitetsoversikten."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:21
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:23
|
||||||
msgid "Keybinding to toggle the visibility of the message tray"
|
msgid "Keybinding to toggle the visibility of the message tray"
|
||||||
msgstr "Tastaturbinding som slår av/på synlighet for meldingstrau"
|
msgstr "Tastaturbinding som slår av/på synlighet for meldingstrau"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:22
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:24
|
||||||
msgid "Keybinding to toggle the visibility of the message tray."
|
msgid "Keybinding to toggle the visibility of the message tray."
|
||||||
msgstr "Tastaturbinding som slår av/på synlighet for meldingstrauet."
|
msgstr "Tastaturbinding som slår av/på synlighet for meldingstrauet."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:23
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:25
|
||||||
msgid "Keybinding to focus the active notification"
|
msgid "Keybinding to focus the active notification"
|
||||||
msgstr "Tastaturbinding som fokuserer aktiv varsling"
|
msgstr "Tastaturbinding som fokuserer aktiv varsling"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:24
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:26
|
||||||
msgid "Keybinding to focus the active notification."
|
msgid "Keybinding to focus the active notification."
|
||||||
msgstr "Tastaturbinding som fokuserer aktiv varsling."
|
msgstr "Tastaturbinding som fokuserer aktiv varsling."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:25
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:27
|
||||||
msgid "Which keyboard to use"
|
msgid "Which keyboard to use"
|
||||||
msgstr "Tastatur som skal brukes"
|
msgstr "Tastatur som skal brukes"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:26
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:28
|
||||||
msgid "The type of keyboard to use."
|
msgid "The type of keyboard to use."
|
||||||
msgstr "Type tastatur som skal brukes."
|
msgstr "Type tastatur som skal brukes."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:27
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:29
|
||||||
|
msgid "The maximum accuracy level of location."
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:30
|
||||||
|
msgid ""
|
||||||
|
"Configures the maximum level of location accuracy applications are allowed "
|
||||||
|
"to see. Valid options are 'off' (disable location tracking), 'country', "
|
||||||
|
"'city', 'neighborhood', 'street', and 'exact' (typically requires GPS "
|
||||||
|
"receiver). Please keep in mind that this only controls what Geoclue will "
|
||||||
|
"allow applications to see and they can find user's location on their own "
|
||||||
|
"using network resources (albeit with street-level accuracy at best)."
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:31
|
||||||
msgid "The application icon mode."
|
msgid "The application icon mode."
|
||||||
msgstr "Ikonmodus for programmet."
|
msgstr "Ikonmodus for programmet."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:28
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:32
|
||||||
msgid ""
|
msgid ""
|
||||||
"Configures how the windows are shown in the switcher. Valid possibilities "
|
"Configures how the windows are shown in the switcher. Valid possibilities "
|
||||||
"are 'thumbnail-only' (shows a thumbnail of the window), 'app-icon-"
|
"are 'thumbnail-only' (shows a thumbnail of the window), 'app-icon-"
|
||||||
"only' (shows only the application icon) or 'both'."
|
"only' (shows only the application icon) or 'both'."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:29
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:33
|
||||||
msgid "Attach modal dialog to the parent window"
|
msgid "Attach modal dialog to the parent window"
|
||||||
msgstr "Fest modal dialog til opphavsvinduet"
|
msgstr "Fest modal dialog til opphavsvinduet"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:30
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:34
|
||||||
msgid ""
|
msgid ""
|
||||||
"This key overrides the key in org.gnome.mutter when running GNOME Shell."
|
"This key overrides the key in org.gnome.mutter when running GNOME Shell."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Denne nøkkelen overstyrer nøkkelen i org.gnome.mutter når GNOME Shell kjøres."
|
"Denne nøkkelen overstyrer nøkkelen i org.gnome.mutter når GNOME Shell kjøres."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:31
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:35
|
||||||
msgid "Arrangement of buttons on the titlebar"
|
msgid "Arrangement of buttons on the titlebar"
|
||||||
msgstr "Plassering av knappene på tittellinjen"
|
msgstr "Plassering av knappene på tittellinjen"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:32
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:36
|
||||||
msgid ""
|
msgid ""
|
||||||
"This key overrides the key in org.gnome.desktop.wm.preferences when running "
|
"This key overrides the key in org.gnome.desktop.wm.preferences when running "
|
||||||
"GNOME Shell."
|
"GNOME Shell."
|
||||||
@ -222,19 +251,19 @@ msgstr ""
|
|||||||
"Denne nøkkelen overstyrer nøkkelen i org.gnome.desktop.wm.preferences når "
|
"Denne nøkkelen overstyrer nøkkelen i org.gnome.desktop.wm.preferences når "
|
||||||
"GNOME Shell kjøres."
|
"GNOME Shell kjøres."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:33
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:37
|
||||||
msgid "Enable edge tiling when dropping windows on screen edges"
|
msgid "Enable edge tiling when dropping windows on screen edges"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:34
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:38
|
||||||
msgid "Workspaces are managed dynamically"
|
msgid "Workspaces are managed dynamically"
|
||||||
msgstr "Arbeidsområder håndteres dynamisk"
|
msgstr "Arbeidsområder håndteres dynamisk"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:35
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:39
|
||||||
msgid "Workspaces only on primary monitor"
|
msgid "Workspaces only on primary monitor"
|
||||||
msgstr "Arbeidsområder vises kun på hovedskjerm"
|
msgstr "Arbeidsområder vises kun på hovedskjerm"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:36
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:40
|
||||||
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 ""
|
||||||
|
|
||||||
@ -254,7 +283,7 @@ msgstr "Velg en utvidelse som skal konfigureres med komboboksen over."
|
|||||||
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
||||||
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
||||||
#: ../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:724
|
#: ../js/ui/status/network.js:883
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
msgstr "Avbryt"
|
msgstr "Avbryt"
|
||||||
|
|
||||||
@ -315,27 +344,27 @@ msgstr "Klarte ikke å lese kommando:"
|
|||||||
msgid "Execution of “%s” failed:"
|
msgid "Execution of “%s” failed:"
|
||||||
msgstr "Kjøring av «%s» feilet:"
|
msgstr "Kjøring av «%s» feilet:"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:543
|
#: ../js/ui/appDisplay.js:629
|
||||||
msgid "Frequently used applications will appear here"
|
msgid "Frequently used applications will appear here"
|
||||||
msgstr "Ofte brukte programmer vil vises her"
|
msgstr "Ofte brukte programmer vil vises her"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:663
|
#: ../js/ui/appDisplay.js:740
|
||||||
msgid "Frequent"
|
msgid "Frequent"
|
||||||
msgstr "Ofte"
|
msgstr "Ofte"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:670
|
#: ../js/ui/appDisplay.js:747
|
||||||
msgid "All"
|
msgid "All"
|
||||||
msgstr "Alle"
|
msgstr "Alle"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1499
|
#: ../js/ui/appDisplay.js:1552
|
||||||
msgid "New Window"
|
msgid "New Window"
|
||||||
msgstr "Nytt vindu"
|
msgstr "Nytt vindu"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1521 ../js/ui/dash.js:285
|
#: ../js/ui/appDisplay.js:1574 ../js/ui/dash.js:285
|
||||||
msgid "Remove from Favorites"
|
msgid "Remove from Favorites"
|
||||||
msgstr "Fjern fra favoritter"
|
msgstr "Fjern fra favoritter"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1527
|
#: ../js/ui/appDisplay.js:1580
|
||||||
msgid "Add to Favorites"
|
msgid "Add to Favorites"
|
||||||
msgstr "Legg til i favoritter"
|
msgstr "Legg til i favoritter"
|
||||||
|
|
||||||
@ -548,8 +577,8 @@ msgstr "Passord:"
|
|||||||
msgid "Type again:"
|
msgid "Type again:"
|
||||||
msgstr "Skriv på nytt:"
|
msgstr "Skriv på nytt:"
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:131
|
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:250
|
||||||
#: ../js/ui/status/network.js:293 ../js/ui/status/network.js:727
|
#: ../js/ui/status/network.js:327 ../js/ui/status/network.js:886
|
||||||
msgid "Connect"
|
msgid "Connect"
|
||||||
msgstr "Koble til"
|
msgstr "Koble til"
|
||||||
|
|
||||||
@ -643,60 +672,102 @@ msgstr "Autentiser"
|
|||||||
msgid "Sorry, that didn't work. Please try again."
|
msgid "Sorry, that didn't work. Please try again."
|
||||||
msgstr "Beklager, det virket ikke. Vennligst prøv igjen."
|
msgstr "Beklager, det virket ikke. Vennligst prøv igjen."
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:237
|
#: ../js/ui/components/telepathyClient.js:240
|
||||||
msgid "Invitation"
|
msgid "Invitation"
|
||||||
msgstr "Invitasjon"
|
msgstr "Invitasjon"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:297
|
#: ../js/ui/components/telepathyClient.js:300
|
||||||
msgid "Call"
|
msgid "Call"
|
||||||
msgstr "Ring"
|
msgstr "Ring"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:313
|
#: ../js/ui/components/telepathyClient.js:316
|
||||||
msgid "File Transfer"
|
msgid "File Transfer"
|
||||||
msgstr "Filoverføring"
|
msgstr "Filoverføring"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:417
|
#: ../js/ui/components/telepathyClient.js:420
|
||||||
msgid "Chat"
|
msgid "Chat"
|
||||||
msgstr "Prat"
|
msgstr "Prat"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:480
|
#: ../js/ui/components/telepathyClient.js:483
|
||||||
msgid "Unmute"
|
msgid "Unmute"
|
||||||
msgstr "Fjern demping"
|
msgstr "Fjern demping"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:480
|
#: ../js/ui/components/telepathyClient.js:483
|
||||||
msgid "Mute"
|
msgid "Mute"
|
||||||
msgstr "Demp"
|
msgstr "Demp"
|
||||||
|
|
||||||
#. Translators: this is the word "Yesterday" followed by a time string. i.e. "Yesterday, 14:30"*/
|
#. Translators: Time in 24h format */
|
||||||
#: ../js/ui/components/telepathyClient.js:941
|
#: ../js/ui/components/telepathyClient.js:955
|
||||||
msgid "<b>Yesterday</b>, <b>%H:%M</b>"
|
msgid "%H∶%M"
|
||||||
msgstr "<b>I går</b>, <b>%H.%M</b>"
|
msgstr "%H.%M"
|
||||||
|
|
||||||
#. Translators: this is the week day name followed by a time string. i.e. "Monday, 14:30*/
|
#. Translators: this is the word "Yesterday" followed by a
|
||||||
#: ../js/ui/components/telepathyClient.js:947
|
#. time string in 24h format. i.e. "Yesterday, 14:30" */
|
||||||
msgid "<b>%A</b>, <b>%H:%M</b>"
|
#: ../js/ui/components/telepathyClient.js:962
|
||||||
msgstr "<b>%A</b>, <b>%H.%M</b>"
|
msgid "Yesterday, %H∶%M"
|
||||||
|
msgstr "I går, %H.%M"
|
||||||
|
|
||||||
#. Translators: this is the month name and day number followed by a time string. i.e. "May 25, 14:30"*/
|
#. Translators: this is the week day name followed by a time
|
||||||
#: ../js/ui/components/telepathyClient.js:952
|
#. string in 24h format. i.e. "Monday, 14:30" */
|
||||||
msgid "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
#: ../js/ui/components/telepathyClient.js:969
|
||||||
msgstr "<b>%d</b>, <b>%B</b>, <b>%H.%M</b>"
|
msgid "%A, %H∶%M"
|
||||||
|
msgstr "%A, %H.%M"
|
||||||
|
|
||||||
#. Translators: this is the month name, day number, year number followed by a time string. i.e. "May 25 2012, 14:30"*/
|
#. Translators: this is the month name and day number
|
||||||
#: ../js/ui/components/telepathyClient.js:956
|
#. followed by a time string in 24h format.
|
||||||
msgid "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
#. i.e. "May 25, 14:30" */
|
||||||
msgstr "<b>%d</b> <b>%B</b> <b>%Y</b>, <b>%H.%M</b> "
|
#: ../js/ui/components/telepathyClient.js:976
|
||||||
|
msgid "%B %d, %H∶%M"
|
||||||
|
msgstr "%d %B, %H.%M"
|
||||||
|
|
||||||
|
#. Translators: this is the month name, day number, year
|
||||||
|
#. number followed by a time string in 24h format.
|
||||||
|
#. i.e. "May 25 2012, 14:30" */
|
||||||
|
#: ../js/ui/components/telepathyClient.js:982
|
||||||
|
msgid "%B %d %Y, %H∶%M"
|
||||||
|
msgstr "%d %B %Y, %H.%M"
|
||||||
|
|
||||||
|
#. Translators: Time in 24h format */
|
||||||
|
#: ../js/ui/components/telepathyClient.js:991
|
||||||
|
msgid "%l∶%M %p"
|
||||||
|
msgstr "%H.%M"
|
||||||
|
|
||||||
|
#. Translators: this is the word "Yesterday" followed by a
|
||||||
|
#. time string in 12h format. i.e. "Yesterday, 2:30 pm" */
|
||||||
|
#: ../js/ui/components/telepathyClient.js:998
|
||||||
|
msgid "Yesterday, %l∶%M %p"
|
||||||
|
msgstr "I går, %H.%M"
|
||||||
|
|
||||||
|
#. Translators: this is the week day name followed by a time
|
||||||
|
#. string in 12h format. i.e. "Monday, 2:30 pm" */
|
||||||
|
#: ../js/ui/components/telepathyClient.js:1005
|
||||||
|
msgid "%A, %l∶%M %p"
|
||||||
|
msgstr "%A, %H.%M"
|
||||||
|
|
||||||
|
#. Translators: this is the month name and day number
|
||||||
|
#. followed by a time string in 12h format.
|
||||||
|
#. i.e. "May 25, 2:30 pm" */
|
||||||
|
#: ../js/ui/components/telepathyClient.js:1012
|
||||||
|
msgid "%B %d, %l∶%M %p"
|
||||||
|
msgstr "%d %B, %H.%M"
|
||||||
|
|
||||||
|
#. Translators: this is the month name, day number, year
|
||||||
|
#. number followed by a time string in 12h format.
|
||||||
|
#. i.e. "May 25 2012, 2:30 pm"*/
|
||||||
|
#: ../js/ui/components/telepathyClient.js:1018
|
||||||
|
msgid "%B %d %Y, %l∶%M %p"
|
||||||
|
msgstr "%d %B %Y, %H.%M"
|
||||||
|
|
||||||
#. 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:987
|
#: ../js/ui/components/telepathyClient.js:1051
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s is now known as %s"
|
msgid "%s is now known as %s"
|
||||||
msgstr "%s er nå kjent som %s"
|
msgstr "%s er nå kjent som %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:1090
|
#: ../js/ui/components/telepathyClient.js:1154
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Invitation to %s"
|
msgid "Invitation to %s"
|
||||||
msgstr "Invitasjon til %s"
|
msgstr "Invitasjon til %s"
|
||||||
@ -704,38 +775,38 @@ msgstr "Invitasjon til %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:1098
|
#: ../js/ui/components/telepathyClient.js:1162
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s is inviting you to join %s"
|
msgid "%s is inviting you to join %s"
|
||||||
msgstr "%s inviterer deg til å bli med i %s"
|
msgstr "%s inviterer deg til å bli med i %s"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1100
|
#: ../js/ui/components/telepathyClient.js:1164
|
||||||
#: ../js/ui/components/telepathyClient.js:1135
|
#: ../js/ui/components/telepathyClient.js:1199
|
||||||
#: ../js/ui/components/telepathyClient.js:1169
|
#: ../js/ui/components/telepathyClient.js:1233
|
||||||
#: ../js/ui/components/telepathyClient.js:1226
|
#: ../js/ui/components/telepathyClient.js:1290
|
||||||
msgid "Decline"
|
msgid "Decline"
|
||||||
msgstr "Avslå"
|
msgstr "Avslå"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1106
|
#: ../js/ui/components/telepathyClient.js:1170
|
||||||
#: ../js/ui/components/telepathyClient.js:1175
|
#: ../js/ui/components/telepathyClient.js:1239
|
||||||
#: ../js/ui/components/telepathyClient.js:1231
|
#: ../js/ui/components/telepathyClient.js:1295
|
||||||
msgid "Accept"
|
msgid "Accept"
|
||||||
msgstr "Godta"
|
msgstr "Godta"
|
||||||
|
|
||||||
#. 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:1125
|
#: ../js/ui/components/telepathyClient.js:1189
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Video call from %s"
|
msgid "Video call from %s"
|
||||||
msgstr "Videosamtale fra %s"
|
msgstr "Videosamtale fra %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:1128
|
#: ../js/ui/components/telepathyClient.js:1192
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Call from %s"
|
msgid "Call from %s"
|
||||||
msgstr "Samtale fra %s"
|
msgstr "Samtale fra %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:1142
|
#: ../js/ui/components/telepathyClient.js:1206
|
||||||
msgid "Answer"
|
msgid "Answer"
|
||||||
msgstr "Svar"
|
msgstr "Svar"
|
||||||
|
|
||||||
@ -744,110 +815,110 @@ msgstr "Svar"
|
|||||||
#. * 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:1163
|
#: ../js/ui/components/telepathyClient.js:1227
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%s is sending you %s"
|
msgid "%s is sending you %s"
|
||||||
msgstr "%s sender deg %s"
|
msgstr "%s sender deg %s"
|
||||||
|
|
||||||
#. To translators: The parameter is the contact's alias */
|
#. To translators: The parameter is the contact's alias */
|
||||||
#: ../js/ui/components/telepathyClient.js:1192
|
#: ../js/ui/components/telepathyClient.js:1256
|
||||||
#, 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 vil ha rettigheter til å se når du er tilkoblet"
|
msgstr "%s vil ha rettigheter til å se når du er tilkoblet"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1277
|
#: ../js/ui/components/telepathyClient.js:1341
|
||||||
msgid "Network error"
|
msgid "Network error"
|
||||||
msgstr "Nettverksfeil"
|
msgstr "Nettverksfeil"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1279
|
#: ../js/ui/components/telepathyClient.js:1343
|
||||||
msgid "Authentication failed"
|
msgid "Authentication failed"
|
||||||
msgstr "Autentisering feilet"
|
msgstr "Autentisering feilet"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1281
|
#: ../js/ui/components/telepathyClient.js:1345
|
||||||
msgid "Encryption error"
|
msgid "Encryption error"
|
||||||
msgstr "Feil ved kryptering"
|
msgstr "Feil ved kryptering"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1283
|
#: ../js/ui/components/telepathyClient.js:1347
|
||||||
msgid "Certificate not provided"
|
msgid "Certificate not provided"
|
||||||
msgstr "Sertifikat ikke oppgitt"
|
msgstr "Sertifikat ikke oppgitt"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1285
|
#: ../js/ui/components/telepathyClient.js:1349
|
||||||
msgid "Certificate untrusted"
|
msgid "Certificate untrusted"
|
||||||
msgstr "Stoler ikke på sertifikatet"
|
msgstr "Stoler ikke på sertifikatet"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1287
|
#: ../js/ui/components/telepathyClient.js:1351
|
||||||
msgid "Certificate expired"
|
msgid "Certificate expired"
|
||||||
msgstr "Sertifikatet er utløpt"
|
msgstr "Sertifikatet er utløpt"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1289
|
#: ../js/ui/components/telepathyClient.js:1353
|
||||||
msgid "Certificate not activated"
|
msgid "Certificate not activated"
|
||||||
msgstr "Sertifikatet er ikke aktivert"
|
msgstr "Sertifikatet er ikke aktivert"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1291
|
#: ../js/ui/components/telepathyClient.js:1355
|
||||||
msgid "Certificate hostname mismatch"
|
msgid "Certificate hostname mismatch"
|
||||||
msgstr "Feil vertsnavn for sertifikat"
|
msgstr "Feil vertsnavn for sertifikat"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1293
|
#: ../js/ui/components/telepathyClient.js:1357
|
||||||
msgid "Certificate fingerprint mismatch"
|
msgid "Certificate fingerprint mismatch"
|
||||||
msgstr "Feil fingeravtrykk for sertifikat"
|
msgstr "Feil fingeravtrykk for sertifikat"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1295
|
#: ../js/ui/components/telepathyClient.js:1359
|
||||||
msgid "Certificate self-signed"
|
msgid "Certificate self-signed"
|
||||||
msgstr "Sertifikatet er selvsignert"
|
msgstr "Sertifikatet er selvsignert"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1297
|
#: ../js/ui/components/telepathyClient.js:1361
|
||||||
msgid "Status is set to offline"
|
msgid "Status is set to offline"
|
||||||
msgstr "Status er satt til frakoblet"
|
msgstr "Status er satt til frakoblet"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1299
|
#: ../js/ui/components/telepathyClient.js:1363
|
||||||
msgid "Encryption is not available"
|
msgid "Encryption is not available"
|
||||||
msgstr "Kryptering er ikke tilgjengelig"
|
msgstr "Kryptering er ikke tilgjengelig"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1301
|
#: ../js/ui/components/telepathyClient.js:1365
|
||||||
msgid "Certificate is invalid"
|
msgid "Certificate is invalid"
|
||||||
msgstr "Sertifikatet er ugyldig"
|
msgstr "Sertifikatet er ugyldig"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1303
|
#: ../js/ui/components/telepathyClient.js:1367
|
||||||
msgid "Connection has been refused"
|
msgid "Connection has been refused"
|
||||||
msgstr "Tilkobling ble nektet"
|
msgstr "Tilkobling ble nektet"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1305
|
#: ../js/ui/components/telepathyClient.js:1369
|
||||||
msgid "Connection can't be established"
|
msgid "Connection can't be established"
|
||||||
msgstr "Tilkobling kan ikke etableres"
|
msgstr "Tilkobling kan ikke etableres"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1307
|
#: ../js/ui/components/telepathyClient.js:1371
|
||||||
msgid "Connection has been lost"
|
msgid "Connection has been lost"
|
||||||
msgstr "Tilkobling tapt"
|
msgstr "Tilkobling tapt"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1309
|
#: ../js/ui/components/telepathyClient.js:1373
|
||||||
msgid "This account is already connected to the server"
|
msgid "This account is already connected to the server"
|
||||||
msgstr "Denne kontoen er allerede koblet til tjeneren"
|
msgstr "Denne kontoen er allerede koblet til tjeneren"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1311
|
#: ../js/ui/components/telepathyClient.js:1375
|
||||||
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 ""
|
||||||
"Tilkoblingen har blitt erstattet av en ny tilkobling som bruker samme ressurs"
|
"Tilkoblingen har blitt erstattet av en ny tilkobling som bruker samme ressurs"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1313
|
#: ../js/ui/components/telepathyClient.js:1377
|
||||||
msgid "The account already exists on the server"
|
msgid "The account already exists on the server"
|
||||||
msgstr "Kontoen eksisterer allerede på tjeneren"
|
msgstr "Kontoen eksisterer allerede på tjeneren"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1315
|
#: ../js/ui/components/telepathyClient.js:1379
|
||||||
msgid "Server is currently too busy to handle the connection"
|
msgid "Server is currently too busy to handle the connection"
|
||||||
msgstr "Tjener er for opptatt til å håndtere tilkoblingen"
|
msgstr "Tjener er for opptatt til å håndtere tilkoblingen"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1317
|
#: ../js/ui/components/telepathyClient.js:1381
|
||||||
msgid "Certificate has been revoked"
|
msgid "Certificate has been revoked"
|
||||||
msgstr "Sertifikatet er tilbaketrukket"
|
msgstr "Sertifikatet er tilbaketrukket"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1319
|
#: ../js/ui/components/telepathyClient.js:1383
|
||||||
msgid ""
|
msgid ""
|
||||||
"Certificate uses an insecure cipher algorithm or is cryptographically weak"
|
"Certificate uses an insecure cipher algorithm or is cryptographically weak"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Sertifikatet bruker en usikker sifferalgoritme eller er krytografisk svakt"
|
"Sertifikatet bruker en usikker sifferalgoritme eller er krytografisk svakt"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1321
|
#: ../js/ui/components/telepathyClient.js:1385
|
||||||
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"
|
||||||
@ -855,22 +926,22 @@ msgstr ""
|
|||||||
"Lengden eller dybden på tjenersertifikatet oversteg grensen som er satt i "
|
"Lengden eller dybden på tjenersertifikatet oversteg grensen som er satt i "
|
||||||
"kryptografibiblioteket"
|
"kryptografibiblioteket"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1323
|
#: ../js/ui/components/telepathyClient.js:1387
|
||||||
msgid "Internal error"
|
msgid "Internal error"
|
||||||
msgstr "Intern feil"
|
msgstr "Intern feil"
|
||||||
|
|
||||||
#. 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:1333
|
#: ../js/ui/components/telepathyClient.js:1397
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Unable to connect to %s"
|
msgid "Unable to connect to %s"
|
||||||
msgstr "Kan ikke koble til %s"
|
msgstr "Kan ikke koble til %s"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1338
|
#: ../js/ui/components/telepathyClient.js:1402
|
||||||
msgid "View account"
|
msgid "View account"
|
||||||
msgstr "Vis konto"
|
msgstr "Vis konto"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1370
|
#: ../js/ui/components/telepathyClient.js:1434
|
||||||
msgid "Unknown reason"
|
msgid "Unknown reason"
|
||||||
msgstr "Ukjent årsak"
|
msgstr "Ukjent årsak"
|
||||||
|
|
||||||
@ -882,7 +953,7 @@ msgstr "Vinduer"
|
|||||||
msgid "Show Applications"
|
msgid "Show Applications"
|
||||||
msgstr "Vis programmer"
|
msgstr "Vis programmer"
|
||||||
|
|
||||||
#: ../js/ui/dash.js:443
|
#: ../js/ui/dash.js:445
|
||||||
msgid "Dash"
|
msgid "Dash"
|
||||||
msgstr "Favoritter"
|
msgstr "Favoritter"
|
||||||
|
|
||||||
@ -1050,7 +1121,7 @@ msgstr "Aktivert"
|
|||||||
#. 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:717 ../js/ui/status/network.js:470
|
#: ../js/ui/lookingGlass.js:717 ../js/ui/status/network.js:560
|
||||||
#: ../src/gvc/gvc-mixer-control.c:1830
|
#: ../src/gvc/gvc-mixer-control.c:1830
|
||||||
msgid "Disabled"
|
msgid "Disabled"
|
||||||
msgstr "Deaktivert"
|
msgstr "Deaktivert"
|
||||||
@ -1075,43 +1146,43 @@ msgstr "Vis kildekode"
|
|||||||
msgid "Web Page"
|
msgid "Web Page"
|
||||||
msgstr "Nettside"
|
msgstr "Nettside"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1312
|
#: ../js/ui/messageTray.js:1324
|
||||||
msgid "Open"
|
msgid "Open"
|
||||||
msgstr "Åpne"
|
msgstr "Åpne"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1319
|
#: ../js/ui/messageTray.js:1331
|
||||||
msgid "Remove"
|
msgid "Remove"
|
||||||
msgstr "Fjern"
|
msgstr "Fjern"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1616
|
#: ../js/ui/messageTray.js:1628
|
||||||
msgid "Notifications"
|
msgid "Notifications"
|
||||||
msgstr "Varslinger"
|
msgstr "Varslinger"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1623
|
#: ../js/ui/messageTray.js:1635
|
||||||
msgid "Clear Messages"
|
msgid "Clear Messages"
|
||||||
msgstr "Tøm meldinger"
|
msgstr "Tøm meldinger"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1642
|
#: ../js/ui/messageTray.js:1654
|
||||||
msgid "Notification Settings"
|
msgid "Notification Settings"
|
||||||
msgstr "Innstillinger for varsling"
|
msgstr "Innstillinger for varsling"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1695
|
#: ../js/ui/messageTray.js:1707
|
||||||
msgid "Tray Menu"
|
msgid "Tray Menu"
|
||||||
msgstr "Meny for varslingsområde"
|
msgstr "Meny for varslingsområde"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1912
|
#: ../js/ui/messageTray.js:1924
|
||||||
msgid "No Messages"
|
msgid "No Messages"
|
||||||
msgstr "Ingen meldinger"
|
msgstr "Ingen meldinger"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1950
|
#: ../js/ui/messageTray.js:1962
|
||||||
msgid "Message Tray"
|
msgid "Message Tray"
|
||||||
msgstr "Meldingstrau"
|
msgstr "Meldingstrau"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:2934
|
#: ../js/ui/messageTray.js:2946
|
||||||
msgid "System Information"
|
msgid "System Information"
|
||||||
msgstr "Systeminformasjon"
|
msgstr "Systeminformasjon"
|
||||||
|
|
||||||
#: ../js/ui/notificationDaemon.js:515 ../src/shell-app.c:397
|
#: ../js/ui/notificationDaemon.js:515 ../src/shell-app.c:425
|
||||||
msgctxt "program"
|
msgctxt "program"
|
||||||
msgid "Unknown"
|
msgid "Unknown"
|
||||||
msgstr "Ukjent"
|
msgstr "Ukjent"
|
||||||
@ -1149,11 +1220,11 @@ msgstr "Avslutt"
|
|||||||
msgid "Activities"
|
msgid "Activities"
|
||||||
msgstr "Aktiviteter"
|
msgstr "Aktiviteter"
|
||||||
|
|
||||||
#: ../js/ui/panel.js:903
|
#: ../js/ui/panel.js:914
|
||||||
msgid "Top Bar"
|
msgid "Top Bar"
|
||||||
msgstr "Topp-panel"
|
msgstr "Topp-panel"
|
||||||
|
|
||||||
#: ../js/ui/popupMenu.js:260
|
#: ../js/ui/popupMenu.js:271
|
||||||
msgid "toggle-switch-us"
|
msgid "toggle-switch-us"
|
||||||
msgstr "toggle-switch-intl"
|
msgstr "toggle-switch-intl"
|
||||||
|
|
||||||
@ -1178,19 +1249,19 @@ msgid_plural "%d new notifications"
|
|||||||
msgstr[0] "%d ny varsling"
|
msgstr[0] "%d ny varsling"
|
||||||
msgstr[1] "%d nye varslinger"
|
msgstr[1] "%d nye varslinger"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:472 ../js/ui/status/system.js:342
|
#: ../js/ui/screenShield.js:473 ../js/ui/status/system.js:342
|
||||||
msgid "Lock"
|
msgid "Lock"
|
||||||
msgstr "Lås"
|
msgstr "Lås"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:706
|
#: ../js/ui/screenShield.js:707
|
||||||
msgid "GNOME needs to lock the screen"
|
msgid "GNOME needs to lock the screen"
|
||||||
msgstr "GNOME må låse skjermen"
|
msgstr "GNOME må låse skjermen"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:833 ../js/ui/screenShield.js:1300
|
#: ../js/ui/screenShield.js:834 ../js/ui/screenShield.js:1301
|
||||||
msgid "Unable to lock"
|
msgid "Unable to lock"
|
||||||
msgstr "Kan ikke låse"
|
msgstr "Kan ikke låse"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:834 ../js/ui/screenShield.js:1301
|
#: ../js/ui/screenShield.js:835 ../js/ui/screenShield.js:1302
|
||||||
msgid "Lock was blocked by an application"
|
msgid "Lock was blocked by an application"
|
||||||
msgstr "Låsing ble stoppet av et program"
|
msgstr "Låsing ble stoppet av et program"
|
||||||
|
|
||||||
@ -1270,26 +1341,33 @@ msgstr "Høy kontrast"
|
|||||||
msgid "Large Text"
|
msgid "Large Text"
|
||||||
msgstr "Stor tekst"
|
msgstr "Stor tekst"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:45
|
#: ../js/ui/status/bluetooth.js:48
|
||||||
msgid "Bluetooth"
|
msgid "Bluetooth"
|
||||||
msgstr "Bluetooth"
|
msgstr "Bluetooth"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:47 ../js/ui/status/network.js:131
|
#: ../js/ui/status/bluetooth.js:50 ../js/ui/status/location.js:62
|
||||||
#: ../js/ui/status/network.js:1081 ../js/ui/status/rfkill.js:48
|
#: ../js/ui/status/location.js:162 ../js/ui/status/network.js:151
|
||||||
|
#: ../js/ui/status/network.js:328 ../js/ui/status/network.js:1235
|
||||||
|
#: ../js/ui/status/network.js:1346 ../js/ui/status/rfkill.js:85
|
||||||
|
#: ../js/ui/status/rfkill.js:105
|
||||||
msgid "Turn Off"
|
msgid "Turn Off"
|
||||||
msgstr "Slå av"
|
msgstr "Slå av"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:50
|
#: ../js/ui/status/bluetooth.js:53
|
||||||
msgid "Bluetooth Settings"
|
msgid "Bluetooth Settings"
|
||||||
msgstr "Innstillinger for Bluetooth"
|
msgstr "Innstillinger for Bluetooth"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:98
|
#: ../js/ui/status/bluetooth.js:100
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%d Connected Device"
|
msgid "%d Connected Device"
|
||||||
msgid_plural "%d Connected Devices"
|
msgid_plural "%d Connected Devices"
|
||||||
msgstr[0] "%d tilkoblet enhet"
|
msgstr[0] "%d tilkoblet enhet"
|
||||||
msgstr[1] "%d tilkoblede enheter"
|
msgstr[1] "%d tilkoblede enheter"
|
||||||
|
|
||||||
|
#: ../js/ui/status/bluetooth.js:102 ../js/ui/status/network.js:1263
|
||||||
|
msgid "Not Connected"
|
||||||
|
msgstr "Ikke koblet til"
|
||||||
|
|
||||||
#: ../js/ui/status/brightness.js:44
|
#: ../js/ui/status/brightness.js:44
|
||||||
msgid "Brightness"
|
msgid "Brightness"
|
||||||
msgstr "Lysstyrke"
|
msgstr "Lysstyrke"
|
||||||
@ -1298,99 +1376,156 @@ msgstr "Lysstyrke"
|
|||||||
msgid "Show Keyboard Layout"
|
msgid "Show Keyboard Layout"
|
||||||
msgstr "Vis tastaturutforming"
|
msgstr "Vis tastaturutforming"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:70
|
#: ../js/ui/status/location.js:52
|
||||||
msgid "<unknown>"
|
msgid "Location"
|
||||||
msgstr "<ukjent>"
|
msgstr "Lokasjon"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:220 ../js/ui/status/network.js:377
|
#: ../js/ui/status/location.js:61 ../js/ui/status/location.js:161
|
||||||
#: ../js/ui/status/network.js:1102
|
#: ../js/ui/status/rfkill.js:84
|
||||||
|
msgid "On"
|
||||||
|
msgstr "På"
|
||||||
|
|
||||||
|
#: ../js/ui/status/location.js:158 ../js/ui/status/network.js:246
|
||||||
|
#: ../js/ui/status/network.js:425 ../js/ui/status/network.js:1261
|
||||||
msgid "Off"
|
msgid "Off"
|
||||||
msgstr "Av"
|
msgstr "Av"
|
||||||
|
|
||||||
|
#: ../js/ui/status/location.js:159 ../js/ui/status/network.js:1235
|
||||||
|
msgid "Turn On"
|
||||||
|
msgstr "Slå på"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:74
|
||||||
|
msgid "<unknown>"
|
||||||
|
msgstr "<ukjent>"
|
||||||
|
|
||||||
#. 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:383
|
#: ../js/ui/status/network.js:431
|
||||||
msgid "unmanaged"
|
msgid "unmanaged"
|
||||||
msgstr "ikke håndtert"
|
msgstr "ikke håndtert"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:385
|
#: ../js/ui/status/network.js:433
|
||||||
msgid "disconnecting..."
|
msgid "disconnecting..."
|
||||||
msgstr "kobler fra …"
|
msgstr "kobler fra …"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:391 ../js/ui/status/network.js:1156
|
#: ../js/ui/status/network.js:439 ../js/ui/status/network.js:1363
|
||||||
msgid "connecting..."
|
msgid "connecting..."
|
||||||
msgstr "kobler til …"
|
msgstr "kobler til …"
|
||||||
|
|
||||||
#. 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:394 ../js/ui/status/network.js:1159
|
#: ../js/ui/status/network.js:442 ../js/ui/status/network.js:1366
|
||||||
msgid "authentication required"
|
msgid "authentication required"
|
||||||
msgstr "autentisering kreves"
|
msgstr "autentisering kreves"
|
||||||
|
|
||||||
#. 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:402
|
#: ../js/ui/status/network.js:450
|
||||||
msgid "firmware missing"
|
msgid "firmware missing"
|
||||||
msgstr "fastvare mangler"
|
msgstr "fastvare mangler"
|
||||||
|
|
||||||
#. 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:406
|
#: ../js/ui/status/network.js:454
|
||||||
msgid "unavailable"
|
msgid "unavailable"
|
||||||
msgstr "ikke tilgjengelig"
|
msgstr "ikke tilgjengelig"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:408 ../js/ui/status/network.js:1161
|
#: ../js/ui/status/network.js:456 ../js/ui/status/network.js:1368
|
||||||
msgid "connection failed"
|
msgid "connection failed"
|
||||||
msgstr "tilkobling feilet"
|
msgstr "tilkobling feilet"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:424 ../js/ui/status/network.js:510
|
#: ../js/ui/status/network.js:472
|
||||||
|
msgid "Wired Settings"
|
||||||
|
msgstr "Innstillinger for trådbundet nettverk"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:514 ../js/ui/status/network.js:592
|
||||||
msgid "Mobile Broadband Settings"
|
msgid "Mobile Broadband Settings"
|
||||||
msgstr "Innstillinger for mobilt bredbånd"
|
msgstr "Innstillinger for mobilt bredbånd"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:466 ../js/ui/status/network.js:1100
|
#: ../js/ui/status/network.js:556 ../js/ui/status/network.js:1259
|
||||||
msgid "Hardware Disabled"
|
msgid "Hardware Disabled"
|
||||||
msgstr "Maskinvare slått av"
|
msgstr "Maskinvare slått av"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:692
|
#: ../js/ui/status/network.js:600
|
||||||
|
msgid "Use as Internet connection"
|
||||||
|
msgstr "Bruk som internettforbindelse"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:781
|
||||||
|
msgid "Airplane Mode is On"
|
||||||
|
msgstr "Flymodus er slått på"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:782
|
||||||
|
msgid "Wi-Fi is disabled when airplane mode is on."
|
||||||
|
msgstr "Trådløst blir slått av når flymodus slås på."
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:783
|
||||||
|
msgid "Turn Off Airplane Mode"
|
||||||
|
msgstr "Slå av flymodus"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:792
|
||||||
|
msgid "Wi-Fi is Off"
|
||||||
|
msgstr "Trådløs er av"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:793
|
||||||
|
msgid "Wi-Fi needs to be turned on in order to connect to a network."
|
||||||
|
msgstr "Trådløs må slås på for å koble til et nettverk."
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:794
|
||||||
|
msgid "Turn On Wi-Fi"
|
||||||
|
msgstr "Slå på trådløs"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:819
|
||||||
msgid "Wi-Fi Networks"
|
msgid "Wi-Fi Networks"
|
||||||
msgstr "Wi-Fi nettverk"
|
msgstr "Wi-Fi nettverk"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:694
|
#: ../js/ui/status/network.js:821
|
||||||
msgid "Select a network"
|
msgid "Select a network"
|
||||||
msgstr "Velg et nettverk"
|
msgstr "Velg et nettverk"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:718
|
#: ../js/ui/status/network.js:850
|
||||||
msgid "No Networks"
|
msgid "No Networks"
|
||||||
msgstr "Ingen nettverk"
|
msgstr "Ingen nettverk"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:987
|
#: ../js/ui/status/network.js:871 ../js/ui/status/rfkill.js:103
|
||||||
|
msgid "Use hardware switch to turn off"
|
||||||
|
msgstr "Bruk maskinvarebryter til å slå av"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:1141
|
||||||
msgid "Select Network"
|
msgid "Select Network"
|
||||||
msgstr "Velg nettverk"
|
msgstr "Velg nettverk"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:993
|
#: ../js/ui/status/network.js:1147
|
||||||
msgid "Wi-Fi Settings"
|
msgid "Wi-Fi Settings"
|
||||||
msgstr "Innstillinger"
|
msgstr "Innstillinger"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1081
|
#: ../js/ui/status/network.js:1252
|
||||||
msgid "Turn On"
|
msgid "Hotspot Active"
|
||||||
msgstr "Slå på"
|
msgstr "Trådløst aksesspunkt aktivt"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1104
|
#: ../js/ui/status/network.js:1255
|
||||||
msgid "Not Connected"
|
msgid "Connecting"
|
||||||
msgstr "Ikke koblet til"
|
msgstr "Kobler til"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1224
|
#: ../js/ui/status/network.js:1434 ../js/ui/status/rfkill.js:88
|
||||||
|
msgid "Network Settings"
|
||||||
|
msgstr "Innstillinger for nettverk"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:1436
|
||||||
|
msgid "VPN Settings"
|
||||||
|
msgstr "Innstillinger for VPN"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:1455
|
||||||
msgid "VPN"
|
msgid "VPN"
|
||||||
msgstr "VPN"
|
msgstr "VPN"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1364
|
#: ../js/ui/status/network.js:1598
|
||||||
msgid "Network Manager"
|
msgid "Network Manager"
|
||||||
msgstr "Nettverkshåndtering"
|
msgstr "Nettverkshåndtering"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1403
|
#: ../js/ui/status/network.js:1637
|
||||||
msgid "Connection failed"
|
msgid "Connection failed"
|
||||||
msgstr "Tilkobling feilet"
|
msgstr "Tilkobling feilet"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1404
|
#: ../js/ui/status/network.js:1638
|
||||||
msgid "Activation of network connection failed"
|
msgid "Activation of network connection failed"
|
||||||
msgstr "Aktivering av nettverkstilkobling feilet"
|
msgstr "Aktivering av nettverkstilkobling feilet"
|
||||||
|
|
||||||
@ -1424,18 +1559,10 @@ msgstr "UPS"
|
|||||||
msgid "Battery"
|
msgid "Battery"
|
||||||
msgstr "Batteri"
|
msgstr "Batteri"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:45
|
#: ../js/ui/status/rfkill.js:82
|
||||||
msgid "Airplane Mode"
|
msgid "Airplane Mode"
|
||||||
msgstr "Flymodus"
|
msgstr "Flymodus"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:47
|
|
||||||
msgid "On"
|
|
||||||
msgstr "På"
|
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:51
|
|
||||||
msgid "Network Settings"
|
|
||||||
msgstr "Innstillinger for nettverk"
|
|
||||||
|
|
||||||
#: ../js/ui/status/system.js:314
|
#: ../js/ui/status/system.js:314
|
||||||
msgid "Switch User"
|
msgid "Switch User"
|
||||||
msgstr "Bytt bruker"
|
msgstr "Bytt bruker"
|
||||||
@ -1537,23 +1664,23 @@ msgstr[1] "%u innganger"
|
|||||||
msgid "System Sounds"
|
msgid "System Sounds"
|
||||||
msgstr "Systemlyder"
|
msgstr "Systemlyder"
|
||||||
|
|
||||||
#: ../src/main.c:347
|
#: ../src/main.c:349
|
||||||
msgid "Print version"
|
msgid "Print version"
|
||||||
msgstr "Skriv ut versjon"
|
msgstr "Skriv ut versjon"
|
||||||
|
|
||||||
#: ../src/main.c:353
|
#: ../src/main.c:355
|
||||||
msgid "Mode used by GDM for login screen"
|
msgid "Mode used by GDM for login screen"
|
||||||
msgstr "Modus som brukes av GDM for innloggingsskjermen"
|
msgstr "Modus som brukes av GDM for innloggingsskjermen"
|
||||||
|
|
||||||
#: ../src/main.c:359
|
#: ../src/main.c:361
|
||||||
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
||||||
msgstr "Bruk spesifikt modus, f.eks «gdm» for innloggingsskjerm"
|
msgstr "Bruk spesifikt modus, f.eks «gdm» for innloggingsskjerm"
|
||||||
|
|
||||||
#: ../src/main.c:365
|
#: ../src/main.c:367
|
||||||
msgid "List possible modes"
|
msgid "List possible modes"
|
||||||
msgstr "Vis mulige modi"
|
msgstr "Vis mulige modi"
|
||||||
|
|
||||||
#: ../src/shell-app.c:640
|
#: ../src/shell-app.c:666
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to launch “%s”"
|
msgid "Failed to launch “%s”"
|
||||||
msgstr "Klarte ikke å starte «%s»"
|
msgstr "Klarte ikke å starte «%s»"
|
||||||
|
511
po/pt_BR.po
511
po/pt_BR.po
File diff suppressed because it is too large
Load Diff
261
po/tg.po
261
po/tg.po
@ -8,8 +8,8 @@ msgstr ""
|
|||||||
"Project-Id-Version: Tajik Gnome\n"
|
"Project-Id-Version: Tajik Gnome\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-01-17 21:35+0000\n"
|
"POT-Creation-Date: 2014-02-06 20:58+0000\n"
|
||||||
"PO-Revision-Date: 2014-01-18 16:47+0500\n"
|
"PO-Revision-Date: 2014-02-07 09:58+0500\n"
|
||||||
"Last-Translator: Victor Ibragimov <victor.ibragimov@gmail.com>\n"
|
"Last-Translator: Victor Ibragimov <victor.ibragimov@gmail.com>\n"
|
||||||
"Language-Team: \n"
|
"Language-Team: \n"
|
||||||
"Language: tg\n"
|
"Language: tg\n"
|
||||||
@ -284,7 +284,7 @@ msgstr ""
|
|||||||
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
#: ../js/gdm/authPrompt.js:147 ../js/ui/components/networkAgent.js:136
|
||||||
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
#: ../js/ui/components/polkitAgent.js:166 ../js/ui/endSessionDialog.js:357
|
||||||
#: ../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:724
|
#: ../js/ui/status/network.js:857
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
msgstr "Бекор кардан"
|
msgstr "Бекор кардан"
|
||||||
|
|
||||||
@ -342,31 +342,30 @@ 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/ui/appDisplay.js:540
|
#: ../js/ui/appDisplay.js:633
|
||||||
msgid "Frequently used applications will appear here"
|
msgid "Frequently used applications will appear here"
|
||||||
msgstr "Барномаҳои бештар истифодашуда ин ҷо намоиш дода мешаванд"
|
msgstr "Барномаҳои бештар истифодашуда ин ҷо намоиш дода мешаванд"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:660
|
#: ../js/ui/appDisplay.js:744
|
||||||
msgid "Frequent"
|
msgid "Frequent"
|
||||||
msgstr "Роиҷ"
|
msgstr "Роиҷ"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:667
|
#: ../js/ui/appDisplay.js:751
|
||||||
msgid "All"
|
msgid "All"
|
||||||
msgstr "Ҳама"
|
msgstr "Ҳама"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1498
|
#: ../js/ui/appDisplay.js:1558
|
||||||
msgid "New Window"
|
msgid "New Window"
|
||||||
msgstr "Равзанаи нав"
|
msgstr "Равзанаи нав"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1501 ../js/ui/dash.js:285
|
#: ../js/ui/appDisplay.js:1580 ../js/ui/dash.js:285
|
||||||
msgid "Remove from Favorites"
|
msgid "Remove from Favorites"
|
||||||
msgstr "Тоза кардан аз Баргузидаҳо"
|
msgstr "Тоза кардан аз Баргузидаҳо"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:1502
|
#: ../js/ui/appDisplay.js:1586
|
||||||
msgid "Add to Favorites"
|
msgid "Add to Favorites"
|
||||||
msgstr "Илова кардан ба Баргузидаҳо"
|
msgstr "Илова кардан ба Баргузидаҳо"
|
||||||
|
|
||||||
@ -579,8 +578,8 @@ msgstr "Парол:"
|
|||||||
msgid "Type again:"
|
msgid "Type again:"
|
||||||
msgstr "Аз нав ворид кунед:"
|
msgstr "Аз нав ворид кунед:"
|
||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:131
|
#: ../js/ui/components/networkAgent.js:131 ../js/ui/status/network.js:227
|
||||||
#: ../js/ui/status/network.js:293 ../js/ui/status/network.js:727
|
#: ../js/ui/status/network.js:300 ../js/ui/status/network.js:860
|
||||||
msgid "Connect"
|
msgid "Connect"
|
||||||
msgstr "Пайваст шудан"
|
msgstr "Пайваст шудан"
|
||||||
|
|
||||||
@ -614,9 +613,6 @@ msgstr "Шабакаи бесим санҷиши ҳаққониятро тала
|
|||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:312
|
#: ../js/ui/components/networkAgent.js:312
|
||||||
#, 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”."
|
||||||
@ -654,7 +650,6 @@ msgstr "Пароли шабакаи паҳннавори мобилӣ"
|
|||||||
|
|
||||||
#: ../js/ui/components/networkAgent.js:339
|
#: ../js/ui/components/networkAgent.js:339
|
||||||
#, 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” парол лозим аст."
|
||||||
|
|
||||||
@ -703,35 +698,35 @@ msgid "Mute"
|
|||||||
msgstr "Бесадо кардан"
|
msgstr "Бесадо кардан"
|
||||||
|
|
||||||
#. Translators: this is the word "Yesterday" followed by a time string. i.e. "Yesterday, 14:30"*/
|
#. Translators: this is the word "Yesterday" followed by a time string. i.e. "Yesterday, 14:30"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:941
|
#: ../js/ui/components/telepathyClient.js:952
|
||||||
msgid "<b>Yesterday</b>, <b>%H:%M</b>"
|
msgid "<b>Yesterday</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>Дирӯз</b>, <b>%С:%Д</b>"
|
msgstr "<b>Дирӯз</b>, <b>%С:%Д</b>"
|
||||||
|
|
||||||
#. Translators: this is the week day name followed by a time string. i.e. "Monday, 14:30*/
|
#. Translators: this is the week day name followed by a time string. i.e. "Monday, 14:30*/
|
||||||
#: ../js/ui/components/telepathyClient.js:947
|
#: ../js/ui/components/telepathyClient.js:958
|
||||||
msgid "<b>%A</b>, <b>%H:%M</b>"
|
msgid "<b>%A</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>%A</b>, <b>%H:%M</b>"
|
msgstr "<b>%A</b>, <b>%H:%M</b>"
|
||||||
|
|
||||||
#. Translators: this is the month name and day number followed by a time string. i.e. "May 25, 14:30"*/
|
#. Translators: this is the month name and day number followed by a time string. i.e. "May 25, 14:30"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:952
|
#: ../js/ui/components/telepathyClient.js:963
|
||||||
msgid "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
msgid "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
||||||
msgstr "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
msgstr "<b>%B</b> <b>%d</b>, <b>%H:%M</b>"
|
||||||
|
|
||||||
#. Translators: this is the month name, day number, year number followed by a time string. i.e. "May 25 2012, 14:30"*/
|
#. Translators: this is the month name, day number, year number followed by a time string. i.e. "May 25 2012, 14:30"*/
|
||||||
#: ../js/ui/components/telepathyClient.js:956
|
#: ../js/ui/components/telepathyClient.js:967
|
||||||
msgid "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
msgid "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
||||||
msgstr "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
msgstr "<b>%B</b> <b>%d</b> <b>%Y</b>, <b>%H:%M</b> "
|
||||||
|
|
||||||
#. 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:987
|
#: ../js/ui/components/telepathyClient.js:998
|
||||||
#, 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:1090
|
#: ../js/ui/components/telepathyClient.js:1101
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "Invitation to %s"
|
msgid "Invitation to %s"
|
||||||
msgstr "Даъватнома барои to %s"
|
msgstr "Даъватнома барои to %s"
|
||||||
@ -739,38 +734,38 @@ msgstr "Даъватнома барои to %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:1098
|
#: ../js/ui/components/telepathyClient.js:1109
|
||||||
#, 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:1100
|
#: ../js/ui/components/telepathyClient.js:1111
|
||||||
#: ../js/ui/components/telepathyClient.js:1135
|
#: ../js/ui/components/telepathyClient.js:1146
|
||||||
#: ../js/ui/components/telepathyClient.js:1169
|
#: ../js/ui/components/telepathyClient.js:1180
|
||||||
#: ../js/ui/components/telepathyClient.js:1226
|
#: ../js/ui/components/telepathyClient.js:1237
|
||||||
msgid "Decline"
|
msgid "Decline"
|
||||||
msgstr "Рад кардан"
|
msgstr "Рад кардан"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1106
|
#: ../js/ui/components/telepathyClient.js:1117
|
||||||
#: ../js/ui/components/telepathyClient.js:1175
|
#: ../js/ui/components/telepathyClient.js:1186
|
||||||
#: ../js/ui/components/telepathyClient.js:1231
|
#: ../js/ui/components/telepathyClient.js:1242
|
||||||
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:1125
|
#: ../js/ui/components/telepathyClient.js:1136
|
||||||
#, 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:1128
|
#: ../js/ui/components/telepathyClient.js:1139
|
||||||
#, 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:1142
|
#: ../js/ui/components/telepathyClient.js:1153
|
||||||
msgid "Answer"
|
msgid "Answer"
|
||||||
msgstr "Ҷавоб"
|
msgstr "Ҷавоб"
|
||||||
|
|
||||||
@ -779,110 +774,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:1163
|
#: ../js/ui/components/telepathyClient.js:1174
|
||||||
#, 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:1192
|
#: ../js/ui/components/telepathyClient.js:1203
|
||||||
#, 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:1277
|
#: ../js/ui/components/telepathyClient.js:1288
|
||||||
msgid "Network error"
|
msgid "Network error"
|
||||||
msgstr "Хатои шабака"
|
msgstr "Хатои шабака"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1279
|
#: ../js/ui/components/telepathyClient.js:1290
|
||||||
msgid "Authentication failed"
|
msgid "Authentication failed"
|
||||||
msgstr "Санҷиши ҳаққоният қатъ шудааст."
|
msgstr "Санҷиши ҳаққоният қатъ шудааст."
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1281
|
#: ../js/ui/components/telepathyClient.js:1292
|
||||||
msgid "Encryption error"
|
msgid "Encryption error"
|
||||||
msgstr "Хатои рамзгузорӣ"
|
msgstr "Хатои рамзгузорӣ"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1283
|
#: ../js/ui/components/telepathyClient.js:1294
|
||||||
msgid "Certificate not provided"
|
msgid "Certificate not provided"
|
||||||
msgstr "Гувоҳинома таъмин нашудааст"
|
msgstr "Гувоҳинома таъмин нашудааст"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1285
|
#: ../js/ui/components/telepathyClient.js:1296
|
||||||
msgid "Certificate untrusted"
|
msgid "Certificate untrusted"
|
||||||
msgstr "Гувоҳиномаи беэътибор"
|
msgstr "Гувоҳиномаи беэътибор"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1287
|
#: ../js/ui/components/telepathyClient.js:1298
|
||||||
msgid "Certificate expired"
|
msgid "Certificate expired"
|
||||||
msgstr "Гувоҳинома аз мӯҳлаташ гузашт"
|
msgstr "Гувоҳинома аз мӯҳлаташ гузашт"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1289
|
#: ../js/ui/components/telepathyClient.js:1300
|
||||||
msgid "Certificate not activated"
|
msgid "Certificate not activated"
|
||||||
msgstr "Гувоҳинома фаъол нашудааст"
|
msgstr "Гувоҳинома фаъол нашудааст"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1291
|
#: ../js/ui/components/telepathyClient.js:1302
|
||||||
msgid "Certificate hostname mismatch"
|
msgid "Certificate hostname mismatch"
|
||||||
msgstr "Номувофиқати гувоҳиномаи номи мизоҷон"
|
msgstr "Номувофиқати гувоҳиномаи номи мизоҷон"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1293
|
#: ../js/ui/components/telepathyClient.js:1304
|
||||||
msgid "Certificate fingerprint mismatch"
|
msgid "Certificate fingerprint mismatch"
|
||||||
msgstr "Номувофиқати гувоҳиномаи нақши ангуштон"
|
msgstr "Номувофиқати гувоҳиномаи нақши ангуштон"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1295
|
#: ../js/ui/components/telepathyClient.js:1306
|
||||||
msgid "Certificate self-signed"
|
msgid "Certificate self-signed"
|
||||||
msgstr "Гувоҳиномаи худимзошуда"
|
msgstr "Гувоҳиномаи худимзошуда"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1297
|
#: ../js/ui/components/telepathyClient.js:1308
|
||||||
msgid "Status is set to offline"
|
msgid "Status is set to offline"
|
||||||
msgstr "Вазъият ба \"офлайн\" гузаштааст"
|
msgstr "Вазъият ба \"офлайн\" гузаштааст"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1299
|
#: ../js/ui/components/telepathyClient.js:1310
|
||||||
msgid "Encryption is not available"
|
msgid "Encryption is not available"
|
||||||
msgstr "Рамзгузорӣ дастрас нест"
|
msgstr "Рамзгузорӣ дастрас нест"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1301
|
#: ../js/ui/components/telepathyClient.js:1312
|
||||||
msgid "Certificate is invalid"
|
msgid "Certificate is invalid"
|
||||||
msgstr "Гувоҳинома нодуруст аст"
|
msgstr "Гувоҳинома нодуруст аст"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1303
|
#: ../js/ui/components/telepathyClient.js:1314
|
||||||
msgid "Connection has been refused"
|
msgid "Connection has been refused"
|
||||||
msgstr "Пайваст рад карда шудааст"
|
msgstr "Пайваст рад карда шудааст"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1305
|
#: ../js/ui/components/telepathyClient.js:1316
|
||||||
msgid "Connection can't be established"
|
msgid "Connection can't be established"
|
||||||
msgstr "Пайвастшавӣ имконнопазир аст"
|
msgstr "Пайвастшавӣ имконнопазир аст"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1307
|
#: ../js/ui/components/telepathyClient.js:1318
|
||||||
msgid "Connection has been lost"
|
msgid "Connection has been lost"
|
||||||
msgstr "Пайваст гум шудааст"
|
msgstr "Пайваст гум шудааст"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1309
|
#: ../js/ui/components/telepathyClient.js:1320
|
||||||
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:1311
|
#: ../js/ui/components/telepathyClient.js:1322
|
||||||
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:1313
|
#: ../js/ui/components/telepathyClient.js:1324
|
||||||
msgid "The account already exists on the server"
|
msgid "The account already exists on the server"
|
||||||
msgstr "Ҳисоб дар сервер аллакай мавҷуд аст"
|
msgstr "Ҳисоб дар сервер аллакай мавҷуд аст"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1315
|
#: ../js/ui/components/telepathyClient.js:1326
|
||||||
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:1317
|
#: ../js/ui/components/telepathyClient.js:1328
|
||||||
msgid "Certificate has been revoked"
|
msgid "Certificate has been revoked"
|
||||||
msgstr "Гувоҳинома лағв карда шуд"
|
msgstr "Гувоҳинома лағв карда шуд"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1319
|
#: ../js/ui/components/telepathyClient.js:1330
|
||||||
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:1321
|
#: ../js/ui/components/telepathyClient.js:1332
|
||||||
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"
|
||||||
@ -890,22 +885,22 @@ msgstr ""
|
|||||||
"Дарозии гувоҳиномаи сервер, ё ки чуқурии занҷири гувоҳиномаи сервер, аз "
|
"Дарозии гувоҳиномаи сервер, ё ки чуқурии занҷири гувоҳиномаи сервер, аз "
|
||||||
"маҳдудиятҳое, ки бо китобхонаи рамзгузорӣ таъин шудаанд, дарозтар мебошад"
|
"маҳдудиятҳое, ки бо китобхонаи рамзгузорӣ таъин шудаанд, дарозтар мебошад"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1323
|
#: ../js/ui/components/telepathyClient.js:1334
|
||||||
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:1333
|
#: ../js/ui/components/telepathyClient.js:1344
|
||||||
#, 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:1338
|
#: ../js/ui/components/telepathyClient.js:1349
|
||||||
msgid "View account"
|
msgid "View account"
|
||||||
msgstr "Намоиш додани ҳисоб"
|
msgstr "Намоиш додани ҳисоб"
|
||||||
|
|
||||||
#: ../js/ui/components/telepathyClient.js:1370
|
#: ../js/ui/components/telepathyClient.js:1381
|
||||||
msgid "Unknown reason"
|
msgid "Unknown reason"
|
||||||
msgstr "Сабаби номаълум"
|
msgstr "Сабаби номаълум"
|
||||||
|
|
||||||
@ -1052,7 +1047,6 @@ 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 боргирӣ ва насб мекунед?"
|
||||||
|
|
||||||
@ -1086,7 +1080,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:717 ../js/ui/status/network.js:470
|
#: ../js/ui/lookingGlass.js:717 ../js/ui/status/network.js:523
|
||||||
#: ../src/gvc/gvc-mixer-control.c:1830
|
#: ../src/gvc/gvc-mixer-control.c:1830
|
||||||
msgid "Disabled"
|
msgid "Disabled"
|
||||||
msgstr "Ғайрифаъол"
|
msgstr "Ғайрифаъол"
|
||||||
@ -1111,43 +1105,43 @@ msgstr "Намоиш додани манбаъ"
|
|||||||
msgid "Web Page"
|
msgid "Web Page"
|
||||||
msgstr "Саҳифаи веб"
|
msgstr "Саҳифаи веб"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1309
|
#: ../js/ui/messageTray.js:1312
|
||||||
msgid "Open"
|
msgid "Open"
|
||||||
msgstr "Кушодани файл"
|
msgstr "Кушодани файл"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1316
|
#: ../js/ui/messageTray.js:1319
|
||||||
msgid "Remove"
|
msgid "Remove"
|
||||||
msgstr "Тоза кардан"
|
msgstr "Тоза кардан"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1613
|
#: ../js/ui/messageTray.js:1616
|
||||||
msgid "Notifications"
|
msgid "Notifications"
|
||||||
msgstr "Огоҳиҳо"
|
msgstr "Огоҳиҳо"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1620
|
#: ../js/ui/messageTray.js:1623
|
||||||
msgid "Clear Messages"
|
msgid "Clear Messages"
|
||||||
msgstr "Пок кардани паёмҳо"
|
msgstr "Пок кардани паёмҳо"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1639
|
#: ../js/ui/messageTray.js:1642
|
||||||
msgid "Notification Settings"
|
msgid "Notification Settings"
|
||||||
msgstr "Танзимоти огоҳиҳо"
|
msgstr "Танзимоти огоҳиҳо"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1692
|
#: ../js/ui/messageTray.js:1695
|
||||||
msgid "Tray Menu"
|
msgid "Tray Menu"
|
||||||
msgstr "Менюи қуттӣ"
|
msgstr "Менюи қуттӣ"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1909
|
#: ../js/ui/messageTray.js:1912
|
||||||
msgid "No Messages"
|
msgid "No Messages"
|
||||||
msgstr "Ягон паём нест"
|
msgstr "Ягон паём нест"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1947
|
#: ../js/ui/messageTray.js:1950
|
||||||
msgid "Message Tray"
|
msgid "Message Tray"
|
||||||
msgstr "Қуттии паёмҳо"
|
msgstr "Қуттии паёмҳо"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:2931
|
#: ../js/ui/messageTray.js:2934
|
||||||
msgid "System Information"
|
msgid "System Information"
|
||||||
msgstr "Маълумоти система"
|
msgstr "Маълумоти система"
|
||||||
|
|
||||||
#: ../js/ui/notificationDaemon.js:515 ../src/shell-app.c:397
|
#: ../js/ui/notificationDaemon.js:515 ../src/shell-app.c:399
|
||||||
msgctxt "program"
|
msgctxt "program"
|
||||||
msgid "Unknown"
|
msgid "Unknown"
|
||||||
msgstr "Номаълум"
|
msgstr "Номаълум"
|
||||||
@ -1185,7 +1179,7 @@ msgstr "Баромад"
|
|||||||
msgid "Activities"
|
msgid "Activities"
|
||||||
msgstr "Фаъолиятҳо"
|
msgstr "Фаъолиятҳо"
|
||||||
|
|
||||||
#: ../js/ui/panel.js:903
|
#: ../js/ui/panel.js:905
|
||||||
msgid "Top Bar"
|
msgid "Top Bar"
|
||||||
msgstr "Панели боло"
|
msgstr "Панели боло"
|
||||||
|
|
||||||
@ -1214,19 +1208,19 @@ msgid_plural "%d new notifications"
|
|||||||
msgstr[0] "%d огоҳии нав"
|
msgstr[0] "%d огоҳии нав"
|
||||||
msgstr[1] "%d огоҳии нав"
|
msgstr[1] "%d огоҳии нав"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:472 ../js/ui/status/system.js:342
|
#: ../js/ui/screenShield.js:473 ../js/ui/status/system.js:342
|
||||||
msgid "Lock"
|
msgid "Lock"
|
||||||
msgstr "Қулф кардан"
|
msgstr "Қулф кардан"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:706
|
#: ../js/ui/screenShield.js:707
|
||||||
msgid "GNOME needs to lock the screen"
|
msgid "GNOME needs to lock the screen"
|
||||||
msgstr "GNOME бояд экранро қулф кунад"
|
msgstr "GNOME бояд экранро қулф кунад"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:833 ../js/ui/screenShield.js:1300
|
#: ../js/ui/screenShield.js:834 ../js/ui/screenShield.js:1301
|
||||||
msgid "Unable to lock"
|
msgid "Unable to lock"
|
||||||
msgstr "Қулф карда намешавад"
|
msgstr "Қулф карда намешавад"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:834 ../js/ui/screenShield.js:1301
|
#: ../js/ui/screenShield.js:835 ../js/ui/screenShield.js:1302
|
||||||
msgid "Lock was blocked by an application"
|
msgid "Lock was blocked by an application"
|
||||||
msgstr "Қулф аз тарави барнома баста шудааст"
|
msgstr "Қулф аз тарави барнома баста шудааст"
|
||||||
|
|
||||||
@ -1306,26 +1300,31 @@ msgstr "Контрасти баланд"
|
|||||||
msgid "Large Text"
|
msgid "Large Text"
|
||||||
msgstr "Матни бузург"
|
msgstr "Матни бузург"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:45
|
#: ../js/ui/status/bluetooth.js:48
|
||||||
msgid "Bluetooth"
|
msgid "Bluetooth"
|
||||||
msgstr "Bluetooth"
|
msgstr "Bluetooth"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:47 ../js/ui/status/network.js:131
|
#: ../js/ui/status/bluetooth.js:50 ../js/ui/status/network.js:134
|
||||||
#: ../js/ui/status/network.js:1081 ../js/ui/status/rfkill.js:48
|
#: ../js/ui/status/network.js:1209 ../js/ui/status/rfkill.js:85
|
||||||
|
#: ../js/ui/status/rfkill.js:105
|
||||||
msgid "Turn Off"
|
msgid "Turn Off"
|
||||||
msgstr "Хомӯш кардан"
|
msgstr "Хомӯш кардан"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:50
|
#: ../js/ui/status/bluetooth.js:53
|
||||||
msgid "Bluetooth Settings"
|
msgid "Bluetooth Settings"
|
||||||
msgstr "Танзимоти Bluetooth"
|
msgstr "Танзимоти Bluetooth"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:98
|
#: ../js/ui/status/bluetooth.js:100
|
||||||
#, javascript-format
|
#, javascript-format
|
||||||
msgid "%d Connected Device"
|
msgid "%d Connected Device"
|
||||||
msgid_plural "%d Connected Devices"
|
msgid_plural "%d Connected Devices"
|
||||||
msgstr[0] "%d дастгоҳи пайвастшуда"
|
msgstr[0] "%d дастгоҳи пайвастшуда"
|
||||||
msgstr[1] "%d дастгоҳи пайвастшуда"
|
msgstr[1] "%d дастгоҳи пайвастшуда"
|
||||||
|
|
||||||
|
#: ../js/ui/status/bluetooth.js:102 ../js/ui/status/network.js:1232
|
||||||
|
msgid "Not Connected"
|
||||||
|
msgstr "Пайваст нашудааст"
|
||||||
|
|
||||||
#: ../js/ui/status/brightness.js:44
|
#: ../js/ui/status/brightness.js:44
|
||||||
msgid "Brightness"
|
msgid "Brightness"
|
||||||
msgstr "Дурахшонӣ"
|
msgstr "Дурахшонӣ"
|
||||||
@ -1334,99 +1333,131 @@ msgstr "Дурахшонӣ"
|
|||||||
msgid "Show Keyboard Layout"
|
msgid "Show Keyboard Layout"
|
||||||
msgstr "Намоиш додани тарҳбандии клавиатура"
|
msgstr "Намоиш додани тарҳбандии клавиатура"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:70
|
#: ../js/ui/status/network.js:73
|
||||||
msgid "<unknown>"
|
msgid "<unknown>"
|
||||||
msgstr "<номаълум>"
|
msgstr "<номаълум>"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:220 ../js/ui/status/network.js:377
|
#: ../js/ui/status/network.js:223 ../js/ui/status/network.js:389
|
||||||
#: ../js/ui/status/network.js:1102
|
#: ../js/ui/status/network.js:1230
|
||||||
msgid "Off"
|
msgid "Off"
|
||||||
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:383
|
#: ../js/ui/status/network.js:395
|
||||||
msgid "unmanaged"
|
msgid "unmanaged"
|
||||||
msgstr "идоранашуда"
|
msgstr "идоранашуда"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:385
|
#: ../js/ui/status/network.js:397
|
||||||
msgid "disconnecting..."
|
msgid "disconnecting..."
|
||||||
msgstr "қатъ кардани пайваст..."
|
msgstr "қатъ кардани пайваст..."
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:391 ../js/ui/status/network.js:1156
|
#: ../js/ui/status/network.js:403 ../js/ui/status/network.js:1284
|
||||||
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:394 ../js/ui/status/network.js:1159
|
#: ../js/ui/status/network.js:406 ../js/ui/status/network.js:1287
|
||||||
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:402
|
#: ../js/ui/status/network.js:414
|
||||||
msgid "firmware missing"
|
msgid "firmware missing"
|
||||||
msgstr "нармафзори дарунсохт вуҷуд надорад"
|
msgstr "нармафзори дарунсохт вуҷуд надорад"
|
||||||
|
|
||||||
#. 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:406
|
#: ../js/ui/status/network.js:418
|
||||||
msgid "unavailable"
|
msgid "unavailable"
|
||||||
msgstr "дастнорас"
|
msgstr "дастнорас"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:408 ../js/ui/status/network.js:1161
|
#: ../js/ui/status/network.js:420 ../js/ui/status/network.js:1289
|
||||||
msgid "connection failed"
|
msgid "connection failed"
|
||||||
msgstr "пайваст қатъ шудааст"
|
msgstr "пайваст қатъ шудааст"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:424 ../js/ui/status/network.js:510
|
#: ../js/ui/status/network.js:436
|
||||||
|
msgid "Wired Settings"
|
||||||
|
msgstr "Танзимоти шабакаи симдор"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:477 ../js/ui/status/network.js:563
|
||||||
msgid "Mobile Broadband Settings"
|
msgid "Mobile Broadband Settings"
|
||||||
msgstr "Танзимоти паҳннавори мобилӣ"
|
msgstr "Танзимоти паҳннавори мобилӣ"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:466 ../js/ui/status/network.js:1100
|
#: ../js/ui/status/network.js:519 ../js/ui/status/network.js:1228
|
||||||
msgid "Hardware Disabled"
|
msgid "Hardware Disabled"
|
||||||
msgstr "Сахтафзор ғайрифаъол шудааст"
|
msgstr "Сахтафзор ғайрифаъол шудааст"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:692
|
#: ../js/ui/status/network.js:578
|
||||||
|
msgid "Use as Internet connection"
|
||||||
|
msgstr "Ҳамчун пайвасти Интернет истифода кардан"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:755
|
||||||
|
msgid "Airplane Mode is On"
|
||||||
|
msgstr "Ҳолати ҳавопаймо фаъол аст"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:756
|
||||||
|
msgid "Wi-Fi is disabled when airplane mode is on."
|
||||||
|
msgstr "Ҳангоми фаъол будани ҳолати ҳавопаймо Wi-Fi ғайрифаъол аст."
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:757
|
||||||
|
msgid "Turn Off Airplane Mode"
|
||||||
|
msgstr "Ҳолати ҳавопаймо хомӯш аст"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:766
|
||||||
|
msgid "Wi-Fi is Off"
|
||||||
|
msgstr "Wi-Fi хомӯш аст"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:767
|
||||||
|
msgid "Wi-Fi needs to be turned on in order to connect to a network."
|
||||||
|
msgstr "Барои пайваст шудан ба шабака, Wi-Fi бояд фаъол карда шавад."
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:768
|
||||||
|
msgid "Turn On Wi-Fi"
|
||||||
|
msgstr "Фаъол кардани Wi-Fi"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:793
|
||||||
msgid "Wi-Fi Networks"
|
msgid "Wi-Fi Networks"
|
||||||
msgstr "Шабакаҳои Wi-Fi"
|
msgstr "Шабакаҳои Wi-Fi"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:694
|
#: ../js/ui/status/network.js:795
|
||||||
msgid "Select a network"
|
msgid "Select a network"
|
||||||
msgstr "Интихоб кардани шабака"
|
msgstr "Интихоб кардани шабака"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:718
|
#: ../js/ui/status/network.js:824
|
||||||
msgid "No Networks"
|
msgid "No Networks"
|
||||||
msgstr "Ягон шабака нест"
|
msgstr "Ягон шабака нест"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:987
|
#: ../js/ui/status/network.js:845 ../js/ui/status/rfkill.js:103
|
||||||
|
msgid "Use hardware switch to turn off"
|
||||||
|
msgstr "Истифодаи калиди сахтафзорӣ барои фаъолсозӣ ё хомӯшкунӣ"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:1115
|
||||||
msgid "Select Network"
|
msgid "Select Network"
|
||||||
msgstr "Интихоби шабака"
|
msgstr "Интихоби шабака"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:993
|
#: ../js/ui/status/network.js:1121
|
||||||
msgid "Wi-Fi Settings"
|
msgid "Wi-Fi Settings"
|
||||||
msgstr "Танзимоти Wi-Fi"
|
msgstr "Танзимоти Wi-Fi"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1081
|
#: ../js/ui/status/network.js:1209
|
||||||
msgid "Turn On"
|
msgid "Turn On"
|
||||||
msgstr "Фаъол кардан"
|
msgstr "Фаъол кардан"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1104
|
#: ../js/ui/status/network.js:1352
|
||||||
msgid "Not Connected"
|
|
||||||
msgstr "Пайваст нашудааст"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1224
|
|
||||||
msgid "VPN"
|
msgid "VPN"
|
||||||
msgstr "VPN"
|
msgstr "VPN"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1364
|
#: ../js/ui/status/network.js:1495
|
||||||
msgid "Network Manager"
|
msgid "Network Manager"
|
||||||
msgstr "Мудири шабака"
|
msgstr "Мудири шабака"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1403
|
#: ../js/ui/status/network.js:1534
|
||||||
msgid "Connection failed"
|
msgid "Connection failed"
|
||||||
msgstr "Пайваст қатъ шудааст"
|
msgstr "Пайваст қатъ шудааст"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1404
|
#: ../js/ui/status/network.js:1535
|
||||||
msgid "Activation of network connection failed"
|
msgid "Activation of network connection failed"
|
||||||
msgstr "Фаъолсозии пайвасти шабака қатъ шудааст."
|
msgstr "Фаъолсозии пайвасти шабака қатъ шудааст."
|
||||||
|
|
||||||
@ -1460,15 +1491,15 @@ msgstr "UPS"
|
|||||||
msgid "Battery"
|
msgid "Battery"
|
||||||
msgstr "Батарея"
|
msgstr "Батарея"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:45
|
#: ../js/ui/status/rfkill.js:82
|
||||||
msgid "Airplane Mode"
|
msgid "Airplane Mode"
|
||||||
msgstr "Ҳолати ҳавопаймо"
|
msgstr "Ҳолати ҳавопаймо"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:47
|
#: ../js/ui/status/rfkill.js:84
|
||||||
msgid "On"
|
msgid "On"
|
||||||
msgstr "Фаъол"
|
msgstr "Фаъол"
|
||||||
|
|
||||||
#: ../js/ui/status/rfkill.js:51
|
#: ../js/ui/status/rfkill.js:88
|
||||||
msgid "Network Settings"
|
msgid "Network Settings"
|
||||||
msgstr "Танзимоти шабака"
|
msgstr "Танзимоти шабака"
|
||||||
|
|
||||||
@ -1522,7 +1553,6 @@ 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” омода аст"
|
||||||
|
|
||||||
@ -1591,9 +1621,8 @@ msgstr ""
|
|||||||
msgid "List possible modes"
|
msgid "List possible modes"
|
||||||
msgstr "Рӯйхати ҳолатҳои имконпазир"
|
msgstr "Рӯйхати ҳолатҳои имконпазир"
|
||||||
|
|
||||||
#: ../src/shell-app.c:640
|
#: ../src/shell-app.c:642
|
||||||
#, c-format
|
#, c-format
|
||||||
#| msgid "Failed to launch '%s'"
|
|
||||||
msgid "Failed to launch “%s”"
|
msgid "Failed to launch “%s”"
|
||||||
msgstr "Оғози “%s” қатъ шудааст"
|
msgstr "Оғози “%s” қатъ шудааст"
|
||||||
|
|
||||||
|
829
po/zh_HK.po
829
po/zh_HK.po
File diff suppressed because it is too large
Load Diff
833
po/zh_TW.po
833
po/zh_TW.po
File diff suppressed because it is too large
Load Diff
@ -23,7 +23,7 @@ gnome_shell_calendar_server_CFLAGS = \
|
|||||||
$(CALENDAR_SERVER_CFLAGS) \
|
$(CALENDAR_SERVER_CFLAGS) \
|
||||||
$(NULL)
|
$(NULL)
|
||||||
|
|
||||||
gnome_shell_calendar_server_LDFLAGS = \
|
gnome_shell_calendar_server_LDADD = \
|
||||||
$(CALENDAR_SERVER_LIBS) \
|
$(CALENDAR_SERVER_LIBS) \
|
||||||
$(NULL)
|
$(NULL)
|
||||||
|
|
||||||
|
@ -98,7 +98,6 @@ shell_public_headers_h = \
|
|||||||
shell-invert-lightness-effect.h \
|
shell-invert-lightness-effect.h \
|
||||||
shell-keybinding-modes.h \
|
shell-keybinding-modes.h \
|
||||||
shell-mount-operation.h \
|
shell-mount-operation.h \
|
||||||
shell-network-agent.h \
|
|
||||||
shell-perf-log.h \
|
shell-perf-log.h \
|
||||||
shell-screenshot.h \
|
shell-screenshot.h \
|
||||||
shell-slicer.h \
|
shell-slicer.h \
|
||||||
@ -110,6 +109,10 @@ shell_public_headers_h = \
|
|||||||
shell-window-tracker.h \
|
shell-window-tracker.h \
|
||||||
shell-wm.h
|
shell-wm.h
|
||||||
|
|
||||||
|
if HAVE_NETWORKMANAGER
|
||||||
|
shell_public_headers_h += shell-network-agent.h
|
||||||
|
endif
|
||||||
|
|
||||||
libgnome_shell_menu_la_SOURCES = \
|
libgnome_shell_menu_la_SOURCES = \
|
||||||
gtkactionmuxer.h \
|
gtkactionmuxer.h \
|
||||||
gtkactionmuxer.c \
|
gtkactionmuxer.c \
|
||||||
@ -136,7 +139,6 @@ libgnome_shell_base_la_SOURCES = \
|
|||||||
shell-menu-tracker.c \
|
shell-menu-tracker.c \
|
||||||
shell-menu-tracker.h \
|
shell-menu-tracker.h \
|
||||||
shell-mount-operation.c \
|
shell-mount-operation.c \
|
||||||
shell-network-agent.c \
|
|
||||||
shell-perf-log.c \
|
shell-perf-log.c \
|
||||||
shell-polkit-authentication-agent.h \
|
shell-polkit-authentication-agent.h \
|
||||||
shell-polkit-authentication-agent.c \
|
shell-polkit-authentication-agent.c \
|
||||||
@ -147,6 +149,10 @@ libgnome_shell_base_la_SOURCES = \
|
|||||||
shell-tp-client.c \
|
shell-tp-client.c \
|
||||||
$(NULL)
|
$(NULL)
|
||||||
|
|
||||||
|
if HAVE_NETWORKMANAGER
|
||||||
|
libgnome_shell_base_la_SOURCES += shell-network-agent.c
|
||||||
|
endif
|
||||||
|
|
||||||
libgnome_shell_sources = \
|
libgnome_shell_sources = \
|
||||||
$(shell_public_headers_h) \
|
$(shell_public_headers_h) \
|
||||||
shell-app-private.h \
|
shell-app-private.h \
|
||||||
@ -343,7 +349,10 @@ INTROSPECTION_GIRS += ShellMenu-0.1.gir
|
|||||||
CLEANFILES += ShellMenu-0.1.gir
|
CLEANFILES += ShellMenu-0.1.gir
|
||||||
|
|
||||||
Shell-0.1.gir: gnome-shell St-1.0.gir ShellMenu-0.1.gir
|
Shell-0.1.gir: gnome-shell St-1.0.gir ShellMenu-0.1.gir
|
||||||
Shell_0_1_gir_INCLUDES = Clutter-1.0 ClutterX11-1.0 Meta-3.0 TelepathyGLib-0.12 Soup-2.4 GMenu-3.0 NetworkManager-1.0 NMClient-1.0
|
Shell_0_1_gir_INCLUDES = Clutter-1.0 ClutterX11-1.0 Meta-3.0 TelepathyGLib-0.12 Soup-2.4 GMenu-3.0
|
||||||
|
if HAVE_NETWORKMANAGER
|
||||||
|
Shell_0_1_gir_INCLUDES += NetworkManager-1.0 NMClient-1.0
|
||||||
|
endif
|
||||||
Shell_0_1_gir_CFLAGS = $(libgnome_shell_la_CPPFLAGS) -I $(srcdir)
|
Shell_0_1_gir_CFLAGS = $(libgnome_shell_la_CPPFLAGS) -I $(srcdir)
|
||||||
# Hack! we use PROGRAM instead of LIBS so that the soname is not included
|
# Hack! we use PROGRAM instead of LIBS so that the soname is not included
|
||||||
# in the typelib. This way the symbols will be resolved with the libgnome-shell
|
# in the typelib. This way the symbols will be resolved with the libgnome-shell
|
||||||
|
@ -68,6 +68,12 @@ static void gnome_shell_plugin_kill_window_effects (MetaPlugin *plugin,
|
|||||||
MetaWindowActor *actor);
|
MetaWindowActor *actor);
|
||||||
static void gnome_shell_plugin_kill_switch_workspace (MetaPlugin *plugin);
|
static void gnome_shell_plugin_kill_switch_workspace (MetaPlugin *plugin);
|
||||||
|
|
||||||
|
static void gnome_shell_plugin_show_tile_preview (MetaPlugin *plugin,
|
||||||
|
MetaWindow *window,
|
||||||
|
MetaRectangle *tile_rect,
|
||||||
|
int tile_monitor);
|
||||||
|
static void gnome_shell_plugin_hide_tile_preview (MetaPlugin *plugin);
|
||||||
|
|
||||||
|
|
||||||
static gboolean gnome_shell_plugin_xevent_filter (MetaPlugin *plugin,
|
static gboolean gnome_shell_plugin_xevent_filter (MetaPlugin *plugin,
|
||||||
XEvent *event);
|
XEvent *event);
|
||||||
@ -132,6 +138,9 @@ gnome_shell_plugin_class_init (GnomeShellPluginClass *klass)
|
|||||||
plugin_class->kill_window_effects = gnome_shell_plugin_kill_window_effects;
|
plugin_class->kill_window_effects = gnome_shell_plugin_kill_window_effects;
|
||||||
plugin_class->kill_switch_workspace = gnome_shell_plugin_kill_switch_workspace;
|
plugin_class->kill_switch_workspace = gnome_shell_plugin_kill_switch_workspace;
|
||||||
|
|
||||||
|
plugin_class->show_tile_preview = gnome_shell_plugin_show_tile_preview;
|
||||||
|
plugin_class->hide_tile_preview = gnome_shell_plugin_hide_tile_preview;
|
||||||
|
|
||||||
plugin_class->xevent_filter = gnome_shell_plugin_xevent_filter;
|
plugin_class->xevent_filter = gnome_shell_plugin_xevent_filter;
|
||||||
plugin_class->keybinding_filter = gnome_shell_plugin_keybinding_filter;
|
plugin_class->keybinding_filter = gnome_shell_plugin_keybinding_filter;
|
||||||
|
|
||||||
@ -319,6 +328,21 @@ gnome_shell_plugin_kill_switch_workspace (MetaPlugin *plugin)
|
|||||||
_shell_wm_kill_switch_workspace (get_shell_wm());
|
_shell_wm_kill_switch_workspace (get_shell_wm());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gnome_shell_plugin_show_tile_preview (MetaPlugin *plugin,
|
||||||
|
MetaWindow *window,
|
||||||
|
MetaRectangle *tile_rect,
|
||||||
|
int tile_monitor)
|
||||||
|
{
|
||||||
|
_shell_wm_show_tile_preview (get_shell_wm (), window, tile_rect, tile_monitor);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gnome_shell_plugin_hide_tile_preview (MetaPlugin *plugin)
|
||||||
|
{
|
||||||
|
_shell_wm_hide_tile_preview (get_shell_wm ());
|
||||||
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
gnome_shell_plugin_xevent_filter (MetaPlugin *plugin,
|
gnome_shell_plugin_xevent_filter (MetaPlugin *plugin,
|
||||||
XEvent *xev)
|
XEvent *xev)
|
||||||
|
@ -271,7 +271,9 @@ default_log_handler (const char *log_domain,
|
|||||||
|
|
||||||
g_get_current_time (&now);
|
g_get_current_time (&now);
|
||||||
|
|
||||||
tp_debug_sender_add_message (sender, &now, log_domain, log_level, message);
|
/* Send telepathy debug through DBus */
|
||||||
|
if (log_domain != NULL && g_str_has_prefix (log_domain, "tp-glib"))
|
||||||
|
tp_debug_sender_add_message (sender, &now, log_domain, log_level, message);
|
||||||
|
|
||||||
/* Filter out telepathy-glib logs, we don't want to flood Shell's output
|
/* Filter out telepathy-glib logs, we don't want to flood Shell's output
|
||||||
* with those. */
|
* with those. */
|
||||||
|
@ -160,6 +160,15 @@ window_backed_app_get_icon (ShellApp *app,
|
|||||||
{
|
{
|
||||||
MetaWindow *window;
|
MetaWindow *window;
|
||||||
ClutterActor *actor;
|
ClutterActor *actor;
|
||||||
|
gint scale;
|
||||||
|
ShellGlobal *global;
|
||||||
|
StThemeContext *context;
|
||||||
|
|
||||||
|
global = shell_global_get ();
|
||||||
|
context = st_theme_context_get_for_stage (shell_global_get_stage (global));
|
||||||
|
g_object_get (context, "scale-factor", &scale, NULL);
|
||||||
|
|
||||||
|
size *= scale;
|
||||||
|
|
||||||
/* During a state transition from running to not-running for
|
/* During a state transition from running to not-running for
|
||||||
* window-backend apps, it's possible we get a request for the icon.
|
* window-backend apps, it's possible we get a request for the icon.
|
||||||
@ -193,8 +202,14 @@ shell_app_create_icon_texture (ShellApp *app,
|
|||||||
int size)
|
int size)
|
||||||
{
|
{
|
||||||
GIcon *icon;
|
GIcon *icon;
|
||||||
|
gint scale;
|
||||||
ClutterActor *ret;
|
ClutterActor *ret;
|
||||||
|
ShellGlobal *global;
|
||||||
|
StThemeContext *context;
|
||||||
|
|
||||||
|
global = shell_global_get ();
|
||||||
|
context = st_theme_context_get_for_stage (shell_global_get_stage (global));
|
||||||
|
g_object_get (context, "scale-factor", &scale, NULL);
|
||||||
ret = NULL;
|
ret = NULL;
|
||||||
|
|
||||||
if (app->info == NULL)
|
if (app->info == NULL)
|
||||||
@ -202,12 +217,12 @@ shell_app_create_icon_texture (ShellApp *app,
|
|||||||
|
|
||||||
icon = g_app_info_get_icon (G_APP_INFO (app->info));
|
icon = g_app_info_get_icon (G_APP_INFO (app->info));
|
||||||
if (icon != NULL)
|
if (icon != NULL)
|
||||||
ret = st_texture_cache_load_gicon (st_texture_cache_get_default (), NULL, icon, size);
|
ret = st_texture_cache_load_gicon (st_texture_cache_get_default (), NULL, icon, size, scale);
|
||||||
|
|
||||||
if (ret == NULL)
|
if (ret == NULL)
|
||||||
{
|
{
|
||||||
icon = g_themed_icon_new ("application-x-executable");
|
icon = g_themed_icon_new ("application-x-executable");
|
||||||
ret = st_texture_cache_load_gicon (st_texture_cache_get_default (), NULL, icon, size);
|
ret = st_texture_cache_load_gicon (st_texture_cache_get_default (), NULL, icon, size, scale);
|
||||||
g_object_unref (icon);
|
g_object_unref (icon);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -217,6 +232,7 @@ shell_app_create_icon_texture (ShellApp *app,
|
|||||||
typedef struct {
|
typedef struct {
|
||||||
ShellApp *app;
|
ShellApp *app;
|
||||||
int size;
|
int size;
|
||||||
|
int scale;
|
||||||
ClutterTextDirection direction;
|
ClutterTextDirection direction;
|
||||||
} CreateFadedIconData;
|
} CreateFadedIconData;
|
||||||
|
|
||||||
@ -230,6 +246,7 @@ shell_app_create_faded_icon_cpu (StTextureCache *cache,
|
|||||||
ShellApp *app;
|
ShellApp *app;
|
||||||
GdkPixbuf *pixbuf;
|
GdkPixbuf *pixbuf;
|
||||||
int size;
|
int size;
|
||||||
|
int scale;
|
||||||
CoglHandle texture;
|
CoglHandle texture;
|
||||||
gint width, height, rowstride;
|
gint width, height, rowstride;
|
||||||
guint8 n_channels;
|
guint8 n_channels;
|
||||||
@ -245,23 +262,24 @@ shell_app_create_faded_icon_cpu (StTextureCache *cache,
|
|||||||
|
|
||||||
app = data->app;
|
app = data->app;
|
||||||
size = data->size;
|
size = data->size;
|
||||||
|
scale = data->scale;
|
||||||
|
|
||||||
info = NULL;
|
info = NULL;
|
||||||
|
|
||||||
icon = g_app_info_get_icon (G_APP_INFO (app->info));
|
icon = g_app_info_get_icon (G_APP_INFO (app->info));
|
||||||
if (icon != NULL)
|
if (icon != NULL)
|
||||||
{
|
{
|
||||||
info = gtk_icon_theme_lookup_by_gicon (gtk_icon_theme_get_default (),
|
info = gtk_icon_theme_lookup_by_gicon_for_scale (gtk_icon_theme_get_default (),
|
||||||
icon, size,
|
icon, size, scale,
|
||||||
GTK_ICON_LOOKUP_FORCE_SIZE);
|
GTK_ICON_LOOKUP_FORCE_SIZE);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (info == NULL)
|
if (info == NULL)
|
||||||
{
|
{
|
||||||
icon = g_themed_icon_new ("application-x-executable");
|
icon = g_themed_icon_new ("application-x-executable");
|
||||||
info = gtk_icon_theme_lookup_by_gicon (gtk_icon_theme_get_default (),
|
info = gtk_icon_theme_lookup_by_gicon_for_scale (gtk_icon_theme_get_default (),
|
||||||
icon, size,
|
icon, size, scale,
|
||||||
GTK_ICON_LOOKUP_FORCE_SIZE);
|
GTK_ICON_LOOKUP_FORCE_SIZE);
|
||||||
g_object_unref (icon);
|
g_object_unref (icon);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -345,6 +363,9 @@ shell_app_get_faded_icon (ShellApp *app, int size, ClutterTextDirection directio
|
|||||||
ClutterActor *result;
|
ClutterActor *result;
|
||||||
char *cache_key;
|
char *cache_key;
|
||||||
CreateFadedIconData data;
|
CreateFadedIconData data;
|
||||||
|
gint scale;
|
||||||
|
ShellGlobal *global;
|
||||||
|
StThemeContext *context;
|
||||||
|
|
||||||
/* Don't fade for window backed apps for now...easier to reuse the
|
/* Don't fade for window backed apps for now...easier to reuse the
|
||||||
* property tracking bits, and this helps us visually distinguish
|
* property tracking bits, and this helps us visually distinguish
|
||||||
@ -353,14 +374,19 @@ shell_app_get_faded_icon (ShellApp *app, int size, ClutterTextDirection directio
|
|||||||
if (!app->info)
|
if (!app->info)
|
||||||
return window_backed_app_get_icon (app, size);
|
return window_backed_app_get_icon (app, size);
|
||||||
|
|
||||||
|
global = shell_global_get ();
|
||||||
|
context = st_theme_context_get_for_stage (shell_global_get_stage (global));
|
||||||
|
g_object_get (context, "scale-factor", &scale, NULL);
|
||||||
|
|
||||||
/* Use icon: prefix so that we get evicted from the cache on
|
/* Use icon: prefix so that we get evicted from the cache on
|
||||||
* icon theme changes. */
|
* icon theme changes. */
|
||||||
cache_key = g_strdup_printf ("icon:%s,size=%d,faded-%s",
|
cache_key = g_strdup_printf ("icon:%s,size=%d,scale=%d,faded-%s",
|
||||||
shell_app_get_id (app),
|
shell_app_get_id (app),
|
||||||
size,
|
size, scale,
|
||||||
direction == CLUTTER_TEXT_DIRECTION_RTL ? "rtl" : "ltr");
|
direction == CLUTTER_TEXT_DIRECTION_RTL ? "rtl" : "ltr");
|
||||||
data.app = app;
|
data.app = app;
|
||||||
data.size = size;
|
data.size = size;
|
||||||
|
data.scale = scale;
|
||||||
data.direction = direction;
|
data.direction = direction;
|
||||||
texture = st_texture_cache_load (st_texture_cache_get_default (),
|
texture = st_texture_cache_load (st_texture_cache_get_default (),
|
||||||
cache_key,
|
cache_key,
|
||||||
@ -378,7 +404,7 @@ shell_app_get_faded_icon (ShellApp *app, int size, ClutterTextDirection directio
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
result = clutter_texture_new ();
|
result = clutter_texture_new ();
|
||||||
g_object_set (result, "opacity", 0, "width", (float) size, "height", (float) size, NULL);
|
g_object_set (result, "opacity", 0, "width", (float) size * scale, "height", (float) size * scale, NULL);
|
||||||
|
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
@ -585,9 +611,7 @@ shell_app_update_window_actions (ShellApp *app, MetaWindow *window)
|
|||||||
g_object_set_data_full (G_OBJECT (window), "actions", actions, g_object_unref);
|
g_object_set_data_full (G_OBJECT (window), "actions", actions, g_object_unref);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!app->running_state->muxer)
|
g_assert (app->running_state->muxer);
|
||||||
app->running_state->muxer = gtk_action_muxer_new ();
|
|
||||||
|
|
||||||
gtk_action_muxer_insert (app->running_state->muxer, "win", actions);
|
gtk_action_muxer_insert (app->running_state->muxer, "win", actions);
|
||||||
g_object_notify (G_OBJECT (app), "action-group");
|
g_object_notify (G_OBJECT (app), "action-group");
|
||||||
}
|
}
|
||||||
|
@ -746,6 +746,20 @@ global_stage_after_paint (gpointer data)
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void
|
||||||
|
update_scale_factor (GdkScreen *screen, gpointer data)
|
||||||
|
{
|
||||||
|
ShellGlobal *global = SHELL_GLOBAL (data);
|
||||||
|
ClutterStage *stage = CLUTTER_STAGE (global->stage);
|
||||||
|
StThemeContext *context = st_theme_context_get_for_stage (stage);
|
||||||
|
GValue value = G_VALUE_INIT;
|
||||||
|
|
||||||
|
g_value_init (&value, G_TYPE_INT);
|
||||||
|
gdk_screen_get_setting (global->gdk_screen, "gdk-window-scaling-factor", &value);
|
||||||
|
g_object_set (context, "scale-factor", g_value_get_int (&value), NULL);
|
||||||
|
}
|
||||||
|
|
||||||
/* This is an IBus workaround. The flow of events with IBus is that every time
|
/* This is an IBus workaround. The flow of events with IBus is that every time
|
||||||
* it gets gets a key event, it:
|
* it gets gets a key event, it:
|
||||||
*
|
*
|
||||||
@ -924,9 +938,19 @@ _shell_global_set_plugin (ShellGlobal *global,
|
|||||||
g_signal_connect (global->meta_display, "notify::focus-window",
|
g_signal_connect (global->meta_display, "notify::focus-window",
|
||||||
G_CALLBACK (focus_window_changed), global);
|
G_CALLBACK (focus_window_changed), global);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We connect to GdkScreen's monitors-changed here to avoid
|
||||||
|
* a race condition. GdkScreen's monitors-changed signal is
|
||||||
|
* emitted *after* the xsetting has been updated.
|
||||||
|
*/
|
||||||
|
g_signal_connect (global->gdk_screen, "monitors-changed",
|
||||||
|
G_CALLBACK (update_scale_factor), global);
|
||||||
|
|
||||||
gdk_event_handler_set (gnome_shell_gdk_event_handler, global, NULL);
|
gdk_event_handler_set (gnome_shell_gdk_event_handler, global, NULL);
|
||||||
|
|
||||||
global->focus_manager = st_focus_manager_get_for_stage (global->stage);
|
global->focus_manager = st_focus_manager_get_for_stage (global->stage);
|
||||||
|
|
||||||
|
update_scale_factor (global->gdk_screen, global);
|
||||||
}
|
}
|
||||||
|
|
||||||
GjsContext *
|
GjsContext *
|
||||||
|
@ -424,6 +424,16 @@ update_focus_app (ShellWindowTracker *self)
|
|||||||
ShellApp *new_focus_app;
|
ShellApp *new_focus_app;
|
||||||
|
|
||||||
new_focus_win = meta_display_get_focus_window (shell_global_get_display (shell_global_get ()));
|
new_focus_win = meta_display_get_focus_window (shell_global_get_display (shell_global_get ()));
|
||||||
|
|
||||||
|
/* we only consider an app focused if the focus window can be clearly
|
||||||
|
* associated with a running app; this is the case if the focus window
|
||||||
|
* or one of its parents is visible in the taskbar, e.g.
|
||||||
|
* - 'nautilus' should appear focused when its about dialog has focus
|
||||||
|
* - 'nautilus' should not appear focused when the DESKTOP has focus
|
||||||
|
*/
|
||||||
|
while (new_focus_win && meta_window_is_skip_taskbar (new_focus_win))
|
||||||
|
new_focus_win = meta_window_get_transient_for (new_focus_win);
|
||||||
|
|
||||||
new_focus_app = new_focus_win ? shell_window_tracker_get_window_app (self, new_focus_win) : NULL;
|
new_focus_app = new_focus_win ? shell_window_tracker_get_window_app (self, new_focus_win) : NULL;
|
||||||
|
|
||||||
if (new_focus_app)
|
if (new_focus_app)
|
||||||
@ -848,18 +858,25 @@ shell_startup_sequence_create_icon (ShellStartupSequence *sequence, guint size)
|
|||||||
GIcon *themed;
|
GIcon *themed;
|
||||||
const char *icon_name;
|
const char *icon_name;
|
||||||
ClutterActor *texture;
|
ClutterActor *texture;
|
||||||
|
gint scale;
|
||||||
|
ShellGlobal *global;
|
||||||
|
StThemeContext *context;
|
||||||
|
|
||||||
|
global = shell_global_get ();
|
||||||
|
context = st_theme_context_get_for_stage (shell_global_get_stage (global));
|
||||||
|
g_object_get (context, "scale-factor", &scale, NULL);
|
||||||
|
|
||||||
icon_name = sn_startup_sequence_get_icon_name ((SnStartupSequence*)sequence);
|
icon_name = sn_startup_sequence_get_icon_name ((SnStartupSequence*)sequence);
|
||||||
if (!icon_name)
|
if (!icon_name)
|
||||||
{
|
{
|
||||||
texture = clutter_texture_new ();
|
texture = clutter_texture_new ();
|
||||||
clutter_actor_set_size (texture, size, size);
|
clutter_actor_set_size (texture, size * scale, size * scale);
|
||||||
return texture;
|
return texture;
|
||||||
}
|
}
|
||||||
|
|
||||||
themed = g_themed_icon_new (icon_name);
|
themed = g_themed_icon_new (icon_name);
|
||||||
texture = st_texture_cache_load_gicon (st_texture_cache_get_default (),
|
texture = st_texture_cache_load_gicon (st_texture_cache_get_default (),
|
||||||
NULL, themed, size);
|
NULL, themed, size, scale);
|
||||||
g_object_unref (G_OBJECT (themed));
|
g_object_unref (G_OBJECT (themed));
|
||||||
return texture;
|
return texture;
|
||||||
}
|
}
|
||||||
|
@ -35,6 +35,12 @@ void _shell_wm_kill_window_effects (ShellWM *wm,
|
|||||||
MetaWindowActor *actor);
|
MetaWindowActor *actor);
|
||||||
void _shell_wm_kill_switch_workspace (ShellWM *wm);
|
void _shell_wm_kill_switch_workspace (ShellWM *wm);
|
||||||
|
|
||||||
|
void _shell_wm_show_tile_preview (ShellWM *wm,
|
||||||
|
MetaWindow *window,
|
||||||
|
MetaRectangle *tile_rect,
|
||||||
|
int tile_monitor);
|
||||||
|
void _shell_wm_hide_tile_preview (ShellWM *wm);
|
||||||
|
|
||||||
gboolean _shell_wm_filter_keybinding (ShellWM *wm,
|
gboolean _shell_wm_filter_keybinding (ShellWM *wm,
|
||||||
MetaKeyBinding *binding);
|
MetaKeyBinding *binding);
|
||||||
|
|
||||||
|
@ -26,6 +26,8 @@ enum
|
|||||||
SWITCH_WORKSPACE,
|
SWITCH_WORKSPACE,
|
||||||
KILL_SWITCH_WORKSPACE,
|
KILL_SWITCH_WORKSPACE,
|
||||||
KILL_WINDOW_EFFECTS,
|
KILL_WINDOW_EFFECTS,
|
||||||
|
SHOW_TILE_PREVIEW,
|
||||||
|
HIDE_TILE_PREVIEW,
|
||||||
FILTER_KEYBINDING,
|
FILTER_KEYBINDING,
|
||||||
CONFIRM_DISPLAY_CHANGE,
|
CONFIRM_DISPLAY_CHANGE,
|
||||||
|
|
||||||
@ -117,6 +119,22 @@ shell_wm_class_init (ShellWMClass *klass)
|
|||||||
NULL, NULL, NULL,
|
NULL, NULL, NULL,
|
||||||
G_TYPE_NONE, 1,
|
G_TYPE_NONE, 1,
|
||||||
META_TYPE_WINDOW_ACTOR);
|
META_TYPE_WINDOW_ACTOR);
|
||||||
|
shell_wm_signals[SHOW_TILE_PREVIEW] =
|
||||||
|
g_signal_new ("show-tile-preview",
|
||||||
|
G_TYPE_FROM_CLASS (klass),
|
||||||
|
G_SIGNAL_RUN_LAST,
|
||||||
|
0, NULL, NULL, NULL,
|
||||||
|
G_TYPE_NONE, 3,
|
||||||
|
META_TYPE_WINDOW,
|
||||||
|
META_TYPE_RECTANGLE,
|
||||||
|
G_TYPE_INT);
|
||||||
|
shell_wm_signals[HIDE_TILE_PREVIEW] =
|
||||||
|
g_signal_new ("hide-tile-preview",
|
||||||
|
G_TYPE_FROM_CLASS (klass),
|
||||||
|
G_SIGNAL_RUN_LAST,
|
||||||
|
0,
|
||||||
|
NULL, NULL, NULL,
|
||||||
|
G_TYPE_NONE, 0);
|
||||||
shell_wm_signals[FILTER_KEYBINDING] =
|
shell_wm_signals[FILTER_KEYBINDING] =
|
||||||
g_signal_new ("filter-keybinding",
|
g_signal_new ("filter-keybinding",
|
||||||
G_TYPE_FROM_CLASS (klass),
|
G_TYPE_FROM_CLASS (klass),
|
||||||
@ -254,6 +272,22 @@ _shell_wm_kill_window_effects (ShellWM *wm,
|
|||||||
g_signal_emit (wm, shell_wm_signals[KILL_WINDOW_EFFECTS], 0, actor);
|
g_signal_emit (wm, shell_wm_signals[KILL_WINDOW_EFFECTS], 0, actor);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
_shell_wm_show_tile_preview (ShellWM *wm,
|
||||||
|
MetaWindow *window,
|
||||||
|
MetaRectangle *tile_rect,
|
||||||
|
int tile_monitor)
|
||||||
|
{
|
||||||
|
g_signal_emit (wm, shell_wm_signals[SHOW_TILE_PREVIEW], 0,
|
||||||
|
window, tile_rect, tile_monitor);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
_shell_wm_hide_tile_preview (ShellWM *wm)
|
||||||
|
{
|
||||||
|
g_signal_emit (wm, shell_wm_signals[HIDE_TILE_PREVIEW], 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
_shell_wm_minimize (ShellWM *wm,
|
_shell_wm_minimize (ShellWM *wm,
|
||||||
|
106
src/st/st-icon.c
106
src/st/st-icon.c
@ -29,6 +29,7 @@
|
|||||||
#include "st-enum-types.h"
|
#include "st-enum-types.h"
|
||||||
#include "st-icon.h"
|
#include "st-icon.h"
|
||||||
#include "st-texture-cache.h"
|
#include "st-texture-cache.h"
|
||||||
|
#include "st-theme-context.h"
|
||||||
#include "st-private.h"
|
#include "st-private.h"
|
||||||
|
|
||||||
enum
|
enum
|
||||||
@ -162,76 +163,6 @@ st_icon_dispose (GObject *gobject)
|
|||||||
G_OBJECT_CLASS (st_icon_parent_class)->dispose (gobject);
|
G_OBJECT_CLASS (st_icon_parent_class)->dispose (gobject);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
st_icon_get_preferred_height (ClutterActor *actor,
|
|
||||||
gfloat for_width,
|
|
||||||
gfloat *min_height_p,
|
|
||||||
gfloat *nat_height_p)
|
|
||||||
{
|
|
||||||
StIconPrivate *priv = ST_ICON (actor)->priv;
|
|
||||||
StThemeNode *theme_node = st_widget_get_theme_node (ST_WIDGET (actor));
|
|
||||||
|
|
||||||
if (min_height_p)
|
|
||||||
*min_height_p = priv->icon_size;
|
|
||||||
|
|
||||||
if (nat_height_p)
|
|
||||||
*nat_height_p = priv->icon_size;
|
|
||||||
|
|
||||||
st_theme_node_adjust_preferred_height (theme_node, min_height_p, nat_height_p);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
st_icon_get_preferred_width (ClutterActor *actor,
|
|
||||||
gfloat for_height,
|
|
||||||
gfloat *min_width_p,
|
|
||||||
gfloat *nat_width_p)
|
|
||||||
{
|
|
||||||
StIconPrivate *priv = ST_ICON (actor)->priv;
|
|
||||||
StThemeNode *theme_node = st_widget_get_theme_node (ST_WIDGET (actor));
|
|
||||||
|
|
||||||
if (min_width_p)
|
|
||||||
*min_width_p = priv->icon_size;
|
|
||||||
|
|
||||||
if (nat_width_p)
|
|
||||||
*nat_width_p = priv->icon_size;
|
|
||||||
|
|
||||||
st_theme_node_adjust_preferred_width (theme_node, min_width_p, nat_width_p);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
st_icon_allocate (ClutterActor *actor,
|
|
||||||
const ClutterActorBox *box,
|
|
||||||
ClutterAllocationFlags flags)
|
|
||||||
{
|
|
||||||
StIconPrivate *priv = ST_ICON (actor)->priv;
|
|
||||||
StThemeNode *theme_node = st_widget_get_theme_node (ST_WIDGET (actor));
|
|
||||||
|
|
||||||
clutter_actor_set_allocation (actor, box, flags);
|
|
||||||
|
|
||||||
if (priv->icon_texture)
|
|
||||||
{
|
|
||||||
ClutterActorBox content_box;
|
|
||||||
|
|
||||||
st_theme_node_get_content_box (theme_node, box, &content_box);
|
|
||||||
|
|
||||||
/* Center the texture in the allocation; scaling up the icon from the size
|
|
||||||
* we loaded it at is just a bad idea and probably accidental. Main downside
|
|
||||||
* of doing this is that it may not be obvious that they have to turn off
|
|
||||||
* fill to align the icon non-centered in the parent container.
|
|
||||||
*
|
|
||||||
* We don't use clutter_actor_allocate_align_fill() for a bit of efficiency
|
|
||||||
* and because we expect to get rid of the child actor in favor of a
|
|
||||||
* CoglTexture in the future.
|
|
||||||
*/
|
|
||||||
content_box.x1 = (int)(0.5 + content_box.x1 + (content_box.x2 - content_box.x1 - priv->icon_size) / 2.);
|
|
||||||
content_box.x2 = content_box.x1 + priv->icon_size;
|
|
||||||
content_box.y1 = (int)(0.5 + content_box.y1 + (content_box.y2 - content_box.y1 - priv->icon_size) / 2.);
|
|
||||||
content_box.y2 = content_box.y1 + priv->icon_size;
|
|
||||||
|
|
||||||
clutter_actor_allocate (priv->icon_texture, &content_box, flags);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
st_icon_paint (ClutterActor *actor)
|
st_icon_paint (ClutterActor *actor)
|
||||||
{
|
{
|
||||||
@ -307,9 +238,6 @@ st_icon_class_init (StIconClass *klass)
|
|||||||
object_class->set_property = st_icon_set_property;
|
object_class->set_property = st_icon_set_property;
|
||||||
object_class->dispose = st_icon_dispose;
|
object_class->dispose = st_icon_dispose;
|
||||||
|
|
||||||
actor_class->get_preferred_height = st_icon_get_preferred_height;
|
|
||||||
actor_class->get_preferred_width = st_icon_get_preferred_width;
|
|
||||||
actor_class->allocate = st_icon_allocate;
|
|
||||||
actor_class->paint = st_icon_paint;
|
actor_class->paint = st_icon_paint;
|
||||||
|
|
||||||
widget_class->style_changed = st_icon_style_changed;
|
widget_class->style_changed = st_icon_style_changed;
|
||||||
@ -338,8 +266,14 @@ st_icon_class_init (StIconClass *klass)
|
|||||||
static void
|
static void
|
||||||
st_icon_init (StIcon *self)
|
st_icon_init (StIcon *self)
|
||||||
{
|
{
|
||||||
|
ClutterLayoutManager *layout_manager;
|
||||||
|
|
||||||
self->priv = ST_ICON_GET_PRIVATE (self);
|
self->priv = ST_ICON_GET_PRIVATE (self);
|
||||||
|
|
||||||
|
layout_manager = clutter_bin_layout_new (CLUTTER_BIN_ALIGNMENT_FILL,
|
||||||
|
CLUTTER_BIN_ALIGNMENT_FILL);
|
||||||
|
clutter_actor_set_layout_manager (CLUTTER_ACTOR (self), layout_manager);
|
||||||
|
|
||||||
self->priv->icon_size = DEFAULT_ICON_SIZE;
|
self->priv->icon_size = DEFAULT_ICON_SIZE;
|
||||||
self->priv->prop_icon_size = -1;
|
self->priv->prop_icon_size = -1;
|
||||||
|
|
||||||
@ -397,6 +331,8 @@ st_icon_finish_update (StIcon *icon)
|
|||||||
{
|
{
|
||||||
priv->icon_texture = priv->pending_texture;
|
priv->icon_texture = priv->pending_texture;
|
||||||
priv->pending_texture = NULL;
|
priv->pending_texture = NULL;
|
||||||
|
clutter_actor_set_x_align (priv->icon_texture, CLUTTER_ACTOR_ALIGN_CENTER);
|
||||||
|
clutter_actor_set_y_align (priv->icon_texture, CLUTTER_ACTOR_ALIGN_CENTER);
|
||||||
clutter_actor_add_child (CLUTTER_ACTOR (icon), priv->icon_texture);
|
clutter_actor_add_child (CLUTTER_ACTOR (icon), priv->icon_texture);
|
||||||
|
|
||||||
/* Remove the temporary ref we added */
|
/* Remove the temporary ref we added */
|
||||||
@ -430,6 +366,9 @@ st_icon_update (StIcon *icon)
|
|||||||
StIconPrivate *priv = icon->priv;
|
StIconPrivate *priv = icon->priv;
|
||||||
StThemeNode *theme_node;
|
StThemeNode *theme_node;
|
||||||
StTextureCache *cache;
|
StTextureCache *cache;
|
||||||
|
gint scale;
|
||||||
|
ClutterActor *stage;
|
||||||
|
StThemeContext *context;
|
||||||
|
|
||||||
if (priv->pending_texture)
|
if (priv->pending_texture)
|
||||||
{
|
{
|
||||||
@ -443,13 +382,18 @@ st_icon_update (StIcon *icon)
|
|||||||
if (theme_node == NULL)
|
if (theme_node == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
stage = clutter_actor_get_stage (CLUTTER_ACTOR (icon));
|
||||||
|
context = st_theme_context_get_for_stage (CLUTTER_STAGE (stage));
|
||||||
|
g_object_get (context, "scale-factor", &scale, NULL);
|
||||||
|
|
||||||
cache = st_texture_cache_get_default ();
|
cache = st_texture_cache_get_default ();
|
||||||
if (priv->gicon)
|
if (priv->gicon)
|
||||||
{
|
{
|
||||||
priv->pending_texture = st_texture_cache_load_gicon (cache,
|
priv->pending_texture = st_texture_cache_load_gicon (cache,
|
||||||
theme_node,
|
theme_node,
|
||||||
priv->gicon,
|
priv->gicon,
|
||||||
priv->icon_size);
|
priv->icon_size,
|
||||||
|
scale);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (priv->pending_texture)
|
if (priv->pending_texture)
|
||||||
@ -483,7 +427,19 @@ st_icon_update_icon_size (StIcon *icon)
|
|||||||
if (priv->prop_icon_size > 0)
|
if (priv->prop_icon_size > 0)
|
||||||
new_size = priv->prop_icon_size;
|
new_size = priv->prop_icon_size;
|
||||||
else if (priv->theme_icon_size > 0)
|
else if (priv->theme_icon_size > 0)
|
||||||
new_size = priv->theme_icon_size;
|
{
|
||||||
|
gint scale;
|
||||||
|
ClutterActor *stage;
|
||||||
|
StThemeContext *context;
|
||||||
|
|
||||||
|
/* The theme will give us an already-scaled size, so we
|
||||||
|
* undo it here, as priv->icon_size is in unscaled pixels.
|
||||||
|
*/
|
||||||
|
stage = clutter_actor_get_stage (CLUTTER_ACTOR (icon));
|
||||||
|
context = st_theme_context_get_for_stage (CLUTTER_STAGE (stage));
|
||||||
|
g_object_get (context, "scale-factor", &scale, NULL);
|
||||||
|
new_size = (gint) (priv->theme_icon_size / scale);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
new_size = DEFAULT_ICON_SIZE;
|
new_size = DEFAULT_ICON_SIZE;
|
||||||
|
|
||||||
|
@ -909,6 +909,7 @@ static ClutterActor *
|
|||||||
load_gicon_with_colors (StTextureCache *cache,
|
load_gicon_with_colors (StTextureCache *cache,
|
||||||
GIcon *icon,
|
GIcon *icon,
|
||||||
gint size,
|
gint size,
|
||||||
|
gint scale,
|
||||||
StIconColors *colors)
|
StIconColors *colors)
|
||||||
{
|
{
|
||||||
AsyncTextureLoadData *request;
|
AsyncTextureLoadData *request;
|
||||||
@ -922,7 +923,7 @@ load_gicon_with_colors (StTextureCache *cache,
|
|||||||
/* Do theme lookups in the main thread to avoid thread-unsafety */
|
/* Do theme lookups in the main thread to avoid thread-unsafety */
|
||||||
theme = cache->priv->icon_theme;
|
theme = cache->priv->icon_theme;
|
||||||
|
|
||||||
info = gtk_icon_theme_lookup_by_gicon (theme, icon, size, GTK_ICON_LOOKUP_USE_BUILTIN);
|
info = gtk_icon_theme_lookup_by_gicon_for_scale (theme, icon, size, scale, GTK_ICON_LOOKUP_USE_BUILTIN);
|
||||||
if (info == NULL)
|
if (info == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
@ -936,8 +937,8 @@ load_gicon_with_colors (StTextureCache *cache,
|
|||||||
if (colors)
|
if (colors)
|
||||||
{
|
{
|
||||||
/* This raises some doubts about the practice of using string keys */
|
/* This raises some doubts about the practice of using string keys */
|
||||||
key = g_strdup_printf (CACHE_PREFIX_ICON "%s,size=%d,colors=%2x%2x%2x%2x,%2x%2x%2x%2x,%2x%2x%2x%2x,%2x%2x%2x%2x",
|
key = g_strdup_printf (CACHE_PREFIX_ICON "%s,size=%d,scale=%d,colors=%2x%2x%2x%2x,%2x%2x%2x%2x,%2x%2x%2x%2x,%2x%2x%2x%2x",
|
||||||
gicon_string, size,
|
gicon_string, size, scale,
|
||||||
colors->foreground.red, colors->foreground.blue, colors->foreground.green, colors->foreground.alpha,
|
colors->foreground.red, colors->foreground.blue, colors->foreground.green, colors->foreground.alpha,
|
||||||
colors->warning.red, colors->warning.blue, colors->warning.green, colors->warning.alpha,
|
colors->warning.red, colors->warning.blue, colors->warning.green, colors->warning.alpha,
|
||||||
colors->error.red, colors->error.blue, colors->error.green, colors->error.alpha,
|
colors->error.red, colors->error.blue, colors->error.green, colors->error.alpha,
|
||||||
@ -945,13 +946,13 @@ load_gicon_with_colors (StTextureCache *cache,
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
key = g_strdup_printf (CACHE_PREFIX_ICON "%s,size=%d",
|
key = g_strdup_printf (CACHE_PREFIX_ICON "%s,size=%d,scale=%d",
|
||||||
gicon_string, size);
|
gicon_string, size, scale);
|
||||||
}
|
}
|
||||||
g_free (gicon_string);
|
g_free (gicon_string);
|
||||||
|
|
||||||
texture = (ClutterActor *) create_default_texture ();
|
texture = (ClutterActor *) create_default_texture ();
|
||||||
clutter_actor_set_size (texture, size, size);
|
clutter_actor_set_size (texture, size * scale, size * scale);
|
||||||
|
|
||||||
if (ensure_request (cache, key, policy, &request, texture))
|
if (ensure_request (cache, key, policy, &request, texture))
|
||||||
{
|
{
|
||||||
@ -969,7 +970,7 @@ load_gicon_with_colors (StTextureCache *cache,
|
|||||||
request->policy = policy;
|
request->policy = policy;
|
||||||
request->colors = colors ? st_icon_colors_ref (colors) : NULL;
|
request->colors = colors ? st_icon_colors_ref (colors) : NULL;
|
||||||
request->icon_info = info;
|
request->icon_info = info;
|
||||||
request->width = request->height = size;
|
request->width = request->height = size * scale;
|
||||||
request->enforced_square = TRUE;
|
request->enforced_square = TRUE;
|
||||||
|
|
||||||
load_texture_async (cache, request);
|
load_texture_async (cache, request);
|
||||||
@ -985,6 +986,7 @@ load_gicon_with_colors (StTextureCache *cache,
|
|||||||
* if the icon must not be recolored
|
* if the icon must not be recolored
|
||||||
* @icon: the #GIcon to load
|
* @icon: the #GIcon to load
|
||||||
* @size: Size of themed
|
* @size: Size of themed
|
||||||
|
* @scale: Scale factor of display
|
||||||
*
|
*
|
||||||
* This method returns a new #ClutterActor for a given #GIcon. If the
|
* This method returns a new #ClutterActor for a given #GIcon. If the
|
||||||
* icon isn't loaded already, the texture will be filled
|
* icon isn't loaded already, the texture will be filled
|
||||||
@ -996,9 +998,10 @@ ClutterActor *
|
|||||||
st_texture_cache_load_gicon (StTextureCache *cache,
|
st_texture_cache_load_gicon (StTextureCache *cache,
|
||||||
StThemeNode *theme_node,
|
StThemeNode *theme_node,
|
||||||
GIcon *icon,
|
GIcon *icon,
|
||||||
gint size)
|
gint size,
|
||||||
|
gint scale)
|
||||||
{
|
{
|
||||||
return load_gicon_with_colors (cache, icon, size, theme_node ? st_theme_node_get_icon_colors (theme_node) : NULL);
|
return load_gicon_with_colors (cache, icon, size, scale, theme_node ? st_theme_node_get_icon_colors (theme_node) : NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
static ClutterActor *
|
static ClutterActor *
|
||||||
|
@ -83,7 +83,8 @@ ClutterActor *st_texture_cache_bind_pixbuf_property (StTextureCache *cache,
|
|||||||
ClutterActor *st_texture_cache_load_gicon (StTextureCache *cache,
|
ClutterActor *st_texture_cache_load_gicon (StTextureCache *cache,
|
||||||
StThemeNode *theme_node,
|
StThemeNode *theme_node,
|
||||||
GIcon *icon,
|
GIcon *icon,
|
||||||
gint size);
|
gint size,
|
||||||
|
gint scale);
|
||||||
|
|
||||||
ClutterActor *st_texture_cache_load_uri_async (StTextureCache *cache,
|
ClutterActor *st_texture_cache_load_uri_async (StTextureCache *cache,
|
||||||
const gchar *uri,
|
const gchar *uri,
|
||||||
|
@ -34,6 +34,8 @@ struct _StThemeContext {
|
|||||||
|
|
||||||
/* set of StThemeNode */
|
/* set of StThemeNode */
|
||||||
GHashTable *nodes;
|
GHashTable *nodes;
|
||||||
|
|
||||||
|
int scale_factor;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct _StThemeContextClass {
|
struct _StThemeContextClass {
|
||||||
@ -42,6 +44,12 @@ struct _StThemeContextClass {
|
|||||||
|
|
||||||
#define DEFAULT_FONT "sans-serif 10"
|
#define DEFAULT_FONT "sans-serif 10"
|
||||||
|
|
||||||
|
enum
|
||||||
|
{
|
||||||
|
PROP_0,
|
||||||
|
PROP_SCALE_FACTOR
|
||||||
|
};
|
||||||
|
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
CHANGED,
|
CHANGED,
|
||||||
@ -57,6 +65,15 @@ static void on_icon_theme_changed (StTextureCache *cache,
|
|||||||
StThemeContext *context);
|
StThemeContext *context);
|
||||||
static void st_theme_context_changed (StThemeContext *context);
|
static void st_theme_context_changed (StThemeContext *context);
|
||||||
|
|
||||||
|
static void st_theme_context_set_property (GObject *object,
|
||||||
|
guint prop_id,
|
||||||
|
const GValue *value,
|
||||||
|
GParamSpec *pspec);
|
||||||
|
static void st_theme_context_get_property (GObject *object,
|
||||||
|
guint prop_id,
|
||||||
|
GValue *value,
|
||||||
|
GParamSpec *pspec);
|
||||||
|
|
||||||
static void
|
static void
|
||||||
st_theme_context_finalize (GObject *object)
|
st_theme_context_finalize (GObject *object)
|
||||||
{
|
{
|
||||||
@ -86,8 +103,23 @@ st_theme_context_class_init (StThemeContextClass *klass)
|
|||||||
{
|
{
|
||||||
GObjectClass *object_class = G_OBJECT_CLASS (klass);
|
GObjectClass *object_class = G_OBJECT_CLASS (klass);
|
||||||
|
|
||||||
|
object_class->set_property = st_theme_context_set_property;
|
||||||
|
object_class->get_property = st_theme_context_get_property;
|
||||||
object_class->finalize = st_theme_context_finalize;
|
object_class->finalize = st_theme_context_finalize;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* StThemeContext:scale-factor:
|
||||||
|
*
|
||||||
|
* The scaling factor used or high dpi scaling.
|
||||||
|
*/
|
||||||
|
g_object_class_install_property (object_class,
|
||||||
|
PROP_SCALE_FACTOR,
|
||||||
|
g_param_spec_int ("scale-factor",
|
||||||
|
"Scale factor",
|
||||||
|
"Integer scale factor used for high dpi scaling",
|
||||||
|
0, G_MAXINT, 1,
|
||||||
|
G_PARAM_READABLE | G_PARAM_WRITABLE));
|
||||||
|
|
||||||
signals[CHANGED] =
|
signals[CHANGED] =
|
||||||
g_signal_new ("changed",
|
g_signal_new ("changed",
|
||||||
G_TYPE_FROM_CLASS (klass),
|
G_TYPE_FROM_CLASS (klass),
|
||||||
@ -114,6 +146,53 @@ st_theme_context_init (StThemeContext *context)
|
|||||||
context->nodes = g_hash_table_new_full ((GHashFunc) st_theme_node_hash,
|
context->nodes = g_hash_table_new_full ((GHashFunc) st_theme_node_hash,
|
||||||
(GEqualFunc) st_theme_node_equal,
|
(GEqualFunc) st_theme_node_equal,
|
||||||
g_object_unref, NULL);
|
g_object_unref, NULL);
|
||||||
|
context->scale_factor = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
st_theme_context_set_property (GObject *object,
|
||||||
|
guint prop_id,
|
||||||
|
const GValue *value,
|
||||||
|
GParamSpec *pspec)
|
||||||
|
{
|
||||||
|
StThemeContext *context = ST_THEME_CONTEXT (object);
|
||||||
|
|
||||||
|
switch (prop_id)
|
||||||
|
{
|
||||||
|
case PROP_SCALE_FACTOR:
|
||||||
|
{
|
||||||
|
int scale_factor = g_value_get_int (value);
|
||||||
|
if (scale_factor != context->scale_factor)
|
||||||
|
{
|
||||||
|
context->scale_factor = scale_factor;
|
||||||
|
st_theme_context_changed (context);
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
st_theme_context_get_property (GObject *object,
|
||||||
|
guint prop_id,
|
||||||
|
GValue *value,
|
||||||
|
GParamSpec *pspec)
|
||||||
|
{
|
||||||
|
StThemeContext *context = ST_THEME_CONTEXT (object);
|
||||||
|
|
||||||
|
switch (prop_id)
|
||||||
|
{
|
||||||
|
case PROP_SCALE_FACTOR:
|
||||||
|
g_value_set_int (value, context->scale_factor);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1015,6 +1015,9 @@ get_length_from_term (StThemeNode *node,
|
|||||||
} type = ABSOLUTE;
|
} type = ABSOLUTE;
|
||||||
|
|
||||||
double multiplier = 1.0;
|
double multiplier = 1.0;
|
||||||
|
int scale_factor;
|
||||||
|
|
||||||
|
g_object_get (node->context, "scale-factor", &scale_factor, NULL);
|
||||||
|
|
||||||
if (term->type != TERM_NUMBER)
|
if (term->type != TERM_NUMBER)
|
||||||
{
|
{
|
||||||
@ -1028,7 +1031,7 @@ get_length_from_term (StThemeNode *node,
|
|||||||
{
|
{
|
||||||
case NUM_LENGTH_PX:
|
case NUM_LENGTH_PX:
|
||||||
type = ABSOLUTE;
|
type = ABSOLUTE;
|
||||||
multiplier = 1;
|
multiplier = 1 * scale_factor;
|
||||||
break;
|
break;
|
||||||
case NUM_LENGTH_PT:
|
case NUM_LENGTH_PT:
|
||||||
type = POINTS;
|
type = POINTS;
|
||||||
|
Reference in New Issue
Block a user