Compare commits
59 Commits
wip/reorg
...
wip/waylan
Author | SHA1 | Date | |
---|---|---|---|
30898007f3 | |||
2754a5e3a1 | |||
da1b7f4f83 | |||
206f036cef | |||
e3be2237b8 | |||
d663beab97 | |||
536ff6f561 | |||
013b6aa44a | |||
0e7d3a7558 | |||
8bd4895538 | |||
465c77ddcf | |||
6ef2d4a4cc | |||
7ae7f046c2 | |||
f4051e810e | |||
e6c239d0f3 | |||
35a7a3c1ac | |||
a0991c8261 | |||
9520880568 | |||
719d793e22 | |||
c7fb65c78e | |||
dd74ea99a7 | |||
c6fe6eb7ab | |||
2cbee05c8a | |||
308b1d6039 | |||
4cd832c05a | |||
2af4925d95 | |||
5e52f0e2a8 | |||
a46a68d616 | |||
203d7c4b43 | |||
24703ffa57 | |||
5cd913a527 | |||
91844e48e9 | |||
6c2f3d1d17 | |||
9c222c7e5c | |||
2249da7976 | |||
a55288bda0 | |||
e645edbda7 | |||
aee7cd73c4 | |||
380a71dd21 | |||
23dd5cc160 | |||
847cb5b972 | |||
cc64091f9c | |||
b68eb44ca5 | |||
403540e8a1 | |||
c39497222f | |||
9e56e668e0 | |||
41ae93dba0 | |||
6c527c1bb4 | |||
90c7876341 | |||
10b77a8305 | |||
1902f4773b | |||
4b95be6a95 | |||
61323926e0 | |||
e30d18febe | |||
9f2f80ae4f | |||
bd6e0ceb81 | |||
673d7038d8 | |||
3a6231dcc1 | |||
9d54e46ce7 |
@ -71,7 +71,7 @@ LIBEDATASERVER_MIN_VERSION=3.5.3
|
|||||||
TELEPATHY_GLIB_MIN_VERSION=0.17.5
|
TELEPATHY_GLIB_MIN_VERSION=0.17.5
|
||||||
POLKIT_MIN_VERSION=0.100
|
POLKIT_MIN_VERSION=0.100
|
||||||
STARTUP_NOTIFICATION_MIN_VERSION=0.11
|
STARTUP_NOTIFICATION_MIN_VERSION=0.11
|
||||||
GCR_MIN_VERSION=3.3.90
|
GCR_MIN_VERSION=3.7.5
|
||||||
GNOME_DESKTOP_REQUIRED_VERSION=3.7.90
|
GNOME_DESKTOP_REQUIRED_VERSION=3.7.90
|
||||||
GNOME_MENUS_REQUIRED_VERSION=3.5.3
|
GNOME_MENUS_REQUIRED_VERSION=3.5.3
|
||||||
NETWORKMANAGER_MIN_VERSION=0.9.8
|
NETWORKMANAGER_MIN_VERSION=0.9.8
|
||||||
@ -109,7 +109,7 @@ PKG_CHECK_MODULES(DESKTOP_SCHEMAS, gsettings-desktop-schemas >= 3.7.4)
|
|||||||
PKG_CHECK_MODULES(CARIBOU, caribou-1.0 >= 0.4.8)
|
PKG_CHECK_MODULES(CARIBOU, caribou-1.0 >= 0.4.8)
|
||||||
|
|
||||||
AC_MSG_CHECKING([for bluetooth support])
|
AC_MSG_CHECKING([for bluetooth support])
|
||||||
PKG_CHECK_EXISTS([gnome-bluetooth-1.0 >= 3.1.0],
|
PKG_CHECK_EXISTS([gnome-bluetooth-1.0 >= 3.9.0],
|
||||||
[BLUETOOTH_DIR=`$PKG_CONFIG --variable=applet_libdir gnome-bluetooth-1.0`
|
[BLUETOOTH_DIR=`$PKG_CONFIG --variable=applet_libdir gnome-bluetooth-1.0`
|
||||||
BLUETOOTH_LIBS=`$PKG_CONFIG --variable=applet_libs gnome-bluetooth-1.0`
|
BLUETOOTH_LIBS=`$PKG_CONFIG --variable=applet_libs gnome-bluetooth-1.0`
|
||||||
AC_SUBST([BLUETOOTH_LIBS],["$BLUETOOTH_LIBS"])
|
AC_SUBST([BLUETOOTH_LIBS],["$BLUETOOTH_LIBS"])
|
||||||
|
@ -204,7 +204,7 @@ value here is from the GsmPresenceStatus enumeration.</_summary>
|
|||||||
</_description>
|
</_description>
|
||||||
</key>
|
</key>
|
||||||
<key type="b" name="current-workspace-only">
|
<key type="b" name="current-workspace-only">
|
||||||
<default>false</default>
|
<default>true</default>
|
||||||
<summary>Limit switcher to current workspace.</summary>
|
<summary>Limit switcher to current workspace.</summary>
|
||||||
<description>
|
<description>
|
||||||
If true, only windows from the current workspace are shown in the switcher.
|
If true, only windows from the current workspace are shown in the switcher.
|
||||||
|
@ -123,6 +123,20 @@ StScrollBar StButton#vhandle:active {
|
|||||||
background-image: url("checkbox-focused.svg");
|
background-image: url("checkbox-focused.svg");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Slider */
|
||||||
|
|
||||||
|
.slider {
|
||||||
|
height: 1em;
|
||||||
|
min-width: 15em;
|
||||||
|
-slider-height: 0.3em;
|
||||||
|
-slider-background-color: #333333;
|
||||||
|
-slider-border-color: #5f5f5f;
|
||||||
|
-slider-active-background-color: #76b0ec;
|
||||||
|
-slider-active-border-color: #1f6dbc;
|
||||||
|
-slider-border-width: 1px;
|
||||||
|
-slider-handle-radius: 0.5em;
|
||||||
|
}
|
||||||
|
|
||||||
/* PopupMenu */
|
/* PopupMenu */
|
||||||
|
|
||||||
.popup-menu-ornament {
|
.popup-menu-ornament {
|
||||||
@ -222,18 +236,6 @@ StScrollBar StButton#vhandle:active {
|
|||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
}
|
}
|
||||||
|
|
||||||
.popup-slider-menu-item {
|
|
||||||
height: 1em;
|
|
||||||
min-width: 15em;
|
|
||||||
-slider-height: 0.3em;
|
|
||||||
-slider-background-color: #333333;
|
|
||||||
-slider-border-color: #5f5f5f;
|
|
||||||
-slider-active-background-color: #76b0ec;
|
|
||||||
-slider-active-border-color: #1f6dbc;
|
|
||||||
-slider-border-width: 1px;
|
|
||||||
-slider-handle-radius: 0.5em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.popup-device-menu-item {
|
.popup-device-menu-item {
|
||||||
spacing: .5em;
|
spacing: .5em;
|
||||||
}
|
}
|
||||||
@ -804,6 +806,11 @@ StScrollBar StButton#vhandle:active {
|
|||||||
height: 24px;
|
height: 24px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.empty-dash-drop-target {
|
||||||
|
width: 24px;
|
||||||
|
height: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
/* Search Box */
|
/* Search Box */
|
||||||
|
|
||||||
#searchEntry {
|
#searchEntry {
|
||||||
@ -891,12 +898,11 @@ StScrollBar StButton#vhandle:active {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.app-view-controls {
|
.app-view-controls {
|
||||||
width: 250px;
|
|
||||||
padding-bottom: 32px;
|
padding-bottom: 32px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.app-view-control {
|
.app-view-control {
|
||||||
padding: 4px 16px;
|
padding: 4px 32px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.search-display > StBoxLayout,
|
.search-display > StBoxLayout,
|
||||||
@ -1148,9 +1154,9 @@ StScrollBar StButton#vhandle:active {
|
|||||||
|
|
||||||
/* Calendar popup */
|
/* Calendar popup */
|
||||||
|
|
||||||
#calendarEventsArea {
|
#calendarArea {
|
||||||
/* this is the width of the second column of the popup */
|
/* this is the total width of the popup */
|
||||||
min-width: 320px;
|
width: 720px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.calendar-vertical-separator {
|
.calendar-vertical-separator {
|
||||||
@ -1289,32 +1295,40 @@ StScrollBar StButton#vhandle:active {
|
|||||||
color: #333333;
|
color: #333333;
|
||||||
}
|
}
|
||||||
|
|
||||||
.events-header-vbox {
|
.events-table {
|
||||||
spacing: 6pt;
|
min-width: 320px;
|
||||||
padding-right: .5em;
|
spacing-columns: 6pt;
|
||||||
|
padding: 0 1.4em;
|
||||||
}
|
}
|
||||||
|
|
||||||
.events-header-vbox:rtl {
|
.events-table:ltr {
|
||||||
padding-left: .5em;
|
padding-right: 1.9em;
|
||||||
}
|
}
|
||||||
|
|
||||||
.events-header-hbox {
|
.events-table:rtl {
|
||||||
padding: 0.3em 1.4em;
|
padding-left: 1.9em;
|
||||||
}
|
}
|
||||||
|
|
||||||
.events-day-header {
|
.events-day-header {
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
color: #999999;
|
color: #999999;
|
||||||
padding: 0.4em 1.4em 0em 1.4em;
|
padding-left: 0.4em;
|
||||||
|
padding-top: 1.2em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.events-day-header:first-child {
|
||||||
|
padding-top: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.events-day-header:rtl {
|
.events-day-header:rtl {
|
||||||
padding: 0em 1.4em 0.4em 1.4em;
|
padding-left: 0;
|
||||||
|
padding-right: 0.4em;
|
||||||
}
|
}
|
||||||
|
|
||||||
.events-day-dayname {
|
.events-day-dayname {
|
||||||
color: rgba(153, 153, 153, 1.0);
|
color: rgba(153, 153, 153, 1.0);
|
||||||
text-align: left;
|
text-align: left;
|
||||||
|
min-width: 20px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.events-day-dayname:rtl {
|
.events-day-dayname:rtl {
|
||||||
@ -1332,23 +1346,12 @@ StScrollBar StButton#vhandle:active {
|
|||||||
|
|
||||||
.events-day-task {
|
.events-day-task {
|
||||||
color: rgba(153, 153, 153, 1.0);
|
color: rgba(153, 153, 153, 1.0);
|
||||||
|
padding-left: 8pt;
|
||||||
}
|
}
|
||||||
|
|
||||||
.events-day-name-box {
|
.events-day-task:rtl {
|
||||||
min-width: 15pt;
|
padding-left: 0px;
|
||||||
}
|
padding-right: 8pt;
|
||||||
|
|
||||||
.events-time-box {
|
|
||||||
min-width: 48pt;
|
|
||||||
padding-right: 12pt;
|
|
||||||
}
|
|
||||||
|
|
||||||
.events-time-box:rtl {
|
|
||||||
padding-right: 0px;
|
|
||||||
padding-left: 12pt;
|
|
||||||
}
|
|
||||||
|
|
||||||
.events-event-box {
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.url-highlighter {
|
.url-highlighter {
|
||||||
|
@ -68,6 +68,7 @@ nobase_dist_js_DATA = \
|
|||||||
ui/sessionMode.js \
|
ui/sessionMode.js \
|
||||||
ui/shellEntry.js \
|
ui/shellEntry.js \
|
||||||
ui/shellMountOperation.js \
|
ui/shellMountOperation.js \
|
||||||
|
ui/slider.js \
|
||||||
ui/notificationDaemon.js \
|
ui/notificationDaemon.js \
|
||||||
ui/osdWindow.js \
|
ui/osdWindow.js \
|
||||||
ui/overview.js \
|
ui/overview.js \
|
||||||
|
@ -42,7 +42,6 @@ const Main = imports.ui.main;
|
|||||||
const ModalDialog = imports.ui.modalDialog;
|
const ModalDialog = imports.ui.modalDialog;
|
||||||
const PanelMenu = imports.ui.panelMenu;
|
const PanelMenu = imports.ui.panelMenu;
|
||||||
const Tweener = imports.ui.tweener;
|
const Tweener = imports.ui.tweener;
|
||||||
const UserMenu = imports.ui.userMenu;
|
|
||||||
const UserWidget = imports.ui.userWidget;
|
const UserWidget = imports.ui.userWidget;
|
||||||
|
|
||||||
const _FADE_ANIMATION_TIME = 0.25;
|
const _FADE_ANIMATION_TIME = 0.25;
|
||||||
@ -69,8 +68,8 @@ const UserListItem = new Lang.Class({
|
|||||||
x_align: St.Align.START,
|
x_align: St.Align.START,
|
||||||
x_fill: true });
|
x_fill: true });
|
||||||
|
|
||||||
this._userAvatar = new UserMenu.UserAvatarWidget(this.user,
|
this._userAvatar = new UserWidget.Avatar(this.user,
|
||||||
{ styleClass: 'login-dialog-user-list-item-icon' });
|
{ styleClass: 'login-dialog-user-list-item-icon' });
|
||||||
layout.add(this._userAvatar.actor);
|
layout.add(this._userAvatar.actor);
|
||||||
let textLayout = new St.BoxLayout({ style_class: 'login-dialog-user-list-item-text-box',
|
let textLayout = new St.BoxLayout({ style_class: 'login-dialog-user-list-item-text-box',
|
||||||
vertical: true });
|
vertical: true });
|
||||||
|
@ -336,6 +336,42 @@ const Views = {
|
|||||||
ALL: 1
|
ALL: 1
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const ControlsBoxLayout = Lang.Class({
|
||||||
|
Name: 'ControlsBoxLayout',
|
||||||
|
Extends: Clutter.BoxLayout,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Override the BoxLayout behavior to use the maximum preferred width of all
|
||||||
|
* buttons for each child
|
||||||
|
*/
|
||||||
|
vfunc_get_preferred_width: function(container, forHeight) {
|
||||||
|
let maxMinWidth = 0;
|
||||||
|
let maxNaturalWidth = 0;
|
||||||
|
for (let child = container.get_first_child();
|
||||||
|
child;
|
||||||
|
child = child.get_next_sibling()) {
|
||||||
|
let [minWidth, natWidth] = child.get_preferred_width(forHeight);
|
||||||
|
maxMinWidth = Math.max(maxMinWidth, minWidth);
|
||||||
|
maxNaturalWidth = Math.max(maxNaturalWidth, natWidth);
|
||||||
|
}
|
||||||
|
let childrenCount = container.get_n_children();
|
||||||
|
let totalSpacing = this.spacing * (childrenCount - 1);
|
||||||
|
return [maxMinWidth * childrenCount + totalSpacing,
|
||||||
|
maxNaturalWidth * childrenCount + totalSpacing];
|
||||||
|
},
|
||||||
|
|
||||||
|
vfunc_set_container: function(container) {
|
||||||
|
if(this._styleChangedId) {
|
||||||
|
this._container.disconnect(this._styleChangedId);
|
||||||
|
this._styleChangedId = 0;
|
||||||
|
}
|
||||||
|
if(container != null)
|
||||||
|
this._styleChangedId = container.connect('style-changed', Lang.bind(this,
|
||||||
|
function() { this.spacing = this._container.get_theme_node().get_length('spacing'); }));
|
||||||
|
this._container = container;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
const AppDisplay = new Lang.Class({
|
const AppDisplay = new Lang.Class({
|
||||||
Name: 'AppDisplay',
|
Name: 'AppDisplay',
|
||||||
|
|
||||||
@ -379,9 +415,9 @@ const AppDisplay = new Lang.Class({
|
|||||||
x_expand: true, y_expand: true });
|
x_expand: true, y_expand: true });
|
||||||
this.actor.add(this._viewStack, { expand: true });
|
this.actor.add(this._viewStack, { expand: true });
|
||||||
|
|
||||||
let layout = new Clutter.BoxLayout({ homogeneous: true });
|
let layout = new ControlsBoxLayout({ homogeneous: true });
|
||||||
this._controls = new St.Widget({ style_class: 'app-view-controls',
|
this._controls = new St.Widget({ style_class: 'app-view-controls' });
|
||||||
layout_manager: layout });
|
this._controls.set_layout_manager(layout);
|
||||||
this.actor.add(new St.Bin({ child: this._controls }));
|
this.actor.add(new St.Bin({ child: this._controls }));
|
||||||
|
|
||||||
|
|
||||||
|
@ -675,7 +675,7 @@ const EventsList = new Lang.Class({
|
|||||||
Name: 'EventsList',
|
Name: 'EventsList',
|
||||||
|
|
||||||
_init: function() {
|
_init: function() {
|
||||||
this.actor = new St.BoxLayout({ vertical: true, style_class: 'events-header-vbox'});
|
this.actor = new St.Table({ style_class: 'events-table' });
|
||||||
this._date = new Date();
|
this._date = new Date();
|
||||||
this._desktopSettings = new Gio.Settings({ schema: 'org.gnome.desktop.interface' });
|
this._desktopSettings = new Gio.Settings({ schema: 'org.gnome.desktop.interface' });
|
||||||
this._desktopSettings.connect('changed', Lang.bind(this, this._update));
|
this._desktopSettings.connect('changed', Lang.bind(this, this._update));
|
||||||
@ -687,55 +687,72 @@ const EventsList = new Lang.Class({
|
|||||||
this._eventSource.connect('changed', Lang.bind(this, this._update));
|
this._eventSource.connect('changed', Lang.bind(this, this._update));
|
||||||
},
|
},
|
||||||
|
|
||||||
_addEvent: function(dayNameBox, timeBox, eventTitleBox, includeDayName, day, time, desc) {
|
_addEvent: function(event, index, includeDayName) {
|
||||||
if (includeDayName) {
|
let dayString;
|
||||||
dayNameBox.add(new St.Label( { style_class: 'events-day-dayname',
|
if (includeDayName)
|
||||||
text: day } ),
|
dayString = _getEventDayAbbreviation(event.date.getDay());
|
||||||
{ x_fill: true } );
|
else
|
||||||
}
|
dayString = '';
|
||||||
timeBox.add(new St.Label( { style_class: 'events-day-time',
|
|
||||||
text: time} ),
|
let dayLabel = new St.Label({ style_class: 'events-day-dayname',
|
||||||
{ x_fill: true } );
|
text: dayString });
|
||||||
eventTitleBox.add(new St.Label( { style_class: 'events-day-task',
|
dayLabel.clutter_text.line_wrap = false;
|
||||||
text: desc} ));
|
dayLabel.clutter_text.ellipsize = false;
|
||||||
|
|
||||||
|
this.actor.add(dayLabel, { row: index, col: 0,
|
||||||
|
x_expand: false, x_align: St.Align.END,
|
||||||
|
y_fill: false, y_align: St.Align.START });
|
||||||
|
|
||||||
|
let clockFormat = this._desktopSettings.get_string(CLOCK_FORMAT_KEY);
|
||||||
|
let timeString = _formatEventTime(event, clockFormat);
|
||||||
|
let timeLabel = new St.Label({ style_class: 'events-day-time',
|
||||||
|
text: timeString });
|
||||||
|
timeLabel.clutter_text.line_wrap = false;
|
||||||
|
timeLabel.clutter_text.ellipsize = false;
|
||||||
|
|
||||||
|
this.actor.add(timeLabel, { row: index, col: 1,
|
||||||
|
x_expand: false, x_align: St.Align.MIDDLE,
|
||||||
|
y_fill: false, y_align: St.Align.START });
|
||||||
|
|
||||||
|
let titleLabel = new St.Label({ style_class: 'events-day-task',
|
||||||
|
text: event.summary });
|
||||||
|
titleLabel.clutter_text.line_wrap = true;
|
||||||
|
titleLabel.clutter_text.ellipsize = false;
|
||||||
|
|
||||||
|
this.actor.add(titleLabel, { row: index, col: 2,
|
||||||
|
x_expand: true, x_align: St.Align.START,
|
||||||
|
y_fill: false, y_align: St.Align.START });
|
||||||
},
|
},
|
||||||
|
|
||||||
_addPeriod: function(header, begin, end, includeDayName, showNothingScheduled) {
|
_addPeriod: function(header, index, begin, end, includeDayName, showNothingScheduled) {
|
||||||
let events = this._eventSource.getEvents(begin, end);
|
let events = this._eventSource.getEvents(begin, end);
|
||||||
|
|
||||||
let clockFormat = this._desktopSettings.get_string(CLOCK_FORMAT_KEY);;
|
|
||||||
|
|
||||||
if (events.length == 0 && !showNothingScheduled)
|
if (events.length == 0 && !showNothingScheduled)
|
||||||
return;
|
return index;
|
||||||
|
|
||||||
let vbox = new St.BoxLayout( {vertical: true} );
|
this.actor.add(new St.Label({ style_class: 'events-day-header', text: header }),
|
||||||
this.actor.add(vbox);
|
{ row: index, col: 0, col_span: 3,
|
||||||
|
// In theory, x_expand should be true here, but x_expand
|
||||||
vbox.add(new St.Label({ style_class: 'events-day-header', text: header }));
|
// is a property of the column for StTable, ie all day cells
|
||||||
let box = new St.BoxLayout({style_class: 'events-header-hbox'});
|
// get it too
|
||||||
let dayNameBox = new St.BoxLayout({ vertical: true, style_class: 'events-day-name-box' });
|
x_expand: false, x_align: St.Align.START,
|
||||||
let timeBox = new St.BoxLayout({ vertical: true, style_class: 'events-time-box' });
|
y_fill: false, y_align: St.Align.START });
|
||||||
let eventTitleBox = new St.BoxLayout({ vertical: true, style_class: 'events-event-box' });
|
index++;
|
||||||
box.add(dayNameBox, {x_fill: false});
|
|
||||||
box.add(timeBox, {x_fill: false});
|
|
||||||
box.add(eventTitleBox, {expand: true});
|
|
||||||
vbox.add(box);
|
|
||||||
|
|
||||||
for (let n = 0; n < events.length; n++) {
|
for (let n = 0; n < events.length; n++) {
|
||||||
let event = events[n];
|
this._addEvent(events[n], index, includeDayName);
|
||||||
let dayString = _getEventDayAbbreviation(event.date.getDay());
|
index++;
|
||||||
let timeString = _formatEventTime(event, clockFormat);
|
|
||||||
let summaryString = event.summary;
|
|
||||||
this._addEvent(dayNameBox, timeBox, eventTitleBox, includeDayName, dayString, timeString, summaryString);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (events.length == 0 && showNothingScheduled) {
|
if (events.length == 0 && showNothingScheduled) {
|
||||||
let now = new Date();
|
let now = new Date();
|
||||||
/* Translators: Text to show if there are no events */
|
/* Translators: Text to show if there are no events */
|
||||||
let nothingEvent = new CalendarEvent(now, now, _("Nothing Scheduled"), true);
|
let nothingEvent = new CalendarEvent(now, now, _("Nothing Scheduled"), true);
|
||||||
let timeString = _formatEventTime(nothingEvent, clockFormat);
|
this._addEvent(nothingEvent, index, false);
|
||||||
this._addEvent(dayNameBox, timeBox, eventTitleBox, false, "", timeString, nothingEvent.summary);
|
index++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return index;
|
||||||
},
|
},
|
||||||
|
|
||||||
_showOtherDay: function(day) {
|
_showOtherDay: function(day) {
|
||||||
@ -752,20 +769,21 @@ const EventsList = new Lang.Class({
|
|||||||
else
|
else
|
||||||
/* Translators: Shown on calendar heading when selected day occurs on different year */
|
/* Translators: Shown on calendar heading when selected day occurs on different year */
|
||||||
dayString = day.toLocaleFormat(C_("calendar heading", "%A, %B %d, %Y"));
|
dayString = day.toLocaleFormat(C_("calendar heading", "%A, %B %d, %Y"));
|
||||||
this._addPeriod(dayString, dayBegin, dayEnd, false, true);
|
this._addPeriod(dayString, 0, dayBegin, dayEnd, false, true);
|
||||||
},
|
},
|
||||||
|
|
||||||
_showToday: function() {
|
_showToday: function() {
|
||||||
this.actor.destroy_all_children();
|
this.actor.destroy_all_children();
|
||||||
|
let index = 0;
|
||||||
|
|
||||||
let now = new Date();
|
let now = new Date();
|
||||||
let dayBegin = _getBeginningOfDay(now);
|
let dayBegin = _getBeginningOfDay(now);
|
||||||
let dayEnd = _getEndOfDay(now);
|
let dayEnd = _getEndOfDay(now);
|
||||||
this._addPeriod(_("Today"), dayBegin, dayEnd, false, true);
|
index = this._addPeriod(_("Today"), index, dayBegin, dayEnd, false, true);
|
||||||
|
|
||||||
let tomorrowBegin = new Date(dayBegin.getTime() + 86400 * 1000);
|
let tomorrowBegin = new Date(dayBegin.getTime() + 86400 * 1000);
|
||||||
let tomorrowEnd = new Date(dayEnd.getTime() + 86400 * 1000);
|
let tomorrowEnd = new Date(dayEnd.getTime() + 86400 * 1000);
|
||||||
this._addPeriod(_("Tomorrow"), tomorrowBegin, tomorrowEnd, false, true);
|
index = this._addPeriod(_("Tomorrow"), index, tomorrowBegin, tomorrowEnd, false, true);
|
||||||
|
|
||||||
let dayInWeek = (dayEnd.getDay() - this._weekStart + 7) % 7;
|
let dayInWeek = (dayEnd.getDay() - this._weekStart + 7) % 7;
|
||||||
|
|
||||||
@ -776,7 +794,7 @@ const EventsList = new Lang.Class({
|
|||||||
*/
|
*/
|
||||||
let thisWeekBegin = new Date(dayBegin.getTime() + 2 * 86400 * 1000);
|
let thisWeekBegin = new Date(dayBegin.getTime() + 2 * 86400 * 1000);
|
||||||
let thisWeekEnd = new Date(dayEnd.getTime() + (6 - dayInWeek) * 86400 * 1000);
|
let thisWeekEnd = new Date(dayEnd.getTime() + (6 - dayInWeek) * 86400 * 1000);
|
||||||
this._addPeriod(_("This week"), thisWeekBegin, thisWeekEnd, true, false);
|
index = this._addPeriod(_("This week"), index, thisWeekBegin, thisWeekEnd, true, false);
|
||||||
} else {
|
} else {
|
||||||
/* otherwise it's one of the two last days of the week ... show
|
/* otherwise it's one of the two last days of the week ... show
|
||||||
* "Next week" and include events up until and including *next*
|
* "Next week" and include events up until and including *next*
|
||||||
@ -784,7 +802,7 @@ const EventsList = new Lang.Class({
|
|||||||
*/
|
*/
|
||||||
let nextWeekBegin = new Date(dayBegin.getTime() + 2 * 86400 * 1000);
|
let nextWeekBegin = new Date(dayBegin.getTime() + 2 * 86400 * 1000);
|
||||||
let nextWeekEnd = new Date(dayEnd.getTime() + (13 - dayInWeek) * 86400 * 1000);
|
let nextWeekEnd = new Date(dayEnd.getTime() + (13 - dayInWeek) * 86400 * 1000);
|
||||||
this._addPeriod(_("Next week"), nextWeekBegin, nextWeekEnd, true, false);
|
index = this._addPeriod(_("Next week"), index, nextWeekBegin, nextWeekEnd, true, false);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -16,7 +16,7 @@ const PolkitAgent = imports.gi.PolkitAgent;
|
|||||||
const Components = imports.ui.components;
|
const Components = imports.ui.components;
|
||||||
const ModalDialog = imports.ui.modalDialog;
|
const ModalDialog = imports.ui.modalDialog;
|
||||||
const ShellEntry = imports.ui.shellEntry;
|
const ShellEntry = imports.ui.shellEntry;
|
||||||
const UserMenu = imports.ui.userMenu;
|
const UserWidget = imports.ui.userWidget;
|
||||||
|
|
||||||
const DIALOG_ICON_SIZE = 48;
|
const DIALOG_ICON_SIZE = 48;
|
||||||
|
|
||||||
@ -100,9 +100,9 @@ const AuthenticationDialog = new Lang.Class({
|
|||||||
let userBox = new St.BoxLayout({ style_class: 'polkit-dialog-user-layout',
|
let userBox = new St.BoxLayout({ style_class: 'polkit-dialog-user-layout',
|
||||||
vertical: false });
|
vertical: false });
|
||||||
messageBox.add(userBox);
|
messageBox.add(userBox);
|
||||||
this._userAvatar = new UserMenu.UserAvatarWidget(this._user,
|
this._userAvatar = new UserWidget.Avatar(this._user,
|
||||||
{ iconSize: DIALOG_ICON_SIZE,
|
{ iconSize: DIALOG_ICON_SIZE,
|
||||||
styleClass: 'polkit-dialog-user-icon' });
|
styleClass: 'polkit-dialog-user-icon' });
|
||||||
this._userAvatar.actor.hide();
|
this._userAvatar.actor.hide();
|
||||||
userBox.add(this._userAvatar.actor,
|
userBox.add(this._userAvatar.actor,
|
||||||
{ x_fill: true,
|
{ x_fill: true,
|
||||||
|
@ -287,13 +287,7 @@ const ShowAppsIcon = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
handleDragOver: function(source, actor, x, y, time) {
|
handleDragOver: function(source, actor, x, y, time) {
|
||||||
let app = getAppFromSource(source);
|
if (!this._canRemoveApp(getAppFromSource(source)))
|
||||||
if (app == null)
|
|
||||||
return DND.DragMotionResult.NO_DROP;
|
|
||||||
|
|
||||||
let id = app.get_id();
|
|
||||||
let isFavorite = AppFavorites.getAppFavorites().isFavorite(id);
|
|
||||||
if (!isFavorite)
|
|
||||||
return DND.DragMotionResult.NO_DROP;
|
return DND.DragMotionResult.NO_DROP;
|
||||||
|
|
||||||
return DND.DragMotionResult.MOVE_DROP;
|
return DND.DragMotionResult.MOVE_DROP;
|
||||||
@ -301,7 +295,7 @@ const ShowAppsIcon = new Lang.Class({
|
|||||||
|
|
||||||
acceptDrop: function(source, actor, x, y, time) {
|
acceptDrop: function(source, actor, x, y, time) {
|
||||||
let app = getAppFromSource(source);
|
let app = getAppFromSource(source);
|
||||||
if (app == null)
|
if (!this._canRemoveApp(app))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
let id = app.get_id();
|
let id = app.get_id();
|
||||||
@ -326,6 +320,16 @@ const DragPlaceholderItem = new Lang.Class({
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const EmptyDropTargetItem = new Lang.Class({
|
||||||
|
Name: 'EmptyDropTargetItem',
|
||||||
|
Extends: DashItemContainer,
|
||||||
|
|
||||||
|
_init: function() {
|
||||||
|
this.parent();
|
||||||
|
this.setChild(new St.Bin({ style_class: 'empty-dash-drop-target' }));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
const DashActor = new Lang.Class({
|
const DashActor = new Lang.Class({
|
||||||
Name: 'DashActor',
|
Name: 'DashActor',
|
||||||
Extends: St.Widget,
|
Extends: St.Widget,
|
||||||
@ -441,6 +445,12 @@ const Dash = new Lang.Class({
|
|||||||
dragMotion: Lang.bind(this, this._onDragMotion)
|
dragMotion: Lang.bind(this, this._onDragMotion)
|
||||||
};
|
};
|
||||||
DND.addDragMonitor(this._dragMonitor);
|
DND.addDragMonitor(this._dragMonitor);
|
||||||
|
|
||||||
|
if (this._box.get_n_children() == 0) {
|
||||||
|
this._emptyDropTarget = new EmptyDropTargetItem();
|
||||||
|
this._box.insert_child_at_index(this._emptyDropTarget, 0);
|
||||||
|
this._emptyDropTarget.show(true);
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_onDragCancelled: function() {
|
_onDragCancelled: function() {
|
||||||
@ -457,6 +467,7 @@ const Dash = new Lang.Class({
|
|||||||
|
|
||||||
_endDrag: function() {
|
_endDrag: function() {
|
||||||
this._clearDragPlaceholder();
|
this._clearDragPlaceholder();
|
||||||
|
this._clearEmptyDropTarget();
|
||||||
this._showAppsIcon.setDragApp(null);
|
this._showAppsIcon.setDragApp(null);
|
||||||
DND.removeDragMonitor(this._dragMonitor);
|
DND.removeDragMonitor(this._dragMonitor);
|
||||||
},
|
},
|
||||||
@ -797,9 +808,21 @@ const Dash = new Lang.Class({
|
|||||||
|
|
||||||
_clearDragPlaceholder: function() {
|
_clearDragPlaceholder: function() {
|
||||||
if (this._dragPlaceholder) {
|
if (this._dragPlaceholder) {
|
||||||
|
this._animatingPlaceholdersCount++;
|
||||||
this._dragPlaceholder.animateOutAndDestroy();
|
this._dragPlaceholder.animateOutAndDestroy();
|
||||||
|
this._dragPlaceholder.connect('destroy',
|
||||||
|
Lang.bind(this, function() {
|
||||||
|
this._animatingPlaceholdersCount--;
|
||||||
|
}));
|
||||||
this._dragPlaceholder = null;
|
this._dragPlaceholder = null;
|
||||||
this._dragPlaceholderPos = -1;
|
}
|
||||||
|
this._dragPlaceholderPos = -1;
|
||||||
|
},
|
||||||
|
|
||||||
|
_clearEmptyDropTarget: function() {
|
||||||
|
if (this._emptyDropTarget) {
|
||||||
|
this._emptyDropTarget.animateOutAndDestroy();
|
||||||
|
this._emptyDropTarget = null;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -827,23 +850,18 @@ const Dash = new Lang.Class({
|
|||||||
numChildren--;
|
numChildren--;
|
||||||
}
|
}
|
||||||
|
|
||||||
let pos = Math.floor(y * numChildren / boxHeight);
|
let pos;
|
||||||
|
if (!this._emptyDropTarget)
|
||||||
|
pos = Math.floor(y * numChildren / boxHeight);
|
||||||
|
else
|
||||||
|
pos = 0; // always insert at the top when dash is empty
|
||||||
|
|
||||||
if (pos != this._dragPlaceholderPos && pos <= numFavorites && this._animatingPlaceholdersCount == 0) {
|
if (pos != this._dragPlaceholderPos && pos <= numFavorites && this._animatingPlaceholdersCount == 0) {
|
||||||
this._dragPlaceholderPos = pos;
|
this._dragPlaceholderPos = pos;
|
||||||
|
|
||||||
// Don't allow positioning before or after self
|
// Don't allow positioning before or after self
|
||||||
if (favPos != -1 && (pos == favPos || pos == favPos + 1)) {
|
if (favPos != -1 && (pos == favPos || pos == favPos + 1)) {
|
||||||
if (this._dragPlaceholder) {
|
this._clearDragPlaceholder();
|
||||||
this._dragPlaceholder.animateOutAndDestroy();
|
|
||||||
this._animatingPlaceholdersCount++;
|
|
||||||
this._dragPlaceholder.connect('destroy',
|
|
||||||
Lang.bind(this, function() {
|
|
||||||
this._animatingPlaceholdersCount--;
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
this._dragPlaceholder = null;
|
|
||||||
|
|
||||||
return DND.DragMotionResult.CONTINUE;
|
return DND.DragMotionResult.CONTINUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -868,9 +886,9 @@ const Dash = new Lang.Class({
|
|||||||
|
|
||||||
// Remove the drag placeholder if we are not in the
|
// Remove the drag placeholder if we are not in the
|
||||||
// "favorites zone"
|
// "favorites zone"
|
||||||
if (pos > numFavorites && this._dragPlaceholder) {
|
if (pos > numFavorites)
|
||||||
this._clearDragPlaceholder();
|
this._clearDragPlaceholder();
|
||||||
}
|
|
||||||
if (!this._dragPlaceholder)
|
if (!this._dragPlaceholder)
|
||||||
return DND.DragMotionResult.NO_DROP;
|
return DND.DragMotionResult.NO_DROP;
|
||||||
|
|
||||||
|
@ -80,8 +80,7 @@ const DateMenuButton = new Lang.Class({
|
|||||||
vbox.add(this._calendar.actor);
|
vbox.add(this._calendar.actor);
|
||||||
|
|
||||||
let separator = new PopupMenu.PopupSeparatorMenuItem();
|
let separator = new PopupMenu.PopupSeparatorMenuItem();
|
||||||
separator.setColumnWidths(1);
|
vbox.add(separator.actor, { y_align: St.Align.END, expand: true, y_fill: false });
|
||||||
vbox.add(separator.actor, {y_align: St.Align.END, expand: true, y_fill: false});
|
|
||||||
|
|
||||||
this._openCalendarItem = new PopupMenu.PopupMenuItem(_("Open Calendar"));
|
this._openCalendarItem = new PopupMenu.PopupMenuItem(_("Open Calendar"));
|
||||||
this._openCalendarItem.connect('activate', Lang.bind(this, this._onOpenCalendarActivate));
|
this._openCalendarItem.connect('activate', Lang.bind(this, this._onOpenCalendarActivate));
|
||||||
@ -107,12 +106,7 @@ const DateMenuButton = new Lang.Class({
|
|||||||
hbox.add(this._separator);
|
hbox.add(this._separator);
|
||||||
|
|
||||||
// Fill up the second column
|
// Fill up the second column
|
||||||
vbox = new St.BoxLayout({ name: 'calendarEventsArea',
|
hbox.add(this._eventList.actor, { expand: true, y_fill: false, y_align: St.Align.START });
|
||||||
vertical: true });
|
|
||||||
hbox.add(vbox, { expand: true });
|
|
||||||
|
|
||||||
// Event list
|
|
||||||
vbox.add(this._eventList.actor, { expand: true });
|
|
||||||
|
|
||||||
// Whenever the menu is opened, select today
|
// Whenever the menu is opened, select today
|
||||||
this.menu.connect('open-state-changed', Lang.bind(this, function(menu, isOpen) {
|
this.menu.connect('open-state-changed', Lang.bind(this, function(menu, isOpen) {
|
||||||
|
@ -147,16 +147,16 @@ const _Draggable = new Lang.Class({
|
|||||||
|
|
||||||
_grabEvents: function() {
|
_grabEvents: function() {
|
||||||
if (!this._eventsGrabbed) {
|
if (!this._eventsGrabbed) {
|
||||||
Clutter.grab_pointer(_getEventHandlerActor());
|
this._eventsGrabbed = Main.pushModal(_getEventHandlerActor());
|
||||||
Clutter.grab_keyboard(_getEventHandlerActor());
|
if (this._eventsGrabbed)
|
||||||
this._eventsGrabbed = true;
|
Clutter.grab_pointer(_getEventHandlerActor());
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_ungrabEvents: function() {
|
_ungrabEvents: function() {
|
||||||
if (this._eventsGrabbed) {
|
if (this._eventsGrabbed) {
|
||||||
Clutter.ungrab_pointer();
|
Clutter.ungrab_pointer();
|
||||||
Clutter.ungrab_keyboard();
|
Main.popModal(_getEventHandlerActor());
|
||||||
this._eventsGrabbed = false;
|
this._eventsGrabbed = false;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -35,7 +35,7 @@ const GnomeSession = imports.misc.gnomeSession;
|
|||||||
const Main = imports.ui.main;
|
const Main = imports.ui.main;
|
||||||
const ModalDialog = imports.ui.modalDialog;
|
const ModalDialog = imports.ui.modalDialog;
|
||||||
const Tweener = imports.ui.tweener;
|
const Tweener = imports.ui.tweener;
|
||||||
const UserMenu = imports.ui.userMenu;
|
const UserWidget = imports.ui.userWidget;
|
||||||
|
|
||||||
let _endSessionDialog = null;
|
let _endSessionDialog = null;
|
||||||
|
|
||||||
@ -360,9 +360,9 @@ const EndSessionDialog = new Lang.Class({
|
|||||||
icon_size: _DIALOG_ICON_SIZE,
|
icon_size: _DIALOG_ICON_SIZE,
|
||||||
style_class: dialogContent.iconStyleClass });
|
style_class: dialogContent.iconStyleClass });
|
||||||
} else {
|
} else {
|
||||||
let avatarWidget = new UserMenu.UserAvatarWidget(this._user,
|
let avatarWidget = new UserWidget.Avatar(this._user,
|
||||||
{ iconSize: _DIALOG_ICON_SIZE,
|
{ iconSize: _DIALOG_ICON_SIZE,
|
||||||
styleClass: dialogContent.iconStyleClass });
|
styleClass: dialogContent.iconStyleClass });
|
||||||
this._iconBin.child = avatarWidget.actor;
|
this._iconBin.child = avatarWidget.actor;
|
||||||
avatarWidget.update();
|
avatarWidget.update();
|
||||||
}
|
}
|
||||||
@ -420,6 +420,7 @@ const EndSessionDialog = new Lang.Class({
|
|||||||
_startTimer: function() {
|
_startTimer: function() {
|
||||||
let startTime = GLib.get_monotonic_time();
|
let startTime = GLib.get_monotonic_time();
|
||||||
this._secondsLeft = this._totalSecondsToStayOpen;
|
this._secondsLeft = this._totalSecondsToStayOpen;
|
||||||
|
this._updateDescription();
|
||||||
|
|
||||||
this._timerId = Mainloop.timeout_add_seconds(1, Lang.bind(this,
|
this._timerId = Mainloop.timeout_add_seconds(1, Lang.bind(this,
|
||||||
function() {
|
function() {
|
||||||
|
@ -53,7 +53,7 @@ const Magnifier = new Lang.Class({
|
|||||||
this._zoomRegions = [];
|
this._zoomRegions = [];
|
||||||
|
|
||||||
// Create small clutter tree for the magnified mouse.
|
// Create small clutter tree for the magnified mouse.
|
||||||
let xfixesCursor = Shell.XFixesCursor.get_for_stage(global.stage);
|
let xfixesCursor = Shell.XFixesCursor.get_for_screen(global.screen);
|
||||||
this._mouseSprite = new Clutter.Texture();
|
this._mouseSprite = new Clutter.Texture();
|
||||||
xfixesCursor.update_texture_image(this._mouseSprite);
|
xfixesCursor.update_texture_image(this._mouseSprite);
|
||||||
this._cursorRoot = new Clutter.Actor();
|
this._cursorRoot = new Clutter.Actor();
|
||||||
@ -83,7 +83,7 @@ const Magnifier = new Lang.Class({
|
|||||||
* Show the system mouse pointer.
|
* Show the system mouse pointer.
|
||||||
*/
|
*/
|
||||||
showSystemCursor: function() {
|
showSystemCursor: function() {
|
||||||
this._xfixesCursor.show();
|
global.stage.show_cursor();
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -91,7 +91,7 @@ const Magnifier = new Lang.Class({
|
|||||||
* Hide the system mouse pointer.
|
* Hide the system mouse pointer.
|
||||||
*/
|
*/
|
||||||
hideSystemCursor: function() {
|
hideSystemCursor: function() {
|
||||||
this._xfixesCursor.hide();
|
global.stage.hide_cursor();
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -112,7 +112,7 @@ const Magnifier = new Lang.Class({
|
|||||||
// 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.
|
||||||
if (!activate)
|
if (!activate)
|
||||||
this._xfixesCursor.show();
|
global.stage.show_cursor();
|
||||||
|
|
||||||
// Notify interested parties of this change
|
// Notify interested parties of this change
|
||||||
this.emit('active-changed', activate);
|
this.emit('active-changed', activate);
|
||||||
|
@ -71,6 +71,7 @@ let _startDate;
|
|||||||
let _defaultCssStylesheet = null;
|
let _defaultCssStylesheet = null;
|
||||||
let _cssStylesheet = null;
|
let _cssStylesheet = null;
|
||||||
let _a11ySettings = null;
|
let _a11ySettings = null;
|
||||||
|
let dynamicWorkspacesSchema = null;
|
||||||
|
|
||||||
function _sessionUpdated() {
|
function _sessionUpdated() {
|
||||||
_loadDefaultStylesheet();
|
_loadDefaultStylesheet();
|
||||||
@ -108,6 +109,7 @@ function start() {
|
|||||||
|
|
||||||
function _sessionsLoaded() {
|
function _sessionsLoaded() {
|
||||||
sessionMode.connect('updated', _sessionUpdated);
|
sessionMode.connect('updated', _sessionUpdated);
|
||||||
|
_initializePrefs();
|
||||||
_initializeUI();
|
_initializeUI();
|
||||||
|
|
||||||
shellDBusService = new ShellDBus.GnomeShell();
|
shellDBusService = new ShellDBus.GnomeShell();
|
||||||
@ -116,6 +118,17 @@ function _sessionsLoaded() {
|
|||||||
_sessionUpdated();
|
_sessionUpdated();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function _initializePrefs() {
|
||||||
|
let keys = new Gio.Settings({ schema: sessionMode.overridesSchema }).list_keys();
|
||||||
|
for (let i = 0; i < keys.length; i++)
|
||||||
|
Meta.prefs_override_preference_schema(keys[i], sessionMode.overridesSchema);
|
||||||
|
|
||||||
|
if (keys.indexOf('dynamic-workspaces') > -1)
|
||||||
|
dynamicWorkspacesSchema = sessionMode.overridesSchema;
|
||||||
|
else
|
||||||
|
dynamicWorkspacesSchema = 'org.gnome.mutter';
|
||||||
|
}
|
||||||
|
|
||||||
function _initializeUI() {
|
function _initializeUI() {
|
||||||
// Ensure ShellWindowTracker and ShellAppUsage are initialized; this will
|
// Ensure ShellWindowTracker and ShellAppUsage are initialized; this will
|
||||||
// also initialize ShellAppSystem first. ShellAppSystem
|
// also initialize ShellAppSystem first. ShellAppSystem
|
||||||
|
@ -136,8 +136,10 @@ const OsdWindow = new Lang.Class({
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
if (!this.actor.visible) {
|
if (!this.actor.visible) {
|
||||||
|
Meta.disable_unredirect_for_screen(global.screen);
|
||||||
this.actor.show();
|
this.actor.show();
|
||||||
this.actor.opacity = 0;
|
this.actor.opacity = 0;
|
||||||
|
this.actor.get_parent().set_child_above_sibling(this.actor, null);
|
||||||
|
|
||||||
Tweener.addTween(this.actor,
|
Tweener.addTween(this.actor,
|
||||||
{ opacity: 255,
|
{ opacity: 255,
|
||||||
@ -172,6 +174,7 @@ const OsdWindow = new Lang.Class({
|
|||||||
this.actor.hide();
|
this.actor.hide();
|
||||||
this.setLabel(null);
|
this.setLabel(null);
|
||||||
this.setLevel(null);
|
this.setLevel(null);
|
||||||
|
Meta.enable_unredirect_for_screen(global.screen);
|
||||||
},
|
},
|
||||||
|
|
||||||
_monitorsChanged: function() {
|
_monitorsChanged: function() {
|
||||||
|
@ -15,10 +15,9 @@ const GrabHelper = imports.ui.grabHelper;
|
|||||||
const Main = imports.ui.main;
|
const Main = imports.ui.main;
|
||||||
const Params = imports.misc.params;
|
const Params = imports.misc.params;
|
||||||
const Separator = imports.ui.separator;
|
const Separator = imports.ui.separator;
|
||||||
|
const Slider = imports.ui.slider;
|
||||||
const Tweener = imports.ui.tweener;
|
const Tweener = imports.ui.tweener;
|
||||||
|
|
||||||
const SLIDER_SCROLL_STEP = 0.05; /* Slider scrolling step in % */
|
|
||||||
|
|
||||||
const Ornament = {
|
const Ornament = {
|
||||||
NONE: 0,
|
NONE: 0,
|
||||||
DOT: 1,
|
DOT: 1,
|
||||||
@ -515,211 +514,19 @@ const PopupSliderMenuItem = new Lang.Class({
|
|||||||
_init: function(value) {
|
_init: function(value) {
|
||||||
this.parent({ activate: false });
|
this.parent({ activate: false });
|
||||||
|
|
||||||
this.actor.connect('key-press-event', Lang.bind(this, this._onKeyPressEvent));
|
this._slider = new Slider.Slider(value);
|
||||||
|
this._slider.connect('value-changed', Lang.bind(this, function(actor, value) {
|
||||||
if (isNaN(value))
|
this.emit('value-changed', value);
|
||||||
// Avoid spreading NaNs around
|
|
||||||
throw TypeError('The slider value must be a number');
|
|
||||||
this._value = Math.max(Math.min(value, 1), 0);
|
|
||||||
|
|
||||||
this._slider = new St.DrawingArea({ style_class: 'popup-slider-menu-item', reactive: true });
|
|
||||||
this.addActor(this._slider, { span: -1, expand: true });
|
|
||||||
this._slider.connect('repaint', Lang.bind(this, this._sliderRepaint));
|
|
||||||
this.actor.connect('button-press-event', Lang.bind(this, this._startDragging));
|
|
||||||
this.actor.connect('scroll-event', Lang.bind(this, this._onScrollEvent));
|
|
||||||
this.actor.connect('notify::mapped', Lang.bind(this, function() {
|
|
||||||
if (!this.actor.mapped)
|
|
||||||
this._endDragging();
|
|
||||||
}));
|
}));
|
||||||
|
this.addActor(this._slider.actor);
|
||||||
this._releaseId = this._motionId = 0;
|
|
||||||
this._dragging = false;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
setValue: function(value) {
|
setValue: function(value) {
|
||||||
if (isNaN(value))
|
this._slider.setValue(value);
|
||||||
throw TypeError('The slider value must be a number');
|
|
||||||
|
|
||||||
this._value = Math.max(Math.min(value, 1), 0);
|
|
||||||
this._slider.queue_repaint();
|
|
||||||
},
|
|
||||||
|
|
||||||
_sliderRepaint: function(area) {
|
|
||||||
let cr = area.get_context();
|
|
||||||
let themeNode = area.get_theme_node();
|
|
||||||
let [width, height] = area.get_surface_size();
|
|
||||||
|
|
||||||
let handleRadius = themeNode.get_length('-slider-handle-radius');
|
|
||||||
|
|
||||||
let handleBorderWidth = themeNode.get_length('-slider-handle-border-width');
|
|
||||||
let [hasHandleColor, handleBorderColor] =
|
|
||||||
themeNode.lookup_color('-slider-handle-border-color', false);
|
|
||||||
|
|
||||||
let sliderWidth = width - 2 * handleRadius;
|
|
||||||
let sliderHeight = themeNode.get_length('-slider-height');
|
|
||||||
|
|
||||||
let sliderBorderWidth = themeNode.get_length('-slider-border-width');
|
|
||||||
|
|
||||||
let sliderBorderColor = themeNode.get_color('-slider-border-color');
|
|
||||||
let sliderColor = themeNode.get_color('-slider-background-color');
|
|
||||||
|
|
||||||
let sliderActiveBorderColor = themeNode.get_color('-slider-active-border-color');
|
|
||||||
let sliderActiveColor = themeNode.get_color('-slider-active-background-color');
|
|
||||||
|
|
||||||
cr.setSourceRGBA (
|
|
||||||
sliderActiveColor.red / 255,
|
|
||||||
sliderActiveColor.green / 255,
|
|
||||||
sliderActiveColor.blue / 255,
|
|
||||||
sliderActiveColor.alpha / 255);
|
|
||||||
cr.rectangle(handleRadius, (height - sliderHeight) / 2, sliderWidth * this._value, sliderHeight);
|
|
||||||
cr.fillPreserve();
|
|
||||||
cr.setSourceRGBA (
|
|
||||||
sliderActiveBorderColor.red / 255,
|
|
||||||
sliderActiveBorderColor.green / 255,
|
|
||||||
sliderActiveBorderColor.blue / 255,
|
|
||||||
sliderActiveBorderColor.alpha / 255);
|
|
||||||
cr.setLineWidth(sliderBorderWidth);
|
|
||||||
cr.stroke();
|
|
||||||
|
|
||||||
cr.setSourceRGBA (
|
|
||||||
sliderColor.red / 255,
|
|
||||||
sliderColor.green / 255,
|
|
||||||
sliderColor.blue / 255,
|
|
||||||
sliderColor.alpha / 255);
|
|
||||||
cr.rectangle(handleRadius + sliderWidth * this._value, (height - sliderHeight) / 2, sliderWidth * (1 - this._value), sliderHeight);
|
|
||||||
cr.fillPreserve();
|
|
||||||
cr.setSourceRGBA (
|
|
||||||
sliderBorderColor.red / 255,
|
|
||||||
sliderBorderColor.green / 255,
|
|
||||||
sliderBorderColor.blue / 255,
|
|
||||||
sliderBorderColor.alpha / 255);
|
|
||||||
cr.setLineWidth(sliderBorderWidth);
|
|
||||||
cr.stroke();
|
|
||||||
|
|
||||||
let handleY = height / 2;
|
|
||||||
let handleX = handleRadius + (width - 2 * handleRadius) * this._value;
|
|
||||||
|
|
||||||
let color = themeNode.get_foreground_color();
|
|
||||||
cr.setSourceRGBA (
|
|
||||||
color.red / 255,
|
|
||||||
color.green / 255,
|
|
||||||
color.blue / 255,
|
|
||||||
color.alpha / 255);
|
|
||||||
cr.arc(handleX, handleY, handleRadius, 0, 2 * Math.PI);
|
|
||||||
cr.fillPreserve();
|
|
||||||
if (hasHandleColor && handleBorderWidth) {
|
|
||||||
cr.setSourceRGBA(
|
|
||||||
handleBorderColor.red / 255,
|
|
||||||
handleBorderColor.green / 255,
|
|
||||||
handleBorderColor.blue / 255,
|
|
||||||
handleBorderColor.alpha / 255);
|
|
||||||
cr.setLineWidth(handleBorderWidth);
|
|
||||||
cr.stroke();
|
|
||||||
}
|
|
||||||
cr.$dispose();
|
|
||||||
},
|
|
||||||
|
|
||||||
_startDragging: function(actor, event) {
|
|
||||||
if (this._dragging) // don't allow two drags at the same time
|
|
||||||
return;
|
|
||||||
|
|
||||||
this._dragging = true;
|
|
||||||
|
|
||||||
// FIXME: we should only grab the specific device that originated
|
|
||||||
// the event, but for some weird reason events are still delivered
|
|
||||||
// outside the slider if using clutter_grab_pointer_for_device
|
|
||||||
Clutter.grab_pointer(this._slider);
|
|
||||||
this._releaseId = this._slider.connect('button-release-event', Lang.bind(this, this._endDragging));
|
|
||||||
this._motionId = this._slider.connect('motion-event', Lang.bind(this, this._motionEvent));
|
|
||||||
let absX, absY;
|
|
||||||
[absX, absY] = event.get_coords();
|
|
||||||
this._moveHandle(absX, absY);
|
|
||||||
},
|
|
||||||
|
|
||||||
_endDragging: function() {
|
|
||||||
if (this._dragging) {
|
|
||||||
this._slider.disconnect(this._releaseId);
|
|
||||||
this._slider.disconnect(this._motionId);
|
|
||||||
|
|
||||||
Clutter.ungrab_pointer();
|
|
||||||
this._dragging = false;
|
|
||||||
|
|
||||||
this.emit('drag-end');
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
},
|
|
||||||
|
|
||||||
scroll: function(event) {
|
|
||||||
let direction = event.get_scroll_direction();
|
|
||||||
let delta;
|
|
||||||
|
|
||||||
if (event.is_pointer_emulated())
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (direction == Clutter.ScrollDirection.DOWN) {
|
|
||||||
delta = -SLIDER_SCROLL_STEP;
|
|
||||||
} else if (direction == Clutter.ScrollDirection.UP) {
|
|
||||||
delta = +SLIDER_SCROLL_STEP;
|
|
||||||
} else if (direction == Clutter.ScrollDirection.SMOOTH) {
|
|
||||||
let [dx, dy] = event.get_scroll_delta();
|
|
||||||
// Even though the slider is horizontal, use dy to match
|
|
||||||
// the UP/DOWN above.
|
|
||||||
delta = -dy / 10;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._value = Math.min(Math.max(0, this._value + delta), 1);
|
|
||||||
|
|
||||||
this._slider.queue_repaint();
|
|
||||||
this.emit('value-changed', this._value);
|
|
||||||
},
|
|
||||||
|
|
||||||
_onScrollEvent: function(actor, event) {
|
|
||||||
this.scroll(event);
|
|
||||||
},
|
|
||||||
|
|
||||||
_motionEvent: function(actor, event) {
|
|
||||||
let absX, absY;
|
|
||||||
[absX, absY] = event.get_coords();
|
|
||||||
this._moveHandle(absX, absY);
|
|
||||||
return true;
|
|
||||||
},
|
|
||||||
|
|
||||||
_moveHandle: function(absX, absY) {
|
|
||||||
let relX, relY, sliderX, sliderY;
|
|
||||||
[sliderX, sliderY] = this._slider.get_transformed_position();
|
|
||||||
relX = absX - sliderX;
|
|
||||||
relY = absY - sliderY;
|
|
||||||
|
|
||||||
let width = this._slider.width;
|
|
||||||
let handleRadius = this._slider.get_theme_node().get_length('-slider-handle-radius');
|
|
||||||
|
|
||||||
let newvalue;
|
|
||||||
if (relX < handleRadius)
|
|
||||||
newvalue = 0;
|
|
||||||
else if (relX > width - handleRadius)
|
|
||||||
newvalue = 1;
|
|
||||||
else
|
|
||||||
newvalue = (relX - handleRadius) / (width - 2 * handleRadius);
|
|
||||||
this._value = newvalue;
|
|
||||||
this._slider.queue_repaint();
|
|
||||||
this.emit('value-changed', this._value);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
get value() {
|
get value() {
|
||||||
return this._value;
|
return this._slider.value;
|
||||||
},
|
|
||||||
|
|
||||||
_onKeyPressEvent: function (actor, event) {
|
|
||||||
let key = event.get_key_symbol();
|
|
||||||
if (key == Clutter.KEY_Right || key == Clutter.KEY_Left) {
|
|
||||||
let delta = key == Clutter.KEY_Right ? 0.1 : -0.1;
|
|
||||||
this._value = Math.max(0, Math.min(this._value + delta, 1));
|
|
||||||
this._slider.queue_repaint();
|
|
||||||
this.emit('value-changed', this._value);
|
|
||||||
this.emit('drag-end');
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -1215,6 +1215,12 @@ const ScreenShield = new Lang.Class({
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Clear the clipboard - otherwise, its contents may be leaked
|
||||||
|
// to unauthorized parties by pasting into the unlock dialog's
|
||||||
|
// password entry and unmasking the entry
|
||||||
|
St.Clipboard.get_default().set_text(St.ClipboardType.CLIPBOARD, '');
|
||||||
|
St.Clipboard.get_default().set_text(St.ClipboardType.PRIMARY, '');
|
||||||
|
|
||||||
this._isLocked = true;
|
this._isLocked = true;
|
||||||
this.activate(animate);
|
this.activate(animate);
|
||||||
|
|
||||||
|
@ -16,6 +16,7 @@ const _modes = {
|
|||||||
'restrictive': {
|
'restrictive': {
|
||||||
parentMode: null,
|
parentMode: null,
|
||||||
stylesheetName: 'gnome-shell.css',
|
stylesheetName: 'gnome-shell.css',
|
||||||
|
overridesSchema: 'org.gnome.shell.overrides',
|
||||||
hasOverview: false,
|
hasOverview: false,
|
||||||
showCalendarEvents: false,
|
showCalendarEvents: false,
|
||||||
allowSettings: false,
|
allowSettings: false,
|
||||||
|
221
js/ui/slider.js
Normal file
221
js/ui/slider.js
Normal file
@ -0,0 +1,221 @@
|
|||||||
|
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
|
||||||
|
|
||||||
|
const Cairo = imports.cairo;
|
||||||
|
const Clutter = imports.gi.Clutter;
|
||||||
|
const Lang = imports.lang;
|
||||||
|
const St = imports.gi.St;
|
||||||
|
const Signals = imports.signals;
|
||||||
|
|
||||||
|
const SLIDER_SCROLL_STEP = 0.05; /* Slider scrolling step in % */
|
||||||
|
|
||||||
|
const Slider = new Lang.Class({
|
||||||
|
Name: "Slider",
|
||||||
|
|
||||||
|
_init: function(value) {
|
||||||
|
if (isNaN(value))
|
||||||
|
// Avoid spreading NaNs around
|
||||||
|
throw TypeError('The slider value must be a number');
|
||||||
|
this._value = Math.max(Math.min(value, 1), 0);
|
||||||
|
|
||||||
|
this.actor = new St.DrawingArea({ style_class: 'slider',
|
||||||
|
can_focus: true,
|
||||||
|
reactive: true });
|
||||||
|
this.actor.connect('repaint', Lang.bind(this, this._sliderRepaint));
|
||||||
|
this.actor.connect('button-press-event', Lang.bind(this, this._startDragging));
|
||||||
|
this.actor.connect('scroll-event', Lang.bind(this, this._onScrollEvent));
|
||||||
|
this.actor.connect('key-press-event', Lang.bind(this, this._onKeyPressEvent));
|
||||||
|
|
||||||
|
this._releaseId = this._motionId = 0;
|
||||||
|
this._dragging = false;
|
||||||
|
},
|
||||||
|
|
||||||
|
setValue: function(value) {
|
||||||
|
if (isNaN(value))
|
||||||
|
throw TypeError('The slider value must be a number');
|
||||||
|
|
||||||
|
this._value = Math.max(Math.min(value, 1), 0);
|
||||||
|
this.actor.queue_repaint();
|
||||||
|
},
|
||||||
|
|
||||||
|
_sliderRepaint: function(area) {
|
||||||
|
let cr = area.get_context();
|
||||||
|
let themeNode = area.get_theme_node();
|
||||||
|
let [width, height] = area.get_surface_size();
|
||||||
|
|
||||||
|
let handleRadius = themeNode.get_length('-slider-handle-radius');
|
||||||
|
|
||||||
|
let handleBorderWidth = themeNode.get_length('-slider-handle-border-width');
|
||||||
|
let [hasHandleColor, handleBorderColor] =
|
||||||
|
themeNode.lookup_color('-slider-handle-border-color', false);
|
||||||
|
|
||||||
|
let sliderWidth = width - 2 * handleRadius;
|
||||||
|
let sliderHeight = themeNode.get_length('-slider-height');
|
||||||
|
|
||||||
|
let sliderBorderWidth = themeNode.get_length('-slider-border-width');
|
||||||
|
|
||||||
|
let sliderBorderColor = themeNode.get_color('-slider-border-color');
|
||||||
|
let sliderColor = themeNode.get_color('-slider-background-color');
|
||||||
|
|
||||||
|
let sliderActiveBorderColor = themeNode.get_color('-slider-active-border-color');
|
||||||
|
let sliderActiveColor = themeNode.get_color('-slider-active-background-color');
|
||||||
|
|
||||||
|
cr.setSourceRGBA (
|
||||||
|
sliderActiveColor.red / 255,
|
||||||
|
sliderActiveColor.green / 255,
|
||||||
|
sliderActiveColor.blue / 255,
|
||||||
|
sliderActiveColor.alpha / 255);
|
||||||
|
cr.rectangle(handleRadius, (height - sliderHeight) / 2, sliderWidth * this._value, sliderHeight);
|
||||||
|
cr.fillPreserve();
|
||||||
|
cr.setSourceRGBA (
|
||||||
|
sliderActiveBorderColor.red / 255,
|
||||||
|
sliderActiveBorderColor.green / 255,
|
||||||
|
sliderActiveBorderColor.blue / 255,
|
||||||
|
sliderActiveBorderColor.alpha / 255);
|
||||||
|
cr.setLineWidth(sliderBorderWidth);
|
||||||
|
cr.stroke();
|
||||||
|
|
||||||
|
cr.setSourceRGBA (
|
||||||
|
sliderColor.red / 255,
|
||||||
|
sliderColor.green / 255,
|
||||||
|
sliderColor.blue / 255,
|
||||||
|
sliderColor.alpha / 255);
|
||||||
|
cr.rectangle(handleRadius + sliderWidth * this._value, (height - sliderHeight) / 2, sliderWidth * (1 - this._value), sliderHeight);
|
||||||
|
cr.fillPreserve();
|
||||||
|
cr.setSourceRGBA (
|
||||||
|
sliderBorderColor.red / 255,
|
||||||
|
sliderBorderColor.green / 255,
|
||||||
|
sliderBorderColor.blue / 255,
|
||||||
|
sliderBorderColor.alpha / 255);
|
||||||
|
cr.setLineWidth(sliderBorderWidth);
|
||||||
|
cr.stroke();
|
||||||
|
|
||||||
|
let handleY = height / 2;
|
||||||
|
let handleX = handleRadius + (width - 2 * handleRadius) * this._value;
|
||||||
|
|
||||||
|
let color = themeNode.get_foreground_color();
|
||||||
|
cr.setSourceRGBA (
|
||||||
|
color.red / 255,
|
||||||
|
color.green / 255,
|
||||||
|
color.blue / 255,
|
||||||
|
color.alpha / 255);
|
||||||
|
cr.arc(handleX, handleY, handleRadius, 0, 2 * Math.PI);
|
||||||
|
cr.fillPreserve();
|
||||||
|
if (hasHandleColor && handleBorderWidth) {
|
||||||
|
cr.setSourceRGBA(
|
||||||
|
handleBorderColor.red / 255,
|
||||||
|
handleBorderColor.green / 255,
|
||||||
|
handleBorderColor.blue / 255,
|
||||||
|
handleBorderColor.alpha / 255);
|
||||||
|
cr.setLineWidth(handleBorderWidth);
|
||||||
|
cr.stroke();
|
||||||
|
}
|
||||||
|
cr.$dispose();
|
||||||
|
},
|
||||||
|
|
||||||
|
_startDragging: function(actor, event) {
|
||||||
|
if (this._dragging) // don't allow two drags at the same time
|
||||||
|
return false;
|
||||||
|
|
||||||
|
this._dragging = true;
|
||||||
|
|
||||||
|
// FIXME: we should only grab the specific device that originated
|
||||||
|
// the event, but for some weird reason events are still delivered
|
||||||
|
// outside the slider if using clutter_grab_pointer_for_device
|
||||||
|
Clutter.grab_pointer(this.actor);
|
||||||
|
this._releaseId = this.actor.connect('button-release-event', Lang.bind(this, this._endDragging));
|
||||||
|
this._motionId = this.actor.connect('motion-event', Lang.bind(this, this._motionEvent));
|
||||||
|
let absX, absY;
|
||||||
|
[absX, absY] = event.get_coords();
|
||||||
|
this._moveHandle(absX, absY);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
},
|
||||||
|
|
||||||
|
_endDragging: function() {
|
||||||
|
if (this._dragging) {
|
||||||
|
this.actor.disconnect(this._releaseId);
|
||||||
|
this.actor.disconnect(this._motionId);
|
||||||
|
|
||||||
|
Clutter.ungrab_pointer();
|
||||||
|
this._dragging = false;
|
||||||
|
|
||||||
|
this.emit('drag-end');
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
},
|
||||||
|
|
||||||
|
scroll: function(event) {
|
||||||
|
let direction = event.get_scroll_direction();
|
||||||
|
let delta;
|
||||||
|
|
||||||
|
if (event.is_pointer_emulated())
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (direction == Clutter.ScrollDirection.DOWN) {
|
||||||
|
delta = -SLIDER_SCROLL_STEP;
|
||||||
|
} else if (direction == Clutter.ScrollDirection.UP) {
|
||||||
|
delta = +SLIDER_SCROLL_STEP;
|
||||||
|
} else if (direction == Clutter.ScrollDirection.SMOOTH) {
|
||||||
|
let [dx, dy] = event.get_scroll_delta();
|
||||||
|
// Even though the slider is horizontal, use dy to match
|
||||||
|
// the UP/DOWN above.
|
||||||
|
delta = -dy / 10;
|
||||||
|
}
|
||||||
|
|
||||||
|
this._value = Math.min(Math.max(0, this._value + delta), 1);
|
||||||
|
|
||||||
|
this.actor.queue_repaint();
|
||||||
|
this.emit('value-changed', this._value);
|
||||||
|
},
|
||||||
|
|
||||||
|
_onScrollEvent: function(actor, event) {
|
||||||
|
this.scroll(event);
|
||||||
|
},
|
||||||
|
|
||||||
|
_motionEvent: function(actor, event) {
|
||||||
|
let absX, absY;
|
||||||
|
[absX, absY] = event.get_coords();
|
||||||
|
this._moveHandle(absX, absY);
|
||||||
|
return true;
|
||||||
|
},
|
||||||
|
|
||||||
|
_onKeyPressEvent: function (actor, event) {
|
||||||
|
let key = event.get_key_symbol();
|
||||||
|
if (key == Clutter.KEY_Right || key == Clutter.KEY_Left) {
|
||||||
|
let delta = key == Clutter.KEY_Right ? 0.1 : -0.1;
|
||||||
|
this._value = Math.max(0, Math.min(this._value + delta, 1));
|
||||||
|
this._slider.queue_repaint();
|
||||||
|
this.emit('value-changed', this._value);
|
||||||
|
this.emit('drag-end');
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
},
|
||||||
|
|
||||||
|
_moveHandle: function(absX, absY) {
|
||||||
|
let relX, relY, sliderX, sliderY;
|
||||||
|
[sliderX, sliderY] = this.actor.get_transformed_position();
|
||||||
|
relX = absX - sliderX;
|
||||||
|
relY = absY - sliderY;
|
||||||
|
|
||||||
|
let width = this.actor.width;
|
||||||
|
let handleRadius = this.actor.get_theme_node().get_length('-slider-handle-radius');
|
||||||
|
|
||||||
|
let newvalue;
|
||||||
|
if (relX < handleRadius)
|
||||||
|
newvalue = 0;
|
||||||
|
else if (relX > width - handleRadius)
|
||||||
|
newvalue = 1;
|
||||||
|
else
|
||||||
|
newvalue = (relX - handleRadius) / (width - 2 * handleRadius);
|
||||||
|
this._value = newvalue;
|
||||||
|
this.actor.queue_repaint();
|
||||||
|
this.emit('value-changed', this._value);
|
||||||
|
},
|
||||||
|
|
||||||
|
get value() {
|
||||||
|
return this._value;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
Signals.addSignalMethods(Slider.prototype);
|
@ -86,6 +86,7 @@ const Indicator = new Lang.Class({
|
|||||||
this._applet.connect('pincode-request', Lang.bind(this, this._pinRequest));
|
this._applet.connect('pincode-request', Lang.bind(this, this._pinRequest));
|
||||||
this._applet.connect('confirm-request', Lang.bind(this, this._confirmRequest));
|
this._applet.connect('confirm-request', Lang.bind(this, this._confirmRequest));
|
||||||
this._applet.connect('auth-request', Lang.bind(this, this._authRequest));
|
this._applet.connect('auth-request', Lang.bind(this, this._authRequest));
|
||||||
|
this._applet.connect('auth-service-request', Lang.bind(this, this._authServiceRequest));
|
||||||
this._applet.connect('cancel-request', Lang.bind(this, this._cancelRequest));
|
this._applet.connect('cancel-request', Lang.bind(this, this._cancelRequest));
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -292,9 +293,14 @@ const Indicator = new Lang.Class({
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_authRequest: function(applet, device_path, name, long_name, uuid) {
|
_authRequest: function(applet, device_path, name, long_name) {
|
||||||
this._ensureSource();
|
this._ensureSource();
|
||||||
this._source.notify(new AuthNotification(this._source, this._applet, device_path, name, long_name, uuid));
|
this._source.notify(new AuthNotification(this._source, this._applet, device_path, name, long_name));
|
||||||
|
},
|
||||||
|
|
||||||
|
_authServiceRequest: function(applet, device_path, name, long_name, uuid) {
|
||||||
|
this._ensureSource();
|
||||||
|
this._source.notify(new AuthServiceNotification(this._source, this._applet, device_path, name, long_name, uuid));
|
||||||
},
|
},
|
||||||
|
|
||||||
_confirmRequest: function(applet, device_path, name, long_name, pin) {
|
_confirmRequest: function(applet, device_path, name, long_name, pin) {
|
||||||
@ -316,6 +322,34 @@ const AuthNotification = new Lang.Class({
|
|||||||
Name: 'AuthNotification',
|
Name: 'AuthNotification',
|
||||||
Extends: MessageTray.Notification,
|
Extends: MessageTray.Notification,
|
||||||
|
|
||||||
|
_init: function(source, applet, device_path, name, long_name) {
|
||||||
|
this.parent(source,
|
||||||
|
_("Bluetooth"),
|
||||||
|
_("Authorization request from %s").format(name),
|
||||||
|
{ customContent: true });
|
||||||
|
this.setResident(true);
|
||||||
|
|
||||||
|
this._applet = applet;
|
||||||
|
this._devicePath = device_path;
|
||||||
|
this.addBody(_("Device %s wants to pair with this computer").format(long_name));
|
||||||
|
|
||||||
|
this.addButton('allow', _("Allow"));
|
||||||
|
this.addButton('deny', _("Deny"));
|
||||||
|
|
||||||
|
this.connect('action-invoked', Lang.bind(this, function(self, action) {
|
||||||
|
if (action == 'allow')
|
||||||
|
this._applet.agent_reply_confirm(this._devicePath, true);
|
||||||
|
else
|
||||||
|
this._applet.agent_reply_confirm(this._devicePath, false);
|
||||||
|
this.destroy();
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
const AuthServiceNotification = new Lang.Class({
|
||||||
|
Name: 'AuthServiceNotification',
|
||||||
|
Extends: MessageTray.Notification,
|
||||||
|
|
||||||
_init: function(source, applet, device_path, name, long_name, uuid) {
|
_init: function(source, applet, device_path, name, long_name, uuid) {
|
||||||
this.parent(source,
|
this.parent(source,
|
||||||
_("Bluetooth"),
|
_("Bluetooth"),
|
||||||
@ -334,14 +368,14 @@ const AuthNotification = new Lang.Class({
|
|||||||
this.connect('action-invoked', Lang.bind(this, function(self, action) {
|
this.connect('action-invoked', Lang.bind(this, function(self, action) {
|
||||||
switch (action) {
|
switch (action) {
|
||||||
case 'always-grant':
|
case 'always-grant':
|
||||||
this._applet.agent_reply_auth(this._devicePath, true, true);
|
this._applet.agent_reply_auth_service(this._devicePath, true, true);
|
||||||
break;
|
break;
|
||||||
case 'grant':
|
case 'grant':
|
||||||
this._applet.agent_reply_auth(this._devicePath, true, false);
|
this._applet.agent_reply_auth_service(this._devicePath, true, false);
|
||||||
break;
|
break;
|
||||||
case 'reject':
|
case 'reject':
|
||||||
default:
|
default:
|
||||||
this._applet.agent_reply_auth(this._devicePath, false, false);
|
this._applet.agent_reply_auth_service(this._devicePath, false, false);
|
||||||
}
|
}
|
||||||
this.destroy();
|
this.destroy();
|
||||||
}));
|
}));
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -10,8 +10,6 @@ const Signals = imports.signals;
|
|||||||
const PanelMenu = imports.ui.panelMenu;
|
const PanelMenu = imports.ui.panelMenu;
|
||||||
const PopupMenu = imports.ui.popupMenu;
|
const PopupMenu = imports.ui.popupMenu;
|
||||||
|
|
||||||
const VOLUME_ADJUSTMENT_STEP = 0.05; /* Volume adjustment step in % */
|
|
||||||
|
|
||||||
const VOLUME_NOTIFY_ID = 1;
|
const VOLUME_NOTIFY_ID = 1;
|
||||||
|
|
||||||
// Each Gvc.MixerControl is a connection to PulseAudio,
|
// Each Gvc.MixerControl is a connection to PulseAudio,
|
||||||
@ -44,7 +42,6 @@ const StreamSlider = new Lang.Class({
|
|||||||
this.item.addMenuItem(this._slider);
|
this.item.addMenuItem(this._slider);
|
||||||
|
|
||||||
this._stream = null;
|
this._stream = null;
|
||||||
this._shouldShow = true;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
get stream() {
|
get stream() {
|
||||||
|
@ -17,7 +17,6 @@ const ModalDialog = imports.ui.modalDialog;
|
|||||||
const Panel = imports.ui.panel;
|
const Panel = imports.ui.panel;
|
||||||
const ShellEntry = imports.ui.shellEntry;
|
const ShellEntry = imports.ui.shellEntry;
|
||||||
const Tweener = imports.ui.tweener;
|
const Tweener = imports.ui.tweener;
|
||||||
const UserMenu = imports.ui.userMenu;
|
|
||||||
const UserWidget = imports.ui.userWidget;
|
const UserWidget = imports.ui.userWidget;
|
||||||
|
|
||||||
const Batch = imports.gdm.batch;
|
const Batch = imports.gdm.batch;
|
||||||
|
@ -20,8 +20,8 @@ const Main = imports.ui.main;
|
|||||||
const ModalDialog = imports.ui.modalDialog;
|
const ModalDialog = imports.ui.modalDialog;
|
||||||
const PanelMenu = imports.ui.panelMenu;
|
const PanelMenu = imports.ui.panelMenu;
|
||||||
const PopupMenu = imports.ui.popupMenu;
|
const PopupMenu = imports.ui.popupMenu;
|
||||||
const Params = imports.misc.params;
|
|
||||||
const Util = imports.misc.util;
|
const Util = imports.misc.util;
|
||||||
|
const UserWidget = imports.ui.userWidget;
|
||||||
|
|
||||||
const LOCKDOWN_SCHEMA = 'org.gnome.desktop.lockdown';
|
const LOCKDOWN_SCHEMA = 'org.gnome.desktop.lockdown';
|
||||||
const SCREENSAVER_SCHEMA = 'org.gnome.desktop.screensaver';
|
const SCREENSAVER_SCHEMA = 'org.gnome.desktop.screensaver';
|
||||||
@ -32,8 +32,6 @@ const DISABLE_LOG_OUT_KEY = 'disable-log-out';
|
|||||||
const ALWAYS_SHOW_LOG_OUT_KEY = 'always-show-log-out';
|
const ALWAYS_SHOW_LOG_OUT_KEY = 'always-show-log-out';
|
||||||
const SHOW_FULL_NAME_IN_TOP_BAR_KEY = 'show-full-name-in-top-bar';
|
const SHOW_FULL_NAME_IN_TOP_BAR_KEY = 'show-full-name-in-top-bar';
|
||||||
|
|
||||||
const DIALOG_ICON_SIZE = 64;
|
|
||||||
|
|
||||||
const MAX_USERS_IN_SESSION_DIALOG = 5;
|
const MAX_USERS_IN_SESSION_DIALOG = 5;
|
||||||
|
|
||||||
const IMStatus = {
|
const IMStatus = {
|
||||||
@ -57,48 +55,6 @@ const SystemdLoginSessionIface = <interface name='org.freedesktop.login1.Session
|
|||||||
|
|
||||||
const SystemdLoginSession = Gio.DBusProxy.makeProxyWrapper(SystemdLoginSessionIface);
|
const SystemdLoginSession = Gio.DBusProxy.makeProxyWrapper(SystemdLoginSessionIface);
|
||||||
|
|
||||||
// Adapted from gdm/gui/user-switch-applet/applet.c
|
|
||||||
//
|
|
||||||
// Copyright (C) 2004-2005 James M. Cape <jcape@ignore-your.tv>.
|
|
||||||
// Copyright (C) 2008,2009 Red Hat, Inc.
|
|
||||||
|
|
||||||
const UserAvatarWidget = new Lang.Class({
|
|
||||||
Name: 'UserAvatarWidget',
|
|
||||||
|
|
||||||
_init: function(user, params) {
|
|
||||||
this._user = user;
|
|
||||||
params = Params.parse(params, { reactive: false,
|
|
||||||
iconSize: DIALOG_ICON_SIZE,
|
|
||||||
styleClass: 'status-chooser-user-icon' });
|
|
||||||
this._iconSize = params.iconSize;
|
|
||||||
|
|
||||||
this.actor = new St.Bin({ style_class: params.styleClass,
|
|
||||||
track_hover: params.reactive,
|
|
||||||
reactive: params.reactive });
|
|
||||||
},
|
|
||||||
|
|
||||||
setSensitive: function(sensitive) {
|
|
||||||
this.actor.can_focus = sensitive;
|
|
||||||
this.actor.reactive = sensitive;
|
|
||||||
},
|
|
||||||
|
|
||||||
update: function() {
|
|
||||||
let iconFile = this._user.get_icon_file();
|
|
||||||
if (iconFile && !GLib.file_test(iconFile, GLib.FileTest.EXISTS))
|
|
||||||
iconFile = null;
|
|
||||||
|
|
||||||
if (iconFile) {
|
|
||||||
let file = Gio.File.new_for_path(iconFile);
|
|
||||||
this.actor.child = null;
|
|
||||||
this.actor.style = 'background-image: url("%s");'.format(iconFile);
|
|
||||||
} else {
|
|
||||||
this.actor.style = null;
|
|
||||||
this.actor.child = new St.Icon({ icon_name: 'avatar-default-symbolic',
|
|
||||||
icon_size: this._iconSize });
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
const IMStatusItem = new Lang.Class({
|
const IMStatusItem = new Lang.Class({
|
||||||
Name: 'IMStatusItem',
|
Name: 'IMStatusItem',
|
||||||
Extends: PopupMenu.PopupBaseMenuItem,
|
Extends: PopupMenu.PopupBaseMenuItem,
|
||||||
@ -170,7 +126,7 @@ const IMStatusChooserItem = 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._avatar = new UserAvatarWidget(this._user, { reactive: true });
|
this._avatar = new UserWidget.Avatar(this._user, { reactive: true });
|
||||||
this._iconBin = new St.Button({ child: this._avatar.actor });
|
this._iconBin = new St.Button({ child: this._avatar.actor });
|
||||||
this.addActor(this._iconBin);
|
this.addActor(this._iconBin);
|
||||||
|
|
||||||
@ -610,7 +566,6 @@ const UserMenuButton = new Lang.Class({
|
|||||||
|
|
||||||
let allowSettings = Main.sessionMode.allowSettings;
|
let allowSettings = Main.sessionMode.allowSettings;
|
||||||
this._statusChooser.setSensitive(allowSettings);
|
this._statusChooser.setSensitive(allowSettings);
|
||||||
this._systemSettings.visible = allowSettings;
|
|
||||||
|
|
||||||
this.setSensitive(!Main.sessionMode.isLocked);
|
this.setSensitive(!Main.sessionMode.isLocked);
|
||||||
this._updatePresenceIcon();
|
this._updatePresenceIcon();
|
||||||
@ -786,10 +741,7 @@ const UserMenuButton = new Lang.Class({
|
|||||||
item = new PopupMenu.PopupSeparatorMenuItem();
|
item = new PopupMenu.PopupSeparatorMenuItem();
|
||||||
this.menu.addMenuItem(item);
|
this.menu.addMenuItem(item);
|
||||||
|
|
||||||
item = new PopupMenu.PopupMenuItem(_("Settings"));
|
this.menu.addSettingsAction(_("Settings"), 'gnome-control-center.desktop');
|
||||||
item.connect('activate', Lang.bind(this, this._onPreferencesActivate));
|
|
||||||
this.menu.addMenuItem(item);
|
|
||||||
this._systemSettings = item;
|
|
||||||
|
|
||||||
item = new PopupMenu.PopupSeparatorMenuItem();
|
item = new PopupMenu.PopupSeparatorMenuItem();
|
||||||
this.menu.addMenuItem(item);
|
this.menu.addMenuItem(item);
|
||||||
@ -850,12 +802,6 @@ const UserMenuButton = new Lang.Class({
|
|||||||
app.activate();
|
app.activate();
|
||||||
},
|
},
|
||||||
|
|
||||||
_onPreferencesActivate: function() {
|
|
||||||
Main.overview.hide();
|
|
||||||
let app = Shell.AppSystem.get_default().lookup_app('gnome-control-center.desktop');
|
|
||||||
app.activate();
|
|
||||||
},
|
|
||||||
|
|
||||||
_onLockScreenActivate: function() {
|
_onLockScreenActivate: function() {
|
||||||
this.menu.close(BoxPointer.PopupAnimation.NONE);
|
this.menu.close(BoxPointer.PopupAnimation.NONE);
|
||||||
Main.overview.hide();
|
Main.overview.hide();
|
||||||
@ -908,7 +854,7 @@ const UserMenuButton = new Lang.Class({
|
|||||||
let session = sessions[i];
|
let session = sessions[i];
|
||||||
let userEntry = new St.BoxLayout({ style_class: 'login-dialog-user-list-item',
|
let userEntry = new St.BoxLayout({ style_class: 'login-dialog-user-list-item',
|
||||||
vertical: false });
|
vertical: false });
|
||||||
let avatar = new UserAvatarWidget(session.user);
|
let avatar = new UserWidget.Avatar(session.user);
|
||||||
avatar.update();
|
avatar.update();
|
||||||
userEntry.add(avatar.actor);
|
userEntry.add(avatar.actor);
|
||||||
|
|
||||||
|
@ -3,10 +3,56 @@
|
|||||||
//
|
//
|
||||||
// A widget showing the user avatar and name
|
// A widget showing the user avatar and name
|
||||||
const AccountsService = imports.gi.AccountsService;
|
const AccountsService = imports.gi.AccountsService;
|
||||||
|
const GLib = imports.gi.GLib;
|
||||||
|
const Gio = imports.gi.Gio;
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
const St = imports.gi.St;
|
const St = imports.gi.St;
|
||||||
|
|
||||||
const UserMenu = imports.ui.userMenu;
|
const Params = imports.misc.params;
|
||||||
|
|
||||||
|
const AVATAR_ICON_SIZE = 64;
|
||||||
|
|
||||||
|
// Adapted from gdm/gui/user-switch-applet/applet.c
|
||||||
|
//
|
||||||
|
// Copyright (C) 2004-2005 James M. Cape <jcape@ignore-your.tv>.
|
||||||
|
// Copyright (C) 2008,2009 Red Hat, Inc.
|
||||||
|
|
||||||
|
const Avatar = new Lang.Class({
|
||||||
|
Name: 'Avatar',
|
||||||
|
|
||||||
|
_init: function(user, params) {
|
||||||
|
this._user = user;
|
||||||
|
params = Params.parse(params, { reactive: false,
|
||||||
|
iconSize: AVATAR_ICON_SIZE,
|
||||||
|
styleClass: 'status-chooser-user-icon' });
|
||||||
|
this._iconSize = params.iconSize;
|
||||||
|
|
||||||
|
this.actor = new St.Bin({ style_class: params.styleClass,
|
||||||
|
track_hover: params.reactive,
|
||||||
|
reactive: params.reactive });
|
||||||
|
},
|
||||||
|
|
||||||
|
setSensitive: function(sensitive) {
|
||||||
|
this.actor.can_focus = sensitive;
|
||||||
|
this.actor.reactive = sensitive;
|
||||||
|
},
|
||||||
|
|
||||||
|
update: function() {
|
||||||
|
let iconFile = this._user.get_icon_file();
|
||||||
|
if (iconFile && !GLib.file_test(iconFile, GLib.FileTest.EXISTS))
|
||||||
|
iconFile = null;
|
||||||
|
|
||||||
|
if (iconFile) {
|
||||||
|
let file = Gio.File.new_for_path(iconFile);
|
||||||
|
this.actor.child = null;
|
||||||
|
this.actor.style = 'background-image: url("%s");'.format(iconFile);
|
||||||
|
} else {
|
||||||
|
this.actor.style = null;
|
||||||
|
this.actor.child = new St.Icon({ icon_name: 'avatar-default-symbolic',
|
||||||
|
icon_size: this._iconSize });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
const UserWidget = new Lang.Class({
|
const UserWidget = new Lang.Class({
|
||||||
Name: 'UserWidget',
|
Name: 'UserWidget',
|
||||||
@ -18,7 +64,7 @@ const UserWidget = new Lang.Class({
|
|||||||
vertical: false });
|
vertical: false });
|
||||||
this.actor.connect('destroy', Lang.bind(this, this._onDestroy));
|
this.actor.connect('destroy', Lang.bind(this, this._onDestroy));
|
||||||
|
|
||||||
this._avatar = new UserMenu.UserAvatarWidget(user);
|
this._avatar = new Avatar(user);
|
||||||
this.actor.add(this._avatar.actor,
|
this.actor.add(this._avatar.actor,
|
||||||
{ x_fill: true, y_fill: true });
|
{ x_fill: true, y_fill: true });
|
||||||
|
|
||||||
|
@ -93,8 +93,8 @@ const WorkspaceTracker = new Lang.Class({
|
|||||||
global.screen.connect('window-left-monitor', Lang.bind(this, this._windowLeftMonitor));
|
global.screen.connect('window-left-monitor', Lang.bind(this, this._windowLeftMonitor));
|
||||||
global.screen.connect('restacked', Lang.bind(this, this._windowsRestacked));
|
global.screen.connect('restacked', Lang.bind(this, this._windowsRestacked));
|
||||||
|
|
||||||
this._overrideSettings = new Gio.Settings({ schema: 'org.gnome.shell.overrides' });
|
this._workspaceSettings = new Gio.Settings({ schema: Main.dynamicWorkspacesSchema });
|
||||||
this._overrideSettings.connect('changed::dynamic-workspaces', Lang.bind(this, this._queueCheckWorkspaces));
|
this._workspaceSettings.connect('changed::dynamic-workspaces', Lang.bind(this, this._queueCheckWorkspaces));
|
||||||
|
|
||||||
this._nWorkspacesChanged();
|
this._nWorkspacesChanged();
|
||||||
},
|
},
|
||||||
|
11
po/cs.po
11
po/cs.po
@ -317,12 +317,12 @@ msgstr ""
|
|||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:42
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:42
|
||||||
msgid "Attach modal dialog to the parent window"
|
msgid "Attach modal dialog to the parent window"
|
||||||
msgstr "Připojovat modální dialogová okna k rodičovským oknům"
|
msgstr "Modální dialogová okna připojovat k rodičovskému oknu"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:43
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:43
|
||||||
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 "Tento kíč přepisuje klíč v org.gnome.mutter, když běží GNOME Shell."
|
msgstr "Když běží GNOME Shell, tento klíč přepíše klíč v org.gnome.mutter"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:44
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:44
|
||||||
msgid "Arrangement of buttons on the titlebar"
|
msgid "Arrangement of buttons on the titlebar"
|
||||||
@ -333,12 +333,11 @@ 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."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Tento kíč přepisuje klíč v org.gnome.desktop.wm.preferences, když běží GNOME "
|
"Když běží GNOME Shell, tento klíč přepíše klíč v org.gnome.desktop.wm.preferences"
|
||||||
"Shell."
|
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:46
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:46
|
||||||
msgid "Enable edge tiling when dropping windows on screen edges"
|
msgid "Enable edge tiling when dropping windows on screen edges"
|
||||||
msgstr "Nechat okna upuštěná při okraji obrazovky vytvářet dlaždice"
|
msgstr "Okna upuštěná u okraje obrazovky nechat řadit jako dlaždice"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:47
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:47
|
||||||
msgid "Workspaces are managed dynamically"
|
msgid "Workspaces are managed dynamically"
|
||||||
@ -346,7 +345,7 @@ msgstr "Pracovní plochy jsou spravovány dynamicky"
|
|||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:48
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:48
|
||||||
msgid "Workspaces only on primary monitor"
|
msgid "Workspaces only on primary monitor"
|
||||||
msgstr "Pracovní plochy pouze na hlavním monitoru"
|
msgstr "Pracovní plochy jen na hlavním monitoru"
|
||||||
|
|
||||||
#: ../js/extensionPrefs/main.js:125
|
#: ../js/extensionPrefs/main.js:125
|
||||||
#, c-format
|
#, c-format
|
||||||
|
389
po/de.po
389
po/de.po
@ -17,9 +17,10 @@
|
|||||||
msgid ""
|
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: http://bugzilla.gnome.org/enter_bug.cgi?product=gnome-"
|
||||||
"POT-Creation-Date: 2013-03-11 14:22+0100\n"
|
"shell&keywords=I18N+L10N&component=general\n"
|
||||||
"PO-Revision-Date: 2013-03-11 14:25+0100\n"
|
"POT-Creation-Date: 2013-05-31 22:35+0000\n"
|
||||||
|
"PO-Revision-Date: 2013-06-02 09:48+0100\n"
|
||||||
"Last-Translator: Christian Kirbach <christian.kirbach@gmail.com>\n"
|
"Last-Translator: Christian Kirbach <christian.kirbach@gmail.com>\n"
|
||||||
"Language-Team: Deutsch <gnome-de@gnome.org>\n"
|
"Language-Team: Deutsch <gnome-de@gnome.org>\n"
|
||||||
"Language: de_DE\n"
|
"Language: de_DE\n"
|
||||||
@ -27,7 +28,7 @@ msgstr ""
|
|||||||
"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: Gtranslator 2.91.6\n"
|
"X-Generator: Poedit 1.5.4\n"
|
||||||
|
|
||||||
#: ../data/50-gnome-shell-screenshot.xml.in.h:1
|
#: ../data/50-gnome-shell-screenshot.xml.in.h:1
|
||||||
msgid "Screenshots"
|
msgid "Screenshots"
|
||||||
@ -50,10 +51,14 @@ msgid "Focus the active notification"
|
|||||||
msgstr "Auf aktive Benachrichtigungen ausrichten"
|
msgstr "Auf aktive Benachrichtigungen ausrichten"
|
||||||
|
|
||||||
#: ../data/50-gnome-shell-system.xml.in.h:4
|
#: ../data/50-gnome-shell-system.xml.in.h:4
|
||||||
|
msgid "Show the overview"
|
||||||
|
msgstr "Die Übersicht anzeigen"
|
||||||
|
|
||||||
|
#: ../data/50-gnome-shell-system.xml.in.h:5
|
||||||
msgid "Show all applications"
|
msgid "Show all applications"
|
||||||
msgstr "Alle Anwendungen anzeigen"
|
msgstr "Alle Anwendungen anzeigen"
|
||||||
|
|
||||||
#: ../data/50-gnome-shell-system.xml.in.h:5
|
#: ../data/50-gnome-shell-system.xml.in.h:6
|
||||||
msgid "Open the application menu"
|
msgid "Open the application menu"
|
||||||
msgstr "Das Anwendungsmenü öffnen"
|
msgstr "Das Anwendungsmenü öffnen"
|
||||||
|
|
||||||
@ -102,27 +107,10 @@ msgstr ""
|
|||||||
"gnome.Shell bearbeiten."
|
"gnome.Shell bearbeiten."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:5
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:5
|
||||||
msgid "Whether to collect stats about applications usage"
|
|
||||||
msgstr "Legt fest, ob Statistiken über Anwendungsnutzung erfasst werden sollen"
|
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:6
|
|
||||||
msgid ""
|
|
||||||
"The shell normally monitors active applications in order to present the most "
|
|
||||||
"used ones (e.g. in launchers). While this data will be kept private, you may "
|
|
||||||
"want to disable this for privacy reasons. Please note that doing so won't "
|
|
||||||
"remove already saved data."
|
|
||||||
msgstr ""
|
|
||||||
"Die Shell überwacht normalerweise aktive Anwendungen, wobei die "
|
|
||||||
"meistgenutzten zuerst erfasst werden (z.B. in Anwendungsstartern). Zwar "
|
|
||||||
"werden diese Daten privat gespeichert, doch möglicherweise wollen Sie dies "
|
|
||||||
"deaktivieren, um Ihre Privatsphäre zu schützen. Bitte beachten Sie, dass "
|
|
||||||
"bereits gespeicherte Daten hiervon nicht beeinflusst werden."
|
|
||||||
|
|
||||||
#: ../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 der Kennungen der Desktop-Dateien für bevorzugte Anwendungen"
|
msgstr "Liste der Kennungen der Desktop-Dateien für bevorzugte Anwendungen"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:8
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:6
|
||||||
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."
|
||||||
@ -130,11 +118,11 @@ msgstr ""
|
|||||||
"Programme, welche auf diese Bezeichner zutreffen, werden im Favoriten-"
|
"Programme, welche auf diese Bezeichner zutreffen, werden im Favoriten-"
|
||||||
"Bereich angezeigt."
|
"Bereich angezeigt."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:9
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:7
|
||||||
msgid "List of categories that should be displayed as folders"
|
msgid "List of categories that should be displayed as folders"
|
||||||
msgstr "Liste der Kategorien, die als Ordner angezeigt werden sollen"
|
msgstr "Liste der Kategorien, die als Ordner angezeigt werden sollen"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:10
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:8
|
||||||
msgid ""
|
msgid ""
|
||||||
"Each category name in this list will be represented as folder in the "
|
"Each category name in this list will be represented as folder in the "
|
||||||
"application view, rather than being displayed inline in the main view."
|
"application view, rather than being displayed inline in the main view."
|
||||||
@ -142,15 +130,15 @@ msgstr ""
|
|||||||
"Jeder Kategoriename in dieser Liste wird als Ordner in der Anwendungsansicht "
|
"Jeder Kategoriename in dieser Liste wird als Ordner in der Anwendungsansicht "
|
||||||
"dargestellt, anstatt in der Hauptansicht eingebettet."
|
"dargestellt, anstatt in der Hauptansicht eingebettet."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:11
|
#: ../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 "Verlauf des Befehlsdialogs (Alt+F2)"
|
msgstr "Verlauf des Befehlsdialogs (Alt+F2)"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:12
|
#: ../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 "Chronik des Dialogs »looking glass«"
|
msgstr "Chronik des Dialogs »looking glass«"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:13
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:11
|
||||||
msgid ""
|
msgid ""
|
||||||
"Internally used to store the last IM presence explicitly set by the user. "
|
"Internally used to store the last IM presence explicitly set by the user. "
|
||||||
"The value here is from the TpConnectionPresenceType enumeration."
|
"The value here is from the TpConnectionPresenceType enumeration."
|
||||||
@ -159,7 +147,7 @@ msgstr ""
|
|||||||
"der explizit vom Benutzer gesetzt wurde. Der hier verwendete Wert wird der "
|
"der explizit vom Benutzer gesetzt wurde. Der hier verwendete Wert wird der "
|
||||||
"TpConnectionPresenceType-Aufzählung entnommen."
|
"TpConnectionPresenceType-Aufzählung entnommen."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:14
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:12
|
||||||
msgid ""
|
msgid ""
|
||||||
"Internally used to store the last session presence status for the user. The "
|
"Internally used to store the last session presence status for the user. The "
|
||||||
"value here is from the GsmPresenceStatus enumeration."
|
"value here is from the GsmPresenceStatus enumeration."
|
||||||
@ -168,11 +156,11 @@ msgstr ""
|
|||||||
"Benutzers verwendet. Der hier verwendete Wert wird der GsmPresenceStatus-"
|
"Benutzers verwendet. Der hier verwendete Wert wird der GsmPresenceStatus-"
|
||||||
"Aufzählung entnommen."
|
"Aufzählung entnommen."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:15
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:13
|
||||||
msgid "Always show the 'Log out' menuitem in the user menu."
|
msgid "Always show the 'Log out' menuitem in the user menu."
|
||||||
msgstr "Den Menüeintrag »Abmelden« immer im Benutzermenü anzeigen."
|
msgstr "Den Menüeintrag »Abmelden« immer im Benutzermenü anzeigen."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:16
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:14
|
||||||
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' menuitem in single-"
|
||||||
"user, single-session situations."
|
"user, single-session situations."
|
||||||
@ -180,14 +168,14 @@ msgstr ""
|
|||||||
"Dieser Schlüssel überschreibt das automatische Verbergen des Menüeintrags "
|
"Dieser Schlüssel überschreibt das automatische Verbergen des Menüeintrags "
|
||||||
"»Abmelden« in Einzelbenutzer, Einzelsitzungssituationen."
|
"»Abmelden« in Einzelbenutzer, Einzelsitzungssituationen."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:17
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:15
|
||||||
msgid ""
|
msgid ""
|
||||||
"Whether to remember password for mounting encrypted or remote filesystems"
|
"Whether to remember password for mounting encrypted or remote filesystems"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Legt fest, ob Passwörter für eingehängte, verschlüsselte oder ferne "
|
"Legt fest, ob Passwörter für eingehängte, verschlüsselte oder ferne "
|
||||||
"Dateisysteme gespeichert werden"
|
"Dateisysteme gespeichert werden"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:18
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:16
|
||||||
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 "
|
||||||
@ -200,34 +188,42 @@ msgstr ""
|
|||||||
"angeboten. Dieser Schlüssel stellt den Standardstatus für dieses Ankreuzfeld "
|
"angeboten. Dieser Schlüssel stellt den Standardstatus für dieses Ankreuzfeld "
|
||||||
"ein."
|
"ein."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:19
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:17
|
||||||
msgid "Show the week date in the calendar"
|
msgid "Show the week date in the calendar"
|
||||||
msgstr "Wochentag im Kalender anzeigen"
|
msgstr "Wochentag im Kalender anzeigen"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:20
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:18
|
||||||
msgid "If true, display the ISO week date in the calendar."
|
msgid "If true, display the ISO week date in the calendar."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Wenn dieser Wert gesetzt ist, wird der ISO-Wochentag im Kalender angezeigt."
|
"Wenn dieser Wert gesetzt ist, wird der ISO-Wochentag im Kalender angezeigt."
|
||||||
|
|
||||||
#: ../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 application menu"
|
msgid "Keybinding to open the application menu"
|
||||||
msgstr "Tastenkombination zum Öffnen des Anwendungsmenüs"
|
msgstr "Tastenkombination zum Öffnen des Anwendungsmenüs"
|
||||||
|
|
||||||
#: ../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 application menu."
|
msgid "Keybinding to open the application menu."
|
||||||
msgstr "Tastenkombination zum Öffnen des Anwendungsmenüs."
|
msgstr "Tastenkombination zum Öffnen des Anwendungsmenüs."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:23
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:21
|
||||||
msgid "Keybinding to open the \"Show Applications\" view"
|
msgid "Keybinding to open the \"Show Applications\" view"
|
||||||
msgstr "Tastenkombination zum Öffnen der »Anwendungen anzeigen«-Ansicht"
|
msgstr "Tastenkombination zum Öffnen der »Anwendungen anzeigen«-Ansicht"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:24
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:22
|
||||||
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 ""
|
||||||
"Tastenkombination zum Öffnen der »Anwendungen anzeigen«-Ansicht der "
|
"Tastenkombination zum Öffnen der »Anwendungen anzeigen«-Ansicht der "
|
||||||
"Aktivitätenübersicht."
|
"Aktivitätenübersicht."
|
||||||
|
|
||||||
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:23
|
||||||
|
msgid "Keybinding to open the overview"
|
||||||
|
msgstr "Tastenkombination zum Öffnen der Übersicht"
|
||||||
|
|
||||||
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:24
|
||||||
|
msgid "Keybinding to open the Activities Overview."
|
||||||
|
msgstr "Tastenkombination zum Öffnen der »Aktivitäten«-Übersicht"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:25
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:25
|
||||||
msgid "Keybinding to toggle the visibility of the message tray"
|
msgid "Keybinding to toggle the visibility of the message tray"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
@ -391,43 +387,50 @@ msgstr "Erweiterung"
|
|||||||
msgid "Select an extension to configure using the combobox above."
|
msgid "Select an extension to configure using the combobox above."
|
||||||
msgstr "Wählen Sie oben eine Erweiterung aus, die Sie konfigurieren wollen."
|
msgstr "Wählen Sie oben eine Erweiterung aus, die Sie konfigurieren wollen."
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:405
|
#: ../js/gdm/loginDialog.js:371
|
||||||
msgid "Session…"
|
msgid "Session…"
|
||||||
msgstr "Sitzung …"
|
msgstr "Sitzung …"
|
||||||
|
|
||||||
#. translators: this message is shown below the user list on the
|
#. translators: this message is shown below the user list on the
|
||||||
#. login screen. It can be activated to reveal an entry for
|
#. login screen. It can be activated to reveal an entry for
|
||||||
#. manually entering the username.
|
#. manually entering the username.
|
||||||
#: ../js/gdm/loginDialog.js:630
|
#: ../js/gdm/loginDialog.js:601
|
||||||
msgid "Not listed?"
|
msgid "Not listed?"
|
||||||
msgstr "Nicht aufgeführt?"
|
msgstr "Nicht aufgeführt?"
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:784 ../js/ui/components/networkAgent.js:137
|
#: ../js/gdm/loginDialog.js:776 ../js/ui/components/networkAgent.js:137
|
||||||
#: ../js/ui/components/polkitAgent.js:162 ../js/ui/endSessionDialog.js:375
|
#: ../js/ui/components/polkitAgent.js:161 ../js/ui/endSessionDialog.js:376
|
||||||
#: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399
|
#: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399
|
||||||
#: ../js/ui/status/bluetooth.js:415 ../js/ui/unlockDialog.js:98
|
#: ../js/ui/status/bluetooth.js:415 ../js/ui/unlockDialog.js:96
|
||||||
#: ../js/ui/userMenu.js:938
|
#: ../js/ui/userMenu.js:938
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
msgstr "Abbrechen"
|
msgstr "Abbrechen"
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:800
|
#: ../js/gdm/loginDialog.js:791
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Sign In"
|
msgid "Sign In"
|
||||||
msgstr "Anmelden"
|
msgstr "Anmelden"
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:800
|
#: ../js/gdm/loginDialog.js:791
|
||||||
msgid "Next"
|
msgid "Next"
|
||||||
msgstr "Nächstes"
|
msgstr "Nächstes"
|
||||||
|
|
||||||
|
#. Translators: this message is shown below the username entry field
|
||||||
|
#. to clue the user in on how to login to the local network realm
|
||||||
|
#: ../js/gdm/loginDialog.js:888
|
||||||
|
#, c-format
|
||||||
|
msgid "(e.g., user or %s)"
|
||||||
|
msgstr "(z.B. Benutzer oder %s)"
|
||||||
|
|
||||||
#. TTLS and PEAP are actually much more complicated, but this complication
|
#. TTLS and PEAP are actually much more complicated, but this complication
|
||||||
#. is not visible here since we only care about phase2 authentication
|
#. is not visible here since we only care about phase2 authentication
|
||||||
#. (and don't even care of which one)
|
#. (and don't even care of which one)
|
||||||
#: ../js/gdm/loginDialog.js:915 ../js/ui/components/networkAgent.js:260
|
#: ../js/gdm/loginDialog.js:892 ../js/ui/components/networkAgent.js:260
|
||||||
#: ../js/ui/components/networkAgent.js:278
|
#: ../js/ui/components/networkAgent.js:278
|
||||||
msgid "Username: "
|
msgid "Username: "
|
||||||
msgstr "Benutzername:"
|
msgstr "Benutzername:"
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:1168
|
#: ../js/gdm/loginDialog.js:1158
|
||||||
msgid "Login Window"
|
msgid "Login Window"
|
||||||
msgstr "Anmeldefenster"
|
msgstr "Anmeldefenster"
|
||||||
|
|
||||||
@ -450,53 +453,48 @@ msgstr "Neu starten"
|
|||||||
msgid "Power Off"
|
msgid "Power Off"
|
||||||
msgstr "Ausschalten"
|
msgstr "Ausschalten"
|
||||||
|
|
||||||
#: ../js/gdm/util.js:182
|
#: ../js/gdm/util.js:247
|
||||||
msgid "Authentication error"
|
msgid "Authentication error"
|
||||||
msgstr "Legitimationsfehler"
|
msgstr "Legitimationsfehler"
|
||||||
|
|
||||||
#. Translators: this message is shown below the password entry field
|
#. Translators: this message is shown below the password entry field
|
||||||
#. to indicate the user can swipe their finger instead
|
#. to indicate the user can swipe their finger instead
|
||||||
#: ../js/gdm/util.js:299
|
#: ../js/gdm/util.js:364
|
||||||
msgid "(or swipe finger)"
|
msgid "(or swipe finger)"
|
||||||
msgstr "(oder benutzen Sie den Fingerabdruckleser)"
|
msgstr "(oder benutzen Sie den Fingerabdruckleser)"
|
||||||
|
|
||||||
#: ../js/gdm/util.js:324
|
#: ../js/misc/util.js:97
|
||||||
#, c-format
|
|
||||||
msgid "(e.g., user or %s)"
|
|
||||||
msgstr "(z.B. Benutzer oder %s)"
|
|
||||||
|
|
||||||
#: ../js/misc/util.js:94
|
|
||||||
msgid "Command not found"
|
msgid "Command not found"
|
||||||
msgstr "Befehl nicht gefunden"
|
msgstr "Befehl nicht gefunden"
|
||||||
|
|
||||||
#. Replace "Error invoking GLib.shell_parse_argv: " with
|
#. Replace "Error invoking GLib.shell_parse_argv: " with
|
||||||
#. something nicer
|
#. something nicer
|
||||||
#: ../js/misc/util.js:127
|
#: ../js/misc/util.js:130
|
||||||
msgid "Could not parse command:"
|
msgid "Could not parse command:"
|
||||||
msgstr "Befehl konnte nicht verarbeitet werden:"
|
msgstr "Befehl konnte nicht verarbeitet werden:"
|
||||||
|
|
||||||
#: ../js/misc/util.js:135
|
#: ../js/misc/util.js:138
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Execution of '%s' failed:"
|
msgid "Execution of '%s' failed:"
|
||||||
msgstr "Ausführung von »%s« ist gescheitert:"
|
msgstr "Ausführung von »%s« ist gescheitert:"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:348
|
#: ../js/ui/appDisplay.js:361
|
||||||
msgid "Frequent"
|
msgid "Frequent"
|
||||||
msgstr "Häufig"
|
msgstr "Häufig"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:355
|
#: ../js/ui/appDisplay.js:368
|
||||||
msgid "All"
|
msgid "All"
|
||||||
msgstr "Alle"
|
msgstr "Alle"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:913
|
#: ../js/ui/appDisplay.js:960
|
||||||
msgid "New Window"
|
msgid "New Window"
|
||||||
msgstr "Neues Fenster"
|
msgstr "Neues Fenster"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:916 ../js/ui/dash.js:284
|
#: ../js/ui/appDisplay.js:963 ../js/ui/dash.js:284
|
||||||
msgid "Remove from Favorites"
|
msgid "Remove from Favorites"
|
||||||
msgstr "Aus Favoriten entfernen"
|
msgstr "Aus Favoriten entfernen"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:917
|
#: ../js/ui/appDisplay.js:964
|
||||||
msgid "Add to Favorites"
|
msgid "Add to Favorites"
|
||||||
msgstr "Zu Favoriten hinzufügen"
|
msgstr "Zu Favoriten hinzufügen"
|
||||||
|
|
||||||
@ -536,7 +534,7 @@ msgstr "%H\\u2236%M"
|
|||||||
|
|
||||||
# wird nur verwendet, wenn die Anwendung explizit auf 12h-Format eingestellt ist.
|
# wird nur verwendet, wenn die Anwendung explizit auf 12h-Format eingestellt ist.
|
||||||
# http://linux.die.net/man/3/strftime
|
# http://linux.die.net/man/3/strftime
|
||||||
#. Transators: Shown in calendar event list, if 12h format,
|
#. Translators: Shown in calendar event list, if 12h format,
|
||||||
#. \u2236 is a ratio character, similar to : and \u2009 is
|
#. \u2236 is a ratio character, similar to : and \u2009 is
|
||||||
#. a thin space
|
#. a thin space
|
||||||
#: ../js/ui/calendar.js:77
|
#: ../js/ui/calendar.js:77
|
||||||
@ -638,35 +636,35 @@ msgid "S"
|
|||||||
msgstr "Sa"
|
msgstr "Sa"
|
||||||
|
|
||||||
#. Translators: Text to show if there are no events
|
#. Translators: Text to show if there are no events
|
||||||
#: ../js/ui/calendar.js:720
|
#: ../js/ui/calendar.js:735
|
||||||
msgid "Nothing Scheduled"
|
msgid "Nothing Scheduled"
|
||||||
msgstr "Nichts geplant"
|
msgstr "Nichts geplant"
|
||||||
|
|
||||||
#. Translators: Shown on calendar heading when selected day occurs on current year
|
#. Translators: Shown on calendar heading when selected day occurs on current year
|
||||||
#: ../js/ui/calendar.js:736
|
#: ../js/ui/calendar.js:751
|
||||||
msgctxt "calendar heading"
|
msgctxt "calendar heading"
|
||||||
msgid "%A, %B %d"
|
msgid "%A, %B %d"
|
||||||
msgstr "%A, %d. %B"
|
msgstr "%A, %d. %B"
|
||||||
|
|
||||||
#. Translators: Shown on calendar heading when selected day occurs on different year
|
#. Translators: Shown on calendar heading when selected day occurs on different year
|
||||||
#: ../js/ui/calendar.js:739
|
#: ../js/ui/calendar.js:754
|
||||||
msgctxt "calendar heading"
|
msgctxt "calendar heading"
|
||||||
msgid "%A, %B %d, %Y"
|
msgid "%A, %B %d, %Y"
|
||||||
msgstr "%a, %d. %B %Y"
|
msgstr "%a, %d. %B %Y"
|
||||||
|
|
||||||
#: ../js/ui/calendar.js:749
|
#: ../js/ui/calendar.js:764
|
||||||
msgid "Today"
|
msgid "Today"
|
||||||
msgstr "Heute"
|
msgstr "Heute"
|
||||||
|
|
||||||
#: ../js/ui/calendar.js:753
|
#: ../js/ui/calendar.js:768
|
||||||
msgid "Tomorrow"
|
msgid "Tomorrow"
|
||||||
msgstr "Morgen"
|
msgstr "Morgen"
|
||||||
|
|
||||||
#: ../js/ui/calendar.js:764
|
#: ../js/ui/calendar.js:779
|
||||||
msgid "This week"
|
msgid "This week"
|
||||||
msgstr "Diese Woche"
|
msgstr "Diese Woche"
|
||||||
|
|
||||||
#: ../js/ui/calendar.js:772
|
#: ../js/ui/calendar.js:787
|
||||||
msgid "Next week"
|
msgid "Next week"
|
||||||
msgstr "Nächste Woche"
|
msgstr "Nächste Woche"
|
||||||
|
|
||||||
@ -682,20 +680,20 @@ msgstr "Externes Laufwerk getrennt"
|
|||||||
msgid "Removable Devices"
|
msgid "Removable Devices"
|
||||||
msgstr "Wechseldatenträger"
|
msgstr "Wechseldatenträger"
|
||||||
|
|
||||||
#: ../js/ui/components/autorunManager.js:593
|
#: ../js/ui/components/autorunManager.js:594
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Open with %s"
|
msgid "Open with %s"
|
||||||
msgstr "Öffnen mit %s"
|
msgstr "Öffnen mit %s"
|
||||||
|
|
||||||
#: ../js/ui/components/autorunManager.js:619
|
#: ../js/ui/components/autorunManager.js:620
|
||||||
msgid "Eject"
|
msgid "Eject"
|
||||||
msgstr "Auswerfen"
|
msgstr "Auswerfen"
|
||||||
|
|
||||||
#: ../js/ui/components/keyring.js:82 ../js/ui/components/polkitAgent.js:268
|
#: ../js/ui/components/keyring.js:88 ../js/ui/components/polkitAgent.js:280
|
||||||
msgid "Password:"
|
msgid "Password:"
|
||||||
msgstr "Passwort:"
|
msgstr "Passwort:"
|
||||||
|
|
||||||
#: ../js/ui/components/keyring.js:101
|
#: ../js/ui/components/keyring.js:107
|
||||||
msgid "Type again:"
|
msgid "Type again:"
|
||||||
msgstr "Erneut eingeben:"
|
msgstr "Erneut eingeben:"
|
||||||
|
|
||||||
@ -775,15 +773,15 @@ msgstr "Passwort der mobilen Breitbandverbindung"
|
|||||||
msgid "A password is required to connect to '%s'."
|
msgid "A password is required to connect to '%s'."
|
||||||
msgstr "Es wird ein Passwort benötigt, um sich mit »%s« zu verbinden."
|
msgstr "Es wird ein Passwort benötigt, um sich mit »%s« zu verbinden."
|
||||||
|
|
||||||
#: ../js/ui/components/polkitAgent.js:55
|
#: ../js/ui/components/polkitAgent.js:54
|
||||||
msgid "Authentication Required"
|
msgid "Authentication Required"
|
||||||
msgstr "Legitimierung erforderlich"
|
msgstr "Legitimierung erforderlich"
|
||||||
|
|
||||||
#: ../js/ui/components/polkitAgent.js:93
|
#: ../js/ui/components/polkitAgent.js:92
|
||||||
msgid "Administrator"
|
msgid "Administrator"
|
||||||
msgstr "Systemverwalter"
|
msgstr "Systemverwalter"
|
||||||
|
|
||||||
#: ../js/ui/components/polkitAgent.js:165
|
#: ../js/ui/components/polkitAgent.js:170
|
||||||
msgid "Authenticate"
|
msgid "Authenticate"
|
||||||
msgstr "Legitimieren"
|
msgstr "Legitimieren"
|
||||||
|
|
||||||
@ -791,12 +789,12 @@ msgstr "Legitimieren"
|
|||||||
#. * requested authentication was not gained; this can happen
|
#. * requested authentication was not gained; this can happen
|
||||||
#. * because of an authentication error (like invalid password),
|
#. * because of an authentication error (like invalid password),
|
||||||
#. * for instance.
|
#. * for instance.
|
||||||
#: ../js/ui/components/polkitAgent.js:256 ../js/ui/shellMountOperation.js:383
|
#: ../js/ui/components/polkitAgent.js:266 ../js/ui/shellMountOperation.js:383
|
||||||
msgid "Sorry, that didn't work. Please try again."
|
msgid "Sorry, that didn't work. Please try again."
|
||||||
msgstr "Entschuldigung, das hat nicht geklappt. Bitte versuchen Sie es erneut."
|
msgstr "Entschuldigung, das hat nicht geklappt. Bitte versuchen Sie es erneut."
|
||||||
|
|
||||||
#. Translators: this is a filename used for screencast recording
|
#. Translators: this is a filename used for screencast recording
|
||||||
#: ../js/ui/components/recorder.js:48
|
#: ../js/ui/components/recorder.js:47
|
||||||
#, no-c-format
|
#, no-c-format
|
||||||
msgid "Screencast from %d %t"
|
msgid "Screencast from %d %t"
|
||||||
msgstr "Bildschirmaufzeichnung von %d %t"
|
msgstr "Bildschirmaufzeichnung von %d %t"
|
||||||
@ -1055,26 +1053,26 @@ msgstr "Anwendungen anzeigen"
|
|||||||
# Würde ich so übernehmen, oder evtl. »Dock«.
|
# Würde ich so übernehmen, oder evtl. »Dock«.
|
||||||
#. Translators: this is the name of the dock/favorites area on
|
#. Translators: this is the name of the dock/favorites area on
|
||||||
#. the left of the overview
|
#. the left of the overview
|
||||||
#: ../js/ui/dash.js:435
|
#: ../js/ui/dash.js:429
|
||||||
msgid "Dash"
|
msgid "Dash"
|
||||||
msgstr "Dash"
|
msgstr "Dash"
|
||||||
|
|
||||||
#: ../js/ui/dateMenu.js:91
|
#: ../js/ui/dateMenu.js:86
|
||||||
msgid "Open Calendar"
|
msgid "Open Calendar"
|
||||||
msgstr "Kalender öffnen"
|
msgstr "Kalender öffnen"
|
||||||
|
|
||||||
#: ../js/ui/dateMenu.js:96
|
#: ../js/ui/dateMenu.js:90
|
||||||
msgid "Open Clocks"
|
msgid "Open Clocks"
|
||||||
msgstr "Uhren öffnen"
|
msgstr "Uhren öffnen"
|
||||||
|
|
||||||
#: ../js/ui/dateMenu.js:105
|
#: ../js/ui/dateMenu.js:97
|
||||||
msgid "Date & Time Settings"
|
msgid "Date & Time Settings"
|
||||||
msgstr "Einstellungen für Datum und Uhrzeit"
|
msgstr "Einstellungen für Datum und Uhrzeit"
|
||||||
|
|
||||||
#. Translators: This is the date format to use when the calendar popup is
|
#. Translators: This is the date format to use when the calendar popup is
|
||||||
#. * shown - it is shown just below the time in the shell (e.g. "Tue 9:29 AM").
|
#. * shown - it is shown just below the time in the shell (e.g. "Tue 9:29 AM").
|
||||||
#.
|
#.
|
||||||
#: ../js/ui/dateMenu.js:215
|
#: ../js/ui/dateMenu.js:208
|
||||||
msgid "%A %B %e, %Y"
|
msgid "%A %B %e, %Y"
|
||||||
msgstr "%A, %e. %B %Y"
|
msgstr "%A, %e. %B %Y"
|
||||||
|
|
||||||
@ -1181,56 +1179,56 @@ msgstr "Installieren"
|
|||||||
msgid "Download and install '%s' from extensions.gnome.org?"
|
msgid "Download and install '%s' from extensions.gnome.org?"
|
||||||
msgstr "»%s« von extensions.gnome.org herunterladen und installieren?"
|
msgstr "»%s« von extensions.gnome.org herunterladen und installieren?"
|
||||||
|
|
||||||
#: ../js/ui/keyboard.js:619 ../js/ui/status/keyboard.js:314
|
#: ../js/ui/keyboard.js:619 ../js/ui/status/keyboard.js:333
|
||||||
#: ../js/ui/status/power.js:211
|
#: ../js/ui/status/power.js:211
|
||||||
msgid "Keyboard"
|
msgid "Keyboard"
|
||||||
msgstr "Tastatur"
|
msgstr "Tastatur"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:693
|
#: ../js/ui/lookingGlass.js:689
|
||||||
msgid "No extensions installed"
|
msgid "No extensions installed"
|
||||||
msgstr "Keine Erweiterungen installiert"
|
msgstr "Keine Erweiterungen installiert"
|
||||||
|
|
||||||
#. Translators: argument is an extension UUID.
|
#. Translators: argument is an extension UUID.
|
||||||
#: ../js/ui/lookingGlass.js:747
|
#: ../js/ui/lookingGlass.js:743
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%s has not emitted any errors."
|
msgid "%s has not emitted any errors."
|
||||||
msgstr "%s hat keine Fehler ausgegeben."
|
msgstr "%s hat keine Fehler ausgegeben."
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:753
|
#: ../js/ui/lookingGlass.js:749
|
||||||
msgid "Hide Errors"
|
msgid "Hide Errors"
|
||||||
msgstr "Fehler verbergen"
|
msgstr "Fehler verbergen"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:757 ../js/ui/lookingGlass.js:817
|
#: ../js/ui/lookingGlass.js:753 ../js/ui/lookingGlass.js:813
|
||||||
msgid "Show Errors"
|
msgid "Show Errors"
|
||||||
msgstr "Fehler anzeigen"
|
msgstr "Fehler anzeigen"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:766
|
#: ../js/ui/lookingGlass.js:762
|
||||||
msgid "Enabled"
|
msgid "Enabled"
|
||||||
msgstr "Aktiviert"
|
msgstr "Aktiviert"
|
||||||
|
|
||||||
#. translators:
|
#. translators:
|
||||||
#. * The device has been disabled
|
#. * The device has been disabled
|
||||||
#: ../js/ui/lookingGlass.js:769 ../src/gvc/gvc-mixer-control.c:1830
|
#: ../js/ui/lookingGlass.js:765 ../src/gvc/gvc-mixer-control.c:1830
|
||||||
msgid "Disabled"
|
msgid "Disabled"
|
||||||
msgstr "Deaktiviert"
|
msgstr "Deaktiviert"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:771
|
#: ../js/ui/lookingGlass.js:767
|
||||||
msgid "Error"
|
msgid "Error"
|
||||||
msgstr "Fehler"
|
msgstr "Fehler"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:773
|
#: ../js/ui/lookingGlass.js:769
|
||||||
msgid "Out of date"
|
msgid "Out of date"
|
||||||
msgstr "Veraltet"
|
msgstr "Veraltet"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:775
|
#: ../js/ui/lookingGlass.js:771
|
||||||
msgid "Downloading"
|
msgid "Downloading"
|
||||||
msgstr "Herunterladen"
|
msgstr "Herunterladen"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:799
|
#: ../js/ui/lookingGlass.js:795
|
||||||
msgid "View Source"
|
msgid "View Source"
|
||||||
msgstr "Quelle zeigen"
|
msgstr "Quelle zeigen"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:808
|
#: ../js/ui/lookingGlass.js:804
|
||||||
msgid "Web Page"
|
msgid "Web Page"
|
||||||
msgstr "Webseite"
|
msgstr "Webseite"
|
||||||
|
|
||||||
@ -1250,35 +1248,35 @@ msgstr "Nachrichten leeren"
|
|||||||
msgid "Notification Settings"
|
msgid "Notification Settings"
|
||||||
msgstr "Benachrichtigungseinstellungen"
|
msgstr "Benachrichtigungseinstellungen"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1707
|
#: ../js/ui/messageTray.js:1711
|
||||||
msgid "No Messages"
|
msgid "No Messages"
|
||||||
msgstr "Keine Nachrichten"
|
msgstr "Keine Nachrichten"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1782
|
#: ../js/ui/messageTray.js:1784
|
||||||
msgid "Message Tray"
|
msgid "Message Tray"
|
||||||
msgstr "Benachrichtigungsfeld"
|
msgstr "Benachrichtigungsfeld"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:2869
|
#: ../js/ui/messageTray.js:2811
|
||||||
msgid "System Information"
|
msgid "System Information"
|
||||||
msgstr "Systeminformationen"
|
msgstr "Systeminformationen"
|
||||||
|
|
||||||
#: ../js/ui/notificationDaemon.js:629 ../src/shell-app.c:374
|
#: ../js/ui/notificationDaemon.js:629 ../src/shell-app.c:378
|
||||||
msgctxt "program"
|
msgctxt "program"
|
||||||
msgid "Unknown"
|
msgid "Unknown"
|
||||||
msgstr "Unbekannt"
|
msgstr "Unbekannt"
|
||||||
|
|
||||||
#: ../js/ui/overviewControls.js:463 ../js/ui/screenShield.js:153
|
#: ../js/ui/overviewControls.js:474 ../js/ui/screenShield.js:150
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%d new message"
|
msgid "%d new message"
|
||||||
msgid_plural "%d new messages"
|
msgid_plural "%d new messages"
|
||||||
msgstr[0] "%d neue Nachricht"
|
msgstr[0] "%d neue Nachricht"
|
||||||
msgstr[1] "%d neue Nachrichten"
|
msgstr[1] "%d neue Nachrichten"
|
||||||
|
|
||||||
#: ../js/ui/overview.js:84
|
#: ../js/ui/overview.js:82
|
||||||
msgid "Undo"
|
msgid "Undo"
|
||||||
msgstr "Rückgängig"
|
msgstr "Rückgängig"
|
||||||
|
|
||||||
#: ../js/ui/overview.js:131
|
#: ../js/ui/overview.js:127
|
||||||
msgid "Overview"
|
msgid "Overview"
|
||||||
msgstr "Übersicht"
|
msgstr "Übersicht"
|
||||||
|
|
||||||
@ -1286,21 +1284,21 @@ msgstr "Übersicht"
|
|||||||
#. in the search entry when no search is
|
#. in the search entry when no search is
|
||||||
#. active; it should not exceed ~30
|
#. active; it should not exceed ~30
|
||||||
#. characters.
|
#. characters.
|
||||||
#: ../js/ui/overview.js:287
|
#: ../js/ui/overview.js:258
|
||||||
msgid "Type to search…"
|
msgid "Type to search…"
|
||||||
msgstr "Suchbegriff eingeben …"
|
msgstr "Suchbegriff eingeben …"
|
||||||
|
|
||||||
#: ../js/ui/panel.js:612
|
#: ../js/ui/panel.js:642
|
||||||
msgid "Quit"
|
msgid "Quit"
|
||||||
msgstr "Beenden"
|
msgstr "Beenden"
|
||||||
|
|
||||||
#. Translators: If there is no suitable word for "Activities"
|
#. Translators: If there is no suitable word for "Activities"
|
||||||
#. in your language, you can use the word for "Overview".
|
#. in your language, you can use the word for "Overview".
|
||||||
#: ../js/ui/panel.js:636
|
#: ../js/ui/panel.js:693
|
||||||
msgid "Activities"
|
msgid "Activities"
|
||||||
msgstr "Aktivitäten"
|
msgstr "Aktivitäten"
|
||||||
|
|
||||||
#: ../js/ui/panel.js:933
|
#: ../js/ui/panel.js:989
|
||||||
msgid "Top Bar"
|
msgid "Top Bar"
|
||||||
msgstr "Oberes Panel"
|
msgstr "Oberes Panel"
|
||||||
|
|
||||||
@ -1309,15 +1307,15 @@ msgstr "Oberes Panel"
|
|||||||
#. "ON" and "OFF") or "toggle-switch-intl" (for toggle
|
#. "ON" and "OFF") or "toggle-switch-intl" (for toggle
|
||||||
#. switches containing "◯" and "|"). Other values will
|
#. switches containing "◯" and "|"). Other values will
|
||||||
#. simply result in invisible toggle switches.
|
#. simply result in invisible toggle switches.
|
||||||
#: ../js/ui/popupMenu.js:727
|
#: ../js/ui/popupMenu.js:738
|
||||||
msgid "toggle-switch-us"
|
msgid "toggle-switch-us"
|
||||||
msgstr "toggle-switch-intl"
|
msgstr "toggle-switch-intl"
|
||||||
|
|
||||||
#: ../js/ui/runDialog.js:73
|
#: ../js/ui/runDialog.js:74
|
||||||
msgid "Enter a Command"
|
msgid "Enter a Command"
|
||||||
msgstr "Bitte geben Sie einen Befehl ein"
|
msgstr "Bitte geben Sie einen Befehl ein"
|
||||||
|
|
||||||
#: ../js/ui/runDialog.js:109
|
#: ../js/ui/runDialog.js:110
|
||||||
msgid "Close"
|
msgid "Close"
|
||||||
msgstr "Schließen"
|
msgstr "Schließen"
|
||||||
|
|
||||||
@ -1326,22 +1324,22 @@ msgstr "Schließen"
|
|||||||
# %B - ausgeschriebener Name des Monats, abhängig von der gesetzten Umgebung
|
# %B - ausgeschriebener Name des Monats, abhängig von der gesetzten Umgebung
|
||||||
#. 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:90
|
#: ../js/ui/screenShield.js:87
|
||||||
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:152
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%d new notification"
|
msgid "%d new notification"
|
||||||
msgid_plural "%d new notifications"
|
msgid_plural "%d new notifications"
|
||||||
msgstr[0] "%d neue Benachrichtigung"
|
msgstr[0] "%d neue Benachrichtigung"
|
||||||
msgstr[1] "%d neue Benachrichtigungen"
|
msgstr[1] "%d neue Benachrichtigungen"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:442 ../js/ui/userMenu.js:807
|
#: ../js/ui/screenShield.js:449 ../js/ui/userMenu.js:807
|
||||||
msgid "Lock"
|
msgid "Lock"
|
||||||
msgstr "Sperren"
|
msgstr "Sperren"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:639
|
#: ../js/ui/screenShield.js:652
|
||||||
msgid "GNOME needs to lock the screen"
|
msgid "GNOME needs to lock the screen"
|
||||||
msgstr "GNOME muss den Bildschirm sperren"
|
msgstr "GNOME muss den Bildschirm sperren"
|
||||||
|
|
||||||
@ -1352,35 +1350,35 @@ msgstr "GNOME muss den Bildschirm sperren"
|
|||||||
#.
|
#.
|
||||||
#. 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:758 ../js/ui/screenShield.js:1169
|
#: ../js/ui/screenShield.js:773 ../js/ui/screenShield.js:1213
|
||||||
msgid "Unable to lock"
|
msgid "Unable to lock"
|
||||||
msgstr "Sperrung fehlgeschlagen"
|
msgstr "Sperrung fehlgeschlagen"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:759 ../js/ui/screenShield.js:1170
|
#: ../js/ui/screenShield.js:774 ../js/ui/screenShield.js:1214
|
||||||
msgid "Lock was blocked by an application"
|
msgid "Lock was blocked by an application"
|
||||||
msgstr "Sperrung wurde von einer Anwendung blockiert"
|
msgstr "Sperrung wurde von einer Anwendung blockiert"
|
||||||
|
|
||||||
#: ../js/ui/searchDisplay.js:431
|
#: ../js/ui/searchDisplay.js:445
|
||||||
msgid "Searching…"
|
msgid "Searching…"
|
||||||
msgstr "Suche läuft …"
|
msgstr "Suche läuft …"
|
||||||
|
|
||||||
#: ../js/ui/searchDisplay.js:475
|
#: ../js/ui/searchDisplay.js:489
|
||||||
msgid "No results."
|
msgid "No results."
|
||||||
msgstr "Keine Ergebnisse."
|
msgstr "Keine Ergebnisse."
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:29
|
#: ../js/ui/shellEntry.js:27
|
||||||
msgid "Copy"
|
msgid "Copy"
|
||||||
msgstr "Kopieren"
|
msgstr "Kopieren"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:34
|
#: ../js/ui/shellEntry.js:32
|
||||||
msgid "Paste"
|
msgid "Paste"
|
||||||
msgstr "Einfügen"
|
msgstr "Einfügen"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:106
|
#: ../js/ui/shellEntry.js:99
|
||||||
msgid "Show Text"
|
msgid "Show Text"
|
||||||
msgstr "Text anzeigen"
|
msgstr "Text anzeigen"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:108
|
#: ../js/ui/shellEntry.js:101
|
||||||
msgid "Hide Text"
|
msgid "Hide Text"
|
||||||
msgstr "Text verbergen"
|
msgstr "Text verbergen"
|
||||||
|
|
||||||
@ -1392,7 +1390,7 @@ msgstr "Passwort"
|
|||||||
msgid "Remember Password"
|
msgid "Remember Password"
|
||||||
msgstr "An Passwort erinnern"
|
msgstr "An Passwort erinnern"
|
||||||
|
|
||||||
#: ../js/ui/shellMountOperation.js:403 ../js/ui/unlockDialog.js:112
|
#: ../js/ui/shellMountOperation.js:403 ../js/ui/unlockDialog.js:109
|
||||||
msgid "Unlock"
|
msgid "Unlock"
|
||||||
msgstr "Entsperren"
|
msgstr "Entsperren"
|
||||||
|
|
||||||
@ -1447,7 +1445,7 @@ msgstr "Große Schrift"
|
|||||||
#: ../js/ui/status/bluetooth.js:28 ../js/ui/status/bluetooth.js:32
|
#: ../js/ui/status/bluetooth.js:28 ../js/ui/status/bluetooth.js:32
|
||||||
#: ../js/ui/status/bluetooth.js:289 ../js/ui/status/bluetooth.js:321
|
#: ../js/ui/status/bluetooth.js:289 ../js/ui/status/bluetooth.js:321
|
||||||
#: ../js/ui/status/bluetooth.js:357 ../js/ui/status/bluetooth.js:388
|
#: ../js/ui/status/bluetooth.js:357 ../js/ui/status/bluetooth.js:388
|
||||||
#: ../js/ui/status/network.js:826
|
#: ../js/ui/status/network.js:739
|
||||||
msgid "Bluetooth"
|
msgid "Bluetooth"
|
||||||
msgstr "Bluetooth"
|
msgstr "Bluetooth"
|
||||||
|
|
||||||
@ -1468,7 +1466,7 @@ msgid "Bluetooth Settings"
|
|||||||
msgstr "Bluetooth-Einstellungen"
|
msgstr "Bluetooth-Einstellungen"
|
||||||
|
|
||||||
#. TRANSLATORS: this means that bluetooth was disabled by hardware rfkill
|
#. TRANSLATORS: this means that bluetooth was disabled by hardware rfkill
|
||||||
#: ../js/ui/status/bluetooth.js:104 ../js/ui/status/network.js:178
|
#: ../js/ui/status/bluetooth.js:104 ../js/ui/status/network.js:142
|
||||||
msgid "hardware disabled"
|
msgid "hardware disabled"
|
||||||
msgstr "Hardware deaktiviert"
|
msgstr "Hardware deaktiviert"
|
||||||
|
|
||||||
@ -1476,12 +1474,12 @@ msgstr "Hardware deaktiviert"
|
|||||||
msgid "Connection"
|
msgid "Connection"
|
||||||
msgstr "Verbindung"
|
msgstr "Verbindung"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:208 ../js/ui/status/network.js:460
|
#: ../js/ui/status/bluetooth.js:208 ../js/ui/status/network.js:404
|
||||||
msgid "disconnecting..."
|
msgid "disconnecting..."
|
||||||
msgstr "Verbindungsabbau …"
|
msgstr "Verbindungsabbau …"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:221 ../js/ui/status/network.js:466
|
#: ../js/ui/status/bluetooth.js:221 ../js/ui/status/network.js:410
|
||||||
#: ../js/ui/status/network.js:1546
|
#: ../js/ui/status/network.js:1343
|
||||||
msgid "connecting..."
|
msgid "connecting..."
|
||||||
msgstr "Verbindungsaufbau …"
|
msgstr "Verbindungsaufbau …"
|
||||||
|
|
||||||
@ -1536,7 +1534,8 @@ msgstr "Gerät »%s« möchte mit diesem Rechner gekoppelt werden"
|
|||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:366
|
#: ../js/ui/status/bluetooth.js:366
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Please confirm whether the PIN '%06d' matches the one on the device."
|
msgid ""
|
||||||
|
"Please confirm whether the Passkey '%06d' matches the one on the device."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Bitte bestätigen Sie, ob die PIN »%06d« mit der des Gerätes übereinstimmt."
|
"Bitte bestätigen Sie, ob die PIN »%06d« mit der des Gerätes übereinstimmt."
|
||||||
|
|
||||||
@ -1562,11 +1561,11 @@ msgstr "Bitte geben Sie die auf dem Gerät angezeigte PIN ein."
|
|||||||
msgid "OK"
|
msgid "OK"
|
||||||
msgstr "OK"
|
msgstr "OK"
|
||||||
|
|
||||||
#: ../js/ui/status/keyboard.js:368
|
#: ../js/ui/status/keyboard.js:396
|
||||||
msgid "Show Keyboard Layout"
|
msgid "Show Keyboard Layout"
|
||||||
msgstr "Tastaturbelegung zeigen"
|
msgstr "Tastaturbelegung zeigen"
|
||||||
|
|
||||||
#: ../js/ui/status/keyboard.js:373
|
#: ../js/ui/status/keyboard.js:401
|
||||||
msgid "Region & Language Settings"
|
msgid "Region & Language Settings"
|
||||||
msgstr "Einstellungen für Region und Sprache"
|
msgstr "Einstellungen für Region und Sprache"
|
||||||
|
|
||||||
@ -1574,117 +1573,91 @@ msgstr "Einstellungen für Region und Sprache"
|
|||||||
msgid "Volume, network, battery"
|
msgid "Volume, network, battery"
|
||||||
msgstr "Lautstärke, Netzwerk, Batterie"
|
msgstr "Lautstärke, Netzwerk, Batterie"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:104
|
#: ../js/ui/status/network.js:75
|
||||||
msgid "<unknown>"
|
msgid "<unknown>"
|
||||||
msgstr "<Unbekannt>"
|
msgstr "<Unbekannt>"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:127
|
||||||
|
msgid "Wi-Fi"
|
||||||
|
msgstr "WLAN"
|
||||||
|
|
||||||
#. Translators: this indicates that wireless or wwan is disabled by hardware killswitch
|
#. Translators: this indicates that wireless or wwan is disabled by hardware killswitch
|
||||||
#: ../js/ui/status/network.js:200
|
#: ../js/ui/status/network.js:164
|
||||||
msgid "disabled"
|
msgid "disabled"
|
||||||
msgstr "Deaktiviert"
|
msgstr "Deaktiviert"
|
||||||
|
|
||||||
#. 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:458
|
#: ../js/ui/status/network.js:402
|
||||||
msgid "unmanaged"
|
msgid "unmanaged"
|
||||||
msgstr "nicht verwaltet"
|
msgstr "nicht verwaltet"
|
||||||
|
|
||||||
#. 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:469 ../js/ui/status/network.js:1549
|
#: ../js/ui/status/network.js:413 ../js/ui/status/network.js:1346
|
||||||
msgid "authentication required"
|
msgid "authentication required"
|
||||||
msgstr "Legitimierung erforderlich"
|
msgstr "Legitimierung erforderlich"
|
||||||
|
|
||||||
#. 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:479
|
#: ../js/ui/status/network.js:423
|
||||||
msgid "firmware missing"
|
msgid "firmware missing"
|
||||||
msgstr "Firmware fehlt"
|
msgstr "Firmware fehlt"
|
||||||
|
|
||||||
#. Translators: this is for wired network devices that are physically disconnected
|
#. Translators: this is for wired network devices that are physically disconnected
|
||||||
#: ../js/ui/status/network.js:486
|
#: ../js/ui/status/network.js:430
|
||||||
msgid "cable unplugged"
|
msgid "cable unplugged"
|
||||||
msgstr "Kabel nicht angeschlossen"
|
msgstr "Kabel nicht angeschlossen"
|
||||||
|
|
||||||
#. 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:491
|
#: ../js/ui/status/network.js:435
|
||||||
msgid "unavailable"
|
msgid "unavailable"
|
||||||
msgstr "nicht verfügbar"
|
msgstr "nicht verfügbar"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:493 ../js/ui/status/network.js:1551
|
#: ../js/ui/status/network.js:437 ../js/ui/status/network.js:1348
|
||||||
msgid "connection failed"
|
msgid "connection failed"
|
||||||
msgstr "Verbindung gescheitert"
|
msgstr "Verbindung gescheitert"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:552 ../js/ui/status/network.js:1435
|
#: ../js/ui/status/network.js:490 ../js/ui/status/network.js:1236
|
||||||
#: ../js/ui/status/network.js:1627
|
#: ../js/ui/status/network.js:1424
|
||||||
msgid "More…"
|
msgid "More…"
|
||||||
msgstr "Mehr …"
|
msgstr "Mehr …"
|
||||||
|
|
||||||
#. TRANSLATORS: this is the indication that a connection for another logged in user is active,
|
#. TRANSLATORS: this is the indication that a connection for another logged in user is active,
|
||||||
#. and we cannot access its settings (including the name)
|
#. and we cannot access its settings (including the name)
|
||||||
#: ../js/ui/status/network.js:588 ../js/ui/status/network.js:1365
|
#: ../js/ui/status/network.js:518 ../js/ui/status/network.js:1191
|
||||||
msgid "Connected (private)"
|
msgid "Connected (private)"
|
||||||
msgstr "Verbunden (privat)"
|
msgstr "Verbunden (privat)"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:667
|
#: ../js/ui/status/network.js:597
|
||||||
msgid "Wired"
|
msgid "Wired"
|
||||||
msgstr "Kabelgebunden"
|
msgstr "Kabelgebunden"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:668
|
#: ../js/ui/status/network.js:611
|
||||||
msgid "Auto Ethernet"
|
|
||||||
msgstr "Ethernet (automatisch)"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:695
|
|
||||||
msgid "Mobile broadband"
|
msgid "Mobile broadband"
|
||||||
msgstr "Mobiles Breitband"
|
msgstr "Mobiles Breitband"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:728
|
#: ../js/ui/status/network.js:1522
|
||||||
msgid "Auto broadband"
|
|
||||||
msgstr "Mobiles Breitband (automatisch)"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:731
|
|
||||||
msgid "Auto dial-up"
|
|
||||||
msgstr "Einwählverbindung (automatisch)"
|
|
||||||
|
|
||||||
#. TRANSLATORS: this the automatic wireless connection name (including the network name)
|
|
||||||
#: ../js/ui/status/network.js:861 ../js/ui/status/network.js:1382
|
|
||||||
#, c-format
|
|
||||||
msgid "Auto %s"
|
|
||||||
msgstr "%s (automatisch)"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:863
|
|
||||||
msgid "Auto bluetooth"
|
|
||||||
msgstr "Bluetooth (automatisch)"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1384
|
|
||||||
msgid "Auto wireless"
|
|
||||||
msgstr "Drahtlos (automatisch)"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1729
|
|
||||||
msgid "Enable networking"
|
msgid "Enable networking"
|
||||||
msgstr "Netzwerk aktivieren"
|
msgstr "Netzwerk aktivieren"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1771
|
#: ../js/ui/status/network.js:1583
|
||||||
msgid "Wi-Fi"
|
|
||||||
msgstr "WLAN"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1790
|
|
||||||
msgid "Network Settings"
|
msgid "Network Settings"
|
||||||
msgstr "Netzwerkeinstellungen"
|
msgstr "Netzwerkeinstellungen"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1807
|
#: ../js/ui/status/network.js:1600
|
||||||
msgid "Network Manager"
|
msgid "Network Manager"
|
||||||
msgstr "Netzwerk-Verwaltung"
|
msgstr "Netzwerk-Verwaltung"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1897
|
#: ../js/ui/status/network.js:1690
|
||||||
msgid "Connection failed"
|
msgid "Connection failed"
|
||||||
msgstr "Verbindung gescheitert"
|
msgstr "Verbindung gescheitert"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1898
|
#: ../js/ui/status/network.js:1691
|
||||||
msgid "Activation of network connection failed"
|
msgid "Activation of network connection failed"
|
||||||
msgstr "Aktivierung der Netzwerkverbindung ist gescheitert"
|
msgstr "Aktivierung der Netzwerkverbindung ist gescheitert"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:2276
|
#: ../js/ui/status/network.js:2047
|
||||||
msgid "Networking is disabled"
|
msgid "Networking is disabled"
|
||||||
msgstr "Netzwerk ist deaktiviert"
|
msgstr "Netzwerk ist deaktiviert"
|
||||||
|
|
||||||
@ -1798,11 +1771,11 @@ msgstr "Lautstärke"
|
|||||||
msgid "Microphone"
|
msgid "Microphone"
|
||||||
msgstr "Mikrofon"
|
msgstr "Mikrofon"
|
||||||
|
|
||||||
#: ../js/ui/unlockDialog.js:123
|
#: ../js/ui/unlockDialog.js:120
|
||||||
msgid "Log in as another user"
|
msgid "Log in as another user"
|
||||||
msgstr "Als anderer Benutzer anmelden"
|
msgstr "Als anderer Benutzer anmelden"
|
||||||
|
|
||||||
#: ../js/ui/unlockDialog.js:149
|
#: ../js/ui/unlockDialog.js:141
|
||||||
msgid "Unlock Window"
|
msgid "Unlock Window"
|
||||||
msgstr "Fenster entsperren"
|
msgstr "Fenster entsperren"
|
||||||
|
|
||||||
@ -1928,37 +1901,37 @@ msgid_plural "%u Inputs"
|
|||||||
msgstr[0] "%u Eingang"
|
msgstr[0] "%u Eingang"
|
||||||
msgstr[1] "%u Eingänge"
|
msgstr[1] "%u Eingänge"
|
||||||
|
|
||||||
#: ../src/gvc/gvc-mixer-control.c:2371
|
#: ../src/gvc/gvc-mixer-control.c:2373
|
||||||
msgid "System Sounds"
|
msgid "System Sounds"
|
||||||
msgstr "Systemklänge"
|
msgstr "Systemklänge"
|
||||||
|
|
||||||
#: ../src/main.c:347
|
#: ../src/main.c:372
|
||||||
msgid "Print version"
|
msgid "Print version"
|
||||||
msgstr "Version ausgeben"
|
msgstr "Version ausgeben"
|
||||||
|
|
||||||
#: ../src/main.c:353
|
#: ../src/main.c:378
|
||||||
msgid "Mode used by GDM for login screen"
|
msgid "Mode used by GDM for login screen"
|
||||||
msgstr "Der durch GDM im Anmeldefenster verwendete Modus"
|
msgstr "Der durch GDM im Anmeldefenster verwendete Modus"
|
||||||
|
|
||||||
#: ../src/main.c:359
|
#: ../src/main.c:384
|
||||||
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Einen spezifischen Modus nutzen, wie z.B. »gdm« für den Anmeldebildschirm"
|
"Einen spezifischen Modus nutzen, wie z.B. »gdm« für den Anmeldebildschirm"
|
||||||
|
|
||||||
#: ../src/main.c:365
|
#: ../src/main.c:390
|
||||||
msgid "List possible modes"
|
msgid "List possible modes"
|
||||||
msgstr "Die möglichen Modi auflisten"
|
msgstr "Die möglichen Modi auflisten"
|
||||||
|
|
||||||
#: ../src/shell-app.c:622
|
#: ../src/shell-app.c:626
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to launch '%s'"
|
msgid "Failed to launch '%s'"
|
||||||
msgstr "»%s« konnte nicht gestartet werden"
|
msgstr "»%s« konnte nicht gestartet werden"
|
||||||
|
|
||||||
#: ../src/shell-keyring-prompt.c:708
|
#: ../src/shell-keyring-prompt.c:714
|
||||||
msgid "Passwords do not match."
|
msgid "Passwords do not match."
|
||||||
msgstr "Passwörter stimmen nicht überein."
|
msgstr "Passwörter stimmen nicht überein."
|
||||||
|
|
||||||
#: ../src/shell-keyring-prompt.c:716
|
#: ../src/shell-keyring-prompt.c:722
|
||||||
msgid "Password cannot be blank"
|
msgid "Password cannot be blank"
|
||||||
msgstr "Das Passwort darf nicht leer sein"
|
msgstr "Das Passwort darf nicht leer sein"
|
||||||
|
|
||||||
@ -1966,6 +1939,40 @@ msgstr "Das Passwort darf nicht leer sein"
|
|||||||
msgid "Authentication dialog was dismissed by the user"
|
msgid "Authentication dialog was dismissed by the user"
|
||||||
msgstr "Der Dialog zur Legitimierung wurde vom Benutzer geschlossen"
|
msgstr "Der Dialog zur Legitimierung wurde vom Benutzer geschlossen"
|
||||||
|
|
||||||
|
#~ msgid "Whether to collect stats about applications usage"
|
||||||
|
#~ msgstr ""
|
||||||
|
#~ "Legt fest, ob Statistiken über Anwendungsnutzung erfasst werden sollen"
|
||||||
|
|
||||||
|
#~ msgid ""
|
||||||
|
#~ "The shell normally monitors active applications in order to present the "
|
||||||
|
#~ "most used ones (e.g. in launchers). While this data will be kept private, "
|
||||||
|
#~ "you may want to disable this for privacy reasons. Please note that doing "
|
||||||
|
#~ "so won't remove already saved data."
|
||||||
|
#~ msgstr ""
|
||||||
|
#~ "Die Shell überwacht normalerweise aktive Anwendungen, wobei die "
|
||||||
|
#~ "meistgenutzten zuerst erfasst werden (z.B. in Anwendungsstartern). Zwar "
|
||||||
|
#~ "werden diese Daten privat gespeichert, doch möglicherweise wollen Sie "
|
||||||
|
#~ "dies deaktivieren, um Ihre Privatsphäre zu schützen. Bitte beachten Sie, "
|
||||||
|
#~ "dass bereits gespeicherte Daten hiervon nicht beeinflusst werden."
|
||||||
|
|
||||||
|
#~ msgid "Auto Ethernet"
|
||||||
|
#~ msgstr "Ethernet (automatisch)"
|
||||||
|
|
||||||
|
#~ msgid "Auto broadband"
|
||||||
|
#~ msgstr "Mobiles Breitband (automatisch)"
|
||||||
|
|
||||||
|
#~ msgid "Auto dial-up"
|
||||||
|
#~ msgstr "Einwählverbindung (automatisch)"
|
||||||
|
|
||||||
|
#~ msgid "Auto %s"
|
||||||
|
#~ msgstr "%s (automatisch)"
|
||||||
|
|
||||||
|
#~ msgid "Auto bluetooth"
|
||||||
|
#~ msgstr "Bluetooth (automatisch)"
|
||||||
|
|
||||||
|
#~ msgid "Auto wireless"
|
||||||
|
#~ msgstr "Drahtlos (automatisch)"
|
||||||
|
|
||||||
#~ msgctxt "title"
|
#~ msgctxt "title"
|
||||||
#~ msgid "Sign In"
|
#~ msgid "Sign In"
|
||||||
#~ msgstr "Anmelden"
|
#~ msgstr "Anmelden"
|
||||||
|
363
po/gl.po
363
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: 2013-04-18 01:27+0200\n"
|
"POT-Creation-Date: 2013-05-31 01:03+0200\n"
|
||||||
"PO-Revision-Date: 2013-04-18 01:42+0200\n"
|
"PO-Revision-Date: 2013-05-31 01:04+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"
|
||||||
@ -44,10 +44,14 @@ msgid "Focus the active notification"
|
|||||||
msgstr "Enfocar a notificación activa"
|
msgstr "Enfocar a notificación activa"
|
||||||
|
|
||||||
#: ../data/50-gnome-shell-system.xml.in.h:4
|
#: ../data/50-gnome-shell-system.xml.in.h:4
|
||||||
|
msgid "Show the overview"
|
||||||
|
msgstr "Mostrar a vista xeral"
|
||||||
|
|
||||||
|
#: ../data/50-gnome-shell-system.xml.in.h:5
|
||||||
msgid "Show all applications"
|
msgid "Show all applications"
|
||||||
msgstr "Mostrar todos os aplicativos"
|
msgstr "Mostrar todos os aplicativos"
|
||||||
|
|
||||||
#: ../data/50-gnome-shell-system.xml.in.h:5
|
#: ../data/50-gnome-shell-system.xml.in.h:6
|
||||||
msgid "Open the application menu"
|
msgid "Open the application menu"
|
||||||
msgstr "Abrir o menú de aplicativo"
|
msgstr "Abrir o menú de aplicativo"
|
||||||
|
|
||||||
@ -99,26 +103,10 @@ msgstr ""
|
|||||||
"EnableExtension e DisableExtension de DBus en org.gnome.Shell."
|
"EnableExtension e DisableExtension de DBus en org.gnome.Shell."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:5
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:5
|
||||||
msgid "Whether to collect stats about applications usage"
|
|
||||||
msgstr "Indica se se deben recolectar estatísticas sobre o uso dos aplicativos"
|
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:6
|
|
||||||
msgid ""
|
|
||||||
"The shell normally monitors active applications in order to present the most "
|
|
||||||
"used ones (e.g. in launchers). While this data will be kept private, you may "
|
|
||||||
"want to disable this for privacy reasons. Please note that doing so won't "
|
|
||||||
"remove already saved data."
|
|
||||||
msgstr ""
|
|
||||||
"O shell normalmente monitoriza os aplicativos activos para mostrarlle os "
|
|
||||||
"máis usados (p.ex. nos iniciadores). Aínda que estes datos se manteñen de "
|
|
||||||
"forma privada, vostede pode desactivar isto por razóns de privacidade. Teña "
|
|
||||||
"en conta que facendo isto non retirará os datos gardados."
|
|
||||||
|
|
||||||
#: ../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 "Lista de ID de ficheiros de escritorio para os aplicativos preferidos"
|
msgstr "Lista de ID de ficheiros de escritorio para os aplicativos preferidos"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:8
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:6
|
||||||
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."
|
||||||
@ -126,11 +114,11 @@ msgstr ""
|
|||||||
"Os aplicativos que corresponden a estes identificadores mostraranse na área "
|
"Os aplicativos que corresponden a estes identificadores mostraranse na área "
|
||||||
"de preferidos."
|
"de preferidos."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:9
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:7
|
||||||
msgid "List of categories that should be displayed as folders"
|
msgid "List of categories that should be displayed as folders"
|
||||||
msgstr "Lista de categorías que se debería mostrar como cartafoles"
|
msgstr "Lista de categorías que se debería mostrar como cartafoles"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:10
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:8
|
||||||
msgid ""
|
msgid ""
|
||||||
"Each category name in this list will be represented as folder in the "
|
"Each category name in this list will be represented as folder in the "
|
||||||
"application view, rather than being displayed inline in the main view."
|
"application view, rather than being displayed inline in the main view."
|
||||||
@ -138,15 +126,15 @@ msgstr ""
|
|||||||
"Cada nome de categoría nesta lista representarase como un cartafol na vista "
|
"Cada nome de categoría nesta lista representarase como un cartafol na vista "
|
||||||
"de aplicativos, no lugar de mostrarse en liña na vista principal."
|
"de aplicativos, no lugar de mostrarse en liña na vista principal."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:11
|
#: ../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 "Historial do diálogo de ordes (Alt-F2)"
|
msgstr "Historial do diálogo de ordes (Alt-F2)"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:12
|
#: ../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 "Historial do diálogo de «looking glass»"
|
msgstr "Historial do diálogo de «looking glass»"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:13
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:11
|
||||||
msgid ""
|
msgid ""
|
||||||
"Internally used to store the last IM presence explicitly set by the user. "
|
"Internally used to store the last IM presence explicitly set by the user. "
|
||||||
"The value here is from the TpConnectionPresenceType enumeration."
|
"The value here is from the TpConnectionPresenceType enumeration."
|
||||||
@ -155,7 +143,7 @@ msgstr ""
|
|||||||
"explícitamente polo usuario. O valor aquí é da enumeración "
|
"explícitamente polo usuario. O valor aquí é da enumeración "
|
||||||
"TpConnectionPresenceType."
|
"TpConnectionPresenceType."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:14
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:12
|
||||||
msgid ""
|
msgid ""
|
||||||
"Internally used to store the last session presence status for the user. The "
|
"Internally used to store the last session presence status for the user. The "
|
||||||
"value here is from the GsmPresenceStatus enumeration."
|
"value here is from the GsmPresenceStatus enumeration."
|
||||||
@ -163,11 +151,11 @@ msgstr ""
|
|||||||
"Usado internamente para gardar o último estado de presenza da sesión do "
|
"Usado internamente para gardar o último estado de presenza da sesión do "
|
||||||
"usuario. O valor aquí é da GsmPresenceStatus."
|
"usuario. O valor aquí é da GsmPresenceStatus."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:15
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:13
|
||||||
msgid "Always show the 'Log out' menuitem in the user menu."
|
msgid "Always show the 'Log out' menuitem in the user menu."
|
||||||
msgstr "Mostrar sempre o elemento de menú «Saír da sesión» no menú de usuario."
|
msgstr "Mostrar sempre o elemento de menú «Saír da sesión» no menú de usuario."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:16
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:14
|
||||||
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' menuitem in single-"
|
||||||
"user, single-session situations."
|
"user, single-session situations."
|
||||||
@ -176,14 +164,14 @@ msgstr ""
|
|||||||
"sesión» en situacións de existir un único usuario ou existir unha única "
|
"sesión» en situacións de existir un único usuario ou existir unha única "
|
||||||
"sesión. "
|
"sesión. "
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:17
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:15
|
||||||
msgid ""
|
msgid ""
|
||||||
"Whether to remember password for mounting encrypted or remote filesystems"
|
"Whether to remember password for mounting encrypted or remote filesystems"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Indica se se debe lembrar o contrasinal para montar os sistemas de ficheiros "
|
"Indica se se debe lembrar o contrasinal para montar os sistemas de ficheiros "
|
||||||
"cifrados ou remotos"
|
"cifrados ou remotos"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:18
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:16
|
||||||
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 "
|
||||||
@ -195,33 +183,41 @@ msgstr ""
|
|||||||
"futuro aparecerá a opción «Lembrar contrasinal» Esta chave estabelece o "
|
"futuro aparecerá a opción «Lembrar contrasinal» Esta chave estabelece o "
|
||||||
"estado por omisión da opción. "
|
"estado por omisión da opción. "
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:19
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:17
|
||||||
msgid "Show the week date in the calendar"
|
msgid "Show the week date in the calendar"
|
||||||
msgstr "Mostrar a data da semana no calendario"
|
msgstr "Mostrar a data da semana no calendario"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:20
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:18
|
||||||
msgid "If true, display the ISO week date in the calendar."
|
msgid "If true, display the ISO week date in the calendar."
|
||||||
msgstr "Se é verdadeiro, móstrase a data da semana ISO no calendario."
|
msgstr "Se é verdadeiro, móstrase a data da semana ISO no calendario."
|
||||||
|
|
||||||
#: ../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 application menu"
|
msgid "Keybinding to open the application menu"
|
||||||
msgstr "Combinación de teclas para abrir o menú de aplicativo"
|
msgstr "Combinación de teclas para abrir o menú de aplicativo"
|
||||||
|
|
||||||
#: ../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 application menu."
|
msgid "Keybinding to open the application menu."
|
||||||
msgstr "Combinación de teclas para abrir o menú de aplicativo."
|
msgstr "Combinación de teclas para abrir o menú de aplicativo."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:23
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:21
|
||||||
msgid "Keybinding to open the \"Show Applications\" view"
|
msgid "Keybinding to open the \"Show Applications\" view"
|
||||||
msgstr "Combinación de teclas para abrir a vista «Mostrar aplicativos»"
|
msgstr "Combinación de teclas para abrir a vista «Mostrar aplicativos»"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:24
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:22
|
||||||
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 ""
|
||||||
"Combinación de teclas para abrir a vista \"Mostrar aplicativos\" da Vista "
|
"Combinación de teclas para abrir a vista \"Mostrar aplicativos\" da Vista "
|
||||||
"xera de Actividades."
|
"xera de Actividades."
|
||||||
|
|
||||||
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:23
|
||||||
|
msgid "Keybinding to open the overview"
|
||||||
|
msgstr "Combinación de teclas para abrir a Vista xeral"
|
||||||
|
|
||||||
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:24
|
||||||
|
msgid "Keybinding to open the Activities Overview."
|
||||||
|
msgstr "Combinación de teclas para abrir a Vista de actividades."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:25
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:25
|
||||||
msgid "Keybinding to toggle the visibility of the message tray"
|
msgid "Keybinding to toggle the visibility of the message tray"
|
||||||
msgstr "Combinación de teclas para mostrar/ocultar a área de mensaxes"
|
msgstr "Combinación de teclas para mostrar/ocultar a área de mensaxes"
|
||||||
@ -373,43 +369,50 @@ msgid "Select an extension to configure using the combobox above."
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Seleccione unha extensión que configurar usando a caixa combinada de arriba."
|
"Seleccione unha extensión que configurar usando a caixa combinada de arriba."
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:405
|
#: ../js/gdm/loginDialog.js:371
|
||||||
msgid "Session…"
|
msgid "Session…"
|
||||||
msgstr "Sesión…"
|
msgstr "Sesión…"
|
||||||
|
|
||||||
#. translators: this message is shown below the user list on the
|
#. translators: this message is shown below the user list on the
|
||||||
#. login screen. It can be activated to reveal an entry for
|
#. login screen. It can be activated to reveal an entry for
|
||||||
#. manually entering the username.
|
#. manually entering the username.
|
||||||
#: ../js/gdm/loginDialog.js:630
|
#: ../js/gdm/loginDialog.js:601
|
||||||
msgid "Not listed?"
|
msgid "Not listed?"
|
||||||
msgstr "Non está na lista?"
|
msgstr "Non está na lista?"
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:787 ../js/ui/components/networkAgent.js:137
|
#: ../js/gdm/loginDialog.js:776 ../js/ui/components/networkAgent.js:137
|
||||||
#: ../js/ui/components/polkitAgent.js:162 ../js/ui/endSessionDialog.js:376
|
#: ../js/ui/components/polkitAgent.js:161 ../js/ui/endSessionDialog.js:376
|
||||||
#: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399
|
#: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399
|
||||||
#: ../js/ui/status/bluetooth.js:415 ../js/ui/unlockDialog.js:100
|
#: ../js/ui/status/bluetooth.js:415 ../js/ui/unlockDialog.js:96
|
||||||
#: ../js/ui/userMenu.js:938
|
#: ../js/ui/userMenu.js:938
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
msgstr "Cancelar"
|
msgstr "Cancelar"
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:803
|
#: ../js/gdm/loginDialog.js:791
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Sign In"
|
msgid "Sign In"
|
||||||
msgstr "Iniciar sesión"
|
msgstr "Iniciar sesión"
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:803
|
#: ../js/gdm/loginDialog.js:791
|
||||||
msgid "Next"
|
msgid "Next"
|
||||||
msgstr "Seguinte"
|
msgstr "Seguinte"
|
||||||
|
|
||||||
|
#. Translators: this message is shown below the username entry field
|
||||||
|
#. to clue the user in on how to login to the local network realm
|
||||||
|
#: ../js/gdm/loginDialog.js:888
|
||||||
|
#, c-format
|
||||||
|
msgid "(e.g., user or %s)"
|
||||||
|
msgstr "(p.ex., usuario ou %s)"
|
||||||
|
|
||||||
#. TTLS and PEAP are actually much more complicated, but this complication
|
#. TTLS and PEAP are actually much more complicated, but this complication
|
||||||
#. is not visible here since we only care about phase2 authentication
|
#. is not visible here since we only care about phase2 authentication
|
||||||
#. (and don't even care of which one)
|
#. (and don't even care of which one)
|
||||||
#: ../js/gdm/loginDialog.js:918 ../js/ui/components/networkAgent.js:260
|
#: ../js/gdm/loginDialog.js:892 ../js/ui/components/networkAgent.js:260
|
||||||
#: ../js/ui/components/networkAgent.js:278
|
#: ../js/ui/components/networkAgent.js:278
|
||||||
msgid "Username: "
|
msgid "Username: "
|
||||||
msgstr "Nome de usuario: "
|
msgstr "Nome de usuario: "
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:1174
|
#: ../js/gdm/loginDialog.js:1158
|
||||||
msgid "Login Window"
|
msgid "Login Window"
|
||||||
msgstr "Xanela de inicio de sesión"
|
msgstr "Xanela de inicio de sesión"
|
||||||
|
|
||||||
@ -432,21 +435,16 @@ msgstr "Reiniciar"
|
|||||||
msgid "Power Off"
|
msgid "Power Off"
|
||||||
msgstr "Apagar"
|
msgstr "Apagar"
|
||||||
|
|
||||||
#: ../js/gdm/util.js:249
|
#: ../js/gdm/util.js:247
|
||||||
msgid "Authentication error"
|
msgid "Authentication error"
|
||||||
msgstr "Erro de autenticación"
|
msgstr "Erro de autenticación"
|
||||||
|
|
||||||
#. Translators: this message is shown below the password entry field
|
#. Translators: this message is shown below the password entry field
|
||||||
#. to indicate the user can swipe their finger instead
|
#. to indicate the user can swipe their finger instead
|
||||||
#: ../js/gdm/util.js:366
|
#: ../js/gdm/util.js:364
|
||||||
msgid "(or swipe finger)"
|
msgid "(or swipe finger)"
|
||||||
msgstr "(ou pase o dedo)"
|
msgstr "(ou pase o dedo)"
|
||||||
|
|
||||||
#: ../js/gdm/util.js:391
|
|
||||||
#, c-format
|
|
||||||
msgid "(e.g., user or %s)"
|
|
||||||
msgstr "(p.ex., usuario ou %s)"
|
|
||||||
|
|
||||||
#: ../js/misc/util.js:97
|
#: ../js/misc/util.js:97
|
||||||
msgid "Command not found"
|
msgid "Command not found"
|
||||||
msgstr "Orde non atopada"
|
msgstr "Orde non atopada"
|
||||||
@ -462,23 +460,23 @@ 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:349
|
#: ../js/ui/appDisplay.js:361
|
||||||
msgid "Frequent"
|
msgid "Frequent"
|
||||||
msgstr "Frecuentes"
|
msgstr "Frecuentes"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:356
|
#: ../js/ui/appDisplay.js:368
|
||||||
msgid "All"
|
msgid "All"
|
||||||
msgstr "Todos"
|
msgstr "Todos"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:914
|
#: ../js/ui/appDisplay.js:960
|
||||||
msgid "New Window"
|
msgid "New Window"
|
||||||
msgstr "Xanela nova"
|
msgstr "Xanela nova"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:917 ../js/ui/dash.js:284
|
#: ../js/ui/appDisplay.js:963 ../js/ui/dash.js:284
|
||||||
msgid "Remove from Favorites"
|
msgid "Remove from Favorites"
|
||||||
msgstr "Retirar dos marcadores"
|
msgstr "Retirar dos marcadores"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:918
|
#: ../js/ui/appDisplay.js:964
|
||||||
msgid "Add to Favorites"
|
msgid "Add to Favorites"
|
||||||
msgstr "Engadir aos favoritos"
|
msgstr "Engadir aos favoritos"
|
||||||
|
|
||||||
@ -617,35 +615,35 @@ msgid "S"
|
|||||||
msgstr "S"
|
msgstr "S"
|
||||||
|
|
||||||
#. Translators: Text to show if there are no events
|
#. Translators: Text to show if there are no events
|
||||||
#: ../js/ui/calendar.js:720
|
#: ../js/ui/calendar.js:735
|
||||||
msgid "Nothing Scheduled"
|
msgid "Nothing Scheduled"
|
||||||
msgstr "Nada programado"
|
msgstr "Nada programado"
|
||||||
|
|
||||||
#. Translators: Shown on calendar heading when selected day occurs on current year
|
#. Translators: Shown on calendar heading when selected day occurs on current year
|
||||||
#: ../js/ui/calendar.js:736
|
#: ../js/ui/calendar.js:751
|
||||||
msgctxt "calendar heading"
|
msgctxt "calendar heading"
|
||||||
msgid "%A, %B %d"
|
msgid "%A, %B %d"
|
||||||
msgstr "%A, %d de %B"
|
msgstr "%A, %d de %B"
|
||||||
|
|
||||||
#. Translators: Shown on calendar heading when selected day occurs on different year
|
#. Translators: Shown on calendar heading when selected day occurs on different year
|
||||||
#: ../js/ui/calendar.js:739
|
#: ../js/ui/calendar.js:754
|
||||||
msgctxt "calendar heading"
|
msgctxt "calendar heading"
|
||||||
msgid "%A, %B %d, %Y"
|
msgid "%A, %B %d, %Y"
|
||||||
msgstr "%A, %d de %B de %Y"
|
msgstr "%A, %d de %B de %Y"
|
||||||
|
|
||||||
#: ../js/ui/calendar.js:749
|
#: ../js/ui/calendar.js:764
|
||||||
msgid "Today"
|
msgid "Today"
|
||||||
msgstr "Hoxe"
|
msgstr "Hoxe"
|
||||||
|
|
||||||
#: ../js/ui/calendar.js:753
|
#: ../js/ui/calendar.js:768
|
||||||
msgid "Tomorrow"
|
msgid "Tomorrow"
|
||||||
msgstr "Mañá"
|
msgstr "Mañá"
|
||||||
|
|
||||||
#: ../js/ui/calendar.js:764
|
#: ../js/ui/calendar.js:779
|
||||||
msgid "This week"
|
msgid "This week"
|
||||||
msgstr "Esta semana"
|
msgstr "Esta semana"
|
||||||
|
|
||||||
#: ../js/ui/calendar.js:772
|
#: ../js/ui/calendar.js:787
|
||||||
msgid "Next week"
|
msgid "Next week"
|
||||||
msgstr "A vindeira semana"
|
msgstr "A vindeira semana"
|
||||||
|
|
||||||
@ -670,11 +668,11 @@ msgstr "Abrir con %s"
|
|||||||
msgid "Eject"
|
msgid "Eject"
|
||||||
msgstr "Expulsar"
|
msgstr "Expulsar"
|
||||||
|
|
||||||
#: ../js/ui/components/keyring.js:82 ../js/ui/components/polkitAgent.js:268
|
#: ../js/ui/components/keyring.js:88 ../js/ui/components/polkitAgent.js:280
|
||||||
msgid "Password:"
|
msgid "Password:"
|
||||||
msgstr "Contrasinal:"
|
msgstr "Contrasinal:"
|
||||||
|
|
||||||
#: ../js/ui/components/keyring.js:101
|
#: ../js/ui/components/keyring.js:107
|
||||||
msgid "Type again:"
|
msgid "Type again:"
|
||||||
msgstr "Escriba de novo:"
|
msgstr "Escriba de novo:"
|
||||||
|
|
||||||
@ -754,15 +752,15 @@ msgstr "Contrasinal da rede de banda larga móbil"
|
|||||||
msgid "A password is required to connect to '%s'."
|
msgid "A password is required to connect to '%s'."
|
||||||
msgstr "Requírese un contrasinal para conectarse a «%s»."
|
msgstr "Requírese un contrasinal para conectarse a «%s»."
|
||||||
|
|
||||||
#: ../js/ui/components/polkitAgent.js:55
|
#: ../js/ui/components/polkitAgent.js:54
|
||||||
msgid "Authentication Required"
|
msgid "Authentication Required"
|
||||||
msgstr "Requírese autenticación"
|
msgstr "Requírese autenticación"
|
||||||
|
|
||||||
#: ../js/ui/components/polkitAgent.js:93
|
#: ../js/ui/components/polkitAgent.js:92
|
||||||
msgid "Administrator"
|
msgid "Administrator"
|
||||||
msgstr "Administrador"
|
msgstr "Administrador"
|
||||||
|
|
||||||
#: ../js/ui/components/polkitAgent.js:165
|
#: ../js/ui/components/polkitAgent.js:170
|
||||||
msgid "Authenticate"
|
msgid "Authenticate"
|
||||||
msgstr "Autenticar"
|
msgstr "Autenticar"
|
||||||
|
|
||||||
@ -770,7 +768,7 @@ msgstr "Autenticar"
|
|||||||
#. * requested authentication was not gained; this can happen
|
#. * requested authentication was not gained; this can happen
|
||||||
#. * because of an authentication error (like invalid password),
|
#. * because of an authentication error (like invalid password),
|
||||||
#. * for instance.
|
#. * for instance.
|
||||||
#: ../js/ui/components/polkitAgent.js:256 ../js/ui/shellMountOperation.js:383
|
#: ../js/ui/components/polkitAgent.js:266 ../js/ui/shellMountOperation.js:383
|
||||||
msgid "Sorry, that didn't work. Please try again."
|
msgid "Sorry, that didn't work. Please try again."
|
||||||
msgstr "Desculpe, iso non funcionou. Ténteo de novo."
|
msgstr "Desculpe, iso non funcionou. Ténteo de novo."
|
||||||
|
|
||||||
@ -1036,22 +1034,22 @@ msgstr "Mostrar aplicativos"
|
|||||||
msgid "Dash"
|
msgid "Dash"
|
||||||
msgstr "Taboleiro"
|
msgstr "Taboleiro"
|
||||||
|
|
||||||
#: ../js/ui/dateMenu.js:91
|
#: ../js/ui/dateMenu.js:86
|
||||||
msgid "Open Calendar"
|
msgid "Open Calendar"
|
||||||
msgstr "Abrir Calendario"
|
msgstr "Abrir Calendario"
|
||||||
|
|
||||||
#: ../js/ui/dateMenu.js:96
|
#: ../js/ui/dateMenu.js:90
|
||||||
msgid "Open Clocks"
|
msgid "Open Clocks"
|
||||||
msgstr "Abrir Reloxos"
|
msgstr "Abrir Reloxos"
|
||||||
|
|
||||||
#: ../js/ui/dateMenu.js:105
|
#: ../js/ui/dateMenu.js:97
|
||||||
msgid "Date & Time Settings"
|
msgid "Date & Time Settings"
|
||||||
msgstr "Preferencias de data e hora"
|
msgstr "Preferencias de data e hora"
|
||||||
|
|
||||||
#. Translators: This is the date format to use when the calendar popup is
|
#. Translators: This is the date format to use when the calendar popup is
|
||||||
#. * shown - it is shown just below the time in the shell (e.g. "Tue 9:29 AM").
|
#. * shown - it is shown just below the time in the shell (e.g. "Tue 9:29 AM").
|
||||||
#.
|
#.
|
||||||
#: ../js/ui/dateMenu.js:215
|
#: ../js/ui/dateMenu.js:208
|
||||||
msgid "%A %B %e, %Y"
|
msgid "%A %B %e, %Y"
|
||||||
msgstr "%a, %e de %B, %Y"
|
msgstr "%a, %e de %B, %Y"
|
||||||
|
|
||||||
@ -1154,56 +1152,56 @@ msgstr "Instalar"
|
|||||||
msgid "Download and install '%s' from extensions.gnome.org?"
|
msgid "Download and install '%s' from extensions.gnome.org?"
|
||||||
msgstr "Desexa descargar e instalar «%s» desde extensions.gnome.org?"
|
msgstr "Desexa descargar e instalar «%s» desde extensions.gnome.org?"
|
||||||
|
|
||||||
#: ../js/ui/keyboard.js:619 ../js/ui/status/keyboard.js:314
|
#: ../js/ui/keyboard.js:619 ../js/ui/status/keyboard.js:333
|
||||||
#: ../js/ui/status/power.js:211
|
#: ../js/ui/status/power.js:211
|
||||||
msgid "Keyboard"
|
msgid "Keyboard"
|
||||||
msgstr "Teclado"
|
msgstr "Teclado"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:693
|
#: ../js/ui/lookingGlass.js:689
|
||||||
msgid "No extensions installed"
|
msgid "No extensions installed"
|
||||||
msgstr "Non hai ningunha extensión instalada"
|
msgstr "Non hai ningunha extensión instalada"
|
||||||
|
|
||||||
#. Translators: argument is an extension UUID.
|
#. Translators: argument is an extension UUID.
|
||||||
#: ../js/ui/lookingGlass.js:747
|
#: ../js/ui/lookingGlass.js:743
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%s has not emitted any errors."
|
msgid "%s has not emitted any errors."
|
||||||
msgstr "%s non emitiu ningún erro."
|
msgstr "%s non emitiu ningún erro."
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:753
|
#: ../js/ui/lookingGlass.js:749
|
||||||
msgid "Hide Errors"
|
msgid "Hide Errors"
|
||||||
msgstr "Ocultar erros"
|
msgstr "Ocultar erros"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:757 ../js/ui/lookingGlass.js:817
|
#: ../js/ui/lookingGlass.js:753 ../js/ui/lookingGlass.js:813
|
||||||
msgid "Show Errors"
|
msgid "Show Errors"
|
||||||
msgstr "Mostrar erros"
|
msgstr "Mostrar erros"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:766
|
#: ../js/ui/lookingGlass.js:762
|
||||||
msgid "Enabled"
|
msgid "Enabled"
|
||||||
msgstr "Activado"
|
msgstr "Activado"
|
||||||
|
|
||||||
#. translators:
|
#. translators:
|
||||||
#. * The device has been disabled
|
#. * The device has been disabled
|
||||||
#: ../js/ui/lookingGlass.js:769 ../src/gvc/gvc-mixer-control.c:1830
|
#: ../js/ui/lookingGlass.js:765 ../src/gvc/gvc-mixer-control.c:1830
|
||||||
msgid "Disabled"
|
msgid "Disabled"
|
||||||
msgstr "Desactivado"
|
msgstr "Desactivado"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:771
|
#: ../js/ui/lookingGlass.js:767
|
||||||
msgid "Error"
|
msgid "Error"
|
||||||
msgstr "Erro"
|
msgstr "Erro"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:773
|
#: ../js/ui/lookingGlass.js:769
|
||||||
msgid "Out of date"
|
msgid "Out of date"
|
||||||
msgstr "Obsoleto"
|
msgstr "Obsoleto"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:775
|
#: ../js/ui/lookingGlass.js:771
|
||||||
msgid "Downloading"
|
msgid "Downloading"
|
||||||
msgstr "Descargando"
|
msgstr "Descargando"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:799
|
#: ../js/ui/lookingGlass.js:795
|
||||||
msgid "View Source"
|
msgid "View Source"
|
||||||
msgstr "Ver fonte"
|
msgstr "Ver fonte"
|
||||||
|
|
||||||
#: ../js/ui/lookingGlass.js:808
|
#: ../js/ui/lookingGlass.js:804
|
||||||
msgid "Web Page"
|
msgid "Web Page"
|
||||||
msgstr "Páxina web"
|
msgstr "Páxina web"
|
||||||
|
|
||||||
@ -1223,35 +1221,35 @@ msgstr "Limpar mensaxes"
|
|||||||
msgid "Notification Settings"
|
msgid "Notification Settings"
|
||||||
msgstr "Preferencias das notificacións"
|
msgstr "Preferencias das notificacións"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1709
|
#: ../js/ui/messageTray.js:1711
|
||||||
msgid "No Messages"
|
msgid "No Messages"
|
||||||
msgstr "Non hai mensaxes"
|
msgstr "Non hai mensaxes"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:1785
|
#: ../js/ui/messageTray.js:1784
|
||||||
msgid "Message Tray"
|
msgid "Message Tray"
|
||||||
msgstr "Bandexa de mensaxes"
|
msgstr "Bandexa de mensaxes"
|
||||||
|
|
||||||
#: ../js/ui/messageTray.js:2813
|
#: ../js/ui/messageTray.js:2811
|
||||||
msgid "System Information"
|
msgid "System Information"
|
||||||
msgstr "Información do sistema"
|
msgstr "Información do sistema"
|
||||||
|
|
||||||
#: ../js/ui/notificationDaemon.js:629 ../src/shell-app.c:374
|
#: ../js/ui/notificationDaemon.js:629 ../src/shell-app.c:378
|
||||||
msgctxt "program"
|
msgctxt "program"
|
||||||
msgid "Unknown"
|
msgid "Unknown"
|
||||||
msgstr "Descoñecido"
|
msgstr "Descoñecido"
|
||||||
|
|
||||||
#: ../js/ui/overviewControls.js:463 ../js/ui/screenShield.js:149
|
#: ../js/ui/overviewControls.js:474 ../js/ui/screenShield.js:150
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%d new message"
|
msgid "%d new message"
|
||||||
msgid_plural "%d new messages"
|
msgid_plural "%d new messages"
|
||||||
msgstr[0] "%d mensaxe nova"
|
msgstr[0] "%d mensaxe nova"
|
||||||
msgstr[1] "%d mensaxes novas"
|
msgstr[1] "%d mensaxes novas"
|
||||||
|
|
||||||
#: ../js/ui/overview.js:84
|
#: ../js/ui/overview.js:82
|
||||||
msgid "Undo"
|
msgid "Undo"
|
||||||
msgstr "Desfacer"
|
msgstr "Desfacer"
|
||||||
|
|
||||||
#: ../js/ui/overview.js:129
|
#: ../js/ui/overview.js:127
|
||||||
msgid "Overview"
|
msgid "Overview"
|
||||||
msgstr "Vista xeral"
|
msgstr "Vista xeral"
|
||||||
|
|
||||||
@ -1259,21 +1257,21 @@ msgstr "Vista xeral"
|
|||||||
#. in the search entry when no search is
|
#. in the search entry when no search is
|
||||||
#. active; it should not exceed ~30
|
#. active; it should not exceed ~30
|
||||||
#. characters.
|
#. characters.
|
||||||
#: ../js/ui/overview.js:271
|
#: ../js/ui/overview.js:258
|
||||||
msgid "Type to search…"
|
msgid "Type to search…"
|
||||||
msgstr "Escriba para buscar…"
|
msgstr "Escriba para buscar…"
|
||||||
|
|
||||||
#: ../js/ui/panel.js:633
|
#: ../js/ui/panel.js:642
|
||||||
msgid "Quit"
|
msgid "Quit"
|
||||||
msgstr "Saír"
|
msgstr "Saír"
|
||||||
|
|
||||||
#. Translators: If there is no suitable word for "Activities"
|
#. Translators: If there is no suitable word for "Activities"
|
||||||
#. in your language, you can use the word for "Overview".
|
#. in your language, you can use the word for "Overview".
|
||||||
#: ../js/ui/panel.js:657
|
#: ../js/ui/panel.js:693
|
||||||
msgid "Activities"
|
msgid "Activities"
|
||||||
msgstr "Actividades"
|
msgstr "Actividades"
|
||||||
|
|
||||||
#: ../js/ui/panel.js:954
|
#: ../js/ui/panel.js:989
|
||||||
msgid "Top Bar"
|
msgid "Top Bar"
|
||||||
msgstr "Barra superior"
|
msgstr "Barra superior"
|
||||||
|
|
||||||
@ -1282,7 +1280,7 @@ msgstr "Barra superior"
|
|||||||
#. "ON" and "OFF") or "toggle-switch-intl" (for toggle
|
#. "ON" and "OFF") or "toggle-switch-intl" (for toggle
|
||||||
#. switches containing "◯" and "|"). Other values will
|
#. switches containing "◯" and "|"). Other values will
|
||||||
#. simply result in invisible toggle switches.
|
#. simply result in invisible toggle switches.
|
||||||
#: ../js/ui/popupMenu.js:727
|
#: ../js/ui/popupMenu.js:738
|
||||||
msgid "toggle-switch-us"
|
msgid "toggle-switch-us"
|
||||||
msgstr "toggle-switch-intl"
|
msgstr "toggle-switch-intl"
|
||||||
|
|
||||||
@ -1296,22 +1294,22 @@ msgstr "Pechar"
|
|||||||
|
|
||||||
#. 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:86
|
#: ../js/ui/screenShield.js:87
|
||||||
msgid "%A, %B %d"
|
msgid "%A, %B %d"
|
||||||
msgstr "%A, %d de %B"
|
msgstr "%A, %d de %B"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:151
|
#: ../js/ui/screenShield.js:152
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%d new notification"
|
msgid "%d new notification"
|
||||||
msgid_plural "%d new notifications"
|
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:438 ../js/ui/userMenu.js:807
|
#: ../js/ui/screenShield.js:449 ../js/ui/userMenu.js:807
|
||||||
msgid "Lock"
|
msgid "Lock"
|
||||||
msgstr "Bloquear"
|
msgstr "Bloquear"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:641
|
#: ../js/ui/screenShield.js:652
|
||||||
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"
|
||||||
|
|
||||||
@ -1322,35 +1320,35 @@ 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:762 ../js/ui/screenShield.js:1198
|
#: ../js/ui/screenShield.js:773 ../js/ui/screenShield.js:1213
|
||||||
msgid "Unable to lock"
|
msgid "Unable to lock"
|
||||||
msgstr "Non foi posíbel bloquear"
|
msgstr "Non foi posíbel bloquear"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:763 ../js/ui/screenShield.js:1199
|
#: ../js/ui/screenShield.js:774 ../js/ui/screenShield.js:1214
|
||||||
msgid "Lock was blocked by an application"
|
msgid "Lock was blocked by an application"
|
||||||
msgstr "Un aplicativo impediu o bloqueo"
|
msgstr "Un aplicativo impediu o bloqueo"
|
||||||
|
|
||||||
#: ../js/ui/searchDisplay.js:453
|
#: ../js/ui/searchDisplay.js:445
|
||||||
msgid "Searching…"
|
msgid "Searching…"
|
||||||
msgstr "Buscando…"
|
msgstr "Buscando…"
|
||||||
|
|
||||||
#: ../js/ui/searchDisplay.js:497
|
#: ../js/ui/searchDisplay.js:489
|
||||||
msgid "No results."
|
msgid "No results."
|
||||||
msgstr "Sen resultados."
|
msgstr "Sen resultados."
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:29
|
#: ../js/ui/shellEntry.js:27
|
||||||
msgid "Copy"
|
msgid "Copy"
|
||||||
msgstr "Copiar"
|
msgstr "Copiar"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:34
|
#: ../js/ui/shellEntry.js:32
|
||||||
msgid "Paste"
|
msgid "Paste"
|
||||||
msgstr "Pegar"
|
msgstr "Pegar"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:101
|
#: ../js/ui/shellEntry.js:99
|
||||||
msgid "Show Text"
|
msgid "Show Text"
|
||||||
msgstr "Mostrar texto"
|
msgstr "Mostrar texto"
|
||||||
|
|
||||||
#: ../js/ui/shellEntry.js:103
|
#: ../js/ui/shellEntry.js:101
|
||||||
msgid "Hide Text"
|
msgid "Hide Text"
|
||||||
msgstr "Ocultar texto"
|
msgstr "Ocultar texto"
|
||||||
|
|
||||||
@ -1362,7 +1360,7 @@ msgstr "Contrasinal"
|
|||||||
msgid "Remember Password"
|
msgid "Remember Password"
|
||||||
msgstr "Lembrar contrasinal"
|
msgstr "Lembrar contrasinal"
|
||||||
|
|
||||||
#: ../js/ui/shellMountOperation.js:403 ../js/ui/unlockDialog.js:114
|
#: ../js/ui/shellMountOperation.js:403 ../js/ui/unlockDialog.js:109
|
||||||
msgid "Unlock"
|
msgid "Unlock"
|
||||||
msgstr "Desbloquear"
|
msgstr "Desbloquear"
|
||||||
|
|
||||||
@ -1417,7 +1415,7 @@ msgstr "Texto grande"
|
|||||||
#: ../js/ui/status/bluetooth.js:28 ../js/ui/status/bluetooth.js:32
|
#: ../js/ui/status/bluetooth.js:28 ../js/ui/status/bluetooth.js:32
|
||||||
#: ../js/ui/status/bluetooth.js:289 ../js/ui/status/bluetooth.js:321
|
#: ../js/ui/status/bluetooth.js:289 ../js/ui/status/bluetooth.js:321
|
||||||
#: ../js/ui/status/bluetooth.js:357 ../js/ui/status/bluetooth.js:388
|
#: ../js/ui/status/bluetooth.js:357 ../js/ui/status/bluetooth.js:388
|
||||||
#: ../js/ui/status/network.js:826
|
#: ../js/ui/status/network.js:739
|
||||||
msgid "Bluetooth"
|
msgid "Bluetooth"
|
||||||
msgstr "Bluetooth"
|
msgstr "Bluetooth"
|
||||||
|
|
||||||
@ -1438,7 +1436,7 @@ msgid "Bluetooth Settings"
|
|||||||
msgstr "Preferencias do Bluetooth"
|
msgstr "Preferencias do Bluetooth"
|
||||||
|
|
||||||
#. TRANSLATORS: this means that bluetooth was disabled by hardware rfkill
|
#. TRANSLATORS: this means that bluetooth was disabled by hardware rfkill
|
||||||
#: ../js/ui/status/bluetooth.js:104 ../js/ui/status/network.js:178
|
#: ../js/ui/status/bluetooth.js:104 ../js/ui/status/network.js:142
|
||||||
msgid "hardware disabled"
|
msgid "hardware disabled"
|
||||||
msgstr "hardware desactivado"
|
msgstr "hardware desactivado"
|
||||||
|
|
||||||
@ -1446,12 +1444,12 @@ msgstr "hardware desactivado"
|
|||||||
msgid "Connection"
|
msgid "Connection"
|
||||||
msgstr "Conexión"
|
msgstr "Conexión"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:208 ../js/ui/status/network.js:460
|
#: ../js/ui/status/bluetooth.js:208 ../js/ui/status/network.js:404
|
||||||
msgid "disconnecting..."
|
msgid "disconnecting..."
|
||||||
msgstr "desconectando…"
|
msgstr "desconectando…"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:221 ../js/ui/status/network.js:466
|
#: ../js/ui/status/bluetooth.js:221 ../js/ui/status/network.js:410
|
||||||
#: ../js/ui/status/network.js:1546
|
#: ../js/ui/status/network.js:1343
|
||||||
msgid "connecting..."
|
msgid "connecting..."
|
||||||
msgstr "conectando…"
|
msgstr "conectando…"
|
||||||
|
|
||||||
@ -1506,8 +1504,10 @@ msgstr "O dispositivo «%s» quere emparellarse con este equipo"
|
|||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:366
|
#: ../js/ui/status/bluetooth.js:366
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Please confirm whether the PIN '%06d' matches the one on the device."
|
msgid ""
|
||||||
msgstr "Confirme que o PIN «%06d» coincide co mostrado no dispositivo."
|
"Please confirm whether the Passkey '%06d' matches the one on the device."
|
||||||
|
msgstr ""
|
||||||
|
"Confirme que a frase de paso «%06d» coincide coa mostrada no dispositivo."
|
||||||
|
|
||||||
#. Translators: this is the verb, not the noun
|
#. Translators: this is the verb, not the noun
|
||||||
#: ../js/ui/status/bluetooth.js:369
|
#: ../js/ui/status/bluetooth.js:369
|
||||||
@ -1531,11 +1531,11 @@ msgstr "Escriba o PIN mencionado no dispositivo."
|
|||||||
msgid "OK"
|
msgid "OK"
|
||||||
msgstr "Aceptar"
|
msgstr "Aceptar"
|
||||||
|
|
||||||
#: ../js/ui/status/keyboard.js:368
|
#: ../js/ui/status/keyboard.js:396
|
||||||
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/keyboard.js:373
|
#: ../js/ui/status/keyboard.js:401
|
||||||
msgid "Region & Language Settings"
|
msgid "Region & Language Settings"
|
||||||
msgstr "Preferencias de rexión e idioma"
|
msgstr "Preferencias de rexión e idioma"
|
||||||
|
|
||||||
@ -1543,117 +1543,91 @@ msgstr "Preferencias de rexión e idioma"
|
|||||||
msgid "Volume, network, battery"
|
msgid "Volume, network, battery"
|
||||||
msgstr "Volume, rede, batería"
|
msgstr "Volume, rede, batería"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:104
|
#: ../js/ui/status/network.js:75
|
||||||
msgid "<unknown>"
|
msgid "<unknown>"
|
||||||
msgstr "<descoñecido>"
|
msgstr "<descoñecido>"
|
||||||
|
|
||||||
|
#: ../js/ui/status/network.js:127
|
||||||
|
msgid "Wi-Fi"
|
||||||
|
msgstr "Wifi"
|
||||||
|
|
||||||
#. Translators: this indicates that wireless or wwan is disabled by hardware killswitch
|
#. Translators: this indicates that wireless or wwan is disabled by hardware killswitch
|
||||||
#: ../js/ui/status/network.js:200
|
#: ../js/ui/status/network.js:164
|
||||||
msgid "disabled"
|
msgid "disabled"
|
||||||
msgstr "desactivada"
|
msgstr "desactivada"
|
||||||
|
|
||||||
#. 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:458
|
#: ../js/ui/status/network.js:402
|
||||||
msgid "unmanaged"
|
msgid "unmanaged"
|
||||||
msgstr "non xestionada"
|
msgstr "non xestionada"
|
||||||
|
|
||||||
#. 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:469 ../js/ui/status/network.js:1549
|
#: ../js/ui/status/network.js:413 ../js/ui/status/network.js:1346
|
||||||
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:479
|
#: ../js/ui/status/network.js:423
|
||||||
msgid "firmware missing"
|
msgid "firmware missing"
|
||||||
msgstr "falta o «firmware»"
|
msgstr "falta o «firmware»"
|
||||||
|
|
||||||
#. Translators: this is for wired network devices that are physically disconnected
|
#. Translators: this is for wired network devices that are physically disconnected
|
||||||
#: ../js/ui/status/network.js:486
|
#: ../js/ui/status/network.js:430
|
||||||
msgid "cable unplugged"
|
msgid "cable unplugged"
|
||||||
msgstr "cable desconectado"
|
msgstr "cable desconectado"
|
||||||
|
|
||||||
#. 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:491
|
#: ../js/ui/status/network.js:435
|
||||||
msgid "unavailable"
|
msgid "unavailable"
|
||||||
msgstr "non dispoñíbel"
|
msgstr "non dispoñíbel"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:493 ../js/ui/status/network.js:1551
|
#: ../js/ui/status/network.js:437 ../js/ui/status/network.js:1348
|
||||||
msgid "connection failed"
|
msgid "connection failed"
|
||||||
msgstr "conexión fallada"
|
msgstr "conexión fallada"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:552 ../js/ui/status/network.js:1435
|
#: ../js/ui/status/network.js:490 ../js/ui/status/network.js:1236
|
||||||
#: ../js/ui/status/network.js:1627
|
#: ../js/ui/status/network.js:1424
|
||||||
msgid "More…"
|
msgid "More…"
|
||||||
msgstr "Máis…"
|
msgstr "Máis…"
|
||||||
|
|
||||||
#. TRANSLATORS: this is the indication that a connection for another logged in user is active,
|
#. TRANSLATORS: this is the indication that a connection for another logged in user is active,
|
||||||
#. and we cannot access its settings (including the name)
|
#. and we cannot access its settings (including the name)
|
||||||
#: ../js/ui/status/network.js:588 ../js/ui/status/network.js:1365
|
#: ../js/ui/status/network.js:518 ../js/ui/status/network.js:1191
|
||||||
msgid "Connected (private)"
|
msgid "Connected (private)"
|
||||||
msgstr "Conectada (privada)"
|
msgstr "Conectada (privada)"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:667
|
#: ../js/ui/status/network.js:597
|
||||||
msgid "Wired"
|
msgid "Wired"
|
||||||
msgstr "Con fíos"
|
msgstr "Con fíos"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:668
|
#: ../js/ui/status/network.js:611
|
||||||
msgid "Auto Ethernet"
|
|
||||||
msgstr "Ethernet automática"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:695
|
|
||||||
msgid "Mobile broadband"
|
msgid "Mobile broadband"
|
||||||
msgstr "Banda larga móbil"
|
msgstr "Banda larga móbil"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:728
|
#: ../js/ui/status/network.js:1522
|
||||||
msgid "Auto broadband"
|
|
||||||
msgstr "Banda larga automática"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:731
|
|
||||||
msgid "Auto dial-up"
|
|
||||||
msgstr "Marcado automático"
|
|
||||||
|
|
||||||
#. TRANSLATORS: this the automatic wireless connection name (including the network name)
|
|
||||||
#: ../js/ui/status/network.js:861 ../js/ui/status/network.js:1382
|
|
||||||
#, c-format
|
|
||||||
msgid "Auto %s"
|
|
||||||
msgstr "%s automática"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:863
|
|
||||||
msgid "Auto bluetooth"
|
|
||||||
msgstr "Bluetooth automática"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1384
|
|
||||||
msgid "Auto wireless"
|
|
||||||
msgstr "Sen fíos automática"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1729
|
|
||||||
msgid "Enable networking"
|
msgid "Enable networking"
|
||||||
msgstr "Activar rede"
|
msgstr "Activar rede"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1771
|
#: ../js/ui/status/network.js:1583
|
||||||
msgid "Wi-Fi"
|
|
||||||
msgstr "Wifi"
|
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1790
|
|
||||||
msgid "Network Settings"
|
msgid "Network Settings"
|
||||||
msgstr "Preferencias da rede"
|
msgstr "Preferencias da rede"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1807
|
#: ../js/ui/status/network.js:1600
|
||||||
msgid "Network Manager"
|
msgid "Network Manager"
|
||||||
msgstr "Xestor da rede"
|
msgstr "Xestor da rede"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1897
|
#: ../js/ui/status/network.js:1690
|
||||||
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:1898
|
#: ../js/ui/status/network.js:1691
|
||||||
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"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:2276
|
#: ../js/ui/status/network.js:2047
|
||||||
msgid "Networking is disabled"
|
msgid "Networking is disabled"
|
||||||
msgstr "A rede está desactivada"
|
msgstr "A rede está desactivada"
|
||||||
|
|
||||||
@ -1767,11 +1741,11 @@ msgstr "Volume"
|
|||||||
msgid "Microphone"
|
msgid "Microphone"
|
||||||
msgstr "Micrófono"
|
msgstr "Micrófono"
|
||||||
|
|
||||||
#: ../js/ui/unlockDialog.js:125
|
#: ../js/ui/unlockDialog.js:120
|
||||||
msgid "Log in as another user"
|
msgid "Log in as another user"
|
||||||
msgstr "Iniciar sesión como outro usuario"
|
msgstr "Iniciar sesión como outro usuario"
|
||||||
|
|
||||||
#: ../js/ui/unlockDialog.js:146
|
#: ../js/ui/unlockDialog.js:141
|
||||||
msgid "Unlock Window"
|
msgid "Unlock Window"
|
||||||
msgstr "Desbloquear xanela"
|
msgstr "Desbloquear xanela"
|
||||||
|
|
||||||
@ -1901,34 +1875,34 @@ msgstr[1] "%u entradas"
|
|||||||
msgid "System Sounds"
|
msgid "System Sounds"
|
||||||
msgstr "Sons do sistema"
|
msgstr "Sons do sistema"
|
||||||
|
|
||||||
#: ../src/main.c:347
|
#: ../src/main.c:372
|
||||||
msgid "Print version"
|
msgid "Print version"
|
||||||
msgstr "Imprimir versión"
|
msgstr "Imprimir versión"
|
||||||
|
|
||||||
#: ../src/main.c:353
|
#: ../src/main.c:378
|
||||||
msgid "Mode used by GDM for login screen"
|
msgid "Mode used by GDM for login screen"
|
||||||
msgstr "Modo usado por GDM para a pantalla de inicio"
|
msgstr "Modo usado por GDM para a pantalla de inicio"
|
||||||
|
|
||||||
#: ../src/main.c:359
|
#: ../src/main.c:384
|
||||||
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Usar un modo específico, por exemplo, «gdm» para a pantalla de inicio de "
|
"Usar un modo específico, por exemplo, «gdm» para a pantalla de inicio de "
|
||||||
"sesión"
|
"sesión"
|
||||||
|
|
||||||
#: ../src/main.c:365
|
#: ../src/main.c:390
|
||||||
msgid "List possible modes"
|
msgid "List possible modes"
|
||||||
msgstr "Listar os modos posíbeis"
|
msgstr "Listar os modos posíbeis"
|
||||||
|
|
||||||
#: ../src/shell-app.c:622
|
#: ../src/shell-app.c:626
|
||||||
#, 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»"
|
||||||
|
|
||||||
#: ../src/shell-keyring-prompt.c:708
|
#: ../src/shell-keyring-prompt.c:714
|
||||||
msgid "Passwords do not match."
|
msgid "Passwords do not match."
|
||||||
msgstr "Os contrasinais non coinciden."
|
msgstr "Os contrasinais non coinciden."
|
||||||
|
|
||||||
#: ../src/shell-keyring-prompt.c:716
|
#: ../src/shell-keyring-prompt.c:722
|
||||||
msgid "Password cannot be blank"
|
msgid "Password cannot be blank"
|
||||||
msgstr "O contrasinal non pode estar baleiro"
|
msgstr "O contrasinal non pode estar baleiro"
|
||||||
|
|
||||||
@ -1936,6 +1910,39 @@ msgstr "O contrasinal non pode estar baleiro"
|
|||||||
msgid "Authentication dialog was dismissed by the user"
|
msgid "Authentication dialog was dismissed by the user"
|
||||||
msgstr "O usuario rexeitou o diálogo de autenticación"
|
msgstr "O usuario rexeitou o diálogo de autenticación"
|
||||||
|
|
||||||
|
#~ msgid "Whether to collect stats about applications usage"
|
||||||
|
#~ msgstr ""
|
||||||
|
#~ "Indica se se deben recolectar estatísticas sobre o uso dos aplicativos"
|
||||||
|
|
||||||
|
#~ msgid ""
|
||||||
|
#~ "The shell normally monitors active applications in order to present the "
|
||||||
|
#~ "most used ones (e.g. in launchers). While this data will be kept private, "
|
||||||
|
#~ "you may want to disable this for privacy reasons. Please note that doing "
|
||||||
|
#~ "so won't remove already saved data."
|
||||||
|
#~ msgstr ""
|
||||||
|
#~ "O shell normalmente monitoriza os aplicativos activos para mostrarlle os "
|
||||||
|
#~ "máis usados (p.ex. nos iniciadores). Aínda que estes datos se manteñen de "
|
||||||
|
#~ "forma privada, vostede pode desactivar isto por razóns de privacidade. "
|
||||||
|
#~ "Teña en conta que facendo isto non retirará os datos gardados."
|
||||||
|
|
||||||
|
#~ msgid "Auto Ethernet"
|
||||||
|
#~ msgstr "Ethernet automática"
|
||||||
|
|
||||||
|
#~ msgid "Auto broadband"
|
||||||
|
#~ msgstr "Banda larga automática"
|
||||||
|
|
||||||
|
#~ msgid "Auto dial-up"
|
||||||
|
#~ msgstr "Marcado automático"
|
||||||
|
|
||||||
|
#~ msgid "Auto %s"
|
||||||
|
#~ msgstr "%s automática"
|
||||||
|
|
||||||
|
#~ msgid "Auto bluetooth"
|
||||||
|
#~ msgstr "Bluetooth automática"
|
||||||
|
|
||||||
|
#~ msgid "Auto wireless"
|
||||||
|
#~ msgstr "Sen fíos automática"
|
||||||
|
|
||||||
#~ msgctxt "title"
|
#~ msgctxt "title"
|
||||||
#~ msgid "Sign In"
|
#~ msgid "Sign In"
|
||||||
#~ msgstr "Iniciar sesión"
|
#~ msgstr "Iniciar sesión"
|
||||||
|
265
po/tg.po
265
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: 2013-05-29 22:58+0000\n"
|
"POT-Creation-Date: 2013-06-14 18:16+0000\n"
|
||||||
"PO-Revision-Date: 2013-05-30 17:27+0500\n"
|
"PO-Revision-Date: 2013-06-16 23:32+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: Tajik\n"
|
"Language: Tajik\n"
|
||||||
@ -207,12 +207,10 @@ msgstr ""
|
|||||||
"Тугма барои кушодани намуди \"Намоиш додани барномаҳо\"-и Хулосаи фаъолият."
|
"Тугма барои кушодани намуди \"Намоиш додани барномаҳо\"-и Хулосаи фаъолият."
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:23
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:23
|
||||||
#| msgid "Keybinding to open the \"Show Applications\" view"
|
|
||||||
msgid "Keybinding to open the overview"
|
msgid "Keybinding to open the overview"
|
||||||
msgstr "Тугмабандӣ барои кушодани хулоса"
|
msgstr "Тугмабандӣ барои кушодани хулоса"
|
||||||
|
|
||||||
#: ../data/org.gnome.shell.gschema.xml.in.in.h:24
|
#: ../data/org.gnome.shell.gschema.xml.in.in.h:24
|
||||||
#| msgid "Keybinding to open the \"Show Applications\" view"
|
|
||||||
msgid "Keybinding to open the Activities Overview."
|
msgid "Keybinding to open the Activities Overview."
|
||||||
msgstr "Тугмабандӣ барои кушодани хулосаи фаъолият."
|
msgstr "Тугмабандӣ барои кушодани хулосаи фаъолият."
|
||||||
|
|
||||||
@ -377,37 +375,37 @@ msgstr ""
|
|||||||
"Пасвандеро интихоб кунед, то ин ки бо ҷаъбаи мураккаби боло онро "
|
"Пасвандеро интихоб кунед, то ин ки бо ҷаъбаи мураккаби боло онро "
|
||||||
"конфигуратсия кунед."
|
"конфигуратсия кунед."
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:371
|
#: ../js/gdm/loginDialog.js:370
|
||||||
msgid "Session…"
|
msgid "Session…"
|
||||||
msgstr "Ҷаласа..."
|
msgstr "Ҷаласа..."
|
||||||
|
|
||||||
#. translators: this message is shown below the user list on the
|
#. translators: this message is shown below the user list on the
|
||||||
#. login screen. It can be activated to reveal an entry for
|
#. login screen. It can be activated to reveal an entry for
|
||||||
#. manually entering the username.
|
#. manually entering the username.
|
||||||
#: ../js/gdm/loginDialog.js:601
|
#: ../js/gdm/loginDialog.js:600
|
||||||
msgid "Not listed?"
|
msgid "Not listed?"
|
||||||
msgstr "Вуҷуд надора?"
|
msgstr "Вуҷуд надора?"
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:776 ../js/ui/components/networkAgent.js:137
|
#: ../js/gdm/loginDialog.js:775 ../js/ui/components/networkAgent.js:137
|
||||||
#: ../js/ui/components/polkitAgent.js:161 ../js/ui/endSessionDialog.js:376
|
#: ../js/ui/components/polkitAgent.js:161 ../js/ui/endSessionDialog.js:376
|
||||||
#: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399
|
#: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399
|
||||||
#: ../js/ui/status/bluetooth.js:415 ../js/ui/unlockDialog.js:96
|
#: ../js/ui/status/bluetooth.js:449 ../js/ui/unlockDialog.js:95
|
||||||
#: ../js/ui/userMenu.js:938
|
#: ../js/ui/userMenu.js:884
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
msgstr "Бекор кардан"
|
msgstr "Бекор кардан"
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:791
|
#: ../js/gdm/loginDialog.js:790
|
||||||
msgctxt "button"
|
msgctxt "button"
|
||||||
msgid "Sign In"
|
msgid "Sign In"
|
||||||
msgstr "Ворид шудан"
|
msgstr "Ворид шудан"
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:791
|
#: ../js/gdm/loginDialog.js:790
|
||||||
msgid "Next"
|
msgid "Next"
|
||||||
msgstr "Навбатӣ"
|
msgstr "Навбатӣ"
|
||||||
|
|
||||||
#. Translators: this message is shown below the username entry field
|
#. Translators: this message is shown below the username entry field
|
||||||
#. to clue the user in on how to login to the local network realm
|
#. to clue the user in on how to login to the local network realm
|
||||||
#: ../js/gdm/loginDialog.js:888
|
#: ../js/gdm/loginDialog.js:887
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "(e.g., user or %s)"
|
msgid "(e.g., user or %s)"
|
||||||
msgstr "(масалан, корбар ё %s)"
|
msgstr "(масалан, корбар ё %s)"
|
||||||
@ -415,12 +413,12 @@ msgstr "(масалан, корбар ё %s)"
|
|||||||
#. TTLS and PEAP are actually much more complicated, but this complication
|
#. TTLS and PEAP are actually much more complicated, but this complication
|
||||||
#. is not visible here since we only care about phase2 authentication
|
#. is not visible here since we only care about phase2 authentication
|
||||||
#. (and don't even care of which one)
|
#. (and don't even care of which one)
|
||||||
#: ../js/gdm/loginDialog.js:892 ../js/ui/components/networkAgent.js:260
|
#: ../js/gdm/loginDialog.js:891 ../js/ui/components/networkAgent.js:260
|
||||||
#: ../js/ui/components/networkAgent.js:278
|
#: ../js/ui/components/networkAgent.js:278
|
||||||
msgid "Username: "
|
msgid "Username: "
|
||||||
msgstr "Номи корбар:"
|
msgstr "Номи корбар:"
|
||||||
|
|
||||||
#: ../js/gdm/loginDialog.js:1158
|
#: ../js/gdm/loginDialog.js:1157
|
||||||
msgid "Login Window"
|
msgid "Login Window"
|
||||||
msgstr "Равзанаи воридшавӣ"
|
msgstr "Равзанаи воридшавӣ"
|
||||||
|
|
||||||
@ -429,8 +427,8 @@ msgstr "Равзанаи воридшавӣ"
|
|||||||
msgid "Power"
|
msgid "Power"
|
||||||
msgstr "Барқ"
|
msgstr "Барқ"
|
||||||
|
|
||||||
#: ../js/gdm/powerMenu.js:93 ../js/ui/userMenu.js:696 ../js/ui/userMenu.js:700
|
#: ../js/gdm/powerMenu.js:93 ../js/ui/userMenu.js:651 ../js/ui/userMenu.js:655
|
||||||
#: ../js/ui/userMenu.js:816
|
#: ../js/ui/userMenu.js:768
|
||||||
msgid "Suspend"
|
msgid "Suspend"
|
||||||
msgstr "Таваққуф"
|
msgstr "Таваққуф"
|
||||||
|
|
||||||
@ -438,8 +436,8 @@ msgstr "Таваққуф"
|
|||||||
msgid "Restart"
|
msgid "Restart"
|
||||||
msgstr "Бозоғозидан"
|
msgstr "Бозоғозидан"
|
||||||
|
|
||||||
#: ../js/gdm/powerMenu.js:103 ../js/ui/userMenu.js:698
|
#: ../js/gdm/powerMenu.js:103 ../js/ui/userMenu.js:653
|
||||||
#: ../js/ui/userMenu.js:700 ../js/ui/userMenu.js:815 ../js/ui/userMenu.js:942
|
#: ../js/ui/userMenu.js:655 ../js/ui/userMenu.js:767 ../js/ui/userMenu.js:888
|
||||||
msgid "Power Off"
|
msgid "Power Off"
|
||||||
msgstr "Хомӯш кардан"
|
msgstr "Хомӯш кардан"
|
||||||
|
|
||||||
@ -468,23 +466,23 @@ msgstr "Фармон иҷро нашудааст:"
|
|||||||
msgid "Execution of '%s' failed:"
|
msgid "Execution of '%s' failed:"
|
||||||
msgstr "Иҷрокунии '%s' қатъ шудааст:"
|
msgstr "Иҷрокунии '%s' қатъ шудааст:"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:361
|
#: ../js/ui/appDisplay.js:397
|
||||||
msgid "Frequent"
|
msgid "Frequent"
|
||||||
msgstr "Роиҷ"
|
msgstr "Роиҷ"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:368
|
#: ../js/ui/appDisplay.js:404
|
||||||
msgid "All"
|
msgid "All"
|
||||||
msgstr "Ҳама"
|
msgstr "Ҳама"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:960
|
#: ../js/ui/appDisplay.js:996
|
||||||
msgid "New Window"
|
msgid "New Window"
|
||||||
msgstr "Равзанаи нав"
|
msgstr "Равзанаи нав"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:963 ../js/ui/dash.js:284
|
#: ../js/ui/appDisplay.js:999 ../js/ui/dash.js:284
|
||||||
msgid "Remove from Favorites"
|
msgid "Remove from Favorites"
|
||||||
msgstr "Тоза кардан аз Баргузидаҳо"
|
msgstr "Тоза кардан аз Баргузидаҳо"
|
||||||
|
|
||||||
#: ../js/ui/appDisplay.js:964
|
#: ../js/ui/appDisplay.js:1000
|
||||||
msgid "Add to Favorites"
|
msgid "Add to Favorites"
|
||||||
msgstr "Илова кардан ба Баргузидаҳо"
|
msgstr "Илова кардан ба Баргузидаҳо"
|
||||||
|
|
||||||
@ -498,7 +496,7 @@ msgstr "%s ба баргузидаҳои шумо илова шудааст."
|
|||||||
msgid "%s has been removed from your favorites."
|
msgid "%s has been removed from your favorites."
|
||||||
msgstr "%s аз баргузидаҳои шумо тоза шудааст."
|
msgstr "%s аз баргузидаҳои шумо тоза шудааст."
|
||||||
|
|
||||||
#: ../js/ui/backgroundMenu.js:19 ../js/ui/userMenu.js:789
|
#: ../js/ui/backgroundMenu.js:19 ../js/ui/userMenu.js:744
|
||||||
msgid "Settings"
|
msgid "Settings"
|
||||||
msgstr "Танзимот"
|
msgstr "Танзимот"
|
||||||
|
|
||||||
@ -623,35 +621,35 @@ msgid "S"
|
|||||||
msgstr "Ш"
|
msgstr "Ш"
|
||||||
|
|
||||||
#. Translators: Text to show if there are no events
|
#. Translators: Text to show if there are no events
|
||||||
#: ../js/ui/calendar.js:735
|
#: ../js/ui/calendar.js:750
|
||||||
msgid "Nothing Scheduled"
|
msgid "Nothing Scheduled"
|
||||||
msgstr "Ягон чиз ба нақша нагирифтааст"
|
msgstr "Ягон чиз ба нақша нагирифтааст"
|
||||||
|
|
||||||
#. Translators: Shown on calendar heading when selected day occurs on current year
|
#. Translators: Shown on calendar heading when selected day occurs on current year
|
||||||
#: ../js/ui/calendar.js:751
|
#: ../js/ui/calendar.js:768
|
||||||
msgctxt "calendar heading"
|
msgctxt "calendar heading"
|
||||||
msgid "%A, %B %d"
|
msgid "%A, %B %d"
|
||||||
msgstr "%A, %B %d"
|
msgstr "%A, %B %d"
|
||||||
|
|
||||||
#. Translators: Shown on calendar heading when selected day occurs on different year
|
#. Translators: Shown on calendar heading when selected day occurs on different year
|
||||||
#: ../js/ui/calendar.js:754
|
#: ../js/ui/calendar.js:771
|
||||||
msgctxt "calendar heading"
|
msgctxt "calendar heading"
|
||||||
msgid "%A, %B %d, %Y"
|
msgid "%A, %B %d, %Y"
|
||||||
msgstr "%A, %B %d, %Y"
|
msgstr "%A, %B %d, %Y"
|
||||||
|
|
||||||
#: ../js/ui/calendar.js:764
|
#: ../js/ui/calendar.js:782
|
||||||
msgid "Today"
|
msgid "Today"
|
||||||
msgstr "Имрӯз"
|
msgstr "Имрӯз"
|
||||||
|
|
||||||
#: ../js/ui/calendar.js:768
|
#: ../js/ui/calendar.js:786
|
||||||
msgid "Tomorrow"
|
msgid "Tomorrow"
|
||||||
msgstr "Фардо"
|
msgstr "Фардо"
|
||||||
|
|
||||||
#: ../js/ui/calendar.js:779
|
#: ../js/ui/calendar.js:797
|
||||||
msgid "This week"
|
msgid "This week"
|
||||||
msgstr "Ҳафтаи ҷорӣ"
|
msgstr "Ҳафтаи ҷорӣ"
|
||||||
|
|
||||||
#: ../js/ui/calendar.js:787
|
#: ../js/ui/calendar.js:805
|
||||||
msgid "Next week"
|
msgid "Next week"
|
||||||
msgstr "Ҳафтаи навбатӣ"
|
msgstr "Ҳафтаи навбатӣ"
|
||||||
|
|
||||||
@ -1035,26 +1033,26 @@ msgstr "Намоиш додани барномаҳо"
|
|||||||
|
|
||||||
#. Translators: this is the name of the dock/favorites area on
|
#. Translators: this is the name of the dock/favorites area on
|
||||||
#. the left of the overview
|
#. the left of the overview
|
||||||
#: ../js/ui/dash.js:435
|
#: ../js/ui/dash.js:439
|
||||||
msgid "Dash"
|
msgid "Dash"
|
||||||
msgstr "Рах"
|
msgstr "Рах"
|
||||||
|
|
||||||
#: ../js/ui/dateMenu.js:86
|
#: ../js/ui/dateMenu.js:85
|
||||||
msgid "Open Calendar"
|
msgid "Open Calendar"
|
||||||
msgstr "Кушодани тақвим"
|
msgstr "Кушодани тақвим"
|
||||||
|
|
||||||
#: ../js/ui/dateMenu.js:90
|
#: ../js/ui/dateMenu.js:89
|
||||||
msgid "Open Clocks"
|
msgid "Open Clocks"
|
||||||
msgstr "Кушодани соат"
|
msgstr "Кушодани соат"
|
||||||
|
|
||||||
#: ../js/ui/dateMenu.js:97
|
#: ../js/ui/dateMenu.js:96
|
||||||
msgid "Date & Time Settings"
|
msgid "Date & Time Settings"
|
||||||
msgstr "Танзимоти сана ва вақт"
|
msgstr "Танзимоти сана ва вақт"
|
||||||
|
|
||||||
#. Translators: This is the date format to use when the calendar popup is
|
#. Translators: This is the date format to use when the calendar popup is
|
||||||
#. * shown - it is shown just below the time in the shell (e.g. "Tue 9:29 AM").
|
#. * shown - it is shown just below the time in the shell (e.g. "Tue 9:29 AM").
|
||||||
#.
|
#.
|
||||||
#: ../js/ui/dateMenu.js:208
|
#: ../js/ui/dateMenu.js:202
|
||||||
msgid "%A %B %e, %Y"
|
msgid "%A %B %e, %Y"
|
||||||
msgstr "%A %B %e, %Y"
|
msgstr "%A %B %e, %Y"
|
||||||
|
|
||||||
@ -1284,7 +1282,7 @@ msgstr "Панели боло"
|
|||||||
#. "ON" and "OFF") or "toggle-switch-intl" (for toggle
|
#. "ON" and "OFF") or "toggle-switch-intl" (for toggle
|
||||||
#. switches containing "◯" and "|"). Other values will
|
#. switches containing "◯" and "|"). Other values will
|
||||||
#. simply result in invisible toggle switches.
|
#. simply result in invisible toggle switches.
|
||||||
#: ../js/ui/popupMenu.js:738
|
#: ../js/ui/popupMenu.js:545
|
||||||
msgid "toggle-switch-us"
|
msgid "toggle-switch-us"
|
||||||
msgstr "toggle-switch-us"
|
msgstr "toggle-switch-us"
|
||||||
|
|
||||||
@ -1308,7 +1306,7 @@ msgid "%d new notification"
|
|||||||
msgid_plural "%d new notifications"
|
msgid_plural "%d new notifications"
|
||||||
msgstr[0] "%d огоҳии нав"
|
msgstr[0] "%d огоҳии нав"
|
||||||
|
|
||||||
#: ../js/ui/screenShield.js:449 ../js/ui/userMenu.js:807
|
#: ../js/ui/screenShield.js:449 ../js/ui/userMenu.js:759
|
||||||
msgid "Lock"
|
msgid "Lock"
|
||||||
msgstr "Қулф кардан"
|
msgstr "Қулф кардан"
|
||||||
|
|
||||||
@ -1363,7 +1361,7 @@ msgstr "Парол"
|
|||||||
msgid "Remember Password"
|
msgid "Remember Password"
|
||||||
msgstr "Ба ёд гирифтани парол"
|
msgstr "Ба ёд гирифтани парол"
|
||||||
|
|
||||||
#: ../js/ui/shellMountOperation.js:403 ../js/ui/unlockDialog.js:109
|
#: ../js/ui/shellMountOperation.js:403 ../js/ui/unlockDialog.js:108
|
||||||
msgid "Unlock"
|
msgid "Unlock"
|
||||||
msgstr "Кушодан"
|
msgstr "Кушодан"
|
||||||
|
|
||||||
@ -1416,9 +1414,9 @@ msgid "Large Text"
|
|||||||
msgstr "Матни бузург"
|
msgstr "Матни бузург"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:28 ../js/ui/status/bluetooth.js:32
|
#: ../js/ui/status/bluetooth.js:28 ../js/ui/status/bluetooth.js:32
|
||||||
#: ../js/ui/status/bluetooth.js:289 ../js/ui/status/bluetooth.js:321
|
#: ../js/ui/status/bluetooth.js:290 ../js/ui/status/bluetooth.js:327
|
||||||
#: ../js/ui/status/bluetooth.js:357 ../js/ui/status/bluetooth.js:388
|
#: ../js/ui/status/bluetooth.js:355 ../js/ui/status/bluetooth.js:391
|
||||||
#: ../js/ui/status/network.js:739
|
#: ../js/ui/status/bluetooth.js:422 ../js/ui/status/network.js:713
|
||||||
msgid "Bluetooth"
|
msgid "Bluetooth"
|
||||||
msgstr "Bluetooth"
|
msgstr "Bluetooth"
|
||||||
|
|
||||||
@ -1439,75 +1437,83 @@ msgid "Bluetooth Settings"
|
|||||||
msgstr "Танзимоти Bluetooth"
|
msgstr "Танзимоти Bluetooth"
|
||||||
|
|
||||||
#. TRANSLATORS: this means that bluetooth was disabled by hardware rfkill
|
#. TRANSLATORS: this means that bluetooth was disabled by hardware rfkill
|
||||||
#: ../js/ui/status/bluetooth.js:104 ../js/ui/status/network.js:142
|
#: ../js/ui/status/bluetooth.js:105 ../js/ui/status/network.js:140
|
||||||
msgid "hardware disabled"
|
msgid "hardware disabled"
|
||||||
msgstr "сахтафзор ғайрифаъол шудааст"
|
msgstr "сахтафзор ғайрифаъол шудааст"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:197
|
#: ../js/ui/status/bluetooth.js:198
|
||||||
msgid "Connection"
|
msgid "Connection"
|
||||||
msgstr "Пайвастшавӣ"
|
msgstr "Пайвастшавӣ"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:208 ../js/ui/status/network.js:404
|
#: ../js/ui/status/bluetooth.js:209 ../js/ui/status/network.js:399
|
||||||
msgid "disconnecting..."
|
msgid "disconnecting..."
|
||||||
msgstr "қатъ кардани пайваст..."
|
msgstr "қатъ кардани пайваст..."
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:221 ../js/ui/status/network.js:410
|
#: ../js/ui/status/bluetooth.js:222 ../js/ui/status/network.js:405
|
||||||
#: ../js/ui/status/network.js:1343
|
#: ../js/ui/status/network.js:1298
|
||||||
msgid "connecting..."
|
msgid "connecting..."
|
||||||
msgstr "пайвастшавӣ..."
|
msgstr "пайвастшавӣ..."
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:239
|
#: ../js/ui/status/bluetooth.js:240
|
||||||
msgid "Send Files…"
|
msgid "Send Files…"
|
||||||
msgstr "Фиристодани файлҳо…"
|
msgstr "Фиристодани файлҳо…"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:246
|
#: ../js/ui/status/bluetooth.js:247
|
||||||
msgid "Keyboard Settings"
|
msgid "Keyboard Settings"
|
||||||
msgstr "Танзимоти клавиатура"
|
msgstr "Танзимоти клавиатура"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:249
|
#: ../js/ui/status/bluetooth.js:250
|
||||||
msgid "Mouse Settings"
|
msgid "Mouse Settings"
|
||||||
msgstr "Танзимоти муш"
|
msgstr "Танзимоти муш"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:254 ../js/ui/status/volume.js:316
|
#: ../js/ui/status/bluetooth.js:255 ../js/ui/status/volume.js:313
|
||||||
msgid "Sound Settings"
|
msgid "Sound Settings"
|
||||||
msgstr "Танзимоти садо"
|
msgstr "Танзимоти садо"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:322
|
#: ../js/ui/status/bluetooth.js:328 ../js/ui/status/bluetooth.js:356
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Authorization request from %s"
|
msgid "Authorization request from %s"
|
||||||
msgstr "Дархости санҷиши ҳаққоният аз %s"
|
msgstr "Дархости санҷиши ҳаққоният аз %s"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:328
|
#: ../js/ui/status/bluetooth.js:334 ../js/ui/status/bluetooth.js:399
|
||||||
#, c-format
|
#: ../js/ui/status/bluetooth.js:430
|
||||||
msgid "Device %s wants access to the service '%s'"
|
|
||||||
msgstr "Дастгоҳи %s дастрасиро ба хидмати \"%s\" дархост мекунад"
|
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:330
|
|
||||||
msgid "Always grant access"
|
|
||||||
msgstr "Ҳамеша иҷозат додан"
|
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:331
|
|
||||||
msgid "Grant this time only"
|
|
||||||
msgstr "Танҳо дар ин маротиба иҷозат додан"
|
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:332
|
|
||||||
msgid "Reject"
|
|
||||||
msgstr "Рад кардан"
|
|
||||||
|
|
||||||
#. Translators: argument is the device short name
|
|
||||||
#: ../js/ui/status/bluetooth.js:359
|
|
||||||
#, c-format
|
|
||||||
msgid "Pairing confirmation for %s"
|
|
||||||
msgstr "Тасдиқи ҷуфтсозӣ барои %s"
|
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:365 ../js/ui/status/bluetooth.js:396
|
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Device %s wants to pair with this computer"
|
msgid "Device %s wants to pair with this computer"
|
||||||
msgstr "Дастгоҳи %s мехоҳад, ки бо ин компютер ҷуфт кунад"
|
msgstr "Дастгоҳи %s мехоҳад, ки бо ин компютер ҷуфт кунад"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:366
|
#: ../js/ui/status/bluetooth.js:336
|
||||||
|
msgid "Allow"
|
||||||
|
msgstr "Иҷозат додан"
|
||||||
|
|
||||||
|
#: ../js/ui/status/bluetooth.js:337
|
||||||
|
msgid "Deny"
|
||||||
|
msgstr "Манъ кардан"
|
||||||
|
|
||||||
|
#: ../js/ui/status/bluetooth.js:362
|
||||||
|
#, c-format
|
||||||
|
msgid "Device %s wants access to the service '%s'"
|
||||||
|
msgstr "Дастгоҳи %s дастрасиро ба хидмати \"%s\" дархост мекунад"
|
||||||
|
|
||||||
|
#: ../js/ui/status/bluetooth.js:364
|
||||||
|
msgid "Always grant access"
|
||||||
|
msgstr "Ҳамеша иҷозат додан"
|
||||||
|
|
||||||
|
#: ../js/ui/status/bluetooth.js:365
|
||||||
|
msgid "Grant this time only"
|
||||||
|
msgstr "Танҳо дар ин маротиба иҷозат додан"
|
||||||
|
|
||||||
|
#: ../js/ui/status/bluetooth.js:366
|
||||||
|
msgid "Reject"
|
||||||
|
msgstr "Рад кардан"
|
||||||
|
|
||||||
|
#. Translators: argument is the device short name
|
||||||
|
#: ../js/ui/status/bluetooth.js:393
|
||||||
|
#, c-format
|
||||||
|
msgid "Pairing confirmation for %s"
|
||||||
|
msgstr "Тасдиқи ҷуфтсозӣ барои %s"
|
||||||
|
|
||||||
|
#: ../js/ui/status/bluetooth.js:400
|
||||||
#, c-format
|
#, c-format
|
||||||
#| msgid "Please confirm whether the PIN '%06d' matches the one on the device."
|
|
||||||
msgid ""
|
msgid ""
|
||||||
"Please confirm whether the Passkey '%06d' matches the one on the device."
|
"Please confirm whether the Passkey '%06d' matches the one on the device."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
@ -1515,24 +1521,24 @@ msgstr ""
|
|||||||
"мавҷудбуда мувофиқат мекунад."
|
"мавҷудбуда мувофиқат мекунад."
|
||||||
|
|
||||||
#. Translators: this is the verb, not the noun
|
#. Translators: this is the verb, not the noun
|
||||||
#: ../js/ui/status/bluetooth.js:369
|
#: ../js/ui/status/bluetooth.js:403
|
||||||
msgid "Matches"
|
msgid "Matches"
|
||||||
msgstr "Мутобиқаткунанда"
|
msgstr "Мутобиқаткунанда"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:370
|
#: ../js/ui/status/bluetooth.js:404
|
||||||
msgid "Does not match"
|
msgid "Does not match"
|
||||||
msgstr "Мувофиқат намекунад"
|
msgstr "Мувофиқат намекунад"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:389
|
#: ../js/ui/status/bluetooth.js:423
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Pairing request for %s"
|
msgid "Pairing request for %s"
|
||||||
msgstr "Дархости ҷуфтсозӣ барои %s"
|
msgstr "Дархости ҷуфтсозӣ барои %s"
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:397
|
#: ../js/ui/status/bluetooth.js:431
|
||||||
msgid "Please enter the PIN mentioned on the device."
|
msgid "Please enter the PIN mentioned on the device."
|
||||||
msgstr "Лутфан, рамзи PIN-ро, ки дар дастгоҳ гуфта шудааст, ворид кунед."
|
msgstr "Лутфан, рамзи PIN-ро, ки дар дастгоҳ гуфта шудааст, ворид кунед."
|
||||||
|
|
||||||
#: ../js/ui/status/bluetooth.js:414
|
#: ../js/ui/status/bluetooth.js:448
|
||||||
msgid "OK"
|
msgid "OK"
|
||||||
msgstr "OK"
|
msgstr "OK"
|
||||||
|
|
||||||
@ -1552,87 +1558,81 @@ msgstr "Ҳаҷм, шабака, батарея"
|
|||||||
msgid "<unknown>"
|
msgid "<unknown>"
|
||||||
msgstr "<номаълум>"
|
msgstr "<номаълум>"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:127
|
#: ../js/ui/status/network.js:125
|
||||||
msgid "Wi-Fi"
|
msgid "Wi-Fi"
|
||||||
msgstr "Wi-Fi"
|
msgstr "Wi-Fi"
|
||||||
|
|
||||||
#. Translators: this indicates that wireless or wwan is disabled by hardware killswitch
|
#. Translators: this indicates that wireless or wwan is disabled by hardware killswitch
|
||||||
#: ../js/ui/status/network.js:164
|
#: ../js/ui/status/network.js:162
|
||||||
msgid "disabled"
|
msgid "disabled"
|
||||||
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:402
|
#: ../js/ui/status/network.js:397
|
||||||
msgid "unmanaged"
|
msgid "unmanaged"
|
||||||
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:413 ../js/ui/status/network.js:1346
|
#: ../js/ui/status/network.js:408 ../js/ui/status/network.js:1301
|
||||||
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:423
|
#: ../js/ui/status/network.js:419
|
||||||
msgid "firmware missing"
|
msgid "firmware missing"
|
||||||
msgstr "нармафзори дарунсохт вуҷуд надорад"
|
msgstr "нармафзори дарунсохт вуҷуд надорад"
|
||||||
|
|
||||||
#. Translators: this is for wired network devices that are physically disconnected
|
|
||||||
#: ../js/ui/status/network.js:430
|
|
||||||
msgid "cable unplugged"
|
|
||||||
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:435
|
#: ../js/ui/status/network.js:423
|
||||||
msgid "unavailable"
|
msgid "unavailable"
|
||||||
msgstr "дастнорас"
|
msgstr "дастнорас"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:437 ../js/ui/status/network.js:1348
|
#: ../js/ui/status/network.js:425 ../js/ui/status/network.js:1303
|
||||||
msgid "connection failed"
|
msgid "connection failed"
|
||||||
msgstr "пайваст қатъ шудааст"
|
msgstr "пайваст қатъ шудааст"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:490 ../js/ui/status/network.js:1236
|
#: ../js/ui/status/network.js:478 ../js/ui/status/network.js:1190
|
||||||
#: ../js/ui/status/network.js:1424
|
|
||||||
msgid "More…"
|
msgid "More…"
|
||||||
msgstr "Бештар..."
|
msgstr "Бештар..."
|
||||||
|
|
||||||
#. TRANSLATORS: this is the indication that a connection for another logged in user is active,
|
#. TRANSLATORS: this is the indication that a connection for another logged in user is active,
|
||||||
#. and we cannot access its settings (including the name)
|
#. and we cannot access its settings (including the name)
|
||||||
#: ../js/ui/status/network.js:518 ../js/ui/status/network.js:1191
|
#: ../js/ui/status/network.js:506 ../js/ui/status/network.js:1142
|
||||||
msgid "Connected (private)"
|
msgid "Connected (private)"
|
||||||
msgstr "Пайваст шудааст (шахсӣ)"
|
msgstr "Пайваст шудааст (шахсӣ)"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:597
|
#: ../js/ui/status/network.js:572
|
||||||
msgid "Wired"
|
msgid "Wired"
|
||||||
msgstr "Симдор"
|
msgstr "Симдор"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:611
|
#: ../js/ui/status/network.js:592
|
||||||
msgid "Mobile broadband"
|
msgid "Mobile broadband"
|
||||||
msgstr "Паҳннавори мобилӣ"
|
msgstr "Паҳннавори мобилӣ"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1522
|
#: ../js/ui/status/network.js:1474
|
||||||
msgid "Enable networking"
|
msgid "Enable networking"
|
||||||
msgstr "Фаъол кардани шабака"
|
msgstr "Фаъол кардани шабака"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1583
|
#: ../js/ui/status/network.js:1522
|
||||||
msgid "Network Settings"
|
msgid "Network Settings"
|
||||||
msgstr "Танзимоти шабака"
|
msgstr "Танзимоти шабака"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1600
|
#: ../js/ui/status/network.js:1539
|
||||||
msgid "Network Manager"
|
msgid "Network Manager"
|
||||||
msgstr "Мудири шабака"
|
msgstr "Мудири шабака"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1690
|
#: ../js/ui/status/network.js:1623
|
||||||
msgid "Connection failed"
|
msgid "Connection failed"
|
||||||
msgstr "Пайваст қатъ шудааст"
|
msgstr "Пайваст қатъ шудааст"
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:1691
|
#: ../js/ui/status/network.js:1624
|
||||||
msgid "Activation of network connection failed"
|
msgid "Activation of network connection failed"
|
||||||
msgstr "Фаъолсозии пайвасти шабака қатъ шудааст."
|
msgstr "Фаъолсозии пайвасти шабака қатъ шудааст."
|
||||||
|
|
||||||
#: ../js/ui/status/network.js:2047
|
#: ../js/ui/status/network.js:1933
|
||||||
msgid "Networking is disabled"
|
msgid "Networking is disabled"
|
||||||
msgstr "Шабака ғайрифаъол аст"
|
msgstr "Шабака ғайрифаъол аст"
|
||||||
|
|
||||||
@ -1729,72 +1729,72 @@ msgctxt "device"
|
|||||||
msgid "Unknown"
|
msgid "Unknown"
|
||||||
msgstr "Номаълум"
|
msgstr "Номаълум"
|
||||||
|
|
||||||
#: ../js/ui/status/volume.js:124
|
#: ../js/ui/status/volume.js:121
|
||||||
msgid "Volume changed"
|
msgid "Volume changed"
|
||||||
msgstr "Ҳаҷм тағйир ёфт"
|
msgstr "Ҳаҷм тағйир ёфт"
|
||||||
|
|
||||||
#. Translators: This is the label for audio volume
|
#. Translators: This is the label for audio volume
|
||||||
#: ../js/ui/status/volume.js:249 ../js/ui/status/volume.js:297
|
#: ../js/ui/status/volume.js:246 ../js/ui/status/volume.js:294
|
||||||
msgid "Volume"
|
msgid "Volume"
|
||||||
msgstr "Баландии садо"
|
msgstr "Баландии садо"
|
||||||
|
|
||||||
#: ../js/ui/status/volume.js:258
|
#: ../js/ui/status/volume.js:255
|
||||||
msgid "Microphone"
|
msgid "Microphone"
|
||||||
msgstr "Микрофон"
|
msgstr "Микрофон"
|
||||||
|
|
||||||
#: ../js/ui/unlockDialog.js:120
|
#: ../js/ui/unlockDialog.js:119
|
||||||
msgid "Log in as another user"
|
msgid "Log in as another user"
|
||||||
msgstr "Ворид шудан бо корбари дигар"
|
msgstr "Ворид шудан бо корбари дигар"
|
||||||
|
|
||||||
#: ../js/ui/unlockDialog.js:141
|
#: ../js/ui/unlockDialog.js:140
|
||||||
msgid "Unlock Window"
|
msgid "Unlock Window"
|
||||||
msgstr "Кушодани равзана"
|
msgstr "Кушодани равзана"
|
||||||
|
|
||||||
#: ../js/ui/userMenu.js:193
|
#: ../js/ui/userMenu.js:149
|
||||||
msgid "Available"
|
msgid "Available"
|
||||||
msgstr "Дастрас"
|
msgstr "Дастрас"
|
||||||
|
|
||||||
#: ../js/ui/userMenu.js:196
|
#: ../js/ui/userMenu.js:152
|
||||||
msgid "Busy"
|
msgid "Busy"
|
||||||
msgstr "Машғул"
|
msgstr "Машғул"
|
||||||
|
|
||||||
#: ../js/ui/userMenu.js:199
|
#: ../js/ui/userMenu.js:155
|
||||||
msgid "Invisible"
|
msgid "Invisible"
|
||||||
msgstr "Ноаён"
|
msgstr "Ноаён"
|
||||||
|
|
||||||
#: ../js/ui/userMenu.js:202
|
#: ../js/ui/userMenu.js:158
|
||||||
msgid "Away"
|
msgid "Away"
|
||||||
msgstr "Ғоиб"
|
msgstr "Ғоиб"
|
||||||
|
|
||||||
#: ../js/ui/userMenu.js:205
|
#: ../js/ui/userMenu.js:161
|
||||||
msgid "Idle"
|
msgid "Idle"
|
||||||
msgstr "Ғайрифаъол"
|
msgstr "Ғайрифаъол"
|
||||||
|
|
||||||
#: ../js/ui/userMenu.js:208
|
#: ../js/ui/userMenu.js:164
|
||||||
msgid "Offline"
|
msgid "Offline"
|
||||||
msgstr "Офлайн"
|
msgstr "Офлайн"
|
||||||
|
|
||||||
#: ../js/ui/userMenu.js:781
|
#: ../js/ui/userMenu.js:736
|
||||||
msgid "Notifications"
|
msgid "Notifications"
|
||||||
msgstr "Огоҳиҳо"
|
msgstr "Огоҳиҳо"
|
||||||
|
|
||||||
#: ../js/ui/userMenu.js:797
|
#: ../js/ui/userMenu.js:749
|
||||||
msgid "Switch User"
|
msgid "Switch User"
|
||||||
msgstr "Таъвизи корбар"
|
msgstr "Таъвизи корбар"
|
||||||
|
|
||||||
#: ../js/ui/userMenu.js:802
|
#: ../js/ui/userMenu.js:754
|
||||||
msgid "Log Out"
|
msgid "Log Out"
|
||||||
msgstr "Баромад"
|
msgstr "Баромад"
|
||||||
|
|
||||||
#: ../js/ui/userMenu.js:822
|
#: ../js/ui/userMenu.js:774
|
||||||
msgid "Install Updates & Restart"
|
msgid "Install Updates & Restart"
|
||||||
msgstr "Насб кардани навсозиҳо ва бозоғозидан"
|
msgstr "Насб кардани навсозиҳо ва бозоғозидан"
|
||||||
|
|
||||||
#: ../js/ui/userMenu.js:840
|
#: ../js/ui/userMenu.js:792
|
||||||
msgid "Your chat status will be set to busy"
|
msgid "Your chat status will be set to busy"
|
||||||
msgstr "Вазъияти чати шумо ба \"машғул\" тағйир дода мешавад"
|
msgstr "Вазъияти чати шумо ба \"машғул\" тағйир дода мешавад"
|
||||||
|
|
||||||
#: ../js/ui/userMenu.js:841
|
#: ../js/ui/userMenu.js:793
|
||||||
msgid ""
|
msgid ""
|
||||||
"Notifications are now disabled, including chat messages. Your online status "
|
"Notifications are now disabled, including chat messages. Your online status "
|
||||||
"has been adjusted to let others know that you might not see their messages."
|
"has been adjusted to let others know that you might not see their messages."
|
||||||
@ -1803,22 +1803,22 @@ msgstr ""
|
|||||||
"шумо ба тавре танзим карда шуд, ки дигарон фаҳманд, ки эҳтимолан шумо "
|
"шумо ба тавре танзим карда шуд, ки дигарон фаҳманд, ки эҳтимолан шумо "
|
||||||
"паёмҳои онҳоро намебинед."
|
"паёмҳои онҳоро намебинед."
|
||||||
|
|
||||||
#: ../js/ui/userMenu.js:888
|
#: ../js/ui/userMenu.js:834
|
||||||
msgid "Other users are logged in."
|
msgid "Other users are logged in."
|
||||||
msgstr "Корбарони дигар ворид шудаанд."
|
msgstr "Корбарони дигар ворид шудаанд."
|
||||||
|
|
||||||
#: ../js/ui/userMenu.js:893
|
#: ../js/ui/userMenu.js:839
|
||||||
msgid "Shutting down might cause them to lose unsaved work."
|
msgid "Shutting down might cause them to lose unsaved work."
|
||||||
msgstr "Анҷоми кор метавонад сабаби гум шудани кори захиранашуда гардад."
|
msgstr "Анҷоми кор метавонад сабаби гум шудани кори захиранашуда гардад."
|
||||||
|
|
||||||
#. Translators: Remote here refers to a remote session, like a ssh login
|
#. Translators: Remote here refers to a remote session, like a ssh login
|
||||||
#: ../js/ui/userMenu.js:921
|
#: ../js/ui/userMenu.js:867
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%s (remote)"
|
msgid "%s (remote)"
|
||||||
msgstr "%s (дурдаст)"
|
msgstr "%s (дурдаст)"
|
||||||
|
|
||||||
#. Translators: Console here refers to a tty like a VT console
|
#. Translators: Console here refers to a tty like a VT console
|
||||||
#: ../js/ui/userMenu.js:924
|
#: ../js/ui/userMenu.js:870
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%s (console)"
|
msgid "%s (console)"
|
||||||
msgstr "%s (консол)"
|
msgstr "%s (консол)"
|
||||||
@ -1874,20 +1874,20 @@ msgstr[0] "%u вуруд"
|
|||||||
msgid "System Sounds"
|
msgid "System Sounds"
|
||||||
msgstr "Системаи садо"
|
msgstr "Системаи садо"
|
||||||
|
|
||||||
#: ../src/main.c:372
|
#: ../src/main.c:353
|
||||||
msgid "Print version"
|
msgid "Print version"
|
||||||
msgstr "Версияи чоп"
|
msgstr "Версияи чоп"
|
||||||
|
|
||||||
#: ../src/main.c:378
|
#: ../src/main.c:359
|
||||||
msgid "Mode used by GDM for login screen"
|
msgid "Mode used by GDM for login screen"
|
||||||
msgstr "Усуле, ки бо GDM барои экрани воридшавӣ истифода мешавад"
|
msgstr "Усуле, ки бо GDM барои экрани воридшавӣ истифода мешавад"
|
||||||
|
|
||||||
#: ../src/main.c:384
|
#: ../src/main.c:365
|
||||||
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
msgid "Use a specific mode, e.g. \"gdm\" for login screen"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Истифода бурдани ҳолати мушаххас, масалан \"gdm\" барои экрани воридшавӣ"
|
"Истифода бурдани ҳолати мушаххас, масалан \"gdm\" барои экрани воридшавӣ"
|
||||||
|
|
||||||
#: ../src/main.c:390
|
#: ../src/main.c:371
|
||||||
msgid "List possible modes"
|
msgid "List possible modes"
|
||||||
msgstr "Рӯйхати ҳолатҳои имконпазир"
|
msgstr "Рӯйхати ҳолатҳои имконпазир"
|
||||||
|
|
||||||
@ -1908,6 +1908,9 @@ msgstr "Парол бояд холӣ набошад"
|
|||||||
msgid "Authentication dialog was dismissed by the user"
|
msgid "Authentication dialog was dismissed by the user"
|
||||||
msgstr "Равзанаи гуфтугӯи санҷиши ҳакконият бо корбар бекор карда шуд"
|
msgstr "Равзанаи гуфтугӯи санҷиши ҳакконият бо корбар бекор карда шуд"
|
||||||
|
|
||||||
|
#~ msgid "cable unplugged"
|
||||||
|
#~ msgstr "сим ҷудо шудааст"
|
||||||
|
|
||||||
#~ msgid "Whether to collect stats about applications usage"
|
#~ msgid "Whether to collect stats about applications usage"
|
||||||
#~ msgstr "Ҷамъ кардан ё ҷамъ накардани омор дар бораи истифодабарии барномаҳо"
|
#~ msgstr "Ҷамъ кардан ё ҷамъ накардани омор дар бораи истифодабарии барномаҳо"
|
||||||
|
|
||||||
|
666
po/zh_CN.po
666
po/zh_CN.po
File diff suppressed because it is too large
Load Diff
435
po/zh_HK.po
435
po/zh_HK.po
File diff suppressed because it is too large
Load Diff
438
po/zh_TW.po
438
po/zh_TW.po
File diff suppressed because it is too large
Load Diff
@ -314,38 +314,6 @@ 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 gboolean
|
|
||||||
ignore_crossing_event (MetaPlugin *plugin,
|
|
||||||
XIEnterEvent *enter_event)
|
|
||||||
{
|
|
||||||
MetaScreen *screen = meta_plugin_get_screen (plugin);
|
|
||||||
ClutterStage *stage = CLUTTER_STAGE (meta_get_stage_for_screen (screen));
|
|
||||||
|
|
||||||
if (enter_event->event == clutter_x11_get_stage_window (stage))
|
|
||||||
{
|
|
||||||
/* If the pointer enters a child of the stage window (eg, a
|
|
||||||
* trayicon), we want to consider it to still be in the stage,
|
|
||||||
* so don't let Clutter see the event.
|
|
||||||
*/
|
|
||||||
if (enter_event->detail == XINotifyInferior)
|
|
||||||
return TRUE;
|
|
||||||
|
|
||||||
/* If the pointer is grabbed by a window it is not currently in,
|
|
||||||
* filter that out as well. In particular, if a trayicon grabs
|
|
||||||
* the pointer after a click on its label, we don't want to hide
|
|
||||||
* the message tray. Filtering out this event will leave Clutter
|
|
||||||
* out of sync, but that happens fairly often with grabs, and we
|
|
||||||
* can work around it. (Eg, shell_global_sync_pointer().)
|
|
||||||
*/
|
|
||||||
if (enter_event->mode == XINotifyGrab &&
|
|
||||||
(enter_event->detail == XINotifyNonlinear ||
|
|
||||||
enter_event->detail == XINotifyNonlinearVirtual))
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
gnome_shell_plugin_xevent_filter (MetaPlugin *plugin,
|
gnome_shell_plugin_xevent_filter (MetaPlugin *plugin,
|
||||||
XEvent *xev)
|
XEvent *xev)
|
||||||
@ -371,25 +339,10 @@ gnome_shell_plugin_xevent_filter (MetaPlugin *plugin,
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Make sure that Clutter doesn't see certain focus change events,
|
|
||||||
* so that when we're moving into something like a tray icon, we
|
|
||||||
* don't unfocus the container. */
|
|
||||||
if (xev->type == GenericEvent &&
|
|
||||||
xev->xcookie.extension == meta_display_get_xinput_opcode (display))
|
|
||||||
{
|
|
||||||
XIEvent *input_event = (XIEvent *) xev->xcookie.data;
|
|
||||||
if ((input_event->evtype == XI_Enter || input_event->evtype == XI_Leave) &&
|
|
||||||
ignore_crossing_event (plugin, (XIEnterEvent *) input_event))
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Pass the event to shell-global
|
* Pass the event to shell-global
|
||||||
*/
|
*/
|
||||||
if (_shell_global_check_xdnd_event (shell_plugin->global, xev))
|
return _shell_global_check_xdnd_event (shell_plugin->global, xev);
|
||||||
return TRUE;
|
|
||||||
|
|
||||||
return clutter_x11_handle_event (xev) != CLUTTER_X11_FILTER_CONTINUE;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
|
30
src/main.c
30
src/main.c
@ -22,6 +22,7 @@
|
|||||||
#include <atk-bridge.h>
|
#include <atk-bridge.h>
|
||||||
#include <telepathy-glib/debug.h>
|
#include <telepathy-glib/debug.h>
|
||||||
#include <telepathy-glib/debug-sender.h>
|
#include <telepathy-glib/debug-sender.h>
|
||||||
|
#include <meta/util.h>
|
||||||
|
|
||||||
#include "shell-global.h"
|
#include "shell-global.h"
|
||||||
#include "shell-global-private.h"
|
#include "shell-global-private.h"
|
||||||
@ -36,13 +37,12 @@ extern GType gnome_shell_plugin_get_type (void);
|
|||||||
#define SHELL_DBUS_SERVICE "org.gnome.Shell"
|
#define SHELL_DBUS_SERVICE "org.gnome.Shell"
|
||||||
#define MAGNIFIER_DBUS_SERVICE "org.gnome.Magnifier"
|
#define MAGNIFIER_DBUS_SERVICE "org.gnome.Magnifier"
|
||||||
|
|
||||||
#define OVERRIDES_SCHEMA "org.gnome.shell.overrides"
|
|
||||||
|
|
||||||
#define WM_NAME "GNOME Shell"
|
#define WM_NAME "GNOME Shell"
|
||||||
#define GNOME_WM_KEYBINDINGS "Mutter,GNOME Shell"
|
#define GNOME_WM_KEYBINDINGS "Mutter,GNOME Shell"
|
||||||
|
|
||||||
static gboolean is_gdm_mode = FALSE;
|
static gboolean is_gdm_mode = FALSE;
|
||||||
static char *session_mode = NULL;
|
static char *session_mode = NULL;
|
||||||
|
static gboolean is_display_server = FALSE;
|
||||||
|
|
||||||
#define DBUS_REQUEST_NAME_REPLY_PRIMARY_OWNER 1
|
#define DBUS_REQUEST_NAME_REPLY_PRIMARY_OWNER 1
|
||||||
#define DBUS_REQUEST_NAME_REPLY_ALREADY_OWNER 4
|
#define DBUS_REQUEST_NAME_REPLY_ALREADY_OWNER 4
|
||||||
@ -171,23 +171,6 @@ shell_dbus_init (gboolean replace)
|
|||||||
g_object_unref (session);
|
g_object_unref (session);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
shell_prefs_init (void)
|
|
||||||
{
|
|
||||||
meta_prefs_override_preference_schema ("attach-modal-dialogs",
|
|
||||||
OVERRIDES_SCHEMA);
|
|
||||||
meta_prefs_override_preference_schema ("dynamic-workspaces",
|
|
||||||
OVERRIDES_SCHEMA);
|
|
||||||
meta_prefs_override_preference_schema ("workspaces-only-on-primary",
|
|
||||||
OVERRIDES_SCHEMA);
|
|
||||||
meta_prefs_override_preference_schema ("button-layout",
|
|
||||||
OVERRIDES_SCHEMA);
|
|
||||||
meta_prefs_override_preference_schema ("edge-tiling",
|
|
||||||
OVERRIDES_SCHEMA);
|
|
||||||
meta_prefs_override_preference_schema ("focus-change-on-pointer-rest",
|
|
||||||
OVERRIDES_SCHEMA);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
shell_introspection_init (void)
|
shell_introspection_init (void)
|
||||||
{
|
{
|
||||||
@ -366,6 +349,12 @@ print_version (const gchar *option_name,
|
|||||||
}
|
}
|
||||||
|
|
||||||
GOptionEntry gnome_shell_options[] = {
|
GOptionEntry gnome_shell_options[] = {
|
||||||
|
{
|
||||||
|
"display-server", 0, 0, G_OPTION_ARG_NONE,
|
||||||
|
&is_display_server,
|
||||||
|
N_("Run as a display server"),
|
||||||
|
NULL,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"version", 0, G_OPTION_FLAG_NO_ARG, G_OPTION_ARG_CALLBACK,
|
"version", 0, G_OPTION_FLAG_NO_ARG, G_OPTION_ARG_CALLBACK,
|
||||||
print_version,
|
print_version,
|
||||||
@ -415,6 +404,8 @@ main (int argc, char **argv)
|
|||||||
|
|
||||||
g_option_context_free (ctx);
|
g_option_context_free (ctx);
|
||||||
|
|
||||||
|
meta_set_is_display_server (is_display_server);
|
||||||
|
|
||||||
meta_plugin_manager_set_plugin_type (gnome_shell_plugin_get_type ());
|
meta_plugin_manager_set_plugin_type (gnome_shell_plugin_get_type ());
|
||||||
|
|
||||||
meta_set_wm_name (WM_NAME);
|
meta_set_wm_name (WM_NAME);
|
||||||
@ -436,7 +427,6 @@ main (int argc, char **argv)
|
|||||||
shell_dbus_init (meta_get_replace_current_wm ());
|
shell_dbus_init (meta_get_replace_current_wm ());
|
||||||
shell_a11y_init ();
|
shell_a11y_init ();
|
||||||
shell_perf_log_init ();
|
shell_perf_log_init ();
|
||||||
shell_prefs_init ();
|
|
||||||
shell_introspection_init ();
|
shell_introspection_init ();
|
||||||
shell_fonts_init ();
|
shell_fonts_init ();
|
||||||
|
|
||||||
|
@ -930,9 +930,34 @@ _shell_global_set_plugin (ShellGlobal *global,
|
|||||||
meta_screen_get_screen_number (global->meta_screen));
|
meta_screen_get_screen_number (global->meta_screen));
|
||||||
|
|
||||||
global->stage = CLUTTER_STAGE (meta_get_stage_for_screen (global->meta_screen));
|
global->stage = CLUTTER_STAGE (meta_get_stage_for_screen (global->meta_screen));
|
||||||
global->stage_xwindow = clutter_x11_get_stage_window (global->stage);
|
if (meta_is_display_server ())
|
||||||
global->stage_gdk_window = gdk_x11_window_foreign_new_for_display (global->gdk_display,
|
{
|
||||||
global->stage_xwindow);
|
/* When Mutter is acting as its own display server then the
|
||||||
|
stage does not have a window. Instead we'll just create a
|
||||||
|
dummy window that might make some things blunder along but
|
||||||
|
will probably just leave most things broken. It might be
|
||||||
|
possible to fix this to make the fake window be the same size
|
||||||
|
as the stage window would be and make it more useful. */
|
||||||
|
|
||||||
|
GdkWindowAttr attributes;
|
||||||
|
|
||||||
|
attributes.wclass = GDK_INPUT_OUTPUT;
|
||||||
|
attributes.width = 100;
|
||||||
|
attributes.height = 100;
|
||||||
|
attributes.window_type = GDK_WINDOW_TOPLEVEL;
|
||||||
|
|
||||||
|
global->stage_gdk_window = gdk_window_new (NULL,
|
||||||
|
&attributes,
|
||||||
|
0 /* attributes_mask */);
|
||||||
|
global->stage_xwindow = gdk_x11_window_get_xid (global->stage_gdk_window);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
global->stage_xwindow = clutter_x11_get_stage_window (global->stage);
|
||||||
|
global->stage_gdk_window =
|
||||||
|
gdk_x11_window_foreign_new_for_display (global->gdk_display,
|
||||||
|
global->stage_xwindow);
|
||||||
|
}
|
||||||
|
|
||||||
g_signal_connect (global->stage, "notify::width",
|
g_signal_connect (global->stage, "notify::width",
|
||||||
G_CALLBACK (global_stage_notify_width), global);
|
G_CALLBACK (global_stage_notify_width), global);
|
||||||
@ -1240,9 +1265,12 @@ void shell_global_init_xdnd (ShellGlobal *global)
|
|||||||
gdk_x11_get_xatom_by_name ("XdndAware"), XA_ATOM,
|
gdk_x11_get_xatom_by_name ("XdndAware"), XA_ATOM,
|
||||||
32, PropModeReplace, (const unsigned char *)&xdnd_version, 1);
|
32, PropModeReplace, (const unsigned char *)&xdnd_version, 1);
|
||||||
|
|
||||||
XChangeProperty (global->xdisplay, output_window,
|
/* There is no overlay window when running as a display server */
|
||||||
gdk_x11_get_xatom_by_name ("XdndProxy"), XA_WINDOW,
|
if (output_window)
|
||||||
32, PropModeReplace, (const unsigned char *)&global->stage_xwindow, 1);
|
XChangeProperty (global->xdisplay, output_window,
|
||||||
|
gdk_x11_get_xatom_by_name ("XdndProxy"), XA_WINDOW,
|
||||||
|
32, PropModeReplace,
|
||||||
|
(const unsigned char *)&global->stage_xwindow, 1);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* XdndProxy is additionally set on the proxy window as verification that the
|
* XdndProxy is additionally set on the proxy window as verification that the
|
||||||
|
@ -4,8 +4,11 @@
|
|||||||
|
|
||||||
#include "shell-xfixes-cursor.h"
|
#include "shell-xfixes-cursor.h"
|
||||||
|
|
||||||
#include <clutter/x11/clutter-x11.h>
|
#include <gdk/gdkx.h>
|
||||||
#include <X11/extensions/Xfixes.h>
|
#include <X11/extensions/Xfixes.h>
|
||||||
|
#include <meta/display.h>
|
||||||
|
#include <meta/screen.h>
|
||||||
|
#include <meta/util.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* SECTION:shell-xfixes-cursor
|
* SECTION:shell-xfixes-cursor
|
||||||
@ -24,7 +27,7 @@ struct _ShellXFixesCursorClass
|
|||||||
struct _ShellXFixesCursor {
|
struct _ShellXFixesCursor {
|
||||||
GObject parent;
|
GObject parent;
|
||||||
|
|
||||||
ClutterStage *stage;
|
MetaScreen *screen;
|
||||||
|
|
||||||
gboolean have_xfixes;
|
gboolean have_xfixes;
|
||||||
int xfixes_event_base;
|
int xfixes_event_base;
|
||||||
@ -36,17 +39,14 @@ struct _ShellXFixesCursor {
|
|||||||
int cursor_hot_y;
|
int cursor_hot_y;
|
||||||
};
|
};
|
||||||
|
|
||||||
static void xfixes_cursor_show (ShellXFixesCursor *xfixes_cursor);
|
static void xfixes_cursor_set_screen (ShellXFixesCursor *xfixes_cursor,
|
||||||
static void xfixes_cursor_hide (ShellXFixesCursor *xfixes_cursor);
|
MetaScreen *screen);
|
||||||
|
|
||||||
static void xfixes_cursor_set_stage (ShellXFixesCursor *xfixes_cursor,
|
|
||||||
ClutterStage *stage);
|
|
||||||
|
|
||||||
static void xfixes_cursor_reset_image (ShellXFixesCursor *xfixes_cursor);
|
static void xfixes_cursor_reset_image (ShellXFixesCursor *xfixes_cursor);
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
PROP_0,
|
PROP_0,
|
||||||
PROP_STAGE,
|
PROP_SCREEN,
|
||||||
};
|
};
|
||||||
|
|
||||||
G_DEFINE_TYPE(ShellXFixesCursor, shell_xfixes_cursor, G_TYPE_OBJECT);
|
G_DEFINE_TYPE(ShellXFixesCursor, shell_xfixes_cursor, G_TYPE_OBJECT);
|
||||||
@ -71,31 +71,22 @@ shell_xfixes_cursor_finalize (GObject *object)
|
|||||||
{
|
{
|
||||||
ShellXFixesCursor *xfixes_cursor = SHELL_XFIXES_CURSOR (object);
|
ShellXFixesCursor *xfixes_cursor = SHELL_XFIXES_CURSOR (object);
|
||||||
|
|
||||||
// Make sure the system cursor is showing before leaving the stage.
|
xfixes_cursor_set_screen (xfixes_cursor, NULL);
|
||||||
xfixes_cursor_show (xfixes_cursor);
|
|
||||||
xfixes_cursor_set_stage (xfixes_cursor, NULL);
|
|
||||||
if (xfixes_cursor->cursor_sprite != NULL)
|
if (xfixes_cursor->cursor_sprite != NULL)
|
||||||
cogl_handle_unref (xfixes_cursor->cursor_sprite);
|
cogl_handle_unref (xfixes_cursor->cursor_sprite);
|
||||||
|
|
||||||
G_OBJECT_CLASS (shell_xfixes_cursor_parent_class)->finalize (object);
|
G_OBJECT_CLASS (shell_xfixes_cursor_parent_class)->finalize (object);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static GdkFilterReturn
|
||||||
xfixes_cursor_on_stage_destroy (ClutterActor *actor,
|
xfixes_cursor_event_filter (XEvent *xev,
|
||||||
ShellXFixesCursor *xfixes_cursor)
|
GdkEvent *ev,
|
||||||
{
|
gpointer data)
|
||||||
xfixes_cursor_set_stage (xfixes_cursor, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
static ClutterX11FilterReturn
|
|
||||||
xfixes_cursor_event_filter (XEvent *xev,
|
|
||||||
ClutterEvent *cev,
|
|
||||||
gpointer data)
|
|
||||||
{
|
{
|
||||||
ShellXFixesCursor *xfixes_cursor = data;
|
ShellXFixesCursor *xfixes_cursor = data;
|
||||||
|
|
||||||
if (xev->xany.window != clutter_x11_get_stage_window (xfixes_cursor->stage))
|
if (xev->xany.window != meta_get_overlay_window (xfixes_cursor->screen))
|
||||||
return CLUTTER_X11_FILTER_CONTINUE;
|
return GDK_FILTER_CONTINUE;
|
||||||
|
|
||||||
if (xev->xany.type == xfixes_cursor->xfixes_event_base + XFixesCursorNotify)
|
if (xev->xany.type == xfixes_cursor->xfixes_event_base + XFixesCursorNotify)
|
||||||
{
|
{
|
||||||
@ -103,93 +94,43 @@ xfixes_cursor_event_filter (XEvent *xev,
|
|||||||
if (notify_event->subtype == XFixesDisplayCursorNotify)
|
if (notify_event->subtype == XFixesDisplayCursorNotify)
|
||||||
xfixes_cursor_reset_image (xfixes_cursor);
|
xfixes_cursor_reset_image (xfixes_cursor);
|
||||||
}
|
}
|
||||||
return CLUTTER_X11_FILTER_CONTINUE;
|
|
||||||
|
return GDK_FILTER_CONTINUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
xfixes_cursor_set_stage (ShellXFixesCursor *xfixes_cursor,
|
xfixes_cursor_set_screen (ShellXFixesCursor *xfixes_cursor,
|
||||||
ClutterStage *stage)
|
MetaScreen *screen)
|
||||||
{
|
{
|
||||||
if (xfixes_cursor->stage == stage)
|
if (xfixes_cursor->screen == screen)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (xfixes_cursor->stage)
|
if (xfixes_cursor->screen)
|
||||||
{
|
{
|
||||||
g_signal_handlers_disconnect_by_func (xfixes_cursor->stage,
|
gdk_window_remove_filter (NULL, (GdkFilterFunc)xfixes_cursor_event_filter, xfixes_cursor);
|
||||||
(void *)xfixes_cursor_on_stage_destroy,
|
|
||||||
xfixes_cursor);
|
|
||||||
|
|
||||||
clutter_x11_remove_filter (xfixes_cursor_event_filter, xfixes_cursor);
|
|
||||||
}
|
}
|
||||||
xfixes_cursor->stage = stage;
|
|
||||||
if (xfixes_cursor->stage)
|
xfixes_cursor->screen = screen;
|
||||||
|
if (xfixes_cursor->screen)
|
||||||
{
|
{
|
||||||
int error_base;
|
int error_base;
|
||||||
|
|
||||||
xfixes_cursor->stage = stage;
|
gdk_window_add_filter (NULL, (GdkFilterFunc)xfixes_cursor_event_filter, xfixes_cursor);
|
||||||
g_signal_connect (xfixes_cursor->stage, "destroy",
|
|
||||||
G_CALLBACK (xfixes_cursor_on_stage_destroy), xfixes_cursor);
|
|
||||||
|
|
||||||
clutter_x11_add_filter (xfixes_cursor_event_filter, xfixes_cursor);
|
xfixes_cursor->have_xfixes = XFixesQueryExtension (gdk_x11_get_default_xdisplay (),
|
||||||
|
|
||||||
xfixes_cursor->have_xfixes = XFixesQueryExtension (clutter_x11_get_default_display (),
|
|
||||||
&xfixes_cursor->xfixes_event_base,
|
&xfixes_cursor->xfixes_event_base,
|
||||||
&error_base);
|
&error_base);
|
||||||
if (xfixes_cursor->have_xfixes)
|
|
||||||
XFixesSelectCursorInput (clutter_x11_get_default_display (),
|
/* FIXME: this needs to be moved down to mutter as a whole */
|
||||||
clutter_x11_get_stage_window (stage),
|
if (xfixes_cursor->have_xfixes && !meta_is_display_server())
|
||||||
|
XFixesSelectCursorInput (gdk_x11_get_default_xdisplay (),
|
||||||
|
meta_get_overlay_window (screen),
|
||||||
XFixesDisplayCursorNotifyMask);
|
XFixesDisplayCursorNotifyMask);
|
||||||
|
|
||||||
xfixes_cursor_reset_image (xfixes_cursor);
|
xfixes_cursor_reset_image (xfixes_cursor);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
xfixes_cursor_show (ShellXFixesCursor *xfixes_cursor)
|
|
||||||
{
|
|
||||||
int minor, major;
|
|
||||||
Display *xdisplay;
|
|
||||||
Window xwindow;
|
|
||||||
|
|
||||||
if (xfixes_cursor->is_showing == TRUE)
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (!xfixes_cursor->have_xfixes || !xfixes_cursor->stage)
|
|
||||||
return;
|
|
||||||
|
|
||||||
xdisplay = clutter_x11_get_default_display ();
|
|
||||||
xwindow = clutter_x11_get_stage_window (xfixes_cursor->stage);
|
|
||||||
XFixesQueryVersion (xdisplay, &major, &minor);
|
|
||||||
if (major >= 4)
|
|
||||||
{
|
|
||||||
XFixesShowCursor (xdisplay, xwindow);
|
|
||||||
xfixes_cursor->is_showing = TRUE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
xfixes_cursor_hide (ShellXFixesCursor *xfixes_cursor)
|
|
||||||
{
|
|
||||||
int minor, major;
|
|
||||||
Display *xdisplay;
|
|
||||||
Window xwindow;
|
|
||||||
|
|
||||||
if (xfixes_cursor->is_showing == FALSE)
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (!xfixes_cursor->have_xfixes || !xfixes_cursor->stage)
|
|
||||||
return;
|
|
||||||
|
|
||||||
xdisplay = clutter_x11_get_default_display ();
|
|
||||||
xwindow = clutter_x11_get_stage_window (xfixes_cursor->stage);
|
|
||||||
XFixesQueryVersion (xdisplay, &major, &minor);
|
|
||||||
if (major >= 4)
|
|
||||||
{
|
|
||||||
XFixesHideCursor (xdisplay, xwindow);
|
|
||||||
xfixes_cursor->is_showing = FALSE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
xfixes_cursor_reset_image (ShellXFixesCursor *xfixes_cursor)
|
xfixes_cursor_reset_image (ShellXFixesCursor *xfixes_cursor)
|
||||||
{
|
{
|
||||||
@ -201,7 +142,7 @@ xfixes_cursor_reset_image (ShellXFixesCursor *xfixes_cursor)
|
|||||||
if (!xfixes_cursor->have_xfixes)
|
if (!xfixes_cursor->have_xfixes)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
cursor_image = XFixesGetCursorImage (clutter_x11_get_default_display ());
|
cursor_image = XFixesGetCursorImage (gdk_x11_get_default_xdisplay ());
|
||||||
if (!cursor_image)
|
if (!cursor_image)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@ -265,8 +206,8 @@ shell_xfixes_cursor_set_property (GObject *object,
|
|||||||
|
|
||||||
switch (prop_id)
|
switch (prop_id)
|
||||||
{
|
{
|
||||||
case PROP_STAGE:
|
case PROP_SCREEN:
|
||||||
xfixes_cursor_set_stage (xfixes_cursor, g_value_get_object (value));
|
xfixes_cursor_set_screen (xfixes_cursor, g_value_get_object (value));
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
@ -284,8 +225,8 @@ shell_xfixes_cursor_get_property (GObject *object,
|
|||||||
|
|
||||||
switch (prop_id)
|
switch (prop_id)
|
||||||
{
|
{
|
||||||
case PROP_STAGE:
|
case PROP_SCREEN:
|
||||||
g_value_set_object (value, G_OBJECT (xfixes_cursor->stage));
|
g_value_set_object (value, G_OBJECT (xfixes_cursor->screen));
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
@ -311,22 +252,22 @@ shell_xfixes_cursor_class_init (ShellXFixesCursorClass *klass)
|
|||||||
gobject_class->set_property = shell_xfixes_cursor_set_property;
|
gobject_class->set_property = shell_xfixes_cursor_set_property;
|
||||||
|
|
||||||
g_object_class_install_property (gobject_class,
|
g_object_class_install_property (gobject_class,
|
||||||
PROP_STAGE,
|
PROP_SCREEN,
|
||||||
g_param_spec_object ("stage",
|
g_param_spec_object ("screen",
|
||||||
"Stage",
|
"Screen",
|
||||||
"Stage for mouse cursor",
|
"Screen for mouse cursor",
|
||||||
CLUTTER_TYPE_STAGE,
|
META_TYPE_SCREEN,
|
||||||
G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY));
|
G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* shell_xfixes_cursor_get_for_stage:
|
* shell_xfixes_cursor_get_for_screen:
|
||||||
* @stage: (transfer none): The #ClutterStage to get the cursor for
|
* @screen: (transfer none): The #MetaScreen to get the cursor for
|
||||||
*
|
*
|
||||||
* Return value: (transfer none): A #ShellXFixesCursor instance
|
* Return value: (transfer none): A #ShellXFixesCursor instance
|
||||||
*/
|
*/
|
||||||
ShellXFixesCursor *
|
ShellXFixesCursor *
|
||||||
shell_xfixes_cursor_get_for_stage (ClutterStage *stage)
|
shell_xfixes_cursor_get_for_screen (MetaScreen *screen)
|
||||||
{
|
{
|
||||||
ShellXFixesCursor *instance;
|
ShellXFixesCursor *instance;
|
||||||
static GQuark xfixes_cursor_quark;
|
static GQuark xfixes_cursor_quark;
|
||||||
@ -334,47 +275,19 @@ shell_xfixes_cursor_get_for_stage (ClutterStage *stage)
|
|||||||
if (G_UNLIKELY (xfixes_cursor_quark == 0))
|
if (G_UNLIKELY (xfixes_cursor_quark == 0))
|
||||||
xfixes_cursor_quark = g_quark_from_static_string ("gnome-shell-xfixes-cursor");
|
xfixes_cursor_quark = g_quark_from_static_string ("gnome-shell-xfixes-cursor");
|
||||||
|
|
||||||
instance = g_object_get_qdata (G_OBJECT (stage), xfixes_cursor_quark);
|
instance = g_object_get_qdata (G_OBJECT (screen), xfixes_cursor_quark);
|
||||||
|
|
||||||
if (instance == NULL)
|
if (instance == NULL)
|
||||||
{
|
{
|
||||||
instance = g_object_new (SHELL_TYPE_XFIXES_CURSOR,
|
instance = g_object_new (SHELL_TYPE_XFIXES_CURSOR,
|
||||||
"stage", stage,
|
"screen", screen,
|
||||||
NULL);
|
NULL);
|
||||||
g_object_set_qdata (G_OBJECT (stage), xfixes_cursor_quark, instance);
|
g_object_set_qdata (G_OBJECT (screen), xfixes_cursor_quark, instance);
|
||||||
}
|
}
|
||||||
|
|
||||||
return instance;
|
return instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* shell_xfixes_cursor_hide:
|
|
||||||
* @xfixes_cursor: the #ShellXFixesCursor
|
|
||||||
*
|
|
||||||
* Hide the system mouse cursor.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
shell_xfixes_cursor_hide (ShellXFixesCursor *xfixes_cursor)
|
|
||||||
{
|
|
||||||
g_return_if_fail (SHELL_IS_XFIXES_CURSOR (xfixes_cursor));
|
|
||||||
|
|
||||||
xfixes_cursor_hide (xfixes_cursor);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* shell_xfixes_cursor_show:
|
|
||||||
* @xfixes_cursor: the #ShellXFixesCursor
|
|
||||||
*
|
|
||||||
* Show the system mouse cursor to show
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
shell_xfixes_cursor_show (ShellXFixesCursor *xfixes_cursor)
|
|
||||||
{
|
|
||||||
g_return_if_fail (SHELL_IS_XFIXES_CURSOR (xfixes_cursor));
|
|
||||||
|
|
||||||
xfixes_cursor_show (xfixes_cursor);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* shell_xfixes_cursor_update_texture_image:
|
* shell_xfixes_cursor_update_texture_image:
|
||||||
* @xfixes_cursor: the #ShellXFixesCursor
|
* @xfixes_cursor: the #ShellXFixesCursor
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
|
|
||||||
#include <clutter/clutter.h>
|
#include <clutter/clutter.h>
|
||||||
#include <gdk-pixbuf/gdk-pixbuf.h>
|
#include <gdk-pixbuf/gdk-pixbuf.h>
|
||||||
|
#include <meta/screen.h>
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
@ -19,10 +20,8 @@ typedef struct _ShellXFixesCursorClass ShellXFixesCursorClass;
|
|||||||
|
|
||||||
GType shell_xfixes_cursor_get_type (void) G_GNUC_CONST;
|
GType shell_xfixes_cursor_get_type (void) G_GNUC_CONST;
|
||||||
|
|
||||||
ShellXFixesCursor *shell_xfixes_cursor_get_for_stage (ClutterStage *stage);
|
ShellXFixesCursor *shell_xfixes_cursor_get_for_screen (MetaScreen *screen);
|
||||||
|
|
||||||
void shell_xfixes_cursor_show (ShellXFixesCursor *xfixes_cursor);
|
|
||||||
void shell_xfixes_cursor_hide (ShellXFixesCursor *xfixes_cursor);
|
|
||||||
int shell_xfixes_cursor_get_hot_x (ShellXFixesCursor *xfixes_cursor);
|
int shell_xfixes_cursor_get_hot_x (ShellXFixesCursor *xfixes_cursor);
|
||||||
int shell_xfixes_cursor_get_hot_y (ShellXFixesCursor *xfixes_cursor);
|
int shell_xfixes_cursor_get_hot_y (ShellXFixesCursor *xfixes_cursor);
|
||||||
void shell_xfixes_cursor_update_texture_image (ShellXFixesCursor *xfixes_cursor,
|
void shell_xfixes_cursor_update_texture_image (ShellXFixesCursor *xfixes_cursor,
|
||||||
|
Reference in New Issue
Block a user