Compare commits
34 Commits
Author | SHA1 | Date | |
---|---|---|---|
73f7991264 | |||
976f26cb26 | |||
1278e31b65 | |||
92f27a3c00 | |||
28667a686d | |||
783683a12c | |||
fc70446050 | |||
70ab08aefd | |||
ca6308ae64 | |||
4dcbb84f06 | |||
f4e6f7074e | |||
0d92f2b0c5 | |||
2afb4cc124 | |||
762b0e45e0 | |||
a7acd3b535 | |||
ccc4b20e83 | |||
8dd45bea1c | |||
0c80f8cec4 | |||
27508864bf | |||
117be3b14d | |||
4bc2f9b5e6 | |||
ba5c45deaf | |||
941246a4f0 | |||
7feef56656 | |||
9a2a07f32a | |||
af9594c902 | |||
569008b084 | |||
0e086563bc | |||
91d4a832ad | |||
832ce362f0 | |||
aa04e453b8 | |||
b0a75aed95 | |||
dba97f36c0 | |||
2560b37819 |
31
.gitignore
vendored
@ -3,7 +3,6 @@
|
|||||||
*.o
|
*.o
|
||||||
.deps
|
.deps
|
||||||
.libs
|
.libs
|
||||||
ABOUT-NLS
|
|
||||||
ChangeLog
|
ChangeLog
|
||||||
INSTALL
|
INSTALL
|
||||||
Makefile
|
Makefile
|
||||||
@ -16,29 +15,11 @@ config.log
|
|||||||
config.status
|
config.status
|
||||||
config
|
config
|
||||||
configure
|
configure
|
||||||
data/50-gnome-shell-*.xml
|
|
||||||
data/gnome-shell.desktop
|
data/gnome-shell.desktop
|
||||||
data/gnome-shell.desktop.in
|
data/gnome-shell.desktop.in
|
||||||
data/gnome-shell-extension-prefs.desktop
|
|
||||||
data/gnome-shell-extension-prefs.desktop.in
|
|
||||||
data/gschemas.compiled
|
data/gschemas.compiled
|
||||||
data/org.gnome.shell.gschema.xml
|
data/org.gnome.shell.gschema.xml
|
||||||
data/org.gnome.shell.gschema.valid
|
data/org.gnome.shell.gschema.valid
|
||||||
data/org.gnome.shell.evolution.calendar.gschema.xml
|
|
||||||
data/org.gnome.shell.evolution.calendar.gschema.valid
|
|
||||||
docs/reference/*/*.args
|
|
||||||
docs/reference/*/*.bak
|
|
||||||
docs/reference/*/*.hierarchy
|
|
||||||
docs/reference/*/*.interfaces
|
|
||||||
docs/reference/*/*.prerequisites
|
|
||||||
docs/reference/*/*.sgml
|
|
||||||
docs/reference/*/*.signals
|
|
||||||
docs/reference/*/*.stamp
|
|
||||||
docs/reference/*/*.txt
|
|
||||||
docs/reference/*/*.types
|
|
||||||
docs/reference/*/html/
|
|
||||||
docs/reference/*/xml/
|
|
||||||
gtk-doc.make
|
|
||||||
js/misc/config.js
|
js/misc/config.js
|
||||||
intltool-extract.in
|
intltool-extract.in
|
||||||
intltool-merge.in
|
intltool-merge.in
|
||||||
@ -48,14 +29,8 @@ m4/
|
|||||||
omf.make
|
omf.make
|
||||||
po/*.gmo
|
po/*.gmo
|
||||||
po/gnome-shell.pot
|
po/gnome-shell.pot
|
||||||
po/*.header
|
|
||||||
po/*.sed
|
|
||||||
po/*.sin
|
|
||||||
po/.intltool-merge-cache
|
|
||||||
po/Makefile.in.in
|
po/Makefile.in.in
|
||||||
po/Makevars.template
|
|
||||||
po/POTFILES
|
po/POTFILES
|
||||||
po/Rules-quot
|
|
||||||
po/stamp-it
|
po/stamp-it
|
||||||
scripts/launcher.pyc
|
scripts/launcher.pyc
|
||||||
src/*.gir
|
src/*.gir
|
||||||
@ -64,19 +39,13 @@ src/*-enum-types.[ch]
|
|||||||
src/*-marshal.[ch]
|
src/*-marshal.[ch]
|
||||||
src/Makefile
|
src/Makefile
|
||||||
src/Makefile.in
|
src/Makefile.in
|
||||||
src/calendar-server/evolution-calendar.desktop
|
|
||||||
src/calendar-server/evolution-calendar.desktop.in
|
|
||||||
src/calendar-server/org.gnome.Shell.CalendarServer.service
|
src/calendar-server/org.gnome.Shell.CalendarServer.service
|
||||||
src/gnome-shell
|
src/gnome-shell
|
||||||
src/gnome-shell-calendar-server
|
src/gnome-shell-calendar-server
|
||||||
src/gnome-shell-extension-tool
|
src/gnome-shell-extension-tool
|
||||||
src/gnome-shell-extension-prefs
|
|
||||||
src/gnome-shell-hotplug-sniffer
|
|
||||||
src/gnome-shell-jhbuild
|
src/gnome-shell-jhbuild
|
||||||
src/gnome-shell-perf-helper
|
src/gnome-shell-perf-helper
|
||||||
src/gnome-shell-perf-tool
|
|
||||||
src/gnome-shell-real
|
src/gnome-shell-real
|
||||||
src/hotplug-sniffer/org.gnome.Shell.HotplugSniffer.service
|
|
||||||
src/run-js-test
|
src/run-js-test
|
||||||
src/test-recorder
|
src/test-recorder
|
||||||
src/test-recorder.ogg
|
src/test-recorder.ogg
|
||||||
|
331
HACKING
@ -1,331 +0,0 @@
|
|||||||
Coding guide
|
|
||||||
============
|
|
||||||
|
|
||||||
Our goal is to have all JavaScript code in GNOME follow a consistent style. In
|
|
||||||
a dynamic language like JavaScript, it is essential to be rigorous about style
|
|
||||||
(and unit tests), or you rapidly end up with a spaghetti-code mess.
|
|
||||||
|
|
||||||
A quick note
|
|
||||||
------------
|
|
||||||
|
|
||||||
Life isn't fun if you can't break the rules. If a rule seems unnecessarily
|
|
||||||
restrictive while you're coding, ignore it, and let the patch reviewer decide
|
|
||||||
what to do.
|
|
||||||
|
|
||||||
Indentation and whitespace
|
|
||||||
--------------------------
|
|
||||||
|
|
||||||
Use four-space indents. Braces are on the same line as their associated
|
|
||||||
statements. You should only omit braces if *both* sides of the statement are
|
|
||||||
on one line.
|
|
||||||
|
|
||||||
* One space after the `function` keyword. No space between the function name
|
|
||||||
* in a declaration or a call. One space before the parens in the `if`
|
|
||||||
* statements, or `while`, or `for` loops.
|
|
||||||
|
|
||||||
function foo(a, b) {
|
|
||||||
let bar;
|
|
||||||
|
|
||||||
if (a > b)
|
|
||||||
bar = do_thing(a);
|
|
||||||
else
|
|
||||||
bar = do_thing(b);
|
|
||||||
|
|
||||||
if (var == 5) {
|
|
||||||
for (let i = 0; i < 10; i++) {
|
|
||||||
print(i);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
print(20);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Semicolons
|
|
||||||
----------
|
|
||||||
|
|
||||||
JavaScript allows omitting semicolons at the end of lines, but don't. Always
|
|
||||||
end statements with a semicolon.
|
|
||||||
|
|
||||||
js2-mode
|
|
||||||
--------
|
|
||||||
|
|
||||||
If using Emacs, do not use js2-mode. It is outdated and hasn't worked for a
|
|
||||||
while. emacs now has a built-in JavaScript mode, js-mode, based on
|
|
||||||
espresso-mode. It is the de facto emacs mode for JavaScript.
|
|
||||||
|
|
||||||
File naming and creation
|
|
||||||
------------------------
|
|
||||||
|
|
||||||
For JavaScript files, use lowerCamelCase-style names, with a `.js` extension.
|
|
||||||
|
|
||||||
We only use C where gjs/gobject-introspection is not available for the task, or
|
|
||||||
where C would be cleaner. To work around limitations in
|
|
||||||
gjs/gobject-introspection itself, add a new method in `shell-util.[ch]`.
|
|
||||||
|
|
||||||
Like many other GNOME projects, we prefix our C source filenames with the
|
|
||||||
library name followed by a dash, e.g. `shell-app-system.c`. Create a
|
|
||||||
`-private.h` header when you want to share code internally in the
|
|
||||||
library. These headers are not installed, distributed or introspected.
|
|
||||||
|
|
||||||
Imports
|
|
||||||
-------
|
|
||||||
|
|
||||||
Use UpperCamelCase when importing modules to distinguish them from ordinary
|
|
||||||
variables, e.g.
|
|
||||||
|
|
||||||
const GLib = imports.gi.GLib;
|
|
||||||
|
|
||||||
Imports should be categorized into one of two places. The top-most import block
|
|
||||||
should contain only "environment imports". These are either modules from
|
|
||||||
gobject-introspection or modules added by gjs itself.
|
|
||||||
|
|
||||||
The second block of imports should contain only "application imports". These
|
|
||||||
are the JS code that is in the gnome-shell codebase,
|
|
||||||
e.g. `imports.ui.popupMenu`.
|
|
||||||
|
|
||||||
Each import block should be sorted alphabetically. Don't import modules you
|
|
||||||
don't use.
|
|
||||||
|
|
||||||
const GLib = imports.gi.GLib;
|
|
||||||
const Gio = imports.gi.Gio;
|
|
||||||
const Lang = imports.lang;
|
|
||||||
const St = imports.gi.St;
|
|
||||||
|
|
||||||
const Main = imports.ui.main;
|
|
||||||
const Params = imports.misc.params;
|
|
||||||
const Tweener = imports.ui.tweener;
|
|
||||||
const Util = imports.misc.util;
|
|
||||||
|
|
||||||
The alphabetical ordering should be done independently of the location of the
|
|
||||||
location. Never reference `imports` in actual code.
|
|
||||||
|
|
||||||
Constants
|
|
||||||
---------
|
|
||||||
|
|
||||||
We use CONSTANTS_CASE to define constants. All constants should be directly
|
|
||||||
under the imports:
|
|
||||||
|
|
||||||
const MY_DBUS_INTERFACE = 'org.my.Interface';
|
|
||||||
|
|
||||||
Variable declaration
|
|
||||||
--------------------
|
|
||||||
|
|
||||||
Always use either `const` or `let` when defining a variable.
|
|
||||||
|
|
||||||
// Iterating over an array
|
|
||||||
for (let i = 0; i < arr.length; ++i) {
|
|
||||||
let item = arr[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
// Iterating over an object's properties
|
|
||||||
for (let prop in someobj) {
|
|
||||||
...
|
|
||||||
}
|
|
||||||
|
|
||||||
If you use "var" then the variable is added to function scope, not block scope.
|
|
||||||
See [What's new in JavaScript 1.7](https://developer.mozilla.org/en/JavaScript/New_in_JavaScript/1.7#Block_scope_with_let_%28Merge_into_let_Statement%29)
|
|
||||||
|
|
||||||
Classes
|
|
||||||
-------
|
|
||||||
|
|
||||||
There are many approaches to classes in JavaScript. We use our own class framework
|
|
||||||
(sigh), which is built in gjs. The advantage is that it supports inheriting from
|
|
||||||
GObjects, although this feature isn't used very often in the Shell itself.
|
|
||||||
|
|
||||||
const IconLabelMenuItem = new Lang.Class({
|
|
||||||
Name: 'IconLabelMenuItem',
|
|
||||||
Extends: PopupMenu.PopupMenuBaseItem,
|
|
||||||
|
|
||||||
_init: function(icon, label) {
|
|
||||||
this.parent({ reactive: false });
|
|
||||||
this.addActor(icon);
|
|
||||||
this.addActor(label);
|
|
||||||
},
|
|
||||||
|
|
||||||
open: function() {
|
|
||||||
log("menu opened!");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
* 'Name' is required. 'Extends' is optional. If you leave it out, you will
|
|
||||||
automatically inherit from Object.
|
|
||||||
|
|
||||||
* Leave a blank line between the "class header" (Name, Extends, and other
|
|
||||||
things) and the "class body" (methods). Leave a blank line between each
|
|
||||||
method.
|
|
||||||
|
|
||||||
* No space before the colon, one space after.
|
|
||||||
|
|
||||||
* No trailing comma after the last item.
|
|
||||||
|
|
||||||
* Make sure to use a semicolon after the closing paren to the class. It's
|
|
||||||
still a giant function call, even though it may resemble a more
|
|
||||||
conventional syntax.
|
|
||||||
|
|
||||||
GObject Introspection
|
|
||||||
---------------------
|
|
||||||
|
|
||||||
GObject Introspection is a powerful feature that allows us to have native
|
|
||||||
bindings for almost any library built around GObject. If a library requires
|
|
||||||
you to inherit from a type to use it, you can do so:
|
|
||||||
|
|
||||||
const MyClutterActor = new Lang.Class({
|
|
||||||
Name: 'MyClutterActor',
|
|
||||||
Extends: Clutter.Actor,
|
|
||||||
|
|
||||||
vfunc_get_preferred_width: function(actor, forHeight) {
|
|
||||||
return [100, 100];
|
|
||||||
},
|
|
||||||
|
|
||||||
vfunc_get_preferred_height: function(actor, forWidth) {
|
|
||||||
return [100, 100];
|
|
||||||
},
|
|
||||||
|
|
||||||
vfunc_paint: function(actor) {
|
|
||||||
let alloc = this.get_allocation_box();
|
|
||||||
Cogl.set_source_color4ub(255, 0, 0, 255);
|
|
||||||
Cogl.rectangle(alloc.x1, alloc.y1,
|
|
||||||
alloc.x2, alloc.y2);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
Translatable strings, `environment.js`
|
|
||||||
--------------------------------------
|
|
||||||
|
|
||||||
We use gettext to translate the GNOME Shell into all the languages that GNOME
|
|
||||||
supports. The `gettext` function is aliased globally as `_`, you do not need to
|
|
||||||
explicitly import it. This is done through some magic in the
|
|
||||||
[environment.js](http://git.gnome.org/browse/gnome-shell/tree/js/ui/environment.js)
|
|
||||||
file. If you can't find a method that's used, it's probably either in gjs itself
|
|
||||||
or installed on the global object from the Environment.
|
|
||||||
|
|
||||||
Use 'single quotes' for programming strings that should not be translated
|
|
||||||
and "double quotes" for strings that the user may see. This allows us to
|
|
||||||
quickly find untranslated or mistranslated strings by grepping through the
|
|
||||||
sources for double quotes without a gettext call around them.
|
|
||||||
|
|
||||||
`actor` and `_delegate`
|
|
||||||
-----------------------
|
|
||||||
|
|
||||||
gjs allows us to set so-called "expando properties" on introspected objects,
|
|
||||||
allowing us to treat them like any other. Because the Shell was built before
|
|
||||||
you could inherit from GTypes natively in JS, we usually have a wrapper class
|
|
||||||
that has a property called `actor`. We call this wrapper class the "delegate".
|
|
||||||
|
|
||||||
We sometimes use expando properties to set a property called `_delegate` on
|
|
||||||
the actor itself:
|
|
||||||
|
|
||||||
const MyClass = new Lang.Class({
|
|
||||||
Name: 'MyClass',
|
|
||||||
|
|
||||||
_init: function() {
|
|
||||||
this.actor = new St.Button({ text: "This is a button" });
|
|
||||||
this.actor._delegate = this;
|
|
||||||
|
|
||||||
this.actor.connect('clicked', Lang.bind(this, this._onClicked));
|
|
||||||
},
|
|
||||||
|
|
||||||
_onClicked: function(actor) {
|
|
||||||
actor.set_label("You clicked the button!");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
The 'delegate' property is important for anything which trying to get the
|
|
||||||
delegate object from an associated actor. For instance, the drag and drop
|
|
||||||
system calls the `handleDragOver` function on the delegate of a "drop target"
|
|
||||||
when the user drags an item over it. If you do not set the `_delegate`
|
|
||||||
property, your actor will not be able to be dropped onto.
|
|
||||||
|
|
||||||
Functional style
|
|
||||||
----------------
|
|
||||||
|
|
||||||
JavaScript Array objects offer a lot of common functional programming
|
|
||||||
capabilities such as forEach, map, filter and so on. You can use these when
|
|
||||||
they make sense, but please don't have a spaghetti mess of function programming
|
|
||||||
messed in a procedural style. Use your best judgment.
|
|
||||||
|
|
||||||
Closures
|
|
||||||
--------
|
|
||||||
|
|
||||||
`this` will not be captured in a closure, it is relative to how the closure is
|
|
||||||
invoked, not to the value of this where the closure is created, because "this"
|
|
||||||
is a keyword with a value passed in at function invocation time, it is not a
|
|
||||||
variable that can be captured in closures.
|
|
||||||
|
|
||||||
All closures should be wrapped with a Lang.bind.
|
|
||||||
|
|
||||||
const Lang = imports.lang;
|
|
||||||
|
|
||||||
let closure = Lang.bind(this, function() { this._fnorbate(); });
|
|
||||||
|
|
||||||
A more realistic example would be connecting to a signal on a method of a
|
|
||||||
prototype:
|
|
||||||
|
|
||||||
const Lang = imports.lang;
|
|
||||||
const FnorbLib = imports.fborbLib;
|
|
||||||
|
|
||||||
const MyClass = new Lang.Class({
|
|
||||||
_init: function() {
|
|
||||||
let fnorb = new FnorbLib.Fnorb();
|
|
||||||
fnorb.connect('frobate', Lang.bind(this, this._onFnorbFrobate));
|
|
||||||
},
|
|
||||||
|
|
||||||
_onFnorbFrobate: function(fnorb) {
|
|
||||||
this._updateFnorb();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
Object literal syntax
|
|
||||||
---------------------
|
|
||||||
|
|
||||||
In JavaScript, these are equivalent:
|
|
||||||
|
|
||||||
foo = { 'bar': 42 };
|
|
||||||
foo = { bar: 42 };
|
|
||||||
|
|
||||||
and so are these:
|
|
||||||
|
|
||||||
var b = foo['bar'];
|
|
||||||
var b = foo.bar;
|
|
||||||
|
|
||||||
If your usage of an object is like an object, then you're defining "member
|
|
||||||
variables." For member variables, use the no-quotes no-brackets syntax: `{ bar:
|
|
||||||
42 }` `foo.bar`.
|
|
||||||
|
|
||||||
If your usage of an object is like a hash table (and thus conceptually the keys
|
|
||||||
can have special chars in them), don't use quotes, but use brackets: `{ bar: 42
|
|
||||||
}`, `foo['bar']`.
|
|
||||||
|
|
||||||
Getters, setters, and Tweener
|
|
||||||
-----------------------------
|
|
||||||
|
|
||||||
Getters and setters should be used when you are dealing with an API that is
|
|
||||||
designed around setting properties, like Tweener. If you want to animate an
|
|
||||||
arbitrary property, create a getter and setter, and use Tweener to animate the
|
|
||||||
property.
|
|
||||||
|
|
||||||
const ANIMATION_TIME = 2000;
|
|
||||||
|
|
||||||
const MyClass = new Lang.Class({
|
|
||||||
Name: 'MyClass',
|
|
||||||
|
|
||||||
_init: function() {
|
|
||||||
this.actor = new St.BoxLayout();
|
|
||||||
this._position = 0;
|
|
||||||
},
|
|
||||||
|
|
||||||
get position() {
|
|
||||||
return this._position;
|
|
||||||
},
|
|
||||||
|
|
||||||
set position(value) {
|
|
||||||
this._position = value;
|
|
||||||
this.actor.set_position(value, value);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
let myThing = new MyClass();
|
|
||||||
Tweener.addTween(myThing,
|
|
||||||
{ position: 100,
|
|
||||||
time: ANIMATION_TIME,
|
|
||||||
transition: 'easeOutQuad' });
|
|
@ -3,5 +3,5 @@ E-mail: otaylor@redhat.com
|
|||||||
Userid: otaylor
|
Userid: otaylor
|
||||||
|
|
||||||
Colin Walters
|
Colin Walters
|
||||||
E-mail: walters@verbum.org
|
E-mail: walters@redhat.com
|
||||||
Userid: walters
|
Userid: walters
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
# Point to our macro directory and pick up user flags from the environment
|
# Point to our macro directory and pick up user flags from the environment
|
||||||
ACLOCAL_AMFLAGS = -I m4 ${ACLOCAL_FLAGS}
|
ACLOCAL_AMFLAGS = -I m4 ${ACLOCAL_FLAGS}
|
||||||
|
|
||||||
SUBDIRS = data js src browser-plugin tests po man docs
|
SUBDIRS = data js src tests po man
|
||||||
|
|
||||||
EXTRA_DIST = \
|
EXTRA_DIST = \
|
||||||
.project \
|
.project \
|
||||||
@ -13,12 +13,9 @@ EXTRA_DIST = \
|
|||||||
DIST_EXCLUDE = \
|
DIST_EXCLUDE = \
|
||||||
.gitignore \
|
.gitignore \
|
||||||
gnome-shell.doap \
|
gnome-shell.doap \
|
||||||
HACKING \
|
|
||||||
MAINTAINERS \
|
MAINTAINERS \
|
||||||
tools/build/*
|
tools/build/*
|
||||||
|
|
||||||
distcheck-hook:
|
distcheck-hook:
|
||||||
@echo "Checking disted files against files in git"
|
@echo "Checking disted files against files in git"
|
||||||
@$(srcdir)/tools/check-for-missing.py $(srcdir) $(distdir) $(DIST_EXCLUDE)
|
@$(srcdir)/tools/check-for-missing.py $(srcdir) $(distdir) $(DIST_EXCLUDE)
|
||||||
|
|
||||||
DISTCHECK_CONFIGURE_FLAGS = --enable-gtk-doc
|
|
||||||
|
@ -1,21 +0,0 @@
|
|||||||
|
|
||||||
mozillalibdir = $(BROWSER_PLUGIN_DIR)
|
|
||||||
|
|
||||||
mozillalib_LTLIBRARIES = libgnome-shell-browser-plugin.la
|
|
||||||
|
|
||||||
libgnome_shell_browser_plugin_la_LDFLAGS = -module -avoid-version -no-undefined
|
|
||||||
|
|
||||||
libgnome_shell_browser_plugin_la_LIBADD = \
|
|
||||||
$(BROWSER_PLUGIN_LIBS)
|
|
||||||
|
|
||||||
libgnome_shell_browser_plugin_la_SOURCES = \
|
|
||||||
browser-plugin.c \
|
|
||||||
npapi/npapi.h \
|
|
||||||
npapi/npfunctions.h \
|
|
||||||
npapi/npruntime.h \
|
|
||||||
npapi/nptypes.h
|
|
||||||
|
|
||||||
libgnome_shell_browser_plugin_la_CFLAGS = \
|
|
||||||
$(BROWSER_PLUGIN_CFLAGS) \
|
|
||||||
-DG_DISABLE_DEPRECATED \
|
|
||||||
-DG_LOG_DOMAIN=\"GnomeShellBrowserPlugin\"
|
|
@ -1,17 +0,0 @@
|
|||||||
The GNOME Shell Browser Plugin provides integration with gnome-shell and the
|
|
||||||
corresponding extensions repository, codenamed "SweetTooth". The plugin allows
|
|
||||||
the extensions repository to provide good integration, letting the website
|
|
||||||
know which extensions are enabled and disabled, and allowing the website to
|
|
||||||
enable, disable and install them.
|
|
||||||
|
|
||||||
Bugs should be reported at http://bugzilla.gnome.org against the 'gnome-shell'
|
|
||||||
product.
|
|
||||||
|
|
||||||
License
|
|
||||||
=======
|
|
||||||
The GNOME Shell Browser Plugin, like GNOME Shell itself is distributed under
|
|
||||||
the GNU General Public License, version 2 or later. The plugin also contains
|
|
||||||
header files from the "NPAPI SDK" project, tri-licensed under MPL 1.1, GPL 2.0
|
|
||||||
and LGPL 2.1. These headers are third-party sources and can be retrieved from:
|
|
||||||
|
|
||||||
http://code.google.com/p/npapi-sdk/
|
|
@ -1,893 +0,0 @@
|
|||||||
/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
||||||
/* ***** BEGIN LICENSE BLOCK *****
|
|
||||||
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
||||||
*
|
|
||||||
* The contents of this file are subject to the Mozilla Public License Version
|
|
||||||
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
||||||
* the License. You may obtain a copy of the License at
|
|
||||||
* http://www.mozilla.org/MPL/
|
|
||||||
*
|
|
||||||
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
||||||
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
||||||
* for the specific language governing rights and limitations under the
|
|
||||||
* License.
|
|
||||||
*
|
|
||||||
* The Original Code is mozilla.org code.
|
|
||||||
*
|
|
||||||
* The Initial Developer of the Original Code is
|
|
||||||
* Netscape Communications Corporation.
|
|
||||||
* Portions created by the Initial Developer are Copyright (C) 1998
|
|
||||||
* the Initial Developer. All Rights Reserved.
|
|
||||||
*
|
|
||||||
* Contributor(s):
|
|
||||||
*
|
|
||||||
* Alternatively, the contents of this file may be used under the terms of
|
|
||||||
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
||||||
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
||||||
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
||||||
* of those above. If you wish to allow use of your version of this file only
|
|
||||||
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
||||||
* use your version of this file under the terms of the MPL, indicate your
|
|
||||||
* decision by deleting the provisions above and replace them with the notice
|
|
||||||
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
||||||
* the provisions above, a recipient may use your version of this file under
|
|
||||||
* the terms of any one of the MPL, the GPL or the LGPL.
|
|
||||||
*
|
|
||||||
* ***** END LICENSE BLOCK ***** */
|
|
||||||
|
|
||||||
#ifndef npapi_h_
|
|
||||||
#define npapi_h_
|
|
||||||
|
|
||||||
#if defined(__OS2__)
|
|
||||||
#pragma pack(1)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "nptypes.h"
|
|
||||||
|
|
||||||
#if defined(__OS2__) || defined(OS2)
|
|
||||||
#ifndef XP_OS2
|
|
||||||
#define XP_OS2 1
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(_WIN32) && !defined(__SYMBIAN32__)
|
|
||||||
#include <windef.h>
|
|
||||||
#ifndef XP_WIN
|
|
||||||
#define XP_WIN 1
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(__SYMBIAN32__)
|
|
||||||
#ifndef XP_SYMBIAN
|
|
||||||
#define XP_SYMBIAN 1
|
|
||||||
#undef XP_WIN
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(__APPLE_CC__) && !defined(XP_UNIX)
|
|
||||||
#ifndef XP_MACOSX
|
|
||||||
#define XP_MACOSX 1
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(XP_MACOSX) && defined(__LP64__)
|
|
||||||
#define NP_NO_QUICKDRAW
|
|
||||||
#define NP_NO_CARBON
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(XP_MACOSX)
|
|
||||||
#include <ApplicationServices/ApplicationServices.h>
|
|
||||||
#include <OpenGL/OpenGL.h>
|
|
||||||
#ifndef NP_NO_CARBON
|
|
||||||
#include <Carbon/Carbon.h>
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(XP_UNIX)
|
|
||||||
#include <stdio.h>
|
|
||||||
#if defined(MOZ_X11)
|
|
||||||
#include <X11/Xlib.h>
|
|
||||||
#include <X11/Xutil.h>
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(XP_SYMBIAN)
|
|
||||||
#include <QEvent>
|
|
||||||
#include <QRegion>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*----------------------------------------------------------------------*/
|
|
||||||
/* Plugin Version Constants */
|
|
||||||
/*----------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
#define NP_VERSION_MAJOR 0
|
|
||||||
#define NP_VERSION_MINOR 27
|
|
||||||
|
|
||||||
|
|
||||||
/* The OS/2 version of Netscape uses RC_DATA to define the
|
|
||||||
mime types, file extensions, etc that are required.
|
|
||||||
Use a vertical bar to separate types, end types with \0.
|
|
||||||
FileVersion and ProductVersion are 32bit ints, all other
|
|
||||||
entries are strings that MUST be terminated with a \0.
|
|
||||||
|
|
||||||
AN EXAMPLE:
|
|
||||||
|
|
||||||
RCDATA NP_INFO_ProductVersion { 1,0,0,1,}
|
|
||||||
|
|
||||||
RCDATA NP_INFO_MIMEType { "video/x-video|",
|
|
||||||
"video/x-flick\0" }
|
|
||||||
RCDATA NP_INFO_FileExtents { "avi|",
|
|
||||||
"flc\0" }
|
|
||||||
RCDATA NP_INFO_FileOpenName{ "MMOS2 video player(*.avi)|",
|
|
||||||
"MMOS2 Flc/Fli player(*.flc)\0" }
|
|
||||||
|
|
||||||
RCDATA NP_INFO_FileVersion { 1,0,0,1 }
|
|
||||||
RCDATA NP_INFO_CompanyName { "Netscape Communications\0" }
|
|
||||||
RCDATA NP_INFO_FileDescription { "NPAVI32 Extension DLL\0"
|
|
||||||
RCDATA NP_INFO_InternalName { "NPAVI32\0" )
|
|
||||||
RCDATA NP_INFO_LegalCopyright { "Copyright Netscape Communications \251 1996\0"
|
|
||||||
RCDATA NP_INFO_OriginalFilename { "NVAPI32.DLL" }
|
|
||||||
RCDATA NP_INFO_ProductName { "NPAVI32 Dynamic Link Library\0" }
|
|
||||||
*/
|
|
||||||
/* RC_DATA types for version info - required */
|
|
||||||
#define NP_INFO_ProductVersion 1
|
|
||||||
#define NP_INFO_MIMEType 2
|
|
||||||
#define NP_INFO_FileOpenName 3
|
|
||||||
#define NP_INFO_FileExtents 4
|
|
||||||
/* RC_DATA types for version info - used if found */
|
|
||||||
#define NP_INFO_FileDescription 5
|
|
||||||
#define NP_INFO_ProductName 6
|
|
||||||
/* RC_DATA types for version info - optional */
|
|
||||||
#define NP_INFO_CompanyName 7
|
|
||||||
#define NP_INFO_FileVersion 8
|
|
||||||
#define NP_INFO_InternalName 9
|
|
||||||
#define NP_INFO_LegalCopyright 10
|
|
||||||
#define NP_INFO_OriginalFilename 11
|
|
||||||
|
|
||||||
#ifndef RC_INVOKED
|
|
||||||
|
|
||||||
/*----------------------------------------------------------------------*/
|
|
||||||
/* Definition of Basic Types */
|
|
||||||
/*----------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
typedef unsigned char NPBool;
|
|
||||||
typedef int16_t NPError;
|
|
||||||
typedef int16_t NPReason;
|
|
||||||
typedef char* NPMIMEType;
|
|
||||||
|
|
||||||
/*----------------------------------------------------------------------*/
|
|
||||||
/* Structures and definitions */
|
|
||||||
/*----------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
#if !defined(__LP64__)
|
|
||||||
#if defined(XP_MACOSX)
|
|
||||||
#pragma options align=mac68k
|
|
||||||
#endif
|
|
||||||
#endif /* __LP64__ */
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NPP is a plug-in's opaque instance handle
|
|
||||||
*/
|
|
||||||
typedef struct _NPP
|
|
||||||
{
|
|
||||||
void* pdata; /* plug-in private data */
|
|
||||||
void* ndata; /* netscape private data */
|
|
||||||
} NPP_t;
|
|
||||||
|
|
||||||
typedef NPP_t* NPP;
|
|
||||||
|
|
||||||
typedef struct _NPStream
|
|
||||||
{
|
|
||||||
void* pdata; /* plug-in private data */
|
|
||||||
void* ndata; /* netscape private data */
|
|
||||||
const char* url;
|
|
||||||
uint32_t end;
|
|
||||||
uint32_t lastmodified;
|
|
||||||
void* notifyData;
|
|
||||||
const char* headers; /* Response headers from host.
|
|
||||||
* Exists only for >= NPVERS_HAS_RESPONSE_HEADERS.
|
|
||||||
* Used for HTTP only; NULL for non-HTTP.
|
|
||||||
* Available from NPP_NewStream onwards.
|
|
||||||
* Plugin should copy this data before storing it.
|
|
||||||
* Includes HTTP status line and all headers,
|
|
||||||
* preferably verbatim as received from server,
|
|
||||||
* headers formatted as in HTTP ("Header: Value"),
|
|
||||||
* and newlines (\n, NOT \r\n) separating lines.
|
|
||||||
* Terminated by \n\0 (NOT \n\n\0). */
|
|
||||||
} NPStream;
|
|
||||||
|
|
||||||
typedef struct _NPByteRange
|
|
||||||
{
|
|
||||||
int32_t offset; /* negative offset means from the end */
|
|
||||||
uint32_t length;
|
|
||||||
struct _NPByteRange* next;
|
|
||||||
} NPByteRange;
|
|
||||||
|
|
||||||
typedef struct _NPSavedData
|
|
||||||
{
|
|
||||||
int32_t len;
|
|
||||||
void* buf;
|
|
||||||
} NPSavedData;
|
|
||||||
|
|
||||||
typedef struct _NPRect
|
|
||||||
{
|
|
||||||
uint16_t top;
|
|
||||||
uint16_t left;
|
|
||||||
uint16_t bottom;
|
|
||||||
uint16_t right;
|
|
||||||
} NPRect;
|
|
||||||
|
|
||||||
typedef struct _NPSize
|
|
||||||
{
|
|
||||||
int32_t width;
|
|
||||||
int32_t height;
|
|
||||||
} NPSize;
|
|
||||||
|
|
||||||
typedef enum {
|
|
||||||
NPFocusNext = 0,
|
|
||||||
NPFocusPrevious = 1
|
|
||||||
} NPFocusDirection;
|
|
||||||
|
|
||||||
/* Return values for NPP_HandleEvent */
|
|
||||||
#define kNPEventNotHandled 0
|
|
||||||
#define kNPEventHandled 1
|
|
||||||
/* Exact meaning must be spec'd in event model. */
|
|
||||||
#define kNPEventStartIME 2
|
|
||||||
|
|
||||||
#if defined(XP_UNIX)
|
|
||||||
/*
|
|
||||||
* Unix specific structures and definitions
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Callback Structures.
|
|
||||||
*
|
|
||||||
* These are used to pass additional platform specific information.
|
|
||||||
*/
|
|
||||||
enum {
|
|
||||||
NP_SETWINDOW = 1,
|
|
||||||
NP_PRINT
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
int32_t type;
|
|
||||||
} NPAnyCallbackStruct;
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
int32_t type;
|
|
||||||
#if defined(MOZ_X11)
|
|
||||||
Display* display;
|
|
||||||
Visual* visual;
|
|
||||||
Colormap colormap;
|
|
||||||
unsigned int depth;
|
|
||||||
#endif
|
|
||||||
} NPSetWindowCallbackStruct;
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
int32_t type;
|
|
||||||
FILE* fp;
|
|
||||||
} NPPrintCallbackStruct;
|
|
||||||
|
|
||||||
#endif /* XP_UNIX */
|
|
||||||
|
|
||||||
#if defined(XP_MACOSX)
|
|
||||||
typedef enum {
|
|
||||||
#ifndef NP_NO_QUICKDRAW
|
|
||||||
NPDrawingModelQuickDraw = 0,
|
|
||||||
#endif
|
|
||||||
NPDrawingModelCoreGraphics = 1,
|
|
||||||
NPDrawingModelOpenGL = 2,
|
|
||||||
NPDrawingModelCoreAnimation = 3,
|
|
||||||
NPDrawingModelInvalidatingCoreAnimation = 4
|
|
||||||
} NPDrawingModel;
|
|
||||||
|
|
||||||
typedef enum {
|
|
||||||
#ifndef NP_NO_CARBON
|
|
||||||
NPEventModelCarbon = 0,
|
|
||||||
#endif
|
|
||||||
NPEventModelCocoa = 1
|
|
||||||
} NPEventModel;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The following masks are applied on certain platforms to NPNV and
|
|
||||||
* NPPV selectors that pass around pointers to COM interfaces. Newer
|
|
||||||
* compilers on some platforms may generate vtables that are not
|
|
||||||
* compatible with older compilers. To prevent older plugins from
|
|
||||||
* not understanding a new browser's ABI, these masks change the
|
|
||||||
* values of those selectors on those platforms. To remain backwards
|
|
||||||
* compatible with different versions of the browser, plugins can
|
|
||||||
* use these masks to dynamically determine and use the correct C++
|
|
||||||
* ABI that the browser is expecting. This does not apply to Windows
|
|
||||||
* as Microsoft's COM ABI will likely not change.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define NP_ABI_GCC3_MASK 0x10000000
|
|
||||||
/*
|
|
||||||
* gcc 3.x generated vtables on UNIX and OSX are incompatible with
|
|
||||||
* previous compilers.
|
|
||||||
*/
|
|
||||||
#if (defined(XP_UNIX) && defined(__GNUC__) && (__GNUC__ >= 3))
|
|
||||||
#define _NP_ABI_MIXIN_FOR_GCC3 NP_ABI_GCC3_MASK
|
|
||||||
#else
|
|
||||||
#define _NP_ABI_MIXIN_FOR_GCC3 0
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(XP_MACOSX)
|
|
||||||
#define NP_ABI_MACHO_MASK 0x01000000
|
|
||||||
#define _NP_ABI_MIXIN_FOR_MACHO NP_ABI_MACHO_MASK
|
|
||||||
#else
|
|
||||||
#define _NP_ABI_MIXIN_FOR_MACHO 0
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define NP_ABI_MASK (_NP_ABI_MIXIN_FOR_GCC3 | _NP_ABI_MIXIN_FOR_MACHO)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* List of variable names for which NPP_GetValue shall be implemented
|
|
||||||
*/
|
|
||||||
typedef enum {
|
|
||||||
NPPVpluginNameString = 1,
|
|
||||||
NPPVpluginDescriptionString,
|
|
||||||
NPPVpluginWindowBool,
|
|
||||||
NPPVpluginTransparentBool,
|
|
||||||
NPPVjavaClass,
|
|
||||||
NPPVpluginWindowSize,
|
|
||||||
NPPVpluginTimerInterval,
|
|
||||||
NPPVpluginScriptableInstance = (10 | NP_ABI_MASK),
|
|
||||||
NPPVpluginScriptableIID = 11,
|
|
||||||
NPPVjavascriptPushCallerBool = 12,
|
|
||||||
NPPVpluginKeepLibraryInMemory = 13,
|
|
||||||
NPPVpluginNeedsXEmbed = 14,
|
|
||||||
|
|
||||||
/* Get the NPObject for scripting the plugin. Introduced in NPAPI minor version 14.
|
|
||||||
*/
|
|
||||||
NPPVpluginScriptableNPObject = 15,
|
|
||||||
|
|
||||||
/* Get the plugin value (as \0-terminated UTF-8 string data) for
|
|
||||||
* form submission if the plugin is part of a form. Use
|
|
||||||
* NPN_MemAlloc() to allocate memory for the string data. Introduced
|
|
||||||
* in NPAPI minor version 15.
|
|
||||||
*/
|
|
||||||
NPPVformValue = 16,
|
|
||||||
|
|
||||||
NPPVpluginUrlRequestsDisplayedBool = 17,
|
|
||||||
|
|
||||||
/* Checks if the plugin is interested in receiving the http body of
|
|
||||||
* all http requests (including failed ones, http status != 200).
|
|
||||||
*/
|
|
||||||
NPPVpluginWantsAllNetworkStreams = 18,
|
|
||||||
|
|
||||||
/* Browsers can retrieve a native ATK accessibility plug ID via this variable. */
|
|
||||||
NPPVpluginNativeAccessibleAtkPlugId = 19,
|
|
||||||
|
|
||||||
/* Checks to see if the plug-in would like the browser to load the "src" attribute. */
|
|
||||||
NPPVpluginCancelSrcStream = 20,
|
|
||||||
|
|
||||||
NPPVsupportsAdvancedKeyHandling = 21,
|
|
||||||
|
|
||||||
NPPVpluginUsesDOMForCursorBool = 22
|
|
||||||
|
|
||||||
#if defined(XP_MACOSX)
|
|
||||||
/* Used for negotiating drawing models */
|
|
||||||
, NPPVpluginDrawingModel = 1000
|
|
||||||
/* Used for negotiating event models */
|
|
||||||
, NPPVpluginEventModel = 1001
|
|
||||||
/* In the NPDrawingModelCoreAnimation drawing model, the browser asks the plug-in for a Core Animation layer. */
|
|
||||||
, NPPVpluginCoreAnimationLayer = 1003
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if (MOZ_PLATFORM_MAEMO == 5) || (MOZ_PLATFORM_MAEMO == 6)
|
|
||||||
, NPPVpluginWindowlessLocalBool = 2002
|
|
||||||
#endif
|
|
||||||
} NPPVariable;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* List of variable names for which NPN_GetValue should be implemented.
|
|
||||||
*/
|
|
||||||
typedef enum {
|
|
||||||
NPNVxDisplay = 1,
|
|
||||||
NPNVxtAppContext,
|
|
||||||
NPNVnetscapeWindow,
|
|
||||||
NPNVjavascriptEnabledBool,
|
|
||||||
NPNVasdEnabledBool,
|
|
||||||
NPNVisOfflineBool,
|
|
||||||
|
|
||||||
NPNVserviceManager = (10 | NP_ABI_MASK),
|
|
||||||
NPNVDOMElement = (11 | NP_ABI_MASK),
|
|
||||||
NPNVDOMWindow = (12 | NP_ABI_MASK),
|
|
||||||
NPNVToolkit = (13 | NP_ABI_MASK),
|
|
||||||
NPNVSupportsXEmbedBool = 14,
|
|
||||||
|
|
||||||
/* Get the NPObject wrapper for the browser window. */
|
|
||||||
NPNVWindowNPObject = 15,
|
|
||||||
|
|
||||||
/* Get the NPObject wrapper for the plugins DOM element. */
|
|
||||||
NPNVPluginElementNPObject = 16,
|
|
||||||
|
|
||||||
NPNVSupportsWindowless = 17,
|
|
||||||
|
|
||||||
NPNVprivateModeBool = 18,
|
|
||||||
|
|
||||||
NPNVsupportsAdvancedKeyHandling = 21
|
|
||||||
|
|
||||||
#if defined(XP_MACOSX)
|
|
||||||
/* Used for negotiating drawing models */
|
|
||||||
, NPNVpluginDrawingModel = 1000
|
|
||||||
#ifndef NP_NO_QUICKDRAW
|
|
||||||
, NPNVsupportsQuickDrawBool = 2000
|
|
||||||
#endif
|
|
||||||
, NPNVsupportsCoreGraphicsBool = 2001
|
|
||||||
, NPNVsupportsOpenGLBool = 2002
|
|
||||||
, NPNVsupportsCoreAnimationBool = 2003
|
|
||||||
, NPNVsupportsInvalidatingCoreAnimationBool = 2004
|
|
||||||
#ifndef NP_NO_CARBON
|
|
||||||
, NPNVsupportsCarbonBool = 3000 /* TRUE if the browser supports the Carbon event model */
|
|
||||||
#endif
|
|
||||||
, NPNVsupportsCocoaBool = 3001 /* TRUE if the browser supports the Cocoa event model */
|
|
||||||
, NPNVsupportsUpdatedCocoaTextInputBool = 3002 /* TRUE if the browser supports the updated
|
|
||||||
Cocoa text input specification. */
|
|
||||||
, NPNVsupportsCompositingCoreAnimationPluginsBool = 74656 /* TRUE if the browser supports
|
|
||||||
CA model compositing */
|
|
||||||
#endif
|
|
||||||
#if (MOZ_PLATFORM_MAEMO == 5) || (MOZ_PLATFORM_MAEMO == 6)
|
|
||||||
, NPNVSupportsWindowlessLocal = 2002
|
|
||||||
#endif
|
|
||||||
} NPNVariable;
|
|
||||||
|
|
||||||
typedef enum {
|
|
||||||
NPNURLVCookie = 501,
|
|
||||||
NPNURLVProxy
|
|
||||||
} NPNURLVariable;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The type of Toolkit the widgets use
|
|
||||||
*/
|
|
||||||
typedef enum {
|
|
||||||
NPNVGtk12 = 1,
|
|
||||||
NPNVGtk2
|
|
||||||
} NPNToolkitType;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The type of a NPWindow - it specifies the type of the data structure
|
|
||||||
* returned in the window field.
|
|
||||||
*/
|
|
||||||
typedef enum {
|
|
||||||
NPWindowTypeWindow = 1,
|
|
||||||
NPWindowTypeDrawable
|
|
||||||
} NPWindowType;
|
|
||||||
|
|
||||||
typedef struct _NPWindow
|
|
||||||
{
|
|
||||||
void* window; /* Platform specific window handle */
|
|
||||||
/* OS/2: x - Position of bottom left corner */
|
|
||||||
/* OS/2: y - relative to visible netscape window */
|
|
||||||
int32_t x; /* Position of top left corner relative */
|
|
||||||
int32_t y; /* to a netscape page. */
|
|
||||||
uint32_t width; /* Maximum window size */
|
|
||||||
uint32_t height;
|
|
||||||
NPRect clipRect; /* Clipping rectangle in port coordinates */
|
|
||||||
#if (defined(XP_UNIX) || defined(XP_SYMBIAN)) && !defined(XP_MACOSX)
|
|
||||||
void * ws_info; /* Platform-dependent additional data */
|
|
||||||
#endif /* XP_UNIX */
|
|
||||||
NPWindowType type; /* Is this a window or a drawable? */
|
|
||||||
} NPWindow;
|
|
||||||
|
|
||||||
typedef struct _NPImageExpose
|
|
||||||
{
|
|
||||||
char* data; /* image pointer */
|
|
||||||
int32_t stride; /* Stride of data image pointer */
|
|
||||||
int32_t depth; /* Depth of image pointer */
|
|
||||||
int32_t x; /* Expose x */
|
|
||||||
int32_t y; /* Expose y */
|
|
||||||
uint32_t width; /* Expose width */
|
|
||||||
uint32_t height; /* Expose height */
|
|
||||||
NPSize dataSize; /* Data buffer size */
|
|
||||||
float translateX; /* translate X matrix value */
|
|
||||||
float translateY; /* translate Y matrix value */
|
|
||||||
float scaleX; /* scale X matrix value */
|
|
||||||
float scaleY; /* scale Y matrix value */
|
|
||||||
} NPImageExpose;
|
|
||||||
|
|
||||||
typedef struct _NPFullPrint
|
|
||||||
{
|
|
||||||
NPBool pluginPrinted;/* Set TRUE if plugin handled fullscreen printing */
|
|
||||||
NPBool printOne; /* TRUE if plugin should print one copy to default
|
|
||||||
printer */
|
|
||||||
void* platformPrint; /* Platform-specific printing info */
|
|
||||||
} NPFullPrint;
|
|
||||||
|
|
||||||
typedef struct _NPEmbedPrint
|
|
||||||
{
|
|
||||||
NPWindow window;
|
|
||||||
void* platformPrint; /* Platform-specific printing info */
|
|
||||||
} NPEmbedPrint;
|
|
||||||
|
|
||||||
typedef struct _NPPrint
|
|
||||||
{
|
|
||||||
uint16_t mode; /* NP_FULL or NP_EMBED */
|
|
||||||
union
|
|
||||||
{
|
|
||||||
NPFullPrint fullPrint; /* if mode is NP_FULL */
|
|
||||||
NPEmbedPrint embedPrint; /* if mode is NP_EMBED */
|
|
||||||
} print;
|
|
||||||
} NPPrint;
|
|
||||||
|
|
||||||
#if defined(XP_MACOSX)
|
|
||||||
#ifndef NP_NO_CARBON
|
|
||||||
typedef EventRecord NPEvent;
|
|
||||||
#endif
|
|
||||||
#elif defined(XP_SYMBIAN)
|
|
||||||
typedef QEvent NPEvent;
|
|
||||||
#elif defined(XP_WIN)
|
|
||||||
typedef struct _NPEvent
|
|
||||||
{
|
|
||||||
uint16_t event;
|
|
||||||
uintptr_t wParam;
|
|
||||||
uintptr_t lParam;
|
|
||||||
} NPEvent;
|
|
||||||
#elif defined(XP_OS2)
|
|
||||||
typedef struct _NPEvent
|
|
||||||
{
|
|
||||||
uint32_t event;
|
|
||||||
uint32_t wParam;
|
|
||||||
uint32_t lParam;
|
|
||||||
} NPEvent;
|
|
||||||
#elif defined(XP_UNIX) && defined(MOZ_X11)
|
|
||||||
typedef XEvent NPEvent;
|
|
||||||
#else
|
|
||||||
typedef void* NPEvent;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(XP_MACOSX)
|
|
||||||
typedef void* NPRegion;
|
|
||||||
#ifndef NP_NO_QUICKDRAW
|
|
||||||
typedef RgnHandle NPQDRegion;
|
|
||||||
#endif
|
|
||||||
typedef CGPathRef NPCGRegion;
|
|
||||||
#elif defined(XP_WIN)
|
|
||||||
typedef HRGN NPRegion;
|
|
||||||
#elif defined(XP_UNIX) && defined(MOZ_X11)
|
|
||||||
typedef Region NPRegion;
|
|
||||||
#elif defined(XP_SYMBIAN)
|
|
||||||
typedef QRegion* NPRegion;
|
|
||||||
#else
|
|
||||||
typedef void *NPRegion;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
typedef struct _NPNSString NPNSString;
|
|
||||||
typedef struct _NPNSWindow NPNSWindow;
|
|
||||||
typedef struct _NPNSMenu NPNSMenu;
|
|
||||||
|
|
||||||
#if defined(XP_MACOSX)
|
|
||||||
typedef NPNSMenu NPMenu;
|
|
||||||
#else
|
|
||||||
typedef void *NPMenu;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
typedef enum {
|
|
||||||
NPCoordinateSpacePlugin = 1,
|
|
||||||
NPCoordinateSpaceWindow,
|
|
||||||
NPCoordinateSpaceFlippedWindow,
|
|
||||||
NPCoordinateSpaceScreen,
|
|
||||||
NPCoordinateSpaceFlippedScreen
|
|
||||||
} NPCoordinateSpace;
|
|
||||||
|
|
||||||
#if defined(XP_MACOSX)
|
|
||||||
|
|
||||||
#ifndef NP_NO_QUICKDRAW
|
|
||||||
typedef struct NP_Port
|
|
||||||
{
|
|
||||||
CGrafPtr port;
|
|
||||||
int32_t portx; /* position inside the topmost window */
|
|
||||||
int32_t porty;
|
|
||||||
} NP_Port;
|
|
||||||
#endif /* NP_NO_QUICKDRAW */
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NP_CGContext is the type of the NPWindow's 'window' when the plugin specifies NPDrawingModelCoreGraphics
|
|
||||||
* as its drawing model.
|
|
||||||
*/
|
|
||||||
|
|
||||||
typedef struct NP_CGContext
|
|
||||||
{
|
|
||||||
CGContextRef context;
|
|
||||||
void *window; /* A WindowRef under the Carbon event model. */
|
|
||||||
} NP_CGContext;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NP_GLContext is the type of the NPWindow's 'window' when the plugin specifies NPDrawingModelOpenGL as its
|
|
||||||
* drawing model.
|
|
||||||
*/
|
|
||||||
|
|
||||||
typedef struct NP_GLContext
|
|
||||||
{
|
|
||||||
CGLContextObj context;
|
|
||||||
#ifdef NP_NO_CARBON
|
|
||||||
NPNSWindow *window;
|
|
||||||
#else
|
|
||||||
void *window; /* Can be either an NSWindow or a WindowRef depending on the event model */
|
|
||||||
#endif
|
|
||||||
} NP_GLContext;
|
|
||||||
|
|
||||||
typedef enum {
|
|
||||||
NPCocoaEventDrawRect = 1,
|
|
||||||
NPCocoaEventMouseDown,
|
|
||||||
NPCocoaEventMouseUp,
|
|
||||||
NPCocoaEventMouseMoved,
|
|
||||||
NPCocoaEventMouseEntered,
|
|
||||||
NPCocoaEventMouseExited,
|
|
||||||
NPCocoaEventMouseDragged,
|
|
||||||
NPCocoaEventKeyDown,
|
|
||||||
NPCocoaEventKeyUp,
|
|
||||||
NPCocoaEventFlagsChanged,
|
|
||||||
NPCocoaEventFocusChanged,
|
|
||||||
NPCocoaEventWindowFocusChanged,
|
|
||||||
NPCocoaEventScrollWheel,
|
|
||||||
NPCocoaEventTextInput
|
|
||||||
} NPCocoaEventType;
|
|
||||||
|
|
||||||
typedef struct _NPCocoaEvent {
|
|
||||||
NPCocoaEventType type;
|
|
||||||
uint32_t version;
|
|
||||||
union {
|
|
||||||
struct {
|
|
||||||
uint32_t modifierFlags;
|
|
||||||
double pluginX;
|
|
||||||
double pluginY;
|
|
||||||
int32_t buttonNumber;
|
|
||||||
int32_t clickCount;
|
|
||||||
double deltaX;
|
|
||||||
double deltaY;
|
|
||||||
double deltaZ;
|
|
||||||
} mouse;
|
|
||||||
struct {
|
|
||||||
uint32_t modifierFlags;
|
|
||||||
NPNSString *characters;
|
|
||||||
NPNSString *charactersIgnoringModifiers;
|
|
||||||
NPBool isARepeat;
|
|
||||||
uint16_t keyCode;
|
|
||||||
} key;
|
|
||||||
struct {
|
|
||||||
CGContextRef context;
|
|
||||||
double x;
|
|
||||||
double y;
|
|
||||||
double width;
|
|
||||||
double height;
|
|
||||||
} draw;
|
|
||||||
struct {
|
|
||||||
NPBool hasFocus;
|
|
||||||
} focus;
|
|
||||||
struct {
|
|
||||||
NPNSString *text;
|
|
||||||
} text;
|
|
||||||
} data;
|
|
||||||
} NPCocoaEvent;
|
|
||||||
|
|
||||||
#ifndef NP_NO_CARBON
|
|
||||||
/* Non-standard event types that can be passed to HandleEvent */
|
|
||||||
enum NPEventType {
|
|
||||||
NPEventType_GetFocusEvent = (osEvt + 16),
|
|
||||||
NPEventType_LoseFocusEvent,
|
|
||||||
NPEventType_AdjustCursorEvent,
|
|
||||||
NPEventType_MenuCommandEvent,
|
|
||||||
NPEventType_ClippingChangedEvent,
|
|
||||||
NPEventType_ScrollingBeginsEvent = 1000,
|
|
||||||
NPEventType_ScrollingEndsEvent
|
|
||||||
};
|
|
||||||
#endif /* NP_NO_CARBON */
|
|
||||||
|
|
||||||
#endif /* XP_MACOSX */
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Values for mode passed to NPP_New:
|
|
||||||
*/
|
|
||||||
#define NP_EMBED 1
|
|
||||||
#define NP_FULL 2
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Values for stream type passed to NPP_NewStream:
|
|
||||||
*/
|
|
||||||
#define NP_NORMAL 1
|
|
||||||
#define NP_SEEK 2
|
|
||||||
#define NP_ASFILE 3
|
|
||||||
#define NP_ASFILEONLY 4
|
|
||||||
|
|
||||||
#define NP_MAXREADY (((unsigned)(~0)<<1)>>1)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Flags for NPP_ClearSiteData.
|
|
||||||
*/
|
|
||||||
#define NP_CLEAR_ALL 0
|
|
||||||
#define NP_CLEAR_CACHE (1 << 0)
|
|
||||||
|
|
||||||
#if !defined(__LP64__)
|
|
||||||
#if defined(XP_MACOSX)
|
|
||||||
#pragma options align=reset
|
|
||||||
#endif
|
|
||||||
#endif /* __LP64__ */
|
|
||||||
|
|
||||||
/*----------------------------------------------------------------------*/
|
|
||||||
/* Error and Reason Code definitions */
|
|
||||||
/*----------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Values of type NPError:
|
|
||||||
*/
|
|
||||||
#define NPERR_BASE 0
|
|
||||||
#define NPERR_NO_ERROR (NPERR_BASE + 0)
|
|
||||||
#define NPERR_GENERIC_ERROR (NPERR_BASE + 1)
|
|
||||||
#define NPERR_INVALID_INSTANCE_ERROR (NPERR_BASE + 2)
|
|
||||||
#define NPERR_INVALID_FUNCTABLE_ERROR (NPERR_BASE + 3)
|
|
||||||
#define NPERR_MODULE_LOAD_FAILED_ERROR (NPERR_BASE + 4)
|
|
||||||
#define NPERR_OUT_OF_MEMORY_ERROR (NPERR_BASE + 5)
|
|
||||||
#define NPERR_INVALID_PLUGIN_ERROR (NPERR_BASE + 6)
|
|
||||||
#define NPERR_INVALID_PLUGIN_DIR_ERROR (NPERR_BASE + 7)
|
|
||||||
#define NPERR_INCOMPATIBLE_VERSION_ERROR (NPERR_BASE + 8)
|
|
||||||
#define NPERR_INVALID_PARAM (NPERR_BASE + 9)
|
|
||||||
#define NPERR_INVALID_URL (NPERR_BASE + 10)
|
|
||||||
#define NPERR_FILE_NOT_FOUND (NPERR_BASE + 11)
|
|
||||||
#define NPERR_NO_DATA (NPERR_BASE + 12)
|
|
||||||
#define NPERR_STREAM_NOT_SEEKABLE (NPERR_BASE + 13)
|
|
||||||
#define NPERR_TIME_RANGE_NOT_SUPPORTED (NPERR_BASE + 14)
|
|
||||||
#define NPERR_MALFORMED_SITE (NPERR_BASE + 15)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Values of type NPReason:
|
|
||||||
*/
|
|
||||||
#define NPRES_BASE 0
|
|
||||||
#define NPRES_DONE (NPRES_BASE + 0)
|
|
||||||
#define NPRES_NETWORK_ERR (NPRES_BASE + 1)
|
|
||||||
#define NPRES_USER_BREAK (NPRES_BASE + 2)
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Don't use these obsolete error codes any more.
|
|
||||||
*/
|
|
||||||
#define NP_NOERR NP_NOERR_is_obsolete_use_NPERR_NO_ERROR
|
|
||||||
#define NP_EINVAL NP_EINVAL_is_obsolete_use_NPERR_GENERIC_ERROR
|
|
||||||
#define NP_EABORT NP_EABORT_is_obsolete_use_NPRES_USER_BREAK
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Version feature information
|
|
||||||
*/
|
|
||||||
#define NPVERS_HAS_STREAMOUTPUT 8
|
|
||||||
#define NPVERS_HAS_NOTIFICATION 9
|
|
||||||
#define NPVERS_HAS_LIVECONNECT 9
|
|
||||||
#define NPVERS_68K_HAS_LIVECONNECT 11
|
|
||||||
#define NPVERS_HAS_WINDOWLESS 11
|
|
||||||
#define NPVERS_HAS_XPCONNECT_SCRIPTING 13
|
|
||||||
#define NPVERS_HAS_NPRUNTIME_SCRIPTING 14
|
|
||||||
#define NPVERS_HAS_FORM_VALUES 15
|
|
||||||
#define NPVERS_HAS_POPUPS_ENABLED_STATE 16
|
|
||||||
#define NPVERS_HAS_RESPONSE_HEADERS 17
|
|
||||||
#define NPVERS_HAS_NPOBJECT_ENUM 18
|
|
||||||
#define NPVERS_HAS_PLUGIN_THREAD_ASYNC_CALL 19
|
|
||||||
#define NPVERS_HAS_ALL_NETWORK_STREAMS 20
|
|
||||||
#define NPVERS_HAS_URL_AND_AUTH_INFO 21
|
|
||||||
#define NPVERS_HAS_PRIVATE_MODE 22
|
|
||||||
#define NPVERS_MACOSX_HAS_COCOA_EVENTS 23
|
|
||||||
#define NPVERS_HAS_ADVANCED_KEY_HANDLING 25
|
|
||||||
#define NPVERS_HAS_URL_REDIRECT_HANDLING 26
|
|
||||||
#define NPVERS_HAS_CLEAR_SITE_DATA 27
|
|
||||||
|
|
||||||
/*----------------------------------------------------------------------*/
|
|
||||||
/* Function Prototypes */
|
|
||||||
/*----------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
#if defined(__OS2__)
|
|
||||||
#define NP_LOADDS _System
|
|
||||||
#else
|
|
||||||
#define NP_LOADDS
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* NPP_* functions are provided by the plugin and called by the navigator. */
|
|
||||||
|
|
||||||
#if defined(XP_UNIX)
|
|
||||||
const char* NPP_GetMIMEDescription(void);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
NPError NP_LOADDS NPP_New(NPMIMEType pluginType, NPP instance,
|
|
||||||
uint16_t mode, int16_t argc, char* argn[],
|
|
||||||
char* argv[], NPSavedData* saved);
|
|
||||||
NPError NP_LOADDS NPP_Destroy(NPP instance, NPSavedData** save);
|
|
||||||
NPError NP_LOADDS NPP_SetWindow(NPP instance, NPWindow* window);
|
|
||||||
NPError NP_LOADDS NPP_NewStream(NPP instance, NPMIMEType type,
|
|
||||||
NPStream* stream, NPBool seekable,
|
|
||||||
uint16_t* stype);
|
|
||||||
NPError NP_LOADDS NPP_DestroyStream(NPP instance, NPStream* stream,
|
|
||||||
NPReason reason);
|
|
||||||
int32_t NP_LOADDS NPP_WriteReady(NPP instance, NPStream* stream);
|
|
||||||
int32_t NP_LOADDS NPP_Write(NPP instance, NPStream* stream, int32_t offset,
|
|
||||||
int32_t len, void* buffer);
|
|
||||||
void NP_LOADDS NPP_StreamAsFile(NPP instance, NPStream* stream,
|
|
||||||
const char* fname);
|
|
||||||
void NP_LOADDS NPP_Print(NPP instance, NPPrint* platformPrint);
|
|
||||||
int16_t NP_LOADDS NPP_HandleEvent(NPP instance, void* event);
|
|
||||||
void NP_LOADDS NPP_URLNotify(NPP instance, const char* url,
|
|
||||||
NPReason reason, void* notifyData);
|
|
||||||
NPError NP_LOADDS NPP_GetValue(NPP instance, NPPVariable variable, void *value);
|
|
||||||
NPError NP_LOADDS NPP_SetValue(NPP instance, NPNVariable variable, void *value);
|
|
||||||
NPBool NP_LOADDS NPP_GotFocus(NPP instance, NPFocusDirection direction);
|
|
||||||
void NP_LOADDS NPP_LostFocus(NPP instance);
|
|
||||||
void NP_LOADDS NPP_URLRedirectNotify(NPP instance, const char* url, int32_t status, void* notifyData);
|
|
||||||
NPError NP_LOADDS NPP_ClearSiteData(const char* site, uint64_t flags, uint64_t maxAge);
|
|
||||||
char** NP_LOADDS NPP_GetSitesWithData(void);
|
|
||||||
|
|
||||||
/* NPN_* functions are provided by the navigator and called by the plugin. */
|
|
||||||
void NP_LOADDS NPN_Version(int* plugin_major, int* plugin_minor,
|
|
||||||
int* netscape_major, int* netscape_minor);
|
|
||||||
NPError NP_LOADDS NPN_GetURLNotify(NPP instance, const char* url,
|
|
||||||
const char* target, void* notifyData);
|
|
||||||
NPError NP_LOADDS NPN_GetURL(NPP instance, const char* url,
|
|
||||||
const char* target);
|
|
||||||
NPError NP_LOADDS NPN_PostURLNotify(NPP instance, const char* url,
|
|
||||||
const char* target, uint32_t len,
|
|
||||||
const char* buf, NPBool file,
|
|
||||||
void* notifyData);
|
|
||||||
NPError NP_LOADDS NPN_PostURL(NPP instance, const char* url,
|
|
||||||
const char* target, uint32_t len,
|
|
||||||
const char* buf, NPBool file);
|
|
||||||
NPError NP_LOADDS NPN_RequestRead(NPStream* stream, NPByteRange* rangeList);
|
|
||||||
NPError NP_LOADDS NPN_NewStream(NPP instance, NPMIMEType type,
|
|
||||||
const char* target, NPStream** stream);
|
|
||||||
int32_t NP_LOADDS NPN_Write(NPP instance, NPStream* stream, int32_t len,
|
|
||||||
void* buffer);
|
|
||||||
NPError NP_LOADDS NPN_DestroyStream(NPP instance, NPStream* stream,
|
|
||||||
NPReason reason);
|
|
||||||
void NP_LOADDS NPN_Status(NPP instance, const char* message);
|
|
||||||
const char* NP_LOADDS NPN_UserAgent(NPP instance);
|
|
||||||
void* NP_LOADDS NPN_MemAlloc(uint32_t size);
|
|
||||||
void NP_LOADDS NPN_MemFree(void* ptr);
|
|
||||||
uint32_t NP_LOADDS NPN_MemFlush(uint32_t size);
|
|
||||||
void NP_LOADDS NPN_ReloadPlugins(NPBool reloadPages);
|
|
||||||
NPError NP_LOADDS NPN_GetValue(NPP instance, NPNVariable variable,
|
|
||||||
void *value);
|
|
||||||
NPError NP_LOADDS NPN_SetValue(NPP instance, NPPVariable variable,
|
|
||||||
void *value);
|
|
||||||
void NP_LOADDS NPN_InvalidateRect(NPP instance, NPRect *invalidRect);
|
|
||||||
void NP_LOADDS NPN_InvalidateRegion(NPP instance,
|
|
||||||
NPRegion invalidRegion);
|
|
||||||
void NP_LOADDS NPN_ForceRedraw(NPP instance);
|
|
||||||
void NP_LOADDS NPN_PushPopupsEnabledState(NPP instance, NPBool enabled);
|
|
||||||
void NP_LOADDS NPN_PopPopupsEnabledState(NPP instance);
|
|
||||||
void NP_LOADDS NPN_PluginThreadAsyncCall(NPP instance,
|
|
||||||
void (*func) (void *),
|
|
||||||
void *userData);
|
|
||||||
NPError NP_LOADDS NPN_GetValueForURL(NPP instance, NPNURLVariable variable,
|
|
||||||
const char *url, char **value,
|
|
||||||
uint32_t *len);
|
|
||||||
NPError NP_LOADDS NPN_SetValueForURL(NPP instance, NPNURLVariable variable,
|
|
||||||
const char *url, const char *value,
|
|
||||||
uint32_t len);
|
|
||||||
NPError NP_LOADDS NPN_GetAuthenticationInfo(NPP instance,
|
|
||||||
const char *protocol,
|
|
||||||
const char *host, int32_t port,
|
|
||||||
const char *scheme,
|
|
||||||
const char *realm,
|
|
||||||
char **username, uint32_t *ulen,
|
|
||||||
char **password,
|
|
||||||
uint32_t *plen);
|
|
||||||
uint32_t NP_LOADDS NPN_ScheduleTimer(NPP instance, uint32_t interval, NPBool repeat, void (*timerFunc)(NPP npp, uint32_t timerID));
|
|
||||||
void NP_LOADDS NPN_UnscheduleTimer(NPP instance, uint32_t timerID);
|
|
||||||
NPError NP_LOADDS NPN_PopUpContextMenu(NPP instance, NPMenu* menu);
|
|
||||||
NPBool NP_LOADDS NPN_ConvertPoint(NPP instance, double sourceX, double sourceY, NPCoordinateSpace sourceSpace, double *destX, double *destY, NPCoordinateSpace destSpace);
|
|
||||||
NPBool NP_LOADDS NPN_HandleEvent(NPP instance, void *event, NPBool handled);
|
|
||||||
NPBool NP_LOADDS NPN_UnfocusInstance(NPP instance, NPFocusDirection direction);
|
|
||||||
void NP_LOADDS NPN_URLRedirectResponse(NPP instance, void* notifyData, NPBool allow);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
} /* end extern "C" */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* RC_INVOKED */
|
|
||||||
#if defined(__OS2__)
|
|
||||||
#pragma pack()
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* npapi_h_ */
|
|
@ -1,322 +0,0 @@
|
|||||||
/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
||||||
/* ***** BEGIN LICENSE BLOCK *****
|
|
||||||
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
||||||
*
|
|
||||||
* The contents of this file are subject to the Mozilla Public License Version
|
|
||||||
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
||||||
* the License. You may obtain a copy of the License at
|
|
||||||
* http://www.mozilla.org/MPL/
|
|
||||||
*
|
|
||||||
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
||||||
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
||||||
* for the specific language governing rights and limitations under the
|
|
||||||
* License.
|
|
||||||
*
|
|
||||||
* The Original Code is mozilla.org code.
|
|
||||||
*
|
|
||||||
* The Initial Developer of the Original Code is
|
|
||||||
* Netscape Communications Corporation.
|
|
||||||
* Portions created by the Initial Developer are Copyright (C) 1998
|
|
||||||
* the Initial Developer. All Rights Reserved.
|
|
||||||
*
|
|
||||||
* Contributor(s):
|
|
||||||
*
|
|
||||||
* Alternatively, the contents of this file may be used under the terms of
|
|
||||||
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
||||||
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
||||||
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
||||||
* of those above. If you wish to allow use of your version of this file only
|
|
||||||
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
||||||
* use your version of this file under the terms of the MPL, indicate your
|
|
||||||
* decision by deleting the provisions above and replace them with the notice
|
|
||||||
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
||||||
* the provisions above, a recipient may use your version of this file under
|
|
||||||
* the terms of any one of the MPL, the GPL or the LGPL.
|
|
||||||
*
|
|
||||||
* ***** END LICENSE BLOCK ***** */
|
|
||||||
|
|
||||||
#ifndef npfunctions_h_
|
|
||||||
#define npfunctions_h_
|
|
||||||
|
|
||||||
#ifdef __OS2__
|
|
||||||
#pragma pack(1)
|
|
||||||
#define NP_LOADDS _System
|
|
||||||
#else
|
|
||||||
#define NP_LOADDS
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "npapi.h"
|
|
||||||
#include "npruntime.h"
|
|
||||||
|
|
||||||
typedef NPError (* NP_LOADDS NPP_NewProcPtr)(NPMIMEType pluginType, NPP instance, uint16_t mode, int16_t argc, char* argn[], char* argv[], NPSavedData* saved);
|
|
||||||
typedef NPError (* NP_LOADDS NPP_DestroyProcPtr)(NPP instance, NPSavedData** save);
|
|
||||||
typedef NPError (* NP_LOADDS NPP_SetWindowProcPtr)(NPP instance, NPWindow* window);
|
|
||||||
typedef NPError (* NP_LOADDS NPP_NewStreamProcPtr)(NPP instance, NPMIMEType type, NPStream* stream, NPBool seekable, uint16_t* stype);
|
|
||||||
typedef NPError (* NP_LOADDS NPP_DestroyStreamProcPtr)(NPP instance, NPStream* stream, NPReason reason);
|
|
||||||
typedef int32_t (* NP_LOADDS NPP_WriteReadyProcPtr)(NPP instance, NPStream* stream);
|
|
||||||
typedef int32_t (* NP_LOADDS NPP_WriteProcPtr)(NPP instance, NPStream* stream, int32_t offset, int32_t len, void* buffer);
|
|
||||||
typedef void (* NP_LOADDS NPP_StreamAsFileProcPtr)(NPP instance, NPStream* stream, const char* fname);
|
|
||||||
typedef void (* NP_LOADDS NPP_PrintProcPtr)(NPP instance, NPPrint* platformPrint);
|
|
||||||
typedef int16_t (* NP_LOADDS NPP_HandleEventProcPtr)(NPP instance, void* event);
|
|
||||||
typedef void (* NP_LOADDS NPP_URLNotifyProcPtr)(NPP instance, const char* url, NPReason reason, void* notifyData);
|
|
||||||
/* Any NPObjects returned to the browser via NPP_GetValue should be retained
|
|
||||||
by the plugin on the way out. The browser is responsible for releasing. */
|
|
||||||
typedef NPError (* NP_LOADDS NPP_GetValueProcPtr)(NPP instance, NPPVariable variable, void *ret_value);
|
|
||||||
typedef NPError (* NP_LOADDS NPP_SetValueProcPtr)(NPP instance, NPNVariable variable, void *value);
|
|
||||||
typedef NPBool (* NP_LOADDS NPP_GotFocusPtr)(NPP instance, NPFocusDirection direction);
|
|
||||||
typedef void (* NP_LOADDS NPP_LostFocusPtr)(NPP instance);
|
|
||||||
typedef void (* NP_LOADDS NPP_URLRedirectNotifyPtr)(NPP instance, const char* url, int32_t status, void* notifyData);
|
|
||||||
typedef NPError (* NP_LOADDS NPP_ClearSiteDataPtr)(const char* site, uint64_t flags, uint64_t maxAge);
|
|
||||||
typedef char** (* NP_LOADDS NPP_GetSitesWithDataPtr)(void);
|
|
||||||
|
|
||||||
typedef NPError (*NPN_GetValueProcPtr)(NPP instance, NPNVariable variable, void *ret_value);
|
|
||||||
typedef NPError (*NPN_SetValueProcPtr)(NPP instance, NPPVariable variable, void *value);
|
|
||||||
typedef NPError (*NPN_GetURLNotifyProcPtr)(NPP instance, const char* url, const char* window, void* notifyData);
|
|
||||||
typedef NPError (*NPN_PostURLNotifyProcPtr)(NPP instance, const char* url, const char* window, uint32_t len, const char* buf, NPBool file, void* notifyData);
|
|
||||||
typedef NPError (*NPN_GetURLProcPtr)(NPP instance, const char* url, const char* window);
|
|
||||||
typedef NPError (*NPN_PostURLProcPtr)(NPP instance, const char* url, const char* window, uint32_t len, const char* buf, NPBool file);
|
|
||||||
typedef NPError (*NPN_RequestReadProcPtr)(NPStream* stream, NPByteRange* rangeList);
|
|
||||||
typedef NPError (*NPN_NewStreamProcPtr)(NPP instance, NPMIMEType type, const char* window, NPStream** stream);
|
|
||||||
typedef int32_t (*NPN_WriteProcPtr)(NPP instance, NPStream* stream, int32_t len, void* buffer);
|
|
||||||
typedef NPError (*NPN_DestroyStreamProcPtr)(NPP instance, NPStream* stream, NPReason reason);
|
|
||||||
typedef void (*NPN_StatusProcPtr)(NPP instance, const char* message);
|
|
||||||
/* Browser manages the lifetime of the buffer returned by NPN_UserAgent, don't
|
|
||||||
depend on it sticking around and don't free it. */
|
|
||||||
typedef const char* (*NPN_UserAgentProcPtr)(NPP instance);
|
|
||||||
typedef void* (*NPN_MemAllocProcPtr)(uint32_t size);
|
|
||||||
typedef void (*NPN_MemFreeProcPtr)(void* ptr);
|
|
||||||
typedef uint32_t (*NPN_MemFlushProcPtr)(uint32_t size);
|
|
||||||
typedef void (*NPN_ReloadPluginsProcPtr)(NPBool reloadPages);
|
|
||||||
typedef void* (*NPN_GetJavaEnvProcPtr)(void);
|
|
||||||
typedef void* (*NPN_GetJavaPeerProcPtr)(NPP instance);
|
|
||||||
typedef void (*NPN_InvalidateRectProcPtr)(NPP instance, NPRect *rect);
|
|
||||||
typedef void (*NPN_InvalidateRegionProcPtr)(NPP instance, NPRegion region);
|
|
||||||
typedef void (*NPN_ForceRedrawProcPtr)(NPP instance);
|
|
||||||
typedef NPIdentifier (*NPN_GetStringIdentifierProcPtr)(const NPUTF8* name);
|
|
||||||
typedef void (*NPN_GetStringIdentifiersProcPtr)(const NPUTF8** names, int32_t nameCount, NPIdentifier* identifiers);
|
|
||||||
typedef NPIdentifier (*NPN_GetIntIdentifierProcPtr)(int32_t intid);
|
|
||||||
typedef bool (*NPN_IdentifierIsStringProcPtr)(NPIdentifier identifier);
|
|
||||||
typedef NPUTF8* (*NPN_UTF8FromIdentifierProcPtr)(NPIdentifier identifier);
|
|
||||||
typedef int32_t (*NPN_IntFromIdentifierProcPtr)(NPIdentifier identifier);
|
|
||||||
typedef NPObject* (*NPN_CreateObjectProcPtr)(NPP npp, NPClass *aClass);
|
|
||||||
typedef NPObject* (*NPN_RetainObjectProcPtr)(NPObject *obj);
|
|
||||||
typedef void (*NPN_ReleaseObjectProcPtr)(NPObject *obj);
|
|
||||||
typedef bool (*NPN_InvokeProcPtr)(NPP npp, NPObject* obj, NPIdentifier methodName, const NPVariant *args, uint32_t argCount, NPVariant *result);
|
|
||||||
typedef bool (*NPN_InvokeDefaultProcPtr)(NPP npp, NPObject* obj, const NPVariant *args, uint32_t argCount, NPVariant *result);
|
|
||||||
typedef bool (*NPN_EvaluateProcPtr)(NPP npp, NPObject *obj, NPString *script, NPVariant *result);
|
|
||||||
typedef bool (*NPN_GetPropertyProcPtr)(NPP npp, NPObject *obj, NPIdentifier propertyName, NPVariant *result);
|
|
||||||
typedef bool (*NPN_SetPropertyProcPtr)(NPP npp, NPObject *obj, NPIdentifier propertyName, const NPVariant *value);
|
|
||||||
typedef bool (*NPN_RemovePropertyProcPtr)(NPP npp, NPObject *obj, NPIdentifier propertyName);
|
|
||||||
typedef bool (*NPN_HasPropertyProcPtr)(NPP npp, NPObject *obj, NPIdentifier propertyName);
|
|
||||||
typedef bool (*NPN_HasMethodProcPtr)(NPP npp, NPObject *obj, NPIdentifier propertyName);
|
|
||||||
typedef void (*NPN_ReleaseVariantValueProcPtr)(NPVariant *variant);
|
|
||||||
typedef void (*NPN_SetExceptionProcPtr)(NPObject *obj, const NPUTF8 *message);
|
|
||||||
typedef void (*NPN_PushPopupsEnabledStateProcPtr)(NPP npp, NPBool enabled);
|
|
||||||
typedef void (*NPN_PopPopupsEnabledStateProcPtr)(NPP npp);
|
|
||||||
typedef bool (*NPN_EnumerateProcPtr)(NPP npp, NPObject *obj, NPIdentifier **identifier, uint32_t *count);
|
|
||||||
typedef void (*NPN_PluginThreadAsyncCallProcPtr)(NPP instance, void (*func)(void *), void *userData);
|
|
||||||
typedef bool (*NPN_ConstructProcPtr)(NPP npp, NPObject* obj, const NPVariant *args, uint32_t argCount, NPVariant *result);
|
|
||||||
typedef NPError (*NPN_GetValueForURLPtr)(NPP npp, NPNURLVariable variable, const char *url, char **value, uint32_t *len);
|
|
||||||
typedef NPError (*NPN_SetValueForURLPtr)(NPP npp, NPNURLVariable variable, const char *url, const char *value, uint32_t len);
|
|
||||||
typedef NPError (*NPN_GetAuthenticationInfoPtr)(NPP npp, const char *protocol, const char *host, int32_t port, const char *scheme, const char *realm, char **username, uint32_t *ulen, char **password, uint32_t *plen);
|
|
||||||
typedef uint32_t (*NPN_ScheduleTimerPtr)(NPP instance, uint32_t interval, NPBool repeat, void (*timerFunc)(NPP npp, uint32_t timerID));
|
|
||||||
typedef void (*NPN_UnscheduleTimerPtr)(NPP instance, uint32_t timerID);
|
|
||||||
typedef NPError (*NPN_PopUpContextMenuPtr)(NPP instance, NPMenu* menu);
|
|
||||||
typedef NPBool (*NPN_ConvertPointPtr)(NPP instance, double sourceX, double sourceY, NPCoordinateSpace sourceSpace, double *destX, double *destY, NPCoordinateSpace destSpace);
|
|
||||||
typedef NPBool (*NPN_HandleEventPtr)(NPP instance, void *event, NPBool handled);
|
|
||||||
typedef NPBool (*NPN_UnfocusInstancePtr)(NPP instance, NPFocusDirection direction);
|
|
||||||
typedef void (*NPN_URLRedirectResponsePtr)(NPP instance, void* notifyData, NPBool allow);
|
|
||||||
|
|
||||||
typedef struct _NPPluginFuncs {
|
|
||||||
uint16_t size;
|
|
||||||
uint16_t version;
|
|
||||||
NPP_NewProcPtr newp;
|
|
||||||
NPP_DestroyProcPtr destroy;
|
|
||||||
NPP_SetWindowProcPtr setwindow;
|
|
||||||
NPP_NewStreamProcPtr newstream;
|
|
||||||
NPP_DestroyStreamProcPtr destroystream;
|
|
||||||
NPP_StreamAsFileProcPtr asfile;
|
|
||||||
NPP_WriteReadyProcPtr writeready;
|
|
||||||
NPP_WriteProcPtr write;
|
|
||||||
NPP_PrintProcPtr print;
|
|
||||||
NPP_HandleEventProcPtr event;
|
|
||||||
NPP_URLNotifyProcPtr urlnotify;
|
|
||||||
void* javaClass;
|
|
||||||
NPP_GetValueProcPtr getvalue;
|
|
||||||
NPP_SetValueProcPtr setvalue;
|
|
||||||
NPP_GotFocusPtr gotfocus;
|
|
||||||
NPP_LostFocusPtr lostfocus;
|
|
||||||
NPP_URLRedirectNotifyPtr urlredirectnotify;
|
|
||||||
NPP_ClearSiteDataPtr clearsitedata;
|
|
||||||
NPP_GetSitesWithDataPtr getsiteswithdata;
|
|
||||||
} NPPluginFuncs;
|
|
||||||
|
|
||||||
typedef struct _NPNetscapeFuncs {
|
|
||||||
uint16_t size;
|
|
||||||
uint16_t version;
|
|
||||||
NPN_GetURLProcPtr geturl;
|
|
||||||
NPN_PostURLProcPtr posturl;
|
|
||||||
NPN_RequestReadProcPtr requestread;
|
|
||||||
NPN_NewStreamProcPtr newstream;
|
|
||||||
NPN_WriteProcPtr write;
|
|
||||||
NPN_DestroyStreamProcPtr destroystream;
|
|
||||||
NPN_StatusProcPtr status;
|
|
||||||
NPN_UserAgentProcPtr uagent;
|
|
||||||
NPN_MemAllocProcPtr memalloc;
|
|
||||||
NPN_MemFreeProcPtr memfree;
|
|
||||||
NPN_MemFlushProcPtr memflush;
|
|
||||||
NPN_ReloadPluginsProcPtr reloadplugins;
|
|
||||||
NPN_GetJavaEnvProcPtr getJavaEnv;
|
|
||||||
NPN_GetJavaPeerProcPtr getJavaPeer;
|
|
||||||
NPN_GetURLNotifyProcPtr geturlnotify;
|
|
||||||
NPN_PostURLNotifyProcPtr posturlnotify;
|
|
||||||
NPN_GetValueProcPtr getvalue;
|
|
||||||
NPN_SetValueProcPtr setvalue;
|
|
||||||
NPN_InvalidateRectProcPtr invalidaterect;
|
|
||||||
NPN_InvalidateRegionProcPtr invalidateregion;
|
|
||||||
NPN_ForceRedrawProcPtr forceredraw;
|
|
||||||
NPN_GetStringIdentifierProcPtr getstringidentifier;
|
|
||||||
NPN_GetStringIdentifiersProcPtr getstringidentifiers;
|
|
||||||
NPN_GetIntIdentifierProcPtr getintidentifier;
|
|
||||||
NPN_IdentifierIsStringProcPtr identifierisstring;
|
|
||||||
NPN_UTF8FromIdentifierProcPtr utf8fromidentifier;
|
|
||||||
NPN_IntFromIdentifierProcPtr intfromidentifier;
|
|
||||||
NPN_CreateObjectProcPtr createobject;
|
|
||||||
NPN_RetainObjectProcPtr retainobject;
|
|
||||||
NPN_ReleaseObjectProcPtr releaseobject;
|
|
||||||
NPN_InvokeProcPtr invoke;
|
|
||||||
NPN_InvokeDefaultProcPtr invokeDefault;
|
|
||||||
NPN_EvaluateProcPtr evaluate;
|
|
||||||
NPN_GetPropertyProcPtr getproperty;
|
|
||||||
NPN_SetPropertyProcPtr setproperty;
|
|
||||||
NPN_RemovePropertyProcPtr removeproperty;
|
|
||||||
NPN_HasPropertyProcPtr hasproperty;
|
|
||||||
NPN_HasMethodProcPtr hasmethod;
|
|
||||||
NPN_ReleaseVariantValueProcPtr releasevariantvalue;
|
|
||||||
NPN_SetExceptionProcPtr setexception;
|
|
||||||
NPN_PushPopupsEnabledStateProcPtr pushpopupsenabledstate;
|
|
||||||
NPN_PopPopupsEnabledStateProcPtr poppopupsenabledstate;
|
|
||||||
NPN_EnumerateProcPtr enumerate;
|
|
||||||
NPN_PluginThreadAsyncCallProcPtr pluginthreadasynccall;
|
|
||||||
NPN_ConstructProcPtr construct;
|
|
||||||
NPN_GetValueForURLPtr getvalueforurl;
|
|
||||||
NPN_SetValueForURLPtr setvalueforurl;
|
|
||||||
NPN_GetAuthenticationInfoPtr getauthenticationinfo;
|
|
||||||
NPN_ScheduleTimerPtr scheduletimer;
|
|
||||||
NPN_UnscheduleTimerPtr unscheduletimer;
|
|
||||||
NPN_PopUpContextMenuPtr popupcontextmenu;
|
|
||||||
NPN_ConvertPointPtr convertpoint;
|
|
||||||
NPN_HandleEventPtr handleevent;
|
|
||||||
NPN_UnfocusInstancePtr unfocusinstance;
|
|
||||||
NPN_URLRedirectResponsePtr urlredirectresponse;
|
|
||||||
} NPNetscapeFuncs;
|
|
||||||
|
|
||||||
#ifdef XP_MACOSX
|
|
||||||
/*
|
|
||||||
* Mac OS X version(s) of NP_GetMIMEDescription(const char *)
|
|
||||||
* These can be called to retreive MIME information from the plugin dynamically
|
|
||||||
*
|
|
||||||
* Note: For compatibility with Quicktime, BPSupportedMIMEtypes is another way
|
|
||||||
* to get mime info from the plugin only on OSX and may not be supported
|
|
||||||
* in furture version -- use NP_GetMIMEDescription instead
|
|
||||||
*/
|
|
||||||
enum
|
|
||||||
{
|
|
||||||
kBPSupportedMIMETypesStructVers_1 = 1
|
|
||||||
};
|
|
||||||
typedef struct _BPSupportedMIMETypes
|
|
||||||
{
|
|
||||||
SInt32 structVersion; /* struct version */
|
|
||||||
Handle typeStrings; /* STR# formated handle, allocated by plug-in */
|
|
||||||
Handle infoStrings; /* STR# formated handle, allocated by plug-in */
|
|
||||||
} BPSupportedMIMETypes;
|
|
||||||
OSErr BP_GetSupportedMIMETypes(BPSupportedMIMETypes *mimeInfo, UInt32 flags);
|
|
||||||
#define NP_GETMIMEDESCRIPTION_NAME "NP_GetMIMEDescription"
|
|
||||||
typedef const char* (*NP_GetMIMEDescriptionProcPtr)(void);
|
|
||||||
typedef OSErr (*BP_GetSupportedMIMETypesProcPtr)(BPSupportedMIMETypes*, UInt32);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(_WIN32)
|
|
||||||
#define OSCALL WINAPI
|
|
||||||
#else
|
|
||||||
#if defined(__OS2__)
|
|
||||||
#define OSCALL _System
|
|
||||||
#else
|
|
||||||
#define OSCALL
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(XP_UNIX)
|
|
||||||
/* GCC 3.3 and later support the visibility attribute. */
|
|
||||||
#if defined(__GNUC__) && ((__GNUC__ >= 4) || (__GNUC__ == 3 && __GNUC_MINOR__ >= 3))
|
|
||||||
#define NP_VISIBILITY_DEFAULT __attribute__((visibility("default")))
|
|
||||||
#elif defined(__SUNPRO_C) || defined(__SUNPRO_CC)
|
|
||||||
#define NP_VISIBILITY_DEFAULT __global
|
|
||||||
#else
|
|
||||||
#define NP_VISIBILITY_DEFAULT
|
|
||||||
#endif
|
|
||||||
#define NP_EXPORT(__type) NP_VISIBILITY_DEFAULT __type
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(_WIN32) || defined (__OS2__)
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
/* plugin meta member functions */
|
|
||||||
#if defined(__OS2__)
|
|
||||||
typedef struct _NPPluginData { /* Alternate OS2 Plugin interface */
|
|
||||||
char *pMimeTypes;
|
|
||||||
char *pFileExtents;
|
|
||||||
char *pFileOpenTemplate;
|
|
||||||
char *pProductName;
|
|
||||||
char *pProductDescription;
|
|
||||||
unsigned long dwProductVersionMS;
|
|
||||||
unsigned long dwProductVersionLS;
|
|
||||||
} NPPluginData;
|
|
||||||
typedef NPError (*NP_GetPluginDataFunc)(NPPluginData*);
|
|
||||||
NPError OSCALL NP_GetPluginData(NPPluginData * pPluginData);
|
|
||||||
#endif
|
|
||||||
typedef NPError (*NP_GetEntryPointsFunc)(NPPluginFuncs*);
|
|
||||||
NPError OSCALL NP_GetEntryPoints(NPPluginFuncs* pFuncs);
|
|
||||||
typedef NPError (*NP_InitializeFunc)(NPNetscapeFuncs*);
|
|
||||||
NPError OSCALL NP_Initialize(NPNetscapeFuncs* bFuncs);
|
|
||||||
typedef NPError (*NP_ShutdownFunc)(void);
|
|
||||||
NPError OSCALL NP_Shutdown(void);
|
|
||||||
typedef const char* (*NP_GetMIMEDescriptionFunc)(void);
|
|
||||||
const char* NP_GetMIMEDescription(void);
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(__OS2__)
|
|
||||||
#pragma pack()
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef XP_UNIX
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
typedef char* (*NP_GetPluginVersionFunc)(void);
|
|
||||||
NP_EXPORT(char*) NP_GetPluginVersion(void);
|
|
||||||
typedef const char* (*NP_GetMIMEDescriptionFunc)(void);
|
|
||||||
NP_EXPORT(const char*) NP_GetMIMEDescription(void);
|
|
||||||
#ifdef XP_MACOSX
|
|
||||||
typedef NPError (*NP_InitializeFunc)(NPNetscapeFuncs*);
|
|
||||||
NP_EXPORT(NPError) NP_Initialize(NPNetscapeFuncs* bFuncs);
|
|
||||||
typedef NPError (*NP_GetEntryPointsFunc)(NPPluginFuncs*);
|
|
||||||
NP_EXPORT(NPError) NP_GetEntryPoints(NPPluginFuncs* pFuncs);
|
|
||||||
#else
|
|
||||||
typedef NPError (*NP_InitializeFunc)(NPNetscapeFuncs*, NPPluginFuncs*);
|
|
||||||
NP_EXPORT(NPError) NP_Initialize(NPNetscapeFuncs* bFuncs, NPPluginFuncs* pFuncs);
|
|
||||||
#endif
|
|
||||||
typedef NPError (*NP_ShutdownFunc)(void);
|
|
||||||
NP_EXPORT(NPError) NP_Shutdown(void);
|
|
||||||
typedef NPError (*NP_GetValueFunc)(void *, NPPVariable, void *);
|
|
||||||
NP_EXPORT(NPError) NP_GetValue(void *future, NPPVariable aVariable, void *aValue);
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* npfunctions_h_ */
|
|
@ -1,393 +0,0 @@
|
|||||||
/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
||||||
/*
|
|
||||||
* Copyright (c) 2004, Apple Computer, Inc. and The Mozilla Foundation.
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions are
|
|
||||||
* met:
|
|
||||||
*
|
|
||||||
* 1. Redistributions of source code must retain the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer.
|
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
* 3. Neither the names of Apple Computer, Inc. ("Apple") or The Mozilla
|
|
||||||
* Foundation ("Mozilla") nor the names of their contributors may be used
|
|
||||||
* to endorse or promote products derived from this software without
|
|
||||||
* specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY APPLE, MOZILLA AND THEIR CONTRIBUTORS "AS
|
|
||||||
* IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
|
||||||
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
|
|
||||||
* PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE, MOZILLA OR
|
|
||||||
* THEIR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
|
|
||||||
* TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
|
||||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
|
||||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
|
||||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
||||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
#ifndef _NP_RUNTIME_H_
|
|
||||||
#define _NP_RUNTIME_H_
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "nptypes.h"
|
|
||||||
|
|
||||||
/*
|
|
||||||
This API is used to facilitate binding code written in C to script
|
|
||||||
objects. The API in this header does not assume the presence of a
|
|
||||||
user agent. That is, it can be used to bind C code to scripting
|
|
||||||
environments outside of the context of a user agent.
|
|
||||||
|
|
||||||
However, the normal use of the this API is in the context of a
|
|
||||||
scripting environment running in a browser or other user agent.
|
|
||||||
In particular it is used to support the extended Netscape
|
|
||||||
script-ability API for plugins (NP-SAP). NP-SAP is an extension
|
|
||||||
of the Netscape plugin API. As such we have adopted the use of
|
|
||||||
the "NP" prefix for this API.
|
|
||||||
|
|
||||||
The following NP{N|P}Variables were added to the Netscape plugin
|
|
||||||
API (in npapi.h):
|
|
||||||
|
|
||||||
NPNVWindowNPObject
|
|
||||||
NPNVPluginElementNPObject
|
|
||||||
NPPVpluginScriptableNPObject
|
|
||||||
|
|
||||||
These variables are exposed through NPN_GetValue() and
|
|
||||||
NPP_GetValue() (respectively) and are used to establish the
|
|
||||||
initial binding between the user agent and native code. The DOM
|
|
||||||
objects in the user agent can be examined and manipulated using
|
|
||||||
the NPN_ functions that operate on NPObjects described in this
|
|
||||||
header.
|
|
||||||
|
|
||||||
To the extent possible the assumptions about the scripting
|
|
||||||
language used by the scripting environment have been minimized.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define NP_BEGIN_MACRO do {
|
|
||||||
#define NP_END_MACRO } while (0)
|
|
||||||
|
|
||||||
/*
|
|
||||||
Objects (non-primitive data) passed between 'C' and script is
|
|
||||||
always wrapped in an NPObject. The 'interface' of an NPObject is
|
|
||||||
described by an NPClass.
|
|
||||||
*/
|
|
||||||
typedef struct NPObject NPObject;
|
|
||||||
typedef struct NPClass NPClass;
|
|
||||||
|
|
||||||
typedef char NPUTF8;
|
|
||||||
typedef struct _NPString {
|
|
||||||
const NPUTF8 *UTF8Characters;
|
|
||||||
uint32_t UTF8Length;
|
|
||||||
} NPString;
|
|
||||||
|
|
||||||
typedef enum {
|
|
||||||
NPVariantType_Void,
|
|
||||||
NPVariantType_Null,
|
|
||||||
NPVariantType_Bool,
|
|
||||||
NPVariantType_Int32,
|
|
||||||
NPVariantType_Double,
|
|
||||||
NPVariantType_String,
|
|
||||||
NPVariantType_Object
|
|
||||||
} NPVariantType;
|
|
||||||
|
|
||||||
typedef struct _NPVariant {
|
|
||||||
NPVariantType type;
|
|
||||||
union {
|
|
||||||
bool boolValue;
|
|
||||||
int32_t intValue;
|
|
||||||
double doubleValue;
|
|
||||||
NPString stringValue;
|
|
||||||
NPObject *objectValue;
|
|
||||||
} value;
|
|
||||||
} NPVariant;
|
|
||||||
|
|
||||||
/*
|
|
||||||
NPN_ReleaseVariantValue is called on all 'out' parameters
|
|
||||||
references. Specifically it is to be called on variants that own
|
|
||||||
their value, as is the case with all non-const NPVariant*
|
|
||||||
arguments after a successful call to any methods (except this one)
|
|
||||||
in this API.
|
|
||||||
|
|
||||||
After calling NPN_ReleaseVariantValue, the type of the variant
|
|
||||||
will be NPVariantType_Void.
|
|
||||||
*/
|
|
||||||
void NPN_ReleaseVariantValue(NPVariant *variant);
|
|
||||||
|
|
||||||
#define NPVARIANT_IS_VOID(_v) ((_v).type == NPVariantType_Void)
|
|
||||||
#define NPVARIANT_IS_NULL(_v) ((_v).type == NPVariantType_Null)
|
|
||||||
#define NPVARIANT_IS_BOOLEAN(_v) ((_v).type == NPVariantType_Bool)
|
|
||||||
#define NPVARIANT_IS_INT32(_v) ((_v).type == NPVariantType_Int32)
|
|
||||||
#define NPVARIANT_IS_DOUBLE(_v) ((_v).type == NPVariantType_Double)
|
|
||||||
#define NPVARIANT_IS_STRING(_v) ((_v).type == NPVariantType_String)
|
|
||||||
#define NPVARIANT_IS_OBJECT(_v) ((_v).type == NPVariantType_Object)
|
|
||||||
|
|
||||||
#define NPVARIANT_TO_BOOLEAN(_v) ((_v).value.boolValue)
|
|
||||||
#define NPVARIANT_TO_INT32(_v) ((_v).value.intValue)
|
|
||||||
#define NPVARIANT_TO_DOUBLE(_v) ((_v).value.doubleValue)
|
|
||||||
#define NPVARIANT_TO_STRING(_v) ((_v).value.stringValue)
|
|
||||||
#define NPVARIANT_TO_OBJECT(_v) ((_v).value.objectValue)
|
|
||||||
|
|
||||||
#define VOID_TO_NPVARIANT(_v) \
|
|
||||||
NP_BEGIN_MACRO \
|
|
||||||
(_v).type = NPVariantType_Void; \
|
|
||||||
(_v).value.objectValue = NULL; \
|
|
||||||
NP_END_MACRO
|
|
||||||
|
|
||||||
#define NULL_TO_NPVARIANT(_v) \
|
|
||||||
NP_BEGIN_MACRO \
|
|
||||||
(_v).type = NPVariantType_Null; \
|
|
||||||
(_v).value.objectValue = NULL; \
|
|
||||||
NP_END_MACRO
|
|
||||||
|
|
||||||
#define BOOLEAN_TO_NPVARIANT(_val, _v) \
|
|
||||||
NP_BEGIN_MACRO \
|
|
||||||
(_v).type = NPVariantType_Bool; \
|
|
||||||
(_v).value.boolValue = !!(_val); \
|
|
||||||
NP_END_MACRO
|
|
||||||
|
|
||||||
#define INT32_TO_NPVARIANT(_val, _v) \
|
|
||||||
NP_BEGIN_MACRO \
|
|
||||||
(_v).type = NPVariantType_Int32; \
|
|
||||||
(_v).value.intValue = _val; \
|
|
||||||
NP_END_MACRO
|
|
||||||
|
|
||||||
#define DOUBLE_TO_NPVARIANT(_val, _v) \
|
|
||||||
NP_BEGIN_MACRO \
|
|
||||||
(_v).type = NPVariantType_Double; \
|
|
||||||
(_v).value.doubleValue = _val; \
|
|
||||||
NP_END_MACRO
|
|
||||||
|
|
||||||
#define STRINGZ_TO_NPVARIANT(_val, _v) \
|
|
||||||
NP_BEGIN_MACRO \
|
|
||||||
(_v).type = NPVariantType_String; \
|
|
||||||
NPString str = { _val, (uint32_t)(strlen(_val)) }; \
|
|
||||||
(_v).value.stringValue = str; \
|
|
||||||
NP_END_MACRO
|
|
||||||
|
|
||||||
#define STRINGN_TO_NPVARIANT(_val, _len, _v) \
|
|
||||||
NP_BEGIN_MACRO \
|
|
||||||
(_v).type = NPVariantType_String; \
|
|
||||||
NPString str = { _val, (uint32_t)(_len) }; \
|
|
||||||
(_v).value.stringValue = str; \
|
|
||||||
NP_END_MACRO
|
|
||||||
|
|
||||||
#define OBJECT_TO_NPVARIANT(_val, _v) \
|
|
||||||
NP_BEGIN_MACRO \
|
|
||||||
(_v).type = NPVariantType_Object; \
|
|
||||||
(_v).value.objectValue = _val; \
|
|
||||||
NP_END_MACRO
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
Type mappings (JavaScript types have been used for illustration
|
|
||||||
purposes):
|
|
||||||
|
|
||||||
JavaScript to C (NPVariant with type:)
|
|
||||||
undefined NPVariantType_Void
|
|
||||||
null NPVariantType_Null
|
|
||||||
Boolean NPVariantType_Bool
|
|
||||||
Number NPVariantType_Double or NPVariantType_Int32
|
|
||||||
String NPVariantType_String
|
|
||||||
Object NPVariantType_Object
|
|
||||||
|
|
||||||
C (NPVariant with type:) to JavaScript
|
|
||||||
NPVariantType_Void undefined
|
|
||||||
NPVariantType_Null null
|
|
||||||
NPVariantType_Bool Boolean
|
|
||||||
NPVariantType_Int32 Number
|
|
||||||
NPVariantType_Double Number
|
|
||||||
NPVariantType_String String
|
|
||||||
NPVariantType_Object Object
|
|
||||||
*/
|
|
||||||
|
|
||||||
typedef void *NPIdentifier;
|
|
||||||
|
|
||||||
/*
|
|
||||||
NPObjects have methods and properties. Methods and properties are
|
|
||||||
identified with NPIdentifiers. These identifiers may be reflected
|
|
||||||
in script. NPIdentifiers can be either strings or integers, IOW,
|
|
||||||
methods and properties can be identified by either strings or
|
|
||||||
integers (i.e. foo["bar"] vs foo[1]). NPIdentifiers can be
|
|
||||||
compared using ==. In case of any errors, the requested
|
|
||||||
NPIdentifier(s) will be NULL. NPIdentifier lifetime is controlled
|
|
||||||
by the browser. Plugins do not need to worry about memory management
|
|
||||||
with regards to NPIdentifiers.
|
|
||||||
*/
|
|
||||||
NPIdentifier NPN_GetStringIdentifier(const NPUTF8 *name);
|
|
||||||
void NPN_GetStringIdentifiers(const NPUTF8 **names, int32_t nameCount,
|
|
||||||
NPIdentifier *identifiers);
|
|
||||||
NPIdentifier NPN_GetIntIdentifier(int32_t intid);
|
|
||||||
bool NPN_IdentifierIsString(NPIdentifier identifier);
|
|
||||||
|
|
||||||
/*
|
|
||||||
The NPUTF8 returned from NPN_UTF8FromIdentifier SHOULD be freed.
|
|
||||||
*/
|
|
||||||
NPUTF8 *NPN_UTF8FromIdentifier(NPIdentifier identifier);
|
|
||||||
|
|
||||||
/*
|
|
||||||
Get the integer represented by identifier. If identifier is not an
|
|
||||||
integer identifier, the behaviour is undefined.
|
|
||||||
*/
|
|
||||||
int32_t NPN_IntFromIdentifier(NPIdentifier identifier);
|
|
||||||
|
|
||||||
/*
|
|
||||||
NPObject behavior is implemented using the following set of
|
|
||||||
callback functions.
|
|
||||||
|
|
||||||
The NPVariant *result argument of these functions (where
|
|
||||||
applicable) should be released using NPN_ReleaseVariantValue().
|
|
||||||
*/
|
|
||||||
typedef NPObject *(*NPAllocateFunctionPtr)(NPP npp, NPClass *aClass);
|
|
||||||
typedef void (*NPDeallocateFunctionPtr)(NPObject *npobj);
|
|
||||||
typedef void (*NPInvalidateFunctionPtr)(NPObject *npobj);
|
|
||||||
typedef bool (*NPHasMethodFunctionPtr)(NPObject *npobj, NPIdentifier name);
|
|
||||||
typedef bool (*NPInvokeFunctionPtr)(NPObject *npobj, NPIdentifier name,
|
|
||||||
const NPVariant *args, uint32_t argCount,
|
|
||||||
NPVariant *result);
|
|
||||||
typedef bool (*NPInvokeDefaultFunctionPtr)(NPObject *npobj,
|
|
||||||
const NPVariant *args,
|
|
||||||
uint32_t argCount,
|
|
||||||
NPVariant *result);
|
|
||||||
typedef bool (*NPHasPropertyFunctionPtr)(NPObject *npobj, NPIdentifier name);
|
|
||||||
typedef bool (*NPGetPropertyFunctionPtr)(NPObject *npobj, NPIdentifier name,
|
|
||||||
NPVariant *result);
|
|
||||||
typedef bool (*NPSetPropertyFunctionPtr)(NPObject *npobj, NPIdentifier name,
|
|
||||||
const NPVariant *value);
|
|
||||||
typedef bool (*NPRemovePropertyFunctionPtr)(NPObject *npobj,
|
|
||||||
NPIdentifier name);
|
|
||||||
typedef bool (*NPEnumerationFunctionPtr)(NPObject *npobj, NPIdentifier **value,
|
|
||||||
uint32_t *count);
|
|
||||||
typedef bool (*NPConstructFunctionPtr)(NPObject *npobj,
|
|
||||||
const NPVariant *args,
|
|
||||||
uint32_t argCount,
|
|
||||||
NPVariant *result);
|
|
||||||
|
|
||||||
/*
|
|
||||||
NPObjects returned by create, retain, invoke, and getProperty pass
|
|
||||||
a reference count to the caller. That is, the callee adds a
|
|
||||||
reference count which passes to the caller. It is the caller's
|
|
||||||
responsibility to release the returned object.
|
|
||||||
|
|
||||||
NPInvokeFunctionPtr function may return 0 to indicate a void
|
|
||||||
result.
|
|
||||||
|
|
||||||
NPInvalidateFunctionPtr is called by the scripting environment
|
|
||||||
when the native code is shutdown. Any attempt to message a
|
|
||||||
NPObject instance after the invalidate callback has been
|
|
||||||
called will result in undefined behavior, even if the native code
|
|
||||||
is still retaining those NPObject instances. (The runtime
|
|
||||||
will typically return immediately, with 0 or NULL, from an attempt
|
|
||||||
to dispatch to a NPObject, but this behavior should not be
|
|
||||||
depended upon.)
|
|
||||||
|
|
||||||
The NPEnumerationFunctionPtr function may pass an array of
|
|
||||||
NPIdentifiers back to the caller. The callee allocs the memory of
|
|
||||||
the array using NPN_MemAlloc(), and it's the caller's responsibility
|
|
||||||
to release it using NPN_MemFree().
|
|
||||||
*/
|
|
||||||
struct NPClass
|
|
||||||
{
|
|
||||||
uint32_t structVersion;
|
|
||||||
NPAllocateFunctionPtr allocate;
|
|
||||||
NPDeallocateFunctionPtr deallocate;
|
|
||||||
NPInvalidateFunctionPtr invalidate;
|
|
||||||
NPHasMethodFunctionPtr hasMethod;
|
|
||||||
NPInvokeFunctionPtr invoke;
|
|
||||||
NPInvokeDefaultFunctionPtr invokeDefault;
|
|
||||||
NPHasPropertyFunctionPtr hasProperty;
|
|
||||||
NPGetPropertyFunctionPtr getProperty;
|
|
||||||
NPSetPropertyFunctionPtr setProperty;
|
|
||||||
NPRemovePropertyFunctionPtr removeProperty;
|
|
||||||
NPEnumerationFunctionPtr enumerate;
|
|
||||||
NPConstructFunctionPtr construct;
|
|
||||||
};
|
|
||||||
|
|
||||||
#define NP_CLASS_STRUCT_VERSION 3
|
|
||||||
|
|
||||||
#define NP_CLASS_STRUCT_VERSION_ENUM 2
|
|
||||||
#define NP_CLASS_STRUCT_VERSION_CTOR 3
|
|
||||||
|
|
||||||
#define NP_CLASS_STRUCT_VERSION_HAS_ENUM(npclass) \
|
|
||||||
((npclass)->structVersion >= NP_CLASS_STRUCT_VERSION_ENUM)
|
|
||||||
|
|
||||||
#define NP_CLASS_STRUCT_VERSION_HAS_CTOR(npclass) \
|
|
||||||
((npclass)->structVersion >= NP_CLASS_STRUCT_VERSION_CTOR)
|
|
||||||
|
|
||||||
struct NPObject {
|
|
||||||
NPClass *_class;
|
|
||||||
uint32_t referenceCount;
|
|
||||||
/*
|
|
||||||
* Additional space may be allocated here by types of NPObjects
|
|
||||||
*/
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
|
||||||
If the class has an allocate function, NPN_CreateObject invokes
|
|
||||||
that function, otherwise a NPObject is allocated and
|
|
||||||
returned. This method will initialize the referenceCount member of
|
|
||||||
the NPObject to 1.
|
|
||||||
*/
|
|
||||||
NPObject *NPN_CreateObject(NPP npp, NPClass *aClass);
|
|
||||||
|
|
||||||
/*
|
|
||||||
Increment the NPObject's reference count.
|
|
||||||
*/
|
|
||||||
NPObject *NPN_RetainObject(NPObject *npobj);
|
|
||||||
|
|
||||||
/*
|
|
||||||
Decremented the NPObject's reference count. If the reference
|
|
||||||
count goes to zero, the class's destroy function is invoke if
|
|
||||||
specified, otherwise the object is freed directly.
|
|
||||||
*/
|
|
||||||
void NPN_ReleaseObject(NPObject *npobj);
|
|
||||||
|
|
||||||
/*
|
|
||||||
Functions to access script objects represented by NPObject.
|
|
||||||
|
|
||||||
Calls to script objects are synchronous. If a function returns a
|
|
||||||
value, it will be supplied via the result NPVariant
|
|
||||||
argument. Successful calls will return true, false will be
|
|
||||||
returned in case of an error.
|
|
||||||
|
|
||||||
Calls made from plugin code to script must be made from the thread
|
|
||||||
on which the plugin was initialized.
|
|
||||||
*/
|
|
||||||
|
|
||||||
bool NPN_Invoke(NPP npp, NPObject *npobj, NPIdentifier methodName,
|
|
||||||
const NPVariant *args, uint32_t argCount, NPVariant *result);
|
|
||||||
bool NPN_InvokeDefault(NPP npp, NPObject *npobj, const NPVariant *args,
|
|
||||||
uint32_t argCount, NPVariant *result);
|
|
||||||
bool NPN_Evaluate(NPP npp, NPObject *npobj, NPString *script,
|
|
||||||
NPVariant *result);
|
|
||||||
bool NPN_GetProperty(NPP npp, NPObject *npobj, NPIdentifier propertyName,
|
|
||||||
NPVariant *result);
|
|
||||||
bool NPN_SetProperty(NPP npp, NPObject *npobj, NPIdentifier propertyName,
|
|
||||||
const NPVariant *value);
|
|
||||||
bool NPN_RemoveProperty(NPP npp, NPObject *npobj, NPIdentifier propertyName);
|
|
||||||
bool NPN_HasProperty(NPP npp, NPObject *npobj, NPIdentifier propertyName);
|
|
||||||
bool NPN_HasMethod(NPP npp, NPObject *npobj, NPIdentifier methodName);
|
|
||||||
bool NPN_Enumerate(NPP npp, NPObject *npobj, NPIdentifier **identifier,
|
|
||||||
uint32_t *count);
|
|
||||||
bool NPN_Construct(NPP npp, NPObject *npobj, const NPVariant *args,
|
|
||||||
uint32_t argCount, NPVariant *result);
|
|
||||||
|
|
||||||
/*
|
|
||||||
NPN_SetException may be called to trigger a script exception upon
|
|
||||||
return from entry points into NPObjects. Typical usage:
|
|
||||||
|
|
||||||
NPN_SetException (npobj, message);
|
|
||||||
*/
|
|
||||||
void NPN_SetException(NPObject *npobj, const NPUTF8 *message);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,121 +0,0 @@
|
|||||||
/* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
||||||
/* ***** BEGIN LICENSE BLOCK *****
|
|
||||||
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
||||||
*
|
|
||||||
* The contents of this file are subject to the Mozilla Public License Version
|
|
||||||
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
||||||
* the License. You may obtain a copy of the License at
|
|
||||||
* http://www.mozilla.org/MPL/
|
|
||||||
*
|
|
||||||
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
||||||
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
||||||
* for the specific language governing rights and limitations under the
|
|
||||||
* License.
|
|
||||||
*
|
|
||||||
* The Original Code is mozilla.org code.
|
|
||||||
*
|
|
||||||
* The Initial Developer of the Original Code is
|
|
||||||
* mozilla.org.
|
|
||||||
* Portions created by the Initial Developer are Copyright (C) 2004
|
|
||||||
* the Initial Developer. All Rights Reserved.
|
|
||||||
*
|
|
||||||
* Contributor(s):
|
|
||||||
* Johnny Stenback <jst@mozilla.org> (Original author)
|
|
||||||
*
|
|
||||||
* Alternatively, the contents of this file may be used under the terms of
|
|
||||||
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
||||||
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
||||||
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
||||||
* of those above. If you wish to allow use of your version of this file only
|
|
||||||
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
||||||
* use your version of this file under the terms of the MPL, indicate your
|
|
||||||
* decision by deleting the provisions above and replace them with the notice
|
|
||||||
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
||||||
* the provisions above, a recipient may use your version of this file under
|
|
||||||
* the terms of any one of the MPL, the GPL or the LGPL.
|
|
||||||
*
|
|
||||||
* ***** END LICENSE BLOCK ***** */
|
|
||||||
|
|
||||||
#ifndef nptypes_h_
|
|
||||||
#define nptypes_h_
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Header file for ensuring that C99 types ([u]int32_t, [u]int64_t and bool) and
|
|
||||||
* true/false macros are available.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#if defined(WIN32) || defined(OS2)
|
|
||||||
/*
|
|
||||||
* Win32 and OS/2 don't know C99, so define [u]int_16/32/64 here. The bool
|
|
||||||
* is predefined tho, both in C and C++.
|
|
||||||
*/
|
|
||||||
typedef short int16_t;
|
|
||||||
typedef unsigned short uint16_t;
|
|
||||||
typedef int int32_t;
|
|
||||||
typedef unsigned int uint32_t;
|
|
||||||
typedef long long int64_t;
|
|
||||||
typedef unsigned long long uint64_t;
|
|
||||||
#elif defined(_AIX) || defined(__sun) || defined(__osf__) || defined(IRIX) || defined(HPUX)
|
|
||||||
/*
|
|
||||||
* AIX and SunOS ship a inttypes.h header that defines [u]int32_t,
|
|
||||||
* but not bool for C.
|
|
||||||
*/
|
|
||||||
#include <inttypes.h>
|
|
||||||
|
|
||||||
#ifndef __cplusplus
|
|
||||||
typedef int bool;
|
|
||||||
#define true 1
|
|
||||||
#define false 0
|
|
||||||
#endif
|
|
||||||
#elif defined(bsdi) || defined(FREEBSD) || defined(OPENBSD)
|
|
||||||
/*
|
|
||||||
* BSD/OS, FreeBSD, and OpenBSD ship sys/types.h that define int32_t and
|
|
||||||
* u_int32_t.
|
|
||||||
*/
|
|
||||||
#include <sys/types.h>
|
|
||||||
|
|
||||||
/*
|
|
||||||
* BSD/OS ships no header that defines uint32_t, nor bool (for C)
|
|
||||||
*/
|
|
||||||
#if defined(bsdi)
|
|
||||||
typedef u_int32_t uint32_t;
|
|
||||||
typedef u_int64_t uint64_t;
|
|
||||||
|
|
||||||
#if !defined(__cplusplus)
|
|
||||||
typedef int bool;
|
|
||||||
#define true 1
|
|
||||||
#define false 0
|
|
||||||
#endif
|
|
||||||
#else
|
|
||||||
/*
|
|
||||||
* FreeBSD and OpenBSD define uint32_t and bool.
|
|
||||||
*/
|
|
||||||
#include <inttypes.h>
|
|
||||||
#include <stdbool.h>
|
|
||||||
#endif
|
|
||||||
#elif defined(BEOS)
|
|
||||||
#include <inttypes.h>
|
|
||||||
#else
|
|
||||||
/*
|
|
||||||
* For those that ship a standard C99 stdint.h header file, include
|
|
||||||
* it. Can't do the same for stdbool.h tho, since some systems ship
|
|
||||||
* with a stdbool.h file that doesn't compile!
|
|
||||||
*/
|
|
||||||
#include <stdint.h>
|
|
||||||
|
|
||||||
#ifndef __cplusplus
|
|
||||||
#if !defined(__GNUC__) || (__GNUC__ > 2 || __GNUC_MINOR__ > 95)
|
|
||||||
#include <stdbool.h>
|
|
||||||
#else
|
|
||||||
/*
|
|
||||||
* GCC 2.91 can't deal with a typedef for bool, but a #define
|
|
||||||
* works.
|
|
||||||
*/
|
|
||||||
#define bool int
|
|
||||||
#define true 1
|
|
||||||
#define false 0
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* nptypes_h_ */
|
|
165
configure.ac
@ -1,5 +1,5 @@
|
|||||||
AC_PREREQ(2.63)
|
AC_PREREQ(2.63)
|
||||||
AC_INIT([gnome-shell],[3.6.1],[https://bugzilla.gnome.org/enter_bug.cgi?product=gnome-shell],[gnome-shell])
|
AC_INIT([gnome-shell],[3.0.2],[https://bugzilla.gnome.org/enter_bug.cgi?product=gnome-shell],[gnome-shell])
|
||||||
|
|
||||||
AC_CONFIG_HEADERS([config.h])
|
AC_CONFIG_HEADERS([config.h])
|
||||||
AC_CONFIG_SRCDIR([src/shell-global.c])
|
AC_CONFIG_SRCDIR([src/shell-global.c])
|
||||||
@ -9,8 +9,8 @@ AC_CONFIG_AUX_DIR([config])
|
|||||||
AC_SUBST([PACKAGE_NAME], ["$PACKAGE_NAME"])
|
AC_SUBST([PACKAGE_NAME], ["$PACKAGE_NAME"])
|
||||||
AC_SUBST([PACKAGE_VERSION], ["$PACKAGE_VERSION"])
|
AC_SUBST([PACKAGE_VERSION], ["$PACKAGE_VERSION"])
|
||||||
|
|
||||||
AM_INIT_AUTOMAKE([1.11 no-dist-gzip dist-xz tar-ustar foreign])
|
AM_INIT_AUTOMAKE([1.10 dist-bzip2 no-dist-gzip foreign])
|
||||||
AM_MAINTAINER_MODE([enable])
|
AM_MAINTAINER_MODE
|
||||||
|
|
||||||
m4_ifdef([AM_SILENT_RULES],[AM_SILENT_RULES([yes])])
|
m4_ifdef([AM_SILENT_RULES],[AM_SILENT_RULES([yes])])
|
||||||
|
|
||||||
@ -23,19 +23,19 @@ AM_PROG_CC_C_O
|
|||||||
LT_PREREQ([2.2.6])
|
LT_PREREQ([2.2.6])
|
||||||
LT_INIT([disable-static])
|
LT_INIT([disable-static])
|
||||||
|
|
||||||
# i18n
|
|
||||||
IT_PROG_INTLTOOL([0.40])
|
|
||||||
|
|
||||||
AM_GNU_GETTEXT([external])
|
|
||||||
AM_GNU_GETTEXT_VERSION([0.17])
|
|
||||||
|
|
||||||
GETTEXT_PACKAGE=gnome-shell
|
GETTEXT_PACKAGE=gnome-shell
|
||||||
AC_SUBST(GETTEXT_PACKAGE)
|
AC_SUBST(GETTEXT_PACKAGE)
|
||||||
AC_DEFINE_UNQUOTED(GETTEXT_PACKAGE, "$GETTEXT_PACKAGE",
|
AC_DEFINE_UNQUOTED(GETTEXT_PACKAGE, "$GETTEXT_PACKAGE",
|
||||||
[The prefix for our gettext translation domains.])
|
[The prefix for our gettext translation domains.])
|
||||||
|
IT_PROG_INTLTOOL(0.26)
|
||||||
|
AM_GLIB_GNU_GETTEXT
|
||||||
|
|
||||||
PKG_PROG_PKG_CONFIG([0.22])
|
PKG_PROG_PKG_CONFIG([0.22])
|
||||||
|
|
||||||
|
# GConf stuff
|
||||||
|
AC_PATH_PROG(GCONFTOOL, gconftool-2, no)
|
||||||
|
AM_GCONF_SOURCE_2
|
||||||
|
|
||||||
GLIB_GSETTINGS
|
GLIB_GSETTINGS
|
||||||
|
|
||||||
# Get a value to substitute into gnome-shell.in
|
# Get a value to substitute into gnome-shell.in
|
||||||
@ -44,93 +44,90 @@ AC_SUBST(PYTHON)
|
|||||||
|
|
||||||
# We need at least this, since gst_plugin_register_static() was added
|
# We need at least this, since gst_plugin_register_static() was added
|
||||||
# in 0.10.16, but nothing older than 0.10.21 has been tested.
|
# in 0.10.16, but nothing older than 0.10.21 has been tested.
|
||||||
GSTREAMER_MIN_VERSION=0.11.92
|
GSTREAMER_MIN_VERSION=0.10.16
|
||||||
|
|
||||||
recorder_modules=
|
recorder_modules=
|
||||||
build_recorder=false
|
build_recorder=false
|
||||||
AC_MSG_CHECKING([for GStreamer (needed for recording functionality)])
|
AC_MSG_CHECKING([for GStreamer (needed for recording functionality)])
|
||||||
if $PKG_CONFIG --exists gstreamer-1.0 '>=' $GSTREAMER_MIN_VERSION ; then
|
if $PKG_CONFIG --exists gstreamer-0.10 '>=' $GSTREAMER_MIN_VERSION ; then
|
||||||
AC_MSG_RESULT(yes)
|
AC_MSG_RESULT(yes)
|
||||||
build_recorder=true
|
build_recorder=true
|
||||||
recorder_modules="gstreamer-1.0 gstreamer-base-1.0 x11"
|
recorder_modules="gstreamer-0.10 gstreamer-base-0.10 x11"
|
||||||
PKG_CHECK_MODULES(TEST_SHELL_RECORDER, $recorder_modules clutter-1.0 xfixes gl)
|
PKG_CHECK_MODULES(TEST_SHELL_RECORDER, $recorder_modules clutter-1.0 xfixes)
|
||||||
else
|
else
|
||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
fi
|
fi
|
||||||
|
|
||||||
AM_CONDITIONAL(BUILD_RECORDER, $build_recorder)
|
AM_CONDITIONAL(BUILD_RECORDER, $build_recorder)
|
||||||
|
|
||||||
CLUTTER_MIN_VERSION=1.11.11
|
CLUTTER_MIN_VERSION=1.5.15
|
||||||
GOBJECT_INTROSPECTION_MIN_VERSION=0.10.1
|
GOBJECT_INTROSPECTION_MIN_VERSION=0.10.1
|
||||||
GJS_MIN_VERSION=1.33.2
|
GJS_MIN_VERSION=0.7.11
|
||||||
MUTTER_MIN_VERSION=3.6.1
|
MUTTER_MIN_VERSION=3.0.0
|
||||||
GTK_MIN_VERSION=3.3.9
|
GTK_MIN_VERSION=3.0.0
|
||||||
GIO_MIN_VERSION=2.31.6
|
GIO_MIN_VERSION=2.25.9
|
||||||
LIBECAL_MIN_VERSION=3.5.3
|
LIBECAL_MIN_VERSION=2.32.0
|
||||||
LIBEDATASERVER_MIN_VERSION=3.5.3
|
LIBEDATASERVER_MIN_VERSION=1.2.0
|
||||||
LIBEDATASERVERUI_MIN_VERSION=3.5.3
|
LIBEDATASERVERUI2_MIN_VERSION=1.2.0
|
||||||
TELEPATHY_GLIB_MIN_VERSION=0.17.5
|
LIBEDATASERVERUI3_MIN_VERSION=2.91.6
|
||||||
|
TELEPATHY_GLIB_MIN_VERSION=0.13.12
|
||||||
TELEPATHY_LOGGER_MIN_VERSION=0.2.4
|
TELEPATHY_LOGGER_MIN_VERSION=0.2.4
|
||||||
POLKIT_MIN_VERSION=0.100
|
POLKIT_MIN_VERSION=0.100
|
||||||
STARTUP_NOTIFICATION_MIN_VERSION=0.11
|
|
||||||
GCR_MIN_VERSION=3.3.90
|
|
||||||
GNOME_DESKTOP_REQUIRED_VERSION=3.5.1
|
|
||||||
GNOME_MENUS_REQUIRED_VERSION=3.5.3
|
|
||||||
|
|
||||||
# Collect more than 20 libraries for a prize!
|
# Collect more than 20 libraries for a prize!
|
||||||
PKG_CHECK_MODULES(GNOME_SHELL, gio-unix-2.0 >= $GIO_MIN_VERSION
|
PKG_CHECK_MODULES(GNOME_SHELL, gio-2.0 >= $GIO_MIN_VERSION
|
||||||
libxml-2.0
|
gio-unix-2.0 dbus-glib-1 libxml-2.0
|
||||||
gtk+-3.0 >= $GTK_MIN_VERSION
|
gtk+-3.0 >= $GTK_MIN_VERSION
|
||||||
atk-bridge-2.0
|
|
||||||
libmutter >= $MUTTER_MIN_VERSION
|
libmutter >= $MUTTER_MIN_VERSION
|
||||||
gjs-internals-1.0 >= $GJS_MIN_VERSION
|
gjs-internals-1.0 >= $GJS_MIN_VERSION
|
||||||
libgnome-menu-3.0 >= $GNOME_MENUS_REQUIRED_VERSION
|
libgnome-menu $recorder_modules gconf-2.0
|
||||||
$recorder_modules
|
gdk-x11-3.0
|
||||||
gdk-x11-3.0 libsoup-2.4
|
|
||||||
gl
|
|
||||||
clutter-x11-1.0 >= $CLUTTER_MIN_VERSION
|
clutter-x11-1.0 >= $CLUTTER_MIN_VERSION
|
||||||
clutter-glx-1.0 >= $CLUTTER_MIN_VERSION
|
clutter-glx-1.0 >= $CLUTTER_MIN_VERSION
|
||||||
libstartup-notification-1.0 >= $STARTUP_NOTIFICATION_MIN_VERSION
|
libstartup-notification-1.0
|
||||||
gobject-introspection-1.0 >= $GOBJECT_INTROSPECTION_MIN_VERSION
|
gobject-introspection-1.0 >= $GOBJECT_INTROSPECTION_MIN_VERSION
|
||||||
libcanberra
|
libcanberra
|
||||||
telepathy-glib >= $TELEPATHY_GLIB_MIN_VERSION
|
telepathy-glib >= $TELEPATHY_GLIB_MIN_VERSION
|
||||||
telepathy-logger-0.2 >= $TELEPATHY_LOGGER_MIN_VERSION
|
telepathy-logger-0.2 >= $TELEPATHY_LOGGER_MIN_VERSION
|
||||||
polkit-agent-1 >= $POLKIT_MIN_VERSION xfixes
|
polkit-agent-1 >= $POLKIT_MIN_VERSION xfixes)
|
||||||
libnm-glib libnm-util gnome-keyring-1
|
|
||||||
gcr-3 >= $GCR_MIN_VERSION
|
|
||||||
gnome-desktop-3.0 >= $GNOME_DESKTOP_REQUIRED_VERSION)
|
|
||||||
|
|
||||||
PKG_CHECK_MODULES(SHELL_PERF_HELPER, gtk+-3.0 gio-2.0)
|
PKG_CHECK_MODULES(SHELL_PERF_HELPER, gtk+-3.0 gio-2.0)
|
||||||
|
|
||||||
PKG_CHECK_MODULES(SHELL_HOTPLUG_SNIFFER, gio-2.0 gdk-pixbuf-2.0)
|
GJS_VERSION=`$PKG_CONFIG --modversion gjs-internals-1.0`
|
||||||
|
AC_DEFINE_UNQUOTED([GJS_VERSION], ["$GJS_VERSION"], [The version of GJS we're linking to])
|
||||||
PKG_CHECK_MODULES(BROWSER_PLUGIN, gio-2.0 >= $GIO_MIN_VERSION json-glib-1.0 >= 0.13.2)
|
AC_SUBST([GJS_VERSION], ["$GJS_VERSION"])
|
||||||
|
|
||||||
GNOME_KEYBINDINGS_KEYSDIR=`$PKG_CONFIG --variable keysdir gnome-keybindings`
|
|
||||||
AC_SUBST([GNOME_KEYBINDINGS_KEYSDIR])
|
|
||||||
|
|
||||||
GOBJECT_INTROSPECTION_CHECK([$GOBJECT_INTROSPECTION_MIN_VERSION])
|
GOBJECT_INTROSPECTION_CHECK([$GOBJECT_INTROSPECTION_MIN_VERSION])
|
||||||
|
JHBUILD_TYPELIBDIR="$INTROSPECTION_TYPELIBDIR"
|
||||||
|
# NM is the only typelib we use that we don't jhbuild
|
||||||
|
PKG_CHECK_EXISTS([libnm-glib >= 0.8.999],
|
||||||
|
[NM_TYPELIBDIR=`$PKG_CONFIG --variable=libdir libnm-glib`/girepository-1.0
|
||||||
|
if test "$INTROSPECTION_TYPELIBDIR" != "$NM_TYPELIBDIR"; then
|
||||||
|
JHBUILD_TYPELIBDIR="$JHBUILD_TYPELIBDIR:$NM_TYPELIBDIR"
|
||||||
|
fi])
|
||||||
|
AC_SUBST(JHBUILD_TYPELIBDIR)
|
||||||
|
|
||||||
saved_CFLAGS=$CFLAGS
|
saved_CFLAGS=$CFLAGS
|
||||||
saved_LIBS=$LIBS
|
saved_LIBS=$LIBS
|
||||||
CFLAGS=$GNOME_SHELL_CFLAGS
|
CFLAGS=$GNOME_SHELL_CFLAGS
|
||||||
LIBS=$GNOME_SHELL_LIBS
|
LIBS=$GNOME_SHELL_LIBS
|
||||||
AC_CHECK_FUNCS(JS_NewGlobalObject XFixesCreatePointerBarrier)
|
# sn_startup_sequence_get_application_id, we can replace with a version check later
|
||||||
|
AC_CHECK_FUNCS(JS_NewGlobalObject sn_startup_sequence_get_application_id XFixesCreatePointerBarrier)
|
||||||
CFLAGS=$saved_CFLAGS
|
CFLAGS=$saved_CFLAGS
|
||||||
LIBS=$saved_LIBS
|
LIBS=$saved_LIBS
|
||||||
|
|
||||||
PKG_CHECK_MODULES(GNOME_SHELL_JS, gio-2.0 gjs-internals-1.0 >= $GJS_MIN_VERSION)
|
PKG_CHECK_MODULES(ST, clutter-1.0 gtk+-3.0 libcroco-0.6 gnome-desktop-3.0 >= 2.90.0 x11)
|
||||||
PKG_CHECK_MODULES(ST, clutter-1.0 gtk+-3.0 libcroco-0.6 >= 0.6.2 x11)
|
PKG_CHECK_MODULES(GDMUSER, dbus-glib-1 gtk+-3.0)
|
||||||
PKG_CHECK_MODULES(TRAY, gtk+-3.0)
|
PKG_CHECK_MODULES(TRAY, gtk+-3.0)
|
||||||
PKG_CHECK_MODULES(GVC, libpulse libpulse-mainloop-glib gobject-2.0)
|
PKG_CHECK_MODULES(GVC, libpulse libpulse-mainloop-glib gobject-2.0)
|
||||||
PKG_CHECK_MODULES(DESKTOP_SCHEMAS, gsettings-desktop-schemas >= 3.5.4)
|
PKG_CHECK_MODULES(JS_TEST, clutter-x11-1.0 gjs-1.0 gobject-introspection-1.0 gtk+-3.0)
|
||||||
|
PKG_CHECK_MODULES(DESKTOP_SCHEMAS, gsettings-desktop-schemas >= 0.1.7)
|
||||||
|
|
||||||
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 >= 2.90.0],
|
||||||
[BLUETOOTH_DIR=`$PKG_CONFIG --variable=applet_libdir gnome-bluetooth-1.0`
|
[BLUETOOTH_DIR=`$PKG_CONFIG --variable=libdir gnome-bluetooth-1.0`/gnome-bluetooth
|
||||||
BLUETOOTH_LIBS=`$PKG_CONFIG --variable=applet_libs gnome-bluetooth-1.0`
|
BLUETOOTH_LIBS="-L'$BLUETOOTH_DIR' -lgnome-bluetooth-applet"
|
||||||
AC_SUBST([BLUETOOTH_LIBS],["$BLUETOOTH_LIBS"])
|
AC_SUBST([BLUETOOTH_LIBS],["$BLUETOOTH_LIBS"])
|
||||||
AC_SUBST([BLUETOOTH_DIR],["$BLUETOOTH_DIR"])
|
|
||||||
AC_DEFINE_UNQUOTED([BLUETOOTH_DIR],["$BLUETOOTH_DIR"],[Path to installed GnomeBluetooth typelib and library])
|
AC_DEFINE_UNQUOTED([BLUETOOTH_DIR],["$BLUETOOTH_DIR"],[Path to installed GnomeBluetooth typelib and library])
|
||||||
AC_DEFINE([HAVE_BLUETOOTH],[1],[Define if you have libgnome-bluetooth-applet])
|
AC_DEFINE([HAVE_BLUETOOTH],[1],[Define if you have libgnome-bluetooth-applet])
|
||||||
AC_SUBST([HAVE_BLUETOOTH],[1])
|
AC_SUBST([HAVE_BLUETOOTH],[1])
|
||||||
@ -139,37 +136,16 @@ PKG_CHECK_EXISTS([gnome-bluetooth-1.0 >= 3.1.0],
|
|||||||
AC_SUBST([HAVE_BLUETOOTH],[0])
|
AC_SUBST([HAVE_BLUETOOTH],[0])
|
||||||
AC_MSG_RESULT([no])])
|
AC_MSG_RESULT([no])])
|
||||||
|
|
||||||
PKG_CHECK_MODULES(CALENDAR_SERVER, libecal-1.2 >= $LIBECAL_MIN_VERSION libedataserver-1.2 >= $LIBEDATASERVER_MIN_VERSION libedataserverui-3.0 >= $LIBEDATASERVERUI_MIN_VERSION gio-2.0)
|
# Default to libedataserverui-3.0, but allow falling back to 1.2
|
||||||
|
PKG_CHECK_EXISTS(libedataserverui-3.0,
|
||||||
|
[EDS_API=3.0
|
||||||
|
LIBEDATASERVERUI_MIN_VERSION=$LIBEDATASERVERUI3_MIN_VERSION],
|
||||||
|
[EDS_API=1.2
|
||||||
|
LIBEDATASERVERUI_MIN_VERSION=$LIBEDATASERVERUI2_MIN_VERSION])
|
||||||
|
PKG_CHECK_MODULES(CALENDAR_SERVER, libecal-1.2 >= $LIBECAL_MIN_VERSION libedataserver-1.2 >= $LIBEDATASERVER_MIN_VERSION libedataserverui-$EDS_API >= $LIBEDATASERVERUI_MIN_VERSION gio-2.0)
|
||||||
AC_SUBST(CALENDAR_SERVER_CFLAGS)
|
AC_SUBST(CALENDAR_SERVER_CFLAGS)
|
||||||
AC_SUBST(CALENDAR_SERVER_LIBS)
|
AC_SUBST(CALENDAR_SERVER_LIBS)
|
||||||
|
|
||||||
AC_ARG_WITH(systemd,
|
|
||||||
AS_HELP_STRING([--with-systemd],
|
|
||||||
[Add systemd support]),
|
|
||||||
[with_systemd=$withval], [with_systemd=auto])
|
|
||||||
|
|
||||||
PKG_CHECK_MODULES(SYSTEMD,
|
|
||||||
[libsystemd-login libsystemd-daemon],
|
|
||||||
[have_systemd=yes], [have_systemd=no])
|
|
||||||
|
|
||||||
if test "x$with_systemd" = "xauto" ; then
|
|
||||||
if test x$have_systemd = xno ; then
|
|
||||||
use_systemd=no
|
|
||||||
else
|
|
||||||
use_systemd=yes
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
use_systemd=$with_systemd
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "x$use_systemd" = "xyes"; then
|
|
||||||
if test "x$have_systemd" = "xno"; then
|
|
||||||
AC_MSG_ERROR([Systemd support explicitly required, but systemd not found])
|
|
||||||
fi
|
|
||||||
|
|
||||||
AC_DEFINE(WITH_SYSTEMD, 1, [systemd support])
|
|
||||||
fi
|
|
||||||
|
|
||||||
MUTTER_GIR_DIR=`$PKG_CONFIG --variable=girdir libmutter`
|
MUTTER_GIR_DIR=`$PKG_CONFIG --variable=girdir libmutter`
|
||||||
MUTTER_TYPELIB_DIR=`$PKG_CONFIG --variable=typelibdir libmutter`
|
MUTTER_TYPELIB_DIR=`$PKG_CONFIG --variable=typelibdir libmutter`
|
||||||
AC_SUBST(MUTTER_GIR_DIR)
|
AC_SUBST(MUTTER_GIR_DIR)
|
||||||
@ -182,17 +158,6 @@ AC_CHECK_FUNCS(fdwalk)
|
|||||||
AC_CHECK_FUNCS(mallinfo)
|
AC_CHECK_FUNCS(mallinfo)
|
||||||
AC_CHECK_HEADERS([sys/resource.h])
|
AC_CHECK_HEADERS([sys/resource.h])
|
||||||
|
|
||||||
# _NL_TIME_FIRST_WEEKDAY is an enum and not a define
|
|
||||||
AC_MSG_CHECKING([for _NL_TIME_FIRST_WEEKDAY])
|
|
||||||
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <langinfo.h>]],
|
|
||||||
[[nl_langinfo(_NL_TIME_FIRST_WEEKDAY);]])],
|
|
||||||
[langinfo_ok=yes], [langinfo_ok=no])
|
|
||||||
AC_MSG_RESULT($langinfo_ok)
|
|
||||||
if test "$langinfo_ok" = "yes"; then
|
|
||||||
AC_DEFINE([HAVE__NL_TIME_FIRST_WEEKDAY], [1],
|
|
||||||
[Define if _NL_TIME_FIRST_WEEKDAY is available])
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Sets GLIB_GENMARSHAL and GLIB_MKENUMS
|
# Sets GLIB_GENMARSHAL and GLIB_MKENUMS
|
||||||
AM_PATH_GLIB_2_0()
|
AM_PATH_GLIB_2_0()
|
||||||
G_IR_SCANNER=`$PKG_CONFIG --variable=g_ir_scanner gobject-introspection-1.0`
|
G_IR_SCANNER=`$PKG_CONFIG --variable=g_ir_scanner gobject-introspection-1.0`
|
||||||
@ -206,8 +171,6 @@ AC_SUBST(GIRDIR)
|
|||||||
TYPELIBDIR="$($PKG_CONFIG --variable=typelibdir gobject-introspection-1.0)"
|
TYPELIBDIR="$($PKG_CONFIG --variable=typelibdir gobject-introspection-1.0)"
|
||||||
AC_SUBST(TYPELIBDIR)
|
AC_SUBST(TYPELIBDIR)
|
||||||
|
|
||||||
GTK_DOC_CHECK([1.15], [--flavour no-tmpl])
|
|
||||||
|
|
||||||
# Stay command-line compatible with the gnome-common configure option. Here
|
# Stay command-line compatible with the gnome-common configure option. Here
|
||||||
# minimum/yes/maximum are the same, however.
|
# minimum/yes/maximum are the same, however.
|
||||||
AC_ARG_ENABLE(compile_warnings,
|
AC_ARG_ENABLE(compile_warnings,
|
||||||
@ -228,7 +191,7 @@ if test "$enable_compile_warnings" != no ; then
|
|||||||
if test "$enable_compile_warnings" = error ; then
|
if test "$enable_compile_warnings" = error ; then
|
||||||
case " $CFLAGS " in
|
case " $CFLAGS " in
|
||||||
*[\ \ ]-Werror[\ \ ]*) ;;
|
*[\ \ ]-Werror[\ \ ]*) ;;
|
||||||
*) CFLAGS="$CFLAGS -Werror -Wno-error=deprecated-declarations" ;;
|
*) CFLAGS="$CFLAGS -Werror" ;;
|
||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@ -236,25 +199,15 @@ fi
|
|||||||
changequote([,])dnl
|
changequote([,])dnl
|
||||||
|
|
||||||
AC_ARG_ENABLE(jhbuild-wrapper-script,
|
AC_ARG_ENABLE(jhbuild-wrapper-script,
|
||||||
AS_HELP_STRING([--enable-jhbuild-wrapper-script],[Make "gnome-shell" script work for jhbuild]),,enable_jhbuild_wrapper_script=no)
|
AS_HELP_STRING([--jhbuild-wrapper-script=yes],[Make "gnome-shell" script work for jhbuild]),,enable_jhbuild_wrapper_script=no)
|
||||||
AM_CONDITIONAL(USE_JHBUILD_WRAPPER_SCRIPT, test "x$enable_jhbuild_wrapper_script" = xyes)
|
AM_CONDITIONAL(USE_JHBUILD_WRAPPER_SCRIPT, test "x$enable_jhbuild_wrapper_script" = xyes)
|
||||||
|
|
||||||
BROWSER_PLUGIN_DIR="${BROWSER_PLUGIN_DIR:-"\${libdir}/mozilla/plugins"}"
|
|
||||||
AC_ARG_VAR([BROWSER_PLUGIN_DIR],[Where to install the plugin to])
|
|
||||||
|
|
||||||
AC_CONFIG_FILES([
|
AC_CONFIG_FILES([
|
||||||
Makefile
|
Makefile
|
||||||
data/Makefile
|
data/Makefile
|
||||||
docs/Makefile
|
|
||||||
docs/reference/Makefile
|
|
||||||
docs/reference/shell/Makefile
|
|
||||||
docs/reference/shell/shell-docs.sgml
|
|
||||||
docs/reference/st/Makefile
|
|
||||||
docs/reference/st/st-docs.sgml
|
|
||||||
js/Makefile
|
js/Makefile
|
||||||
src/calendar-server/evolution-calendar.desktop.in
|
js/misc/config.js
|
||||||
src/Makefile
|
src/Makefile
|
||||||
browser-plugin/Makefile
|
|
||||||
tests/Makefile
|
tests/Makefile
|
||||||
po/Makefile.in
|
po/Makefile.in
|
||||||
man/Makefile
|
man/Makefile
|
||||||
|
@ -1,12 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
|
||||||
<KeyListEntries schema="org.gnome.shell.keybindings"
|
|
||||||
group="system"
|
|
||||||
_name="Screenshots"
|
|
||||||
wm_name="GNOME Shell"
|
|
||||||
package="gnome-shell">
|
|
||||||
|
|
||||||
<KeyListEntry name="toggle-recording"
|
|
||||||
_description="Record a screencast"/>
|
|
||||||
|
|
||||||
</KeyListEntries>
|
|
||||||
|
|
@ -1,12 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
|
||||||
<KeyListEntries schema="org.gnome.shell.keybindings"
|
|
||||||
group="system"
|
|
||||||
_name="System"
|
|
||||||
wm_name="GNOME Shell"
|
|
||||||
package="gnome-shell">
|
|
||||||
|
|
||||||
<KeyListEntry name="toggle-message-tray"
|
|
||||||
_description="Show the message tray"/>
|
|
||||||
|
|
||||||
</KeyListEntries>
|
|
||||||
|
|
@ -1,5 +1,5 @@
|
|||||||
desktopdir=$(datadir)/applications
|
desktopdir=$(datadir)/applications
|
||||||
desktop_DATA = gnome-shell.desktop gnome-shell-extension-prefs.desktop
|
desktop_DATA = gnome-shell.desktop
|
||||||
|
|
||||||
# We substitute in bindir so it works as an autostart
|
# We substitute in bindir so it works as an autostart
|
||||||
# file when built in a non-system prefix
|
# file when built in a non-system prefix
|
||||||
@ -8,20 +8,20 @@ desktop_DATA = gnome-shell.desktop gnome-shell-extension-prefs.desktop
|
|||||||
-e "s|@VERSION[@]|$(VERSION)|" \
|
-e "s|@VERSION[@]|$(VERSION)|" \
|
||||||
$< > $@ || rm $@
|
$< > $@ || rm $@
|
||||||
|
|
||||||
@INTLTOOL_DESKTOP_RULE@
|
# Placeholder until we add intltool
|
||||||
|
%.desktop:%.desktop.in
|
||||||
|
$(AM_V_GEN) sed s/^_// < $< > $@ || rm $@
|
||||||
|
|
||||||
introspectiondir = $(datadir)/dbus-1/interfaces
|
searchprovidersdir = $(pkgdatadir)/search_providers
|
||||||
introspection_DATA = org.gnome.ShellSearchProvider.xml
|
dist_searchproviders_DATA = \
|
||||||
|
search_providers/google.xml \
|
||||||
|
search_providers/wikipedia.xml
|
||||||
|
|
||||||
themedir = $(pkgdatadir)/theme
|
themedir = $(pkgdatadir)/theme
|
||||||
dist_theme_DATA = \
|
dist_theme_DATA = \
|
||||||
theme/calendar-arrow-left.svg \
|
theme/calendar-arrow-left.svg \
|
||||||
theme/calendar-arrow-right.svg \
|
theme/calendar-arrow-right.svg \
|
||||||
theme/calendar-today.svg \
|
theme/calendar-today.svg \
|
||||||
theme/checkbox-focused.svg \
|
|
||||||
theme/checkbox-off-focused.svg \
|
|
||||||
theme/checkbox-off.svg \
|
|
||||||
theme/checkbox.svg \
|
|
||||||
theme/close-window.svg \
|
theme/close-window.svg \
|
||||||
theme/close.svg \
|
theme/close.svg \
|
||||||
theme/corner-ripple-ltr.png \
|
theme/corner-ripple-ltr.png \
|
||||||
@ -30,38 +30,37 @@ dist_theme_DATA = \
|
|||||||
theme/filter-selected-ltr.svg \
|
theme/filter-selected-ltr.svg \
|
||||||
theme/filter-selected-rtl.svg \
|
theme/filter-selected-rtl.svg \
|
||||||
theme/gnome-shell.css \
|
theme/gnome-shell.css \
|
||||||
theme/logged-in-indicator.svg \
|
theme/mosaic-view-active.svg \
|
||||||
theme/message-tray-background.png \
|
theme/mosaic-view.svg \
|
||||||
theme/noise-texture.png \
|
theme/move-window-on-new.svg \
|
||||||
|
theme/panel-border.svg \
|
||||||
theme/panel-button-border.svg \
|
theme/panel-button-border.svg \
|
||||||
theme/panel-button-highlight-narrow.svg \
|
theme/panel-button-highlight-narrow.svg \
|
||||||
theme/panel-button-highlight-wide.svg \
|
theme/panel-button-highlight-wide.svg \
|
||||||
theme/process-working.svg \
|
theme/process-working.svg \
|
||||||
theme/running-indicator.svg \
|
theme/running-indicator.svg \
|
||||||
|
theme/scroll-button-down-hover.png \
|
||||||
|
theme/scroll-button-down.png \
|
||||||
|
theme/scroll-button-up-hover.png \
|
||||||
|
theme/scroll-button-up.png \
|
||||||
|
theme/scroll-hhandle.svg \
|
||||||
|
theme/scroll-vhandle.svg \
|
||||||
|
theme/section-more.svg \
|
||||||
|
theme/section-more-open.svg \
|
||||||
|
theme/separator-white.png \
|
||||||
|
theme/single-view-active.svg \
|
||||||
|
theme/single-view.svg \
|
||||||
theme/source-button-border.svg \
|
theme/source-button-border.svg \
|
||||||
theme/summary-counter.svg \
|
|
||||||
theme/toggle-off-us.svg \
|
theme/toggle-off-us.svg \
|
||||||
theme/toggle-off-intl.svg \
|
theme/toggle-off-intl.svg \
|
||||||
theme/toggle-on-us.svg \
|
theme/toggle-on-us.svg \
|
||||||
theme/toggle-on-intl.svg \
|
theme/toggle-on-intl.svg \
|
||||||
theme/ws-switch-arrow-up.png \
|
theme/ws-switch-arrow-up.svg \
|
||||||
theme/ws-switch-arrow-down.png
|
theme/ws-switch-arrow-down.svg
|
||||||
|
|
||||||
keysdir = @GNOME_KEYBINDINGS_KEYSDIR@
|
|
||||||
keys_in_files = \
|
|
||||||
50-gnome-shell-screenshot.xml.in \
|
|
||||||
50-gnome-shell-system.xml.in \
|
|
||||||
$(NULL)
|
|
||||||
keys_DATA = $(keys_in_files:.xml.in=.xml)
|
|
||||||
|
|
||||||
gsettings_SCHEMAS = org.gnome.shell.gschema.xml
|
gsettings_SCHEMAS = org.gnome.shell.gschema.xml
|
||||||
|
|
||||||
@INTLTOOL_XML_NOMERGE_RULE@
|
@INTLTOOL_XML_NOMERGE_RULE@
|
||||||
|
|
||||||
%.gschema.xml.in: %.gschema.xml.in.in Makefile
|
|
||||||
$(AM_V_GEN) sed -e 's|@GETTEXT_PACKAGE[@]|$(GETTEXT_PACKAGE)|g' \
|
|
||||||
$< > $@ || rm $@
|
|
||||||
|
|
||||||
@GSETTINGS_RULES@
|
@GSETTINGS_RULES@
|
||||||
|
|
||||||
# We need to compile schemas at make time
|
# We need to compile schemas at make time
|
||||||
@ -71,24 +70,30 @@ gschemas.compiled: $(gsettings_SCHEMAS:.xml=.valid)
|
|||||||
|
|
||||||
all-local: gschemas.compiled
|
all-local: gschemas.compiled
|
||||||
|
|
||||||
convertdir = $(datadir)/GConf/gsettings
|
|
||||||
convert_DATA = gnome-shell-overrides.convert
|
# GConf schemas: provide defaults for keys from Metacity we are overriding
|
||||||
|
gconfschemadir = @GCONF_SCHEMA_FILE_DIR@
|
||||||
|
gconfschema_DATA = gnome-shell.schemas
|
||||||
|
|
||||||
|
shadersdir = $(pkgdatadir)/shaders
|
||||||
|
shaders_DATA = \
|
||||||
|
shaders/dim-window.glsl
|
||||||
|
|
||||||
|
install-data-local:
|
||||||
|
GCONF_CONFIG_SOURCE=$(GCONF_SCHEMA_CONFIG_SOURCE) $(GCONFTOOL) --makefile-install-rule $(srcdir)/$(gconfschema_DATA)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
EXTRA_DIST = \
|
EXTRA_DIST = \
|
||||||
gnome-shell.desktop.in.in \
|
gnome-shell.desktop.in.in \
|
||||||
gnome-shell-extension-prefs.desktop.in.in \
|
|
||||||
$(introspection_DATA) \
|
|
||||||
$(menu_DATA) \
|
$(menu_DATA) \
|
||||||
$(convert_DATA) \
|
$(gconfschema_DATA) \
|
||||||
$(keys_in_files) \
|
$(shaders_DATA) \
|
||||||
org.gnome.shell.gschema.xml.in.in
|
org.gnome.shell.gschema.xml.in
|
||||||
|
|
||||||
CLEANFILES = \
|
CLEANFILES = \
|
||||||
gnome-shell.desktop.in \
|
gnome-shell.desktop.in \
|
||||||
gnome-shell-extension-prefs.in \
|
|
||||||
$(desktop_DATA) \
|
$(desktop_DATA) \
|
||||||
$(keys_DATA) \
|
|
||||||
$(gsettings_SCHEMAS) \
|
$(gsettings_SCHEMAS) \
|
||||||
gschemas.compiled \
|
gschemas.compiled
|
||||||
org.gnome.shell.gschema.valid \
|
|
||||||
org.gnome.shell.gschema.xml.in
|
|
||||||
|
@ -1,12 +0,0 @@
|
|||||||
[Desktop Entry]
|
|
||||||
Type=Application
|
|
||||||
_Name=GNOME Shell Extension Preferences
|
|
||||||
_Comment=Configure GNOME Shell Extensions
|
|
||||||
Exec=@bindir@/gnome-shell-extension-prefs %u
|
|
||||||
X-GNOME-Bugzilla-Bugzilla=GNOME
|
|
||||||
X-GNOME-Bugzilla-Product=gnome-shell
|
|
||||||
X-GNOME-Bugzilla-Component=extensions
|
|
||||||
X-GNOME-Bugzilla-Version=@VERSION@
|
|
||||||
Categories=GNOME;GTK;
|
|
||||||
OnlyShowIn=GNOME;
|
|
||||||
NoDisplay=true
|
|
@ -1,5 +0,0 @@
|
|||||||
[org.gnome.shell.overrides]
|
|
||||||
attach-modal-dialogs = /desktop/gnome/shell/windows/attach_modal_dialogs
|
|
||||||
button-layout = /desktop/gnome/shell/windows/button_layout
|
|
||||||
edge-tiling = /desktop/gnome/shell/windows/edge_tiling
|
|
||||||
workspaces-only-on-primary = /desktop/gnome/shell/windows/workspaces_only_on_primary
|
|
@ -13,4 +13,4 @@ NoDisplay=true
|
|||||||
X-GNOME-Autostart-Phase=WindowManager
|
X-GNOME-Autostart-Phase=WindowManager
|
||||||
X-GNOME-Provides=panel;windowmanager;
|
X-GNOME-Provides=panel;windowmanager;
|
||||||
X-GNOME-Autostart-Notify=true
|
X-GNOME-Autostart-Notify=true
|
||||||
X-GNOME-AutoRestart=false
|
X-GNOME-AutoRestart=true
|
||||||
|
100
data/gnome-shell.schemas
Normal file
@ -0,0 +1,100 @@
|
|||||||
|
<gconfschemafile>
|
||||||
|
<schemalist>
|
||||||
|
|
||||||
|
<!-- Metacity overrides -->
|
||||||
|
<schema>
|
||||||
|
<key>/schemas/desktop/gnome/shell/windows/attach_modal_dialogs</key>
|
||||||
|
<applyto>/desktop/gnome/shell/windows/attach_modal_dialogs</applyto>
|
||||||
|
<owner>gnome-shell</owner>
|
||||||
|
<type>bool</type>
|
||||||
|
<default>true</default>
|
||||||
|
<locale name="C">
|
||||||
|
<short>Attach modal dialog to the parent window</short>
|
||||||
|
<long>
|
||||||
|
This key overrides /apps/mutter/general/attach_modal_dialogs when
|
||||||
|
running GNOME Shell.
|
||||||
|
</long>
|
||||||
|
</locale>
|
||||||
|
</schema>
|
||||||
|
|
||||||
|
<schema>
|
||||||
|
<key>/schemas/desktop/gnome/shell/windows/button_layout</key>
|
||||||
|
<applyto>/desktop/gnome/shell/windows/button_layout</applyto>
|
||||||
|
<owner>gnome-shell</owner>
|
||||||
|
<type>string</type>
|
||||||
|
<default>:close</default>
|
||||||
|
<locale name="C">
|
||||||
|
<short>Arrangement of buttons on the titlebar</short>
|
||||||
|
<long>
|
||||||
|
Arrangement of buttons on the titlebar. The
|
||||||
|
value should be a string, such as
|
||||||
|
"menu:minimize,maximize,spacer,close"; the colon separates the
|
||||||
|
left corner of the window from the right corner, and
|
||||||
|
the button names are comma-separated. Duplicate buttons
|
||||||
|
are not allowed. Unknown button names are silently ignored
|
||||||
|
so that buttons can be added in future gnome-shell versions
|
||||||
|
without breaking older versions.
|
||||||
|
A special spacer tag can be used to insert some space between
|
||||||
|
two adjacent buttons.
|
||||||
|
|
||||||
|
This key overrides /apps/metacity/general/button_layout when
|
||||||
|
running GNOME Shell.
|
||||||
|
</long>
|
||||||
|
</locale>
|
||||||
|
</schema>
|
||||||
|
|
||||||
|
<schema>
|
||||||
|
<key>/schemas/desktop/gnome/shell/windows/edge_tiling</key>
|
||||||
|
<applyto>/desktop/gnome/shell/windows/edge_tiling</applyto>
|
||||||
|
<owner>gnome-shell</owner>
|
||||||
|
<type>bool</type>
|
||||||
|
<default>true</default>
|
||||||
|
<locale name="C">
|
||||||
|
<short>enable edge tiling when dropping windows on screen edges</short>
|
||||||
|
<long>
|
||||||
|
If enabled, dropping windows on vertical screen edges maximizes them
|
||||||
|
vertically and resizes them horizontally to cover half of the
|
||||||
|
available area. Dropping windows on the top screen edge maximizes them
|
||||||
|
completely.
|
||||||
|
|
||||||
|
This key overrides /apps/metacity/general/edge_tiling when
|
||||||
|
running GNOME Shell.
|
||||||
|
</long>
|
||||||
|
</locale>
|
||||||
|
</schema>
|
||||||
|
|
||||||
|
<schema>
|
||||||
|
<key>/schemas/desktop/gnome/shell/windows/theme</key>
|
||||||
|
<applyto>/desktop/gnome/shell/windows/theme</applyto>
|
||||||
|
<owner>gnome-shell</owner>
|
||||||
|
<type>string</type>
|
||||||
|
<default>Adwaita</default>
|
||||||
|
<locale name="C">
|
||||||
|
<short>Current theme</short>
|
||||||
|
<long>
|
||||||
|
The theme determines the appearance of window borders,
|
||||||
|
titlebar, and so forth.
|
||||||
|
|
||||||
|
This key overrides /apps/metacity/general/theme when
|
||||||
|
running GNOME Shell.
|
||||||
|
</long>
|
||||||
|
</locale>
|
||||||
|
</schema>
|
||||||
|
|
||||||
|
<schema>
|
||||||
|
<key>/schemas/desktop/gnome/shell/windows/workspaces_only_on_primary</key>
|
||||||
|
<applyto>/desktop/gnome/shell/windows/workspaces_only_on_primary</applyto>
|
||||||
|
<owner>gnome-shell</owner>
|
||||||
|
<type>bool</type>
|
||||||
|
<default>true</default>
|
||||||
|
<locale name="C">
|
||||||
|
<short>Workspaces only on primary monitor</short>
|
||||||
|
<long>
|
||||||
|
This key overrides /apps/mutter/general/workspaces_only_on_primary when
|
||||||
|
running GNOME Shell.
|
||||||
|
</long>
|
||||||
|
</locale>
|
||||||
|
</schema>
|
||||||
|
|
||||||
|
</schemalist>
|
||||||
|
</gconfschemafile>
|
@ -1,147 +0,0 @@
|
|||||||
<!DOCTYPE node PUBLIC
|
|
||||||
'-//freedesktop//DTD D-BUS Object Introspection 1.0//EN'
|
|
||||||
'http://www.freedesktop.org/standards/dbus/1.0/introspect.dtd'>
|
|
||||||
<node>
|
|
||||||
<interface name="org.gnome.Shell.SearchProvider">
|
|
||||||
<doc:doc>
|
|
||||||
<doc:description>
|
|
||||||
<doc:para>
|
|
||||||
The interface used for integrating into GNOME Shell's search
|
|
||||||
interface.
|
|
||||||
</doc:para>
|
|
||||||
</doc:description>
|
|
||||||
</doc:doc>
|
|
||||||
|
|
||||||
<method name="GetInitialResultSet">
|
|
||||||
<doc:doc>
|
|
||||||
<doc:description>
|
|
||||||
<doc:para>
|
|
||||||
Called when the user first begins a search.
|
|
||||||
</doc:para>
|
|
||||||
</doc:description>
|
|
||||||
</doc:doc>
|
|
||||||
<arg type="as" direction="in">
|
|
||||||
<doc:doc>
|
|
||||||
<doc:summary>
|
|
||||||
<doc:para>
|
|
||||||
Array of search terms, which the provider should treat as
|
|
||||||
logical AND.
|
|
||||||
</doc:para>
|
|
||||||
</doc:summary>
|
|
||||||
</doc:doc>
|
|
||||||
</arg>
|
|
||||||
<arg type="as" direction="out">
|
|
||||||
<doc:doc>
|
|
||||||
<doc:summary>
|
|
||||||
<doc:para>
|
|
||||||
An array of result identifier strings representing items which
|
|
||||||
match the given search terms. Identifiers must be unique within
|
|
||||||
the provider's domain, but other than that may be chosen freely
|
|
||||||
by the provider.
|
|
||||||
</doc:para>
|
|
||||||
</doc:summary>
|
|
||||||
</doc:doc>
|
|
||||||
</arg>
|
|
||||||
</method>
|
|
||||||
|
|
||||||
<method name="GetSubsearchResultSet">
|
|
||||||
<doc:doc>
|
|
||||||
<doc:description>
|
|
||||||
<doc:para>
|
|
||||||
Called when a search is performed which is a "subsearch" of
|
|
||||||
the previous search, e.g. the method may return less results, but
|
|
||||||
not more or different results.
|
|
||||||
|
|
||||||
This allows search providers to only search through the previous
|
|
||||||
result set, rather than possibly performing a full re-query.
|
|
||||||
</doc:para>
|
|
||||||
</doc:description>
|
|
||||||
</doc:doc>
|
|
||||||
<arg type="as" direction="in">
|
|
||||||
<doc:doc>
|
|
||||||
<doc:summary>
|
|
||||||
<doc:para>
|
|
||||||
Array of item identifiers
|
|
||||||
</doc:para>
|
|
||||||
</doc:summary>
|
|
||||||
</doc:doc>
|
|
||||||
</arg>
|
|
||||||
<arg type="as" direction="in">
|
|
||||||
<doc:doc>
|
|
||||||
<doc:summary>
|
|
||||||
<doc:para>
|
|
||||||
Array of updated search terms, which the provider should treat as
|
|
||||||
logical AND.
|
|
||||||
</doc:para>
|
|
||||||
</doc:summary>
|
|
||||||
</doc:doc>
|
|
||||||
</arg>
|
|
||||||
<arg type="as" direction="out">
|
|
||||||
<doc:doc>
|
|
||||||
<doc:summary>
|
|
||||||
<doc:para>
|
|
||||||
An array of result identifier strings representing items which
|
|
||||||
match the given search terms. Identifiers must be unique within
|
|
||||||
the provider's domain, but other than that may be chosen freely
|
|
||||||
by the provider.
|
|
||||||
</doc:para>
|
|
||||||
</doc:summary>
|
|
||||||
</doc:doc>
|
|
||||||
</arg>
|
|
||||||
</method>
|
|
||||||
|
|
||||||
<method name="GetResultMetas">
|
|
||||||
<doc:doc>
|
|
||||||
<doc:description>
|
|
||||||
<doc:para>
|
|
||||||
Return an array of meta data used to display each given result
|
|
||||||
</doc:para>
|
|
||||||
</doc:description>
|
|
||||||
</doc:doc>
|
|
||||||
<arg type="as" direction="in">
|
|
||||||
<doc:doc>
|
|
||||||
<doc:summary>
|
|
||||||
<doc:para>
|
|
||||||
An array of result identifiers as returned by
|
|
||||||
GetInitialResultSet() or GetSubsearchResultSet()
|
|
||||||
</doc:para>
|
|
||||||
</doc:summary>
|
|
||||||
</doc:doc>
|
|
||||||
</arg>
|
|
||||||
<arg type="aa{sv}" direction="out">
|
|
||||||
<doc:doc>
|
|
||||||
<doc:summary>
|
|
||||||
<doc:para>
|
|
||||||
A dictionary describing the given search result, containing
|
|
||||||
'id', 'name' (both strings) and either 'icon' (a serialized
|
|
||||||
GIcon) or 'icon-data' (raw image data as (iiibiiay) - width,
|
|
||||||
height, rowstride, has-alpha, bits per sample, channels, data)
|
|
||||||
</doc:para>
|
|
||||||
</doc:summary>
|
|
||||||
</doc:doc>
|
|
||||||
</arg>
|
|
||||||
</method>
|
|
||||||
|
|
||||||
<method name="ActivateResult">
|
|
||||||
<doc:doc>
|
|
||||||
<doc:description>
|
|
||||||
<doc:para>
|
|
||||||
Called when the users chooses a given result. The result should
|
|
||||||
be displayed in the application associated with the corresponding
|
|
||||||
provider.
|
|
||||||
</doc:para>
|
|
||||||
</doc:description>
|
|
||||||
</doc:doc>
|
|
||||||
<arg type="s" direction="in">
|
|
||||||
<doc:doc>
|
|
||||||
<doc:summary>
|
|
||||||
<doc:para>
|
|
||||||
A result identifier as returned by GetInitialResultSet() or
|
|
||||||
GetSubsearchResultSet()
|
|
||||||
</doc:para>
|
|
||||||
</doc:summary>
|
|
||||||
</doc:doc>
|
|
||||||
</arg>
|
|
||||||
</method>
|
|
||||||
</interface>
|
|
||||||
</node>
|
|
123
data/org.gnome.shell.gschema.xml.in
Normal file
@ -0,0 +1,123 @@
|
|||||||
|
<schemalist>
|
||||||
|
<schema id="org.gnome.shell" path="/org/gnome/shell/"
|
||||||
|
gettext-domain="@GETTEXT_PACKAGE@">
|
||||||
|
<key name="development-tools" type="b">
|
||||||
|
<default>true</default>
|
||||||
|
<_summary>
|
||||||
|
Enable internal tools useful for developers and testers from Alt-F2
|
||||||
|
</_summary>
|
||||||
|
<_description>
|
||||||
|
Allows access to internal debugging and monitoring tools
|
||||||
|
using the Alt-F2 dialog.
|
||||||
|
</_description>
|
||||||
|
</key>
|
||||||
|
<key name="disabled-extensions" type="as">
|
||||||
|
<default>[]</default>
|
||||||
|
<_summary>Uuids of extensions to disable</_summary>
|
||||||
|
<_description>
|
||||||
|
GNOME Shell extensions have a uuid property;
|
||||||
|
this key lists extensions which should not be loaded.
|
||||||
|
</_description>
|
||||||
|
</key>
|
||||||
|
<key name="enable-app-monitoring" type="b">
|
||||||
|
<default>true</default>
|
||||||
|
<_summary>Whether to collect stats about applications usage</_summary>
|
||||||
|
<_description>
|
||||||
|
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.
|
||||||
|
</_description>
|
||||||
|
</key>
|
||||||
|
<key name="favorite-apps" type="as">
|
||||||
|
<default>[ 'mozilla-firefox.desktop', 'evolution.desktop', 'empathy.desktop', 'rhythmbox.desktop', 'shotwell.desktop', 'openoffice.org-writer.desktop', 'nautilus.desktop' ]</default>
|
||||||
|
<_summary>List of desktop file IDs for favorite applications</_summary>
|
||||||
|
<_description>
|
||||||
|
The applications corresponding to these identifiers
|
||||||
|
will be displayed in the favorites area.
|
||||||
|
</_description>
|
||||||
|
</key>
|
||||||
|
<key name="disabled-open-search-providers" type="as">
|
||||||
|
<default>[]</default>
|
||||||
|
<_summary>disabled OpenSearch providers</_summary>
|
||||||
|
</key>
|
||||||
|
<key name="command-history" type="as">
|
||||||
|
<default>[]</default>
|
||||||
|
<_summary>History for command (Alt-F2) dialog</_summary>
|
||||||
|
</key>
|
||||||
|
<key name="looking-glass-history" type="as">
|
||||||
|
<default>[]</default>
|
||||||
|
<_summary>History for the looking glass dialog</_summary>
|
||||||
|
</key>
|
||||||
|
<child name="clock" schema="org.gnome.shell.clock"/>
|
||||||
|
<child name="calendar" schema="org.gnome.shell.calendar"/>
|
||||||
|
<child name="recorder" schema="org.gnome.shell.recorder"/>
|
||||||
|
</schema>
|
||||||
|
|
||||||
|
<schema id="org.gnome.shell.calendar" path="/org/gnome/shell/calendar/"
|
||||||
|
gettext-domain="@GETTEXT_PACKAGE@">
|
||||||
|
<key name="show-weekdate" type="b">
|
||||||
|
<default>false</default>
|
||||||
|
<_summary>Show the week date in the calendar</_summary>
|
||||||
|
<_description>
|
||||||
|
If true, display the ISO week date in the calendar.
|
||||||
|
</_description>
|
||||||
|
</key>
|
||||||
|
</schema>
|
||||||
|
|
||||||
|
<schema id="org.gnome.shell.clock" path="/org/gnome/shell/clock/"
|
||||||
|
gettext-domain="@GETTEXT_PACKAGE@">
|
||||||
|
<key name="show-seconds" type="b">
|
||||||
|
<default>false</default>
|
||||||
|
<_summary>Show time with seconds</_summary>
|
||||||
|
<_description>
|
||||||
|
If true, display seconds in time.
|
||||||
|
</_description>
|
||||||
|
</key>
|
||||||
|
<key name="show-date" type="b">
|
||||||
|
<default>false</default>
|
||||||
|
<_summary>Show date in clock</_summary>
|
||||||
|
<_description>
|
||||||
|
If true, display date in the clock, in addition to time.
|
||||||
|
</_description>
|
||||||
|
</key>
|
||||||
|
</schema>
|
||||||
|
|
||||||
|
<schema id="org.gnome.shell.recorder" path="/org/gnome/shell/recorder/"
|
||||||
|
gettext-domain="@GETTEXT_PACKAGE@">
|
||||||
|
<key name="framerate" type="i">
|
||||||
|
<default>15</default>
|
||||||
|
<_summary>Framerate used for recording screencasts.</_summary>
|
||||||
|
<_description>
|
||||||
|
The framerate of the resulting screencast recordered
|
||||||
|
by GNOME Shell's screencast recorder in frames-per-second.
|
||||||
|
</_description>
|
||||||
|
</key>
|
||||||
|
<key name="pipeline" type="s">
|
||||||
|
<default>''</default>
|
||||||
|
<_summary>The gstreamer pipeline used to encode the screencast</_summary>
|
||||||
|
<_description>
|
||||||
|
Sets the GStreamer pipeline used to encode recordings.
|
||||||
|
It follows the syntax used for gst-launch. The pipeline should have
|
||||||
|
an unconnected sink pad where the recorded video is recorded. It will
|
||||||
|
normally have a unconnected source pad; output from that pad
|
||||||
|
will be written into the output file. However the pipeline can also
|
||||||
|
take care of its own output - this might be used to send the output
|
||||||
|
to an icecast server via shout2send or similar. When unset or set
|
||||||
|
to an empty value, the default pipeline will be used. This is currently
|
||||||
|
'videorate ! vp8enc quality=10 speed=2 threads=%T ! queue ! webmmux'
|
||||||
|
and records to WEBM using the VP8 codec. %T is used as a placeholder
|
||||||
|
for a guess at the optimal thread count on the system.
|
||||||
|
</_description>
|
||||||
|
</key>
|
||||||
|
<key name="file-extension" type="s">
|
||||||
|
<default>'webm'</default>
|
||||||
|
<_summary>File extension used for storing the screencast</_summary>
|
||||||
|
<_description>
|
||||||
|
The filename for recorded screencasts will be a unique filename
|
||||||
|
based on the current date, and use this extension. It should be
|
||||||
|
changed when recording to a different container format.
|
||||||
|
</_description>
|
||||||
|
</key>
|
||||||
|
</schema>
|
||||||
|
</schemalist>
|
@ -1,202 +0,0 @@
|
|||||||
<schemalist>
|
|
||||||
<schema id="org.gnome.shell" path="/org/gnome/shell/"
|
|
||||||
gettext-domain="@GETTEXT_PACKAGE@">
|
|
||||||
<key name="development-tools" type="b">
|
|
||||||
<default>true</default>
|
|
||||||
<_summary>
|
|
||||||
Enable internal tools useful for developers and testers from Alt-F2
|
|
||||||
</_summary>
|
|
||||||
<_description>
|
|
||||||
Allows access to internal debugging and monitoring tools
|
|
||||||
using the Alt-F2 dialog.
|
|
||||||
</_description>
|
|
||||||
</key>
|
|
||||||
<key name="enabled-extensions" type="as">
|
|
||||||
<default>[]</default>
|
|
||||||
<_summary>Uuids of extensions to enable</_summary>
|
|
||||||
<_description>
|
|
||||||
GNOME Shell extensions have a uuid property; this key lists extensions
|
|
||||||
which should be loaded. Any extension that wants to be loaded needs
|
|
||||||
to be in this list. You can also manipulate this list with the
|
|
||||||
EnableExtension and DisableExtension DBus methods on org.gnome.Shell.
|
|
||||||
</_description>
|
|
||||||
</key>
|
|
||||||
<key name="enable-app-monitoring" type="b">
|
|
||||||
<default>true</default>
|
|
||||||
<_summary>Whether to collect stats about applications usage</_summary>
|
|
||||||
<_description>
|
|
||||||
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.
|
|
||||||
</_description>
|
|
||||||
</key>
|
|
||||||
<key name="favorite-apps" type="as">
|
|
||||||
<default>[ 'epiphany.desktop', 'evolution.desktop', 'empathy.desktop', 'rhythmbox.desktop', 'shotwell.desktop', 'libreoffice-writer.desktop', 'nautilus.desktop', 'gnome-documents.desktop' ]</default>
|
|
||||||
<_summary>List of desktop file IDs for favorite applications</_summary>
|
|
||||||
<_description>
|
|
||||||
The applications corresponding to these identifiers
|
|
||||||
will be displayed in the favorites area.
|
|
||||||
</_description>
|
|
||||||
</key>
|
|
||||||
<key name="command-history" type="as">
|
|
||||||
<default>[]</default>
|
|
||||||
<_summary>History for command (Alt-F2) dialog</_summary>
|
|
||||||
</key>
|
|
||||||
<key name="looking-glass-history" type="as">
|
|
||||||
<default>[]</default>
|
|
||||||
<_summary>History for the looking glass dialog</_summary>
|
|
||||||
</key>
|
|
||||||
<key name="saved-im-presence" type="i">
|
|
||||||
<default>1</default>
|
|
||||||
<_summary>Internally used to store the last IM presence explicitly set by the user. The
|
|
||||||
value here is from the TpConnectionPresenceType enumeration.</_summary>
|
|
||||||
</key>
|
|
||||||
<key name="saved-session-presence" type="i">
|
|
||||||
<default>0</default>
|
|
||||||
<_summary>Internally used to store the last session presence status for the user. The
|
|
||||||
value here is from the GsmPresenceStatus enumeration.</_summary>
|
|
||||||
</key>
|
|
||||||
<child name="calendar" schema="org.gnome.shell.calendar"/>
|
|
||||||
<child name="recorder" schema="org.gnome.shell.recorder"/>
|
|
||||||
<child name="keybindings" schema="org.gnome.shell.keybindings"/>
|
|
||||||
<child name="keyboard" schema="org.gnome.shell.keyboard"/>
|
|
||||||
</schema>
|
|
||||||
|
|
||||||
<schema id="org.gnome.shell.calendar" path="/org/gnome/shell/calendar/"
|
|
||||||
gettext-domain="@GETTEXT_PACKAGE@">
|
|
||||||
<key name="show-weekdate" type="b">
|
|
||||||
<default>false</default>
|
|
||||||
<_summary>Show the week date in the calendar</_summary>
|
|
||||||
<_description>
|
|
||||||
If true, display the ISO week date in the calendar.
|
|
||||||
</_description>
|
|
||||||
</key>
|
|
||||||
</schema>
|
|
||||||
|
|
||||||
<schema id="org.gnome.shell.keybindings" path="/org/gnome/shell/keybindings/"
|
|
||||||
gettext-domain="@GETTEXT_PACKAGE@">
|
|
||||||
<key name="open-application-menu" type="as">
|
|
||||||
<default>["<Super>F10"]</default>
|
|
||||||
<_summary>Keybinding to open the application menu</_summary>
|
|
||||||
<_description>
|
|
||||||
Keybinding to open the application menu.
|
|
||||||
</_description>
|
|
||||||
</key>
|
|
||||||
<key name="toggle-message-tray" type="as">
|
|
||||||
<default>["<Super>m"]</default>
|
|
||||||
<_summary>Keybinding to toggle the visibility of the message tray</_summary>
|
|
||||||
<_description>
|
|
||||||
Keybinding to toggle the visibility of the message tray.
|
|
||||||
</_description>
|
|
||||||
</key>
|
|
||||||
<key name="toggle-recording" type="as">
|
|
||||||
<default><![CDATA[['<Control><Shift><Alt>r']]]></default>
|
|
||||||
<_summary>Keybinding to toggle the screen recorder</_summary>
|
|
||||||
<_description>
|
|
||||||
Keybinding to start/stop the builtin screen recorder.
|
|
||||||
</_description>
|
|
||||||
</key>
|
|
||||||
</schema>
|
|
||||||
|
|
||||||
<schema id="org.gnome.shell.keyboard" path="/org/gnome/shell/keyboard/"
|
|
||||||
gettext-domain="@GETTEXT_PACKAGE@">
|
|
||||||
<key name="keyboard-type" type="s">
|
|
||||||
<default>'touch'</default>
|
|
||||||
<_summary>Which keyboard to use</_summary>
|
|
||||||
<_description>
|
|
||||||
The type of keyboard to use.
|
|
||||||
</_description>
|
|
||||||
</key>
|
|
||||||
</schema>
|
|
||||||
|
|
||||||
<schema id="org.gnome.shell.recorder" path="/org/gnome/shell/recorder/"
|
|
||||||
gettext-domain="@GETTEXT_PACKAGE@">
|
|
||||||
<key name="framerate" type="i">
|
|
||||||
<default>30</default>
|
|
||||||
<_summary>Framerate used for recording screencasts.</_summary>
|
|
||||||
<_description>
|
|
||||||
The framerate of the resulting screencast recordered
|
|
||||||
by GNOME Shell's screencast recorder in frames-per-second.
|
|
||||||
</_description>
|
|
||||||
</key>
|
|
||||||
<key name="pipeline" type="s">
|
|
||||||
<default>''</default>
|
|
||||||
<_summary>The gstreamer pipeline used to encode the screencast</_summary>
|
|
||||||
<_description>
|
|
||||||
Sets the GStreamer pipeline used to encode recordings.
|
|
||||||
It follows the syntax used for gst-launch. The pipeline should have
|
|
||||||
an unconnected sink pad where the recorded video is recorded. It will
|
|
||||||
normally have a unconnected source pad; output from that pad
|
|
||||||
will be written into the output file. However the pipeline can also
|
|
||||||
take care of its own output - this might be used to send the output
|
|
||||||
to an icecast server via shout2send or similar. When unset or set
|
|
||||||
to an empty value, the default pipeline will be used. This is currently
|
|
||||||
'vp8enc min_quantizer=13 max_quantizer=13 cpu-used=5 deadline=1000000 threads=%T ! queue ! webmmux'
|
|
||||||
and records to WEBM using the VP8 codec. %T is used as a placeholder
|
|
||||||
for a guess at the optimal thread count on the system.
|
|
||||||
</_description>
|
|
||||||
</key>
|
|
||||||
<key name="file-extension" type="s">
|
|
||||||
<default>'webm'</default>
|
|
||||||
<_summary>File extension used for storing the screencast</_summary>
|
|
||||||
<_description>
|
|
||||||
The filename for recorded screencasts will be a unique filename
|
|
||||||
based on the current date, and use this extension. It should be
|
|
||||||
changed when recording to a different container format.
|
|
||||||
</_description>
|
|
||||||
</key>
|
|
||||||
</schema>
|
|
||||||
|
|
||||||
<schema id="org.gnome.shell.overrides" path="/org/gnome/shell/overrides/">
|
|
||||||
<key name="attach-modal-dialogs" type="b">
|
|
||||||
<default>true</default>
|
|
||||||
<summary>Attach modal dialog to the parent window</summary>
|
|
||||||
<description>
|
|
||||||
This key overrides the key in org.gnome.mutter when running
|
|
||||||
GNOME Shell.
|
|
||||||
</description>
|
|
||||||
</key>
|
|
||||||
|
|
||||||
<key name="button-layout" type="s">
|
|
||||||
<default>":close"</default>
|
|
||||||
<summary>Arrangement of buttons on the titlebar</summary>
|
|
||||||
<description>
|
|
||||||
This key overrides the key in org.gnome.desktop.wm.preferences when
|
|
||||||
running GNOME Shell.
|
|
||||||
</description>
|
|
||||||
</key>
|
|
||||||
|
|
||||||
<key name="edge-tiling" type="b">
|
|
||||||
<default>true</default>
|
|
||||||
<summary>Enable edge tiling when dropping windows on screen edges</summary>
|
|
||||||
<description>
|
|
||||||
This key overrides the key in org.gnome.mutter when running GNOME Shell.
|
|
||||||
</description>
|
|
||||||
</key>
|
|
||||||
|
|
||||||
<key name="dynamic-workspaces" type="b">
|
|
||||||
<default>true</default>
|
|
||||||
<summary>Workspaces are managed dynamically</summary>
|
|
||||||
<description>
|
|
||||||
This key overrides the key in org.gnome.mutter when running GNOME Shell.
|
|
||||||
</description>
|
|
||||||
</key>
|
|
||||||
|
|
||||||
<key name="workspaces-only-on-primary" type="b">
|
|
||||||
<default>true</default>
|
|
||||||
<summary>Workspaces only on primary monitor</summary>
|
|
||||||
<description>
|
|
||||||
This key overrides the key in org.gnome.mutter when running GNOME Shell.
|
|
||||||
</description>
|
|
||||||
</key>
|
|
||||||
|
|
||||||
<key name="focus-change-on-pointer-rest" type="b">
|
|
||||||
<default>true</default>
|
|
||||||
<summary>Delay focus changes in mouse mode until the pointer stops moving</summary>
|
|
||||||
<description>
|
|
||||||
This key overrides the key in org.gnome.mutter when running GNOME Shell.
|
|
||||||
</description>
|
|
||||||
</key>
|
|
||||||
</schema>
|
|
||||||
</schemalist>
|
|
7
data/search_providers/google.xml
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<OpenSearchDescription xmlns="http://a9.com/-/spec/opensearch/1.1/">
|
||||||
|
<ShortName>Google</ShortName>
|
||||||
|
<Description>Google Search</Description>
|
||||||
|
<InputEncoding>UTF-8</InputEncoding>
|
||||||
|
<Image width="16" height="16">data:image/x-icon;base64,AAABAAEAEBAAAAEAGABoAwAAFgAAACgAAAAQAAAAIAAAAAEAGAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADs9Pt8xetPtu9FsfFNtu%2BTzvb2%2B%2Fne4dFJeBw0egA%2FfAJAfAA8ewBBegAAAAD%2B%2FPtft98Mp%2BwWsfAVsvEbs%2FQeqvF8xO7%2F%2F%2F63yqkxdgM7gwE%2FggM%2BfQA%2BegBDeQDe7PIbotgQufcMufEPtfIPsvAbs%2FQvq%2Bfz%2Bf%2F%2B%2B%2FZKhR05hgBBhQI8hgBAgAI9ewD0%2B%2Fg3pswAtO8Cxf4Kw%2FsJvvYAqupKsNv%2B%2Fv7%2F%2FP5VkSU0iQA7jQA9hgBDgQU%2BfQH%2F%2Ff%2FQ6fM4sM4KsN8AteMCruIqqdbZ7PH8%2Fv%2Fg6Nc%2Fhg05kAA8jAM9iQI%2BhQA%2BgQDQu6b97uv%2F%2F%2F7V8Pqw3eiWz97q8%2Ff%2F%2F%2F%2F7%2FPptpkkqjQE4kwA7kAA5iwI8iAA8hQCOSSKdXjiyflbAkG7u2s%2F%2B%2F%2F39%2F%2F7r8utrqEYtjQE8lgA7kwA7kwA9jwA9igA9hACiWSekVRyeSgiYSBHx6N%2F%2B%2Fv7k7OFRmiYtlAA5lwI7lwI4lAA7kgI9jwE9iwI4iQCoVhWcTxCmb0K%2BooT8%2Fv%2F7%2F%2F%2FJ2r8fdwI1mwA3mQA3mgA8lAE8lAE4jwA9iwE%2BhwGfXifWvqz%2B%2Ff%2F58u%2Fev6Dt4tr%2B%2F%2F2ZuIUsggA7mgM6mAM3lgA5lgA6kQE%2FkwBChwHt4dv%2F%2F%2F728ei1bCi7VAC5XQ7kz7n%2F%2F%2F6bsZkgcB03lQA9lgM7kwA2iQktZToPK4r9%2F%2F%2F9%2F%2F%2FSqYK5UwDKZAS9WALIkFn%2B%2F%2F3%2F%2BP8oKccGGcIRJrERILYFEMwAAuEAAdX%2F%2Ff7%2F%2FP%2B%2BfDvGXQLIZgLEWgLOjlf7%2F%2F%2F%2F%2F%2F9QU90EAPQAAf8DAP0AAfMAAOUDAtr%2F%2F%2F%2F7%2B%2Fu2bCTIYwDPZgDBWQDSr4P%2F%2Fv%2F%2F%2FP5GRuABAPkAA%2FwBAfkDAPAAAesAAN%2F%2F%2B%2Fz%2F%2F%2F64g1C5VwDMYwK8Yg7y5tz8%2Fv%2FV1PYKDOcAAP0DAf4AAf0AAfYEAOwAAuAAAAD%2F%2FPvi28ymXyChTATRrIb8%2F%2F3v8fk6P8MAAdUCAvoAAP0CAP0AAfYAAO4AAACAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACAAQAA</Image>
|
||||||
|
<Url type="text/html" method="GET" template="http://www.google.com/search?q={searchTerms}"/>
|
||||||
|
</OpenSearchDescription>
|
44
data/search_providers/wikipedia.xml
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
<OpenSearchDescription xmlns="http://a9.com/-/spec/opensearch/1.1/">
|
||||||
|
<ShortName>Wikipedia</ShortName>
|
||||||
|
<Description>Wikipedia, the free encyclopedia</Description>
|
||||||
|
<InputEncoding>UTF-8</InputEncoding>
|
||||||
|
<Image width="16" height="16">data:image/x-icon;base64,AAABAAEAEBAQAAEABAAoAQAAFgAAACgAAAAQAAAAIAAAAAEABAAAAAAAAAAAAAAAAAAAAAAAEAAAAAAAAAAEAgQAhIOEAMjHyABIR0gA6ejpAGlqaQCpqKkAKCgoAPz9%2FAAZGBkAmJiYANjZ2ABXWFcAent6ALm6uQA8OjwAiIiIiIiIiIiIiI4oiL6IiIiIgzuIV4iIiIhndo53KIiIiB%2FWvXoYiIiIfEZfWBSIiIEGi%2FfoqoiIgzuL84i9iIjpGIoMiEHoiMkos3FojmiLlUipYliEWIF%2BiDe0GoRa7D6GPbjcu1yIiIiIiIiIiIiIiIiIiIiIiIiIiIiIiIgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA</Image>
|
||||||
|
<Url type="text/html" method="GET" template="http://{language}.wikipedia.org/wiki/Special:Search?search={searchTerms}"/>
|
||||||
|
<!-- The criterion for being below is being listed with more than 100,000
|
||||||
|
articles on http://meta.wikimedia.org/wiki/List_of_Wikipedias -->
|
||||||
|
<Language>ar</Language>
|
||||||
|
<Language>bg</Language>
|
||||||
|
<Language>ca</Language>
|
||||||
|
<Language>cs</Language>
|
||||||
|
<Language>da</Language>
|
||||||
|
<Language>de</Language>
|
||||||
|
<Language>en</Language>
|
||||||
|
<Language>eo</Language>
|
||||||
|
<Language>es</Language>
|
||||||
|
<Language>fa</Language>
|
||||||
|
<Language>fi</Language>
|
||||||
|
<Language>fr</Language>
|
||||||
|
<Language>he</Language>
|
||||||
|
<Language>hu</Language>
|
||||||
|
<Language>id</Language>
|
||||||
|
<Language>it</Language>
|
||||||
|
<Language>ja</Language>
|
||||||
|
<Language>ko</Language>
|
||||||
|
<Language>lt</Language>
|
||||||
|
<Language>nl</Language>
|
||||||
|
<Language>no</Language>
|
||||||
|
<Language>pl</Language>
|
||||||
|
<Language>pt</Language>
|
||||||
|
<Language>ro</Language>
|
||||||
|
<Language>ru</Language>
|
||||||
|
<Language>sk</Language>
|
||||||
|
<Language>sl</Language>
|
||||||
|
<Language>sr</Language>
|
||||||
|
<Language>sv</Language>
|
||||||
|
<Language>tr</Language>
|
||||||
|
<Language>uk</Language>
|
||||||
|
<Language>vi</Language>
|
||||||
|
<Language>vo</Language>
|
||||||
|
<Language>war</Language>
|
||||||
|
<Language>zh</Language>
|
||||||
|
</OpenSearchDescription>
|
26
data/shaders/dim-window.glsl
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
#version 110
|
||||||
|
uniform sampler2D sampler0;
|
||||||
|
uniform float fraction;
|
||||||
|
uniform float height;
|
||||||
|
const float c = -0.2;
|
||||||
|
const float border_max_height = 60.0;
|
||||||
|
|
||||||
|
mat4 contrast = mat4 (1.0 + c, 0.0, 0.0, 0.0,
|
||||||
|
0.0, 1.0 + c, 0.0, 0.0,
|
||||||
|
0.0, 0.0, 1.0 + c, 0.0,
|
||||||
|
0.0, 0.0, 0.0, 1.0);
|
||||||
|
vec4 off = vec4(0.633, 0.633, 0.633, 0);
|
||||||
|
void main()
|
||||||
|
{
|
||||||
|
vec4 color = texture2D(sampler0, gl_TexCoord[0].st);
|
||||||
|
float y = height * gl_TexCoord[0][1];
|
||||||
|
|
||||||
|
// To reduce contrast, blend with a mid gray
|
||||||
|
gl_FragColor = color * contrast - off * c;
|
||||||
|
|
||||||
|
// We only fully dim at a distance of BORDER_MAX_HEIGHT from the edge and
|
||||||
|
// when the fraction is 1.0. For other locations and fractions we linearly
|
||||||
|
// interpolate back to the original undimmed color.
|
||||||
|
gl_FragColor = color + (gl_FragColor - color) * min(y / border_max_height, 1.0);
|
||||||
|
gl_FragColor = color + (gl_FragColor - color) * fraction;
|
||||||
|
}
|
@ -10,11 +10,11 @@
|
|||||||
xmlns:xlink="http://www.w3.org/1999/xlink"
|
xmlns:xlink="http://www.w3.org/1999/xlink"
|
||||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
width="29"
|
width="28"
|
||||||
height="29"
|
height="25"
|
||||||
id="svg10621"
|
id="svg10621"
|
||||||
version="1.1"
|
version="1.1"
|
||||||
inkscape:version="0.48.2 r9819"
|
inkscape:version="0.48.1 r9760"
|
||||||
sodipodi:docname="calendar-today.svg">
|
sodipodi:docname="calendar-today.svg">
|
||||||
<defs
|
<defs
|
||||||
id="defs10623">
|
id="defs10623">
|
||||||
@ -118,17 +118,6 @@
|
|||||||
fx="51"
|
fx="51"
|
||||||
fy="30"
|
fy="30"
|
||||||
r="42" />
|
r="42" />
|
||||||
<radialGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
xlink:href="#linearGradient34508-1-3"
|
|
||||||
id="radialGradient3113"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
gradientTransform="matrix(0.72146227,0,0,0.27484277,14.205424,21.754717)"
|
|
||||||
cx="51"
|
|
||||||
cy="30"
|
|
||||||
fx="51"
|
|
||||||
fy="30"
|
|
||||||
r="42" />
|
|
||||||
</defs>
|
</defs>
|
||||||
<sodipodi:namedview
|
<sodipodi:namedview
|
||||||
id="base"
|
id="base"
|
||||||
@ -138,29 +127,20 @@
|
|||||||
inkscape:pageopacity="0"
|
inkscape:pageopacity="0"
|
||||||
inkscape:pageshadow="2"
|
inkscape:pageshadow="2"
|
||||||
inkscape:zoom="15.839192"
|
inkscape:zoom="15.839192"
|
||||||
inkscape:cx="20.652108"
|
inkscape:cx="8.3750933"
|
||||||
inkscape:cy="11.839084"
|
inkscape:cy="8.0837211"
|
||||||
inkscape:document-units="px"
|
inkscape:document-units="px"
|
||||||
inkscape:current-layer="layer1"
|
inkscape:current-layer="layer1"
|
||||||
showgrid="true"
|
showgrid="false"
|
||||||
fit-margin-top="0"
|
fit-margin-top="0"
|
||||||
fit-margin-left="0"
|
fit-margin-left="0"
|
||||||
fit-margin-right="0"
|
fit-margin-right="0"
|
||||||
fit-margin-bottom="0"
|
fit-margin-bottom="0"
|
||||||
inkscape:window-width="1280"
|
inkscape:window-width="1440"
|
||||||
inkscape:window-height="741"
|
inkscape:window-height="843"
|
||||||
inkscape:window-x="0"
|
inkscape:window-x="0"
|
||||||
inkscape:window-y="27"
|
inkscape:window-y="26"
|
||||||
inkscape:window-maximized="1"
|
inkscape:window-maximized="1" />
|
||||||
borderlayer="true">
|
|
||||||
<inkscape:grid
|
|
||||||
type="xygrid"
|
|
||||||
id="grid3109"
|
|
||||||
empspacing="5"
|
|
||||||
visible="true"
|
|
||||||
enabled="true"
|
|
||||||
snapvisiblegridlinesonly="true" />
|
|
||||||
</sodipodi:namedview>
|
|
||||||
<metadata
|
<metadata
|
||||||
id="metadata10626">
|
id="metadata10626">
|
||||||
<rdf:RDF>
|
<rdf:RDF>
|
||||||
@ -177,28 +157,31 @@
|
|||||||
inkscape:label="Layer 1"
|
inkscape:label="Layer 1"
|
||||||
inkscape:groupmode="layer"
|
inkscape:groupmode="layer"
|
||||||
id="layer1"
|
id="layer1"
|
||||||
transform="translate(-469.08263,-532.99307)">
|
transform="translate(-469.08263,-536.99307)">
|
||||||
<path
|
<g
|
||||||
sodipodi:type="arc"
|
id="g3003">
|
||||||
style="opacity:0.4625;color:#000000;fill:url(#radialGradient3113);fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:3;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
<path
|
||||||
id="path34506-3"
|
inkscape:export-ydpi="90"
|
||||||
sodipodi:cx="51"
|
inkscape:export-xdpi="90"
|
||||||
sodipodi:cy="30"
|
inkscape:export-filename="/home/jimmac/src/cvs/gnome/gnome-shell-design/mockups/motion/textures/panel.png"
|
||||||
sodipodi:rx="42"
|
transform="matrix(0.43692393,0,0,1.3783114,460.60467,517.48289)"
|
||||||
sodipodi:ry="16"
|
sodipodi:end="6.2831853"
|
||||||
d="M 9,29.999999 A 42,16 0 0 1 93,30 l -42,0 z"
|
sodipodi:start="3.1415927"
|
||||||
sodipodi:start="3.1415927"
|
d="M 9,29.999999 C 9.0000011,21.163443 27.804042,14 51.000002,14 74.195961,14 93,21.163444 93,30 l -42,0 z"
|
||||||
sodipodi:end="6.2831853"
|
sodipodi:ry="16"
|
||||||
transform="matrix(0.43692393,0,0,1.3783114,461.29951,517.6437)"
|
sodipodi:rx="42"
|
||||||
inkscape:export-filename="/home/jimmac/src/cvs/gnome/gnome-shell-design/mockups/motion/textures/panel.png"
|
sodipodi:cy="30"
|
||||||
inkscape:export-xdpi="90"
|
sodipodi:cx="51"
|
||||||
inkscape:export-ydpi="90" />
|
id="path34506-3"
|
||||||
<rect
|
style="opacity:0.4625;color:#000000;fill:url(#radialGradient2997);fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:3;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
||||||
style="fill:#ffffff;fill-opacity:0.50196078;stroke-width:0.43599999;stroke-miterlimit:4;stroke-dasharray:none"
|
sodipodi:type="arc" />
|
||||||
id="rect2996"
|
<rect
|
||||||
width="31"
|
y="558.85046"
|
||||||
height="3"
|
x="468.96878"
|
||||||
x="468.08264"
|
height="3.1425927"
|
||||||
y="558.99304" />
|
width="28.149134"
|
||||||
|
id="rect2996"
|
||||||
|
style="fill:#ffffff;fill-opacity:0.50196078;stroke-width:0.43599999;stroke-miterlimit:4;stroke-dasharray:none" />
|
||||||
|
</g>
|
||||||
</g>
|
</g>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 6.1 KiB After Width: | Height: | Size: 5.7 KiB |
@ -1,289 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
|
||||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
|
||||||
|
|
||||||
<svg
|
|
||||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
|
||||||
xmlns:cc="http://creativecommons.org/ns#"
|
|
||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
|
||||||
xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
||||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
|
||||||
width="24"
|
|
||||||
height="22"
|
|
||||||
id="svg3199"
|
|
||||||
version="1.1"
|
|
||||||
inkscape:version="0.48.1 r9760"
|
|
||||||
sodipodi:docname="checkbox.svg">
|
|
||||||
<defs
|
|
||||||
id="defs3201">
|
|
||||||
<linearGradient
|
|
||||||
id="linearGradient15404"
|
|
||||||
inkscape:collect="always">
|
|
||||||
<stop
|
|
||||||
id="stop15406"
|
|
||||||
offset="0"
|
|
||||||
style="stop-color:#515151;stop-opacity:1" />
|
|
||||||
<stop
|
|
||||||
id="stop15408"
|
|
||||||
offset="1"
|
|
||||||
style="stop-color:#292929;stop-opacity:1" />
|
|
||||||
</linearGradient>
|
|
||||||
<inkscape:perspective
|
|
||||||
sodipodi:type="inkscape:persp3d"
|
|
||||||
inkscape:vp_x="0 : 526.18109 : 1"
|
|
||||||
inkscape:vp_y="0 : 1000 : 0"
|
|
||||||
inkscape:vp_z="744.09448 : 526.18109 : 1"
|
|
||||||
inkscape:persp3d-origin="372.04724 : 350.78739 : 1"
|
|
||||||
id="perspective3207" />
|
|
||||||
<inkscape:perspective
|
|
||||||
id="perspective3187"
|
|
||||||
inkscape:persp3d-origin="0.5 : 0.33333333 : 1"
|
|
||||||
inkscape:vp_z="1 : 0.5 : 1"
|
|
||||||
inkscape:vp_y="0 : 1000 : 0"
|
|
||||||
inkscape:vp_x="0 : 0.5 : 1"
|
|
||||||
sodipodi:type="inkscape:persp3d" />
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
xlink:href="#linearGradient5872-5-1"
|
|
||||||
id="linearGradient5891-0-4"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
x1="205.84143"
|
|
||||||
y1="246.7094"
|
|
||||||
x2="206.74803"
|
|
||||||
y2="231.24142" />
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
id="linearGradient5872-5-1">
|
|
||||||
<stop
|
|
||||||
style="stop-color:#0b2e52;stop-opacity:1"
|
|
||||||
offset="0"
|
|
||||||
id="stop5874-4-4" />
|
|
||||||
<stop
|
|
||||||
style="stop-color:#1862af;stop-opacity:1"
|
|
||||||
offset="1"
|
|
||||||
id="stop5876-0-5" />
|
|
||||||
</linearGradient>
|
|
||||||
<inkscape:path-effect
|
|
||||||
effect="spiro"
|
|
||||||
id="path-effect5837-4-6"
|
|
||||||
is_visible="true" />
|
|
||||||
<inkscape:path-effect
|
|
||||||
effect="spiro"
|
|
||||||
id="path-effect14768"
|
|
||||||
is_visible="true" />
|
|
||||||
<inkscape:path-effect
|
|
||||||
effect="spiro"
|
|
||||||
id="path-effect5884-4-7"
|
|
||||||
is_visible="true" />
|
|
||||||
<linearGradient
|
|
||||||
y2="-388.72955"
|
|
||||||
x2="-93.031357"
|
|
||||||
y1="-396.34738"
|
|
||||||
x1="-93.031357"
|
|
||||||
gradientTransform="matrix(1.5918367,0,0,0.85714285,-256.56122,59.685418)"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
id="linearGradient14219"
|
|
||||||
xlink:href="#linearGradient15404"
|
|
||||||
inkscape:collect="always" />
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
id="linearGradient10013-4-63-6">
|
|
||||||
<stop
|
|
||||||
style="stop-color:#333333;stop-opacity:1;"
|
|
||||||
offset="0"
|
|
||||||
id="stop10015-2-76-1" />
|
|
||||||
<stop
|
|
||||||
style="stop-color:#292929;stop-opacity:1"
|
|
||||||
offset="1"
|
|
||||||
id="stop10017-46-15-8" />
|
|
||||||
</linearGradient>
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
id="linearGradient10597-5">
|
|
||||||
<stop
|
|
||||||
style="stop-color:#16191a;stop-opacity:1;"
|
|
||||||
offset="0"
|
|
||||||
id="stop10599-2" />
|
|
||||||
<stop
|
|
||||||
style="stop-color:#2b3133;stop-opacity:1"
|
|
||||||
offset="1"
|
|
||||||
id="stop10601-5" />
|
|
||||||
</linearGradient>
|
|
||||||
<linearGradient
|
|
||||||
y2="-322.16354"
|
|
||||||
x2="921.22498"
|
|
||||||
y1="-330.05121"
|
|
||||||
x1="921.32812"
|
|
||||||
gradientTransform="matrix(1.5918367,0,0,0.85714285,-1456.5464,275.45191)"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
id="linearGradient15374"
|
|
||||||
xlink:href="#linearGradient10013-4-63-6"
|
|
||||||
inkscape:collect="always" />
|
|
||||||
<linearGradient
|
|
||||||
gradientTransform="translate(-1199.9852,216.38048)"
|
|
||||||
y2="-227.07961"
|
|
||||||
x2="1203.9177"
|
|
||||||
y1="-217.56708"
|
|
||||||
x1="1203.9177"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
id="linearGradient15376"
|
|
||||||
xlink:href="#linearGradient10597-5"
|
|
||||||
inkscape:collect="always" />
|
|
||||||
<linearGradient
|
|
||||||
y2="-388.72955"
|
|
||||||
x2="-93.031357"
|
|
||||||
y1="-396.34738"
|
|
||||||
x1="-93.031357"
|
|
||||||
gradientTransform="matrix(1.5918367,0,0,0.85714285,-256.56122,59.685418)"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
id="linearGradient14219-6"
|
|
||||||
xlink:href="#linearGradient15404-9"
|
|
||||||
inkscape:collect="always" />
|
|
||||||
<linearGradient
|
|
||||||
id="linearGradient15404-9"
|
|
||||||
inkscape:collect="always">
|
|
||||||
<stop
|
|
||||||
id="stop15406-6"
|
|
||||||
offset="0"
|
|
||||||
style="stop-color:#515151;stop-opacity:1" />
|
|
||||||
<stop
|
|
||||||
id="stop15408-7"
|
|
||||||
offset="1"
|
|
||||||
style="stop-color:#292929;stop-opacity:1" />
|
|
||||||
</linearGradient>
|
|
||||||
</defs>
|
|
||||||
<sodipodi:namedview
|
|
||||||
id="base"
|
|
||||||
pagecolor="#000000"
|
|
||||||
bordercolor="#2d2d2d"
|
|
||||||
borderopacity="1"
|
|
||||||
inkscape:pageopacity="1"
|
|
||||||
inkscape:pageshadow="2"
|
|
||||||
inkscape:zoom="1"
|
|
||||||
inkscape:cx="71.516955"
|
|
||||||
inkscape:cy="5.8710559"
|
|
||||||
inkscape:document-units="px"
|
|
||||||
inkscape:current-layer="layer1"
|
|
||||||
showgrid="false"
|
|
||||||
inkscape:window-width="1412"
|
|
||||||
inkscape:window-height="1067"
|
|
||||||
inkscape:window-x="2635"
|
|
||||||
inkscape:window-y="226"
|
|
||||||
inkscape:window-maximized="0"
|
|
||||||
borderlayer="true"
|
|
||||||
inkscape:showpageshadow="false"
|
|
||||||
inkscape:snap-nodes="false"
|
|
||||||
inkscape:snap-bbox="true"
|
|
||||||
showborder="false">
|
|
||||||
<inkscape:grid
|
|
||||||
type="xygrid"
|
|
||||||
id="grid14843"
|
|
||||||
empspacing="5"
|
|
||||||
visible="true"
|
|
||||||
enabled="true"
|
|
||||||
snapvisiblegridlinesonly="true" />
|
|
||||||
</sodipodi:namedview>
|
|
||||||
<metadata
|
|
||||||
id="metadata3204">
|
|
||||||
<rdf:RDF>
|
|
||||||
<cc:Work
|
|
||||||
rdf:about="">
|
|
||||||
<dc:format>image/svg+xml</dc:format>
|
|
||||||
<dc:type
|
|
||||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
|
||||||
<dc:title></dc:title>
|
|
||||||
</cc:Work>
|
|
||||||
</rdf:RDF>
|
|
||||||
</metadata>
|
|
||||||
<g
|
|
||||||
inkscape:label="Layer 1"
|
|
||||||
inkscape:groupmode="layer"
|
|
||||||
id="layer1"
|
|
||||||
transform="translate(-342.5,-521.36218)">
|
|
||||||
<g
|
|
||||||
transform="matrix(0.80230061,0,0,0.80230061,-87.624044,-453.10297)"
|
|
||||||
id="g14586-0"
|
|
||||||
style="stroke-width:2.3714385;stroke-miterlimit:4;stroke-dasharray:none">
|
|
||||||
<g
|
|
||||||
inkscape:export-ydpi="90"
|
|
||||||
inkscape:export-xdpi="90"
|
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
|
||||||
transform="matrix(1.9969286,0,0,1.9969286,-397.05491,877.00482)"
|
|
||||||
id="g15291-9-6"
|
|
||||||
style="stroke-width:1.18754292;stroke-miterlimit:4;stroke-dasharray:none;display:inline;enable-background:new">
|
|
||||||
<g
|
|
||||||
transform="translate(877.50354,-102.83507)"
|
|
||||||
id="g16853-4-9"
|
|
||||||
style="stroke-width:1.18754292;stroke-miterlimit:4;stroke-dasharray:none;enable-background:new">
|
|
||||||
<rect
|
|
||||||
transform="scale(1,-1)"
|
|
||||||
style="color:#000000;fill:url(#linearGradient14219-6);fill-opacity:1;fill-rule:nonzero;stroke:#3465a4;stroke-width:1.24833274;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:new"
|
|
||||||
id="rect6506-6"
|
|
||||||
width="11.281681"
|
|
||||||
height="11.26221"
|
|
||||||
x="-409.59354"
|
|
||||||
y="-284.40115"
|
|
||||||
rx="1.0052766"
|
|
||||||
ry="1.0052764" />
|
|
||||||
</g>
|
|
||||||
</g>
|
|
||||||
<g
|
|
||||||
inkscape:export-ydpi="90"
|
|
||||||
inkscape:export-xdpi="90"
|
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
|
||||||
transform="translate(343.99999,987.99997)"
|
|
||||||
id="g5886-5"
|
|
||||||
style="stroke-width:2.3714385;stroke-miterlimit:4;stroke-dasharray:none;display:inline;enable-background:new" />
|
|
||||||
</g>
|
|
||||||
<g
|
|
||||||
transform="matrix(0.84337,0,0,0.84337,-110.16632,-503.56182)"
|
|
||||||
id="g14586">
|
|
||||||
<g
|
|
||||||
inkscape:export-ydpi="90"
|
|
||||||
inkscape:export-xdpi="90"
|
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
|
||||||
transform="matrix(1.9969286,0,0,1.9969286,-397.05491,877.00482)"
|
|
||||||
id="g15291-9"
|
|
||||||
style="display:inline;enable-background:new">
|
|
||||||
<g
|
|
||||||
transform="translate(877.50354,-102.83507)"
|
|
||||||
id="g16853-4"
|
|
||||||
style="enable-background:new" />
|
|
||||||
</g>
|
|
||||||
<g
|
|
||||||
inkscape:export-ydpi="90"
|
|
||||||
inkscape:export-xdpi="90"
|
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
|
||||||
transform="translate(343.99999,987.99997)"
|
|
||||||
id="g5886"
|
|
||||||
style="display:inline;enable-background:new">
|
|
||||||
<path
|
|
||||||
style="fill:none;stroke:url(#linearGradient5891-0-4);stroke-width:7.11431503;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
|
|
||||||
d="m 198.5,240 5.25,5.25 13.98616,-14.43081"
|
|
||||||
id="path5835"
|
|
||||||
inkscape:path-effect="#path-effect5837-4-6"
|
|
||||||
inkscape:original-d="m 198.5,240 5.25,5.25 13.98616,-14.43081"
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
sodipodi:nodetypes="ccc" />
|
|
||||||
<path
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
inkscape:original-d="m 198.5,240 5.25,5.25 13.91205,-14.31964"
|
|
||||||
inkscape:path-effect="#path-effect5837-4-6"
|
|
||||||
id="path5880"
|
|
||||||
d="m 198.5,240 5.25,5.25 13.91205,-14.31964"
|
|
||||||
style="fill:none;stroke:#4787c8;stroke-width:3.55715752;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
|
|
||||||
sodipodi:nodetypes="ccc" />
|
|
||||||
<path
|
|
||||||
style="fill:none;stroke:#7ea7d3;stroke-width:1.18571913px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
|
|
||||||
d="m 197.45937,240.47455 c -0.17828,-0.29362 -0.20087,-0.67548 -0.0603,-0.98892 0.14055,-0.31344 0.43739,-0.54812 0.77144,-0.62817 0.33405,-0.08 0.69314,-0.01 0.99635,0.15175 0.30321,0.16144 0.55146,0.40727 0.79165,0.65284 l 3.66429,3.74643 12.87946,-12.98973 c 0.20796,-0.20974 0.42306,-0.41969 0.68548,-0.55522 0.26242,-0.13553 0.57293,-0.19052 0.85827,-0.11426 0.14267,0.0381 0.27708,0.10787 0.38874,0.20452 0.11167,0.0966 0.20021,0.22004 0.25479,0.35726 0.0546,0.13722 0.075,0.28793 0.0585,0.43468 -0.0165,0.14674 -0.07,0.28919 -0.15422,0.41052"
|
|
||||||
id="path5882"
|
|
||||||
inkscape:path-effect="#path-effect5884-4-7"
|
|
||||||
inkscape:original-d="m 197.45937,240.47455 c 0.65604,-0.56057 2.02485,-1.34847 2.49911,-0.8125 l 3.66429,3.74643 12.87946,-12.98973 c 0.6875,-0.6875 2.09152,0.7375 2.09152,0.7375"
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
sodipodi:nodetypes="csccc" />
|
|
||||||
</g>
|
|
||||||
</g>
|
|
||||||
</g>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 11 KiB |
@ -1,198 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
|
||||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
|
||||||
|
|
||||||
<svg
|
|
||||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
|
||||||
xmlns:cc="http://creativecommons.org/ns#"
|
|
||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
|
||||||
xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
||||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
|
||||||
width="24"
|
|
||||||
height="22"
|
|
||||||
id="svg3199"
|
|
||||||
version="1.1"
|
|
||||||
inkscape:version="0.48.1 r9760"
|
|
||||||
sodipodi:docname="checkbox-off.svg">
|
|
||||||
<defs
|
|
||||||
id="defs3201">
|
|
||||||
<linearGradient
|
|
||||||
id="linearGradient15404"
|
|
||||||
inkscape:collect="always">
|
|
||||||
<stop
|
|
||||||
id="stop15406"
|
|
||||||
offset="0"
|
|
||||||
style="stop-color:#515151;stop-opacity:1" />
|
|
||||||
<stop
|
|
||||||
id="stop15408"
|
|
||||||
offset="1"
|
|
||||||
style="stop-color:#292929;stop-opacity:1" />
|
|
||||||
</linearGradient>
|
|
||||||
<inkscape:perspective
|
|
||||||
sodipodi:type="inkscape:persp3d"
|
|
||||||
inkscape:vp_x="0 : 526.18109 : 1"
|
|
||||||
inkscape:vp_y="0 : 1000 : 0"
|
|
||||||
inkscape:vp_z="744.09448 : 526.18109 : 1"
|
|
||||||
inkscape:persp3d-origin="372.04724 : 350.78739 : 1"
|
|
||||||
id="perspective3207" />
|
|
||||||
<inkscape:perspective
|
|
||||||
id="perspective3187"
|
|
||||||
inkscape:persp3d-origin="0.5 : 0.33333333 : 1"
|
|
||||||
inkscape:vp_z="1 : 0.5 : 1"
|
|
||||||
inkscape:vp_y="0 : 1000 : 0"
|
|
||||||
inkscape:vp_x="0 : 0.5 : 1"
|
|
||||||
sodipodi:type="inkscape:persp3d" />
|
|
||||||
<inkscape:path-effect
|
|
||||||
effect="spiro"
|
|
||||||
id="path-effect5837-4-6"
|
|
||||||
is_visible="true" />
|
|
||||||
<inkscape:path-effect
|
|
||||||
effect="spiro"
|
|
||||||
id="path-effect14768"
|
|
||||||
is_visible="true" />
|
|
||||||
<inkscape:path-effect
|
|
||||||
effect="spiro"
|
|
||||||
id="path-effect5884-4-7"
|
|
||||||
is_visible="true" />
|
|
||||||
<linearGradient
|
|
||||||
y2="-388.72955"
|
|
||||||
x2="-93.031357"
|
|
||||||
y1="-396.34738"
|
|
||||||
x1="-93.031357"
|
|
||||||
gradientTransform="matrix(1.5918367,0,0,0.85714285,-256.56122,59.685418)"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
id="linearGradient14219"
|
|
||||||
xlink:href="#linearGradient15404"
|
|
||||||
inkscape:collect="always" />
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
id="linearGradient10013-4-63-6">
|
|
||||||
<stop
|
|
||||||
style="stop-color:#333333;stop-opacity:1;"
|
|
||||||
offset="0"
|
|
||||||
id="stop10015-2-76-1" />
|
|
||||||
<stop
|
|
||||||
style="stop-color:#292929;stop-opacity:1"
|
|
||||||
offset="1"
|
|
||||||
id="stop10017-46-15-8" />
|
|
||||||
</linearGradient>
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
id="linearGradient10597-5">
|
|
||||||
<stop
|
|
||||||
style="stop-color:#16191a;stop-opacity:1;"
|
|
||||||
offset="0"
|
|
||||||
id="stop10599-2" />
|
|
||||||
<stop
|
|
||||||
style="stop-color:#2b3133;stop-opacity:1"
|
|
||||||
offset="1"
|
|
||||||
id="stop10601-5" />
|
|
||||||
</linearGradient>
|
|
||||||
<linearGradient
|
|
||||||
y2="-322.16354"
|
|
||||||
x2="921.22498"
|
|
||||||
y1="-330.05121"
|
|
||||||
x1="921.32812"
|
|
||||||
gradientTransform="matrix(1.5918367,0,0,0.85714285,-1456.5464,275.45191)"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
id="linearGradient15374"
|
|
||||||
xlink:href="#linearGradient10013-4-63-6"
|
|
||||||
inkscape:collect="always" />
|
|
||||||
<linearGradient
|
|
||||||
gradientTransform="translate(-1199.9852,216.38048)"
|
|
||||||
y2="-227.07961"
|
|
||||||
x2="1203.9177"
|
|
||||||
y1="-217.56708"
|
|
||||||
x1="1203.9177"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
id="linearGradient15376"
|
|
||||||
xlink:href="#linearGradient10597-5"
|
|
||||||
inkscape:collect="always" />
|
|
||||||
</defs>
|
|
||||||
<sodipodi:namedview
|
|
||||||
id="base"
|
|
||||||
pagecolor="#000000"
|
|
||||||
bordercolor="#2d2d2d"
|
|
||||||
borderopacity="1"
|
|
||||||
inkscape:pageopacity="1"
|
|
||||||
inkscape:pageshadow="2"
|
|
||||||
inkscape:zoom="1"
|
|
||||||
inkscape:cx="6.1225392"
|
|
||||||
inkscape:cy="3.6003241"
|
|
||||||
inkscape:document-units="px"
|
|
||||||
inkscape:current-layer="layer1"
|
|
||||||
showgrid="false"
|
|
||||||
inkscape:window-width="1412"
|
|
||||||
inkscape:window-height="1067"
|
|
||||||
inkscape:window-x="2116"
|
|
||||||
inkscape:window-y="261"
|
|
||||||
inkscape:window-maximized="0"
|
|
||||||
borderlayer="true"
|
|
||||||
inkscape:showpageshadow="false"
|
|
||||||
inkscape:snap-nodes="false"
|
|
||||||
inkscape:snap-bbox="true"
|
|
||||||
showborder="false">
|
|
||||||
<inkscape:grid
|
|
||||||
type="xygrid"
|
|
||||||
id="grid14843"
|
|
||||||
empspacing="5"
|
|
||||||
visible="true"
|
|
||||||
enabled="true"
|
|
||||||
snapvisiblegridlinesonly="true" />
|
|
||||||
</sodipodi:namedview>
|
|
||||||
<metadata
|
|
||||||
id="metadata3204">
|
|
||||||
<rdf:RDF>
|
|
||||||
<cc:Work
|
|
||||||
rdf:about="">
|
|
||||||
<dc:format>image/svg+xml</dc:format>
|
|
||||||
<dc:type
|
|
||||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
|
||||||
<dc:title></dc:title>
|
|
||||||
</cc:Work>
|
|
||||||
</rdf:RDF>
|
|
||||||
</metadata>
|
|
||||||
<g
|
|
||||||
inkscape:label="Layer 1"
|
|
||||||
inkscape:groupmode="layer"
|
|
||||||
id="layer1"
|
|
||||||
transform="translate(-342.5,-521.36218)">
|
|
||||||
<g
|
|
||||||
transform="matrix(0.80230061,0,0,0.80230061,-87.624044,-453.10297)"
|
|
||||||
id="g14586"
|
|
||||||
style="stroke-width:2.3714385;stroke-miterlimit:4;stroke-dasharray:none">
|
|
||||||
<g
|
|
||||||
inkscape:export-ydpi="90"
|
|
||||||
inkscape:export-xdpi="90"
|
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
|
||||||
transform="matrix(1.9969286,0,0,1.9969286,-397.05491,877.00482)"
|
|
||||||
id="g15291-9"
|
|
||||||
style="stroke-width:1.18754292;stroke-miterlimit:4;stroke-dasharray:none;display:inline;enable-background:new">
|
|
||||||
<g
|
|
||||||
transform="translate(877.50354,-102.83507)"
|
|
||||||
id="g16853-4"
|
|
||||||
style="stroke-width:1.18754292;stroke-miterlimit:4;stroke-dasharray:none;enable-background:new">
|
|
||||||
<rect
|
|
||||||
transform="scale(1,-1)"
|
|
||||||
style="color:#000000;fill:url(#linearGradient14219);fill-opacity:1;fill-rule:nonzero;stroke:#3465a4;stroke-width:1.24833274;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:new"
|
|
||||||
id="rect6506-6"
|
|
||||||
width="11.281681"
|
|
||||||
height="11.26221"
|
|
||||||
x="-409.59354"
|
|
||||||
y="-284.40115"
|
|
||||||
rx="1.0052766"
|
|
||||||
ry="1.0052764" />
|
|
||||||
</g>
|
|
||||||
</g>
|
|
||||||
<g
|
|
||||||
inkscape:export-ydpi="90"
|
|
||||||
inkscape:export-xdpi="90"
|
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
|
||||||
transform="translate(343.99999,987.99997)"
|
|
||||||
id="g5886"
|
|
||||||
style="stroke-width:2.3714385;stroke-miterlimit:4;stroke-dasharray:none;display:inline;enable-background:new" />
|
|
||||||
</g>
|
|
||||||
</g>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 6.5 KiB |
@ -1,218 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
|
||||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
|
||||||
|
|
||||||
<svg
|
|
||||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
|
||||||
xmlns:cc="http://creativecommons.org/ns#"
|
|
||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
|
||||||
xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
||||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
|
||||||
width="24"
|
|
||||||
height="22"
|
|
||||||
id="svg3199"
|
|
||||||
version="1.1"
|
|
||||||
inkscape:version="0.48.1 r9760"
|
|
||||||
sodipodi:docname="checkbox.svg">
|
|
||||||
<defs
|
|
||||||
id="defs3201">
|
|
||||||
<linearGradient
|
|
||||||
id="linearGradient15404"
|
|
||||||
inkscape:collect="always">
|
|
||||||
<stop
|
|
||||||
id="stop15406"
|
|
||||||
offset="0"
|
|
||||||
style="stop-color:#515151;stop-opacity:1" />
|
|
||||||
<stop
|
|
||||||
id="stop15408"
|
|
||||||
offset="1"
|
|
||||||
style="stop-color:#292929;stop-opacity:1" />
|
|
||||||
</linearGradient>
|
|
||||||
<inkscape:perspective
|
|
||||||
sodipodi:type="inkscape:persp3d"
|
|
||||||
inkscape:vp_x="0 : 526.18109 : 1"
|
|
||||||
inkscape:vp_y="0 : 1000 : 0"
|
|
||||||
inkscape:vp_z="744.09448 : 526.18109 : 1"
|
|
||||||
inkscape:persp3d-origin="372.04724 : 350.78739 : 1"
|
|
||||||
id="perspective3207" />
|
|
||||||
<inkscape:perspective
|
|
||||||
id="perspective3187"
|
|
||||||
inkscape:persp3d-origin="0.5 : 0.33333333 : 1"
|
|
||||||
inkscape:vp_z="1 : 0.5 : 1"
|
|
||||||
inkscape:vp_y="0 : 1000 : 0"
|
|
||||||
inkscape:vp_x="0 : 0.5 : 1"
|
|
||||||
sodipodi:type="inkscape:persp3d" />
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
xlink:href="#linearGradient5872-5-1"
|
|
||||||
id="linearGradient5891-0-4"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
x1="205.84143"
|
|
||||||
y1="246.7094"
|
|
||||||
x2="206.74803"
|
|
||||||
y2="231.24142" />
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
id="linearGradient5872-5-1">
|
|
||||||
<stop
|
|
||||||
style="stop-color:#0b2e52;stop-opacity:1"
|
|
||||||
offset="0"
|
|
||||||
id="stop5874-4-4" />
|
|
||||||
<stop
|
|
||||||
style="stop-color:#1862af;stop-opacity:1"
|
|
||||||
offset="1"
|
|
||||||
id="stop5876-0-5" />
|
|
||||||
</linearGradient>
|
|
||||||
<inkscape:path-effect
|
|
||||||
effect="spiro"
|
|
||||||
id="path-effect5837-4-6"
|
|
||||||
is_visible="true" />
|
|
||||||
<inkscape:path-effect
|
|
||||||
effect="spiro"
|
|
||||||
id="path-effect14768"
|
|
||||||
is_visible="true" />
|
|
||||||
<inkscape:path-effect
|
|
||||||
effect="spiro"
|
|
||||||
id="path-effect5884-4-7"
|
|
||||||
is_visible="true" />
|
|
||||||
<linearGradient
|
|
||||||
y2="-388.72955"
|
|
||||||
x2="-93.031357"
|
|
||||||
y1="-396.34738"
|
|
||||||
x1="-93.031357"
|
|
||||||
gradientTransform="matrix(1.5918367,0,0,0.85714285,-256.56122,59.685418)"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
id="linearGradient14219"
|
|
||||||
xlink:href="#linearGradient15404"
|
|
||||||
inkscape:collect="always" />
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
id="linearGradient10013-4-63-6">
|
|
||||||
<stop
|
|
||||||
style="stop-color:#333333;stop-opacity:1;"
|
|
||||||
offset="0"
|
|
||||||
id="stop10015-2-76-1" />
|
|
||||||
<stop
|
|
||||||
style="stop-color:#292929;stop-opacity:1"
|
|
||||||
offset="1"
|
|
||||||
id="stop10017-46-15-8" />
|
|
||||||
</linearGradient>
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
id="linearGradient10597-5">
|
|
||||||
<stop
|
|
||||||
style="stop-color:#16191a;stop-opacity:1;"
|
|
||||||
offset="0"
|
|
||||||
id="stop10599-2" />
|
|
||||||
<stop
|
|
||||||
style="stop-color:#2b3133;stop-opacity:1"
|
|
||||||
offset="1"
|
|
||||||
id="stop10601-5" />
|
|
||||||
</linearGradient>
|
|
||||||
<linearGradient
|
|
||||||
y2="-322.16354"
|
|
||||||
x2="921.22498"
|
|
||||||
y1="-330.05121"
|
|
||||||
x1="921.32812"
|
|
||||||
gradientTransform="matrix(1.5918367,0,0,0.85714285,-1456.5464,275.45191)"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
id="linearGradient15374"
|
|
||||||
xlink:href="#linearGradient10013-4-63-6"
|
|
||||||
inkscape:collect="always" />
|
|
||||||
<linearGradient
|
|
||||||
gradientTransform="translate(-1199.9852,216.38048)"
|
|
||||||
y2="-227.07961"
|
|
||||||
x2="1203.9177"
|
|
||||||
y1="-217.56708"
|
|
||||||
x1="1203.9177"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
id="linearGradient15376"
|
|
||||||
xlink:href="#linearGradient10597-5"
|
|
||||||
inkscape:collect="always" />
|
|
||||||
</defs>
|
|
||||||
<sodipodi:namedview
|
|
||||||
id="base"
|
|
||||||
pagecolor="#000000"
|
|
||||||
bordercolor="#2d2d2d"
|
|
||||||
borderopacity="1"
|
|
||||||
inkscape:pageopacity="1"
|
|
||||||
inkscape:pageshadow="2"
|
|
||||||
inkscape:zoom="4"
|
|
||||||
inkscape:cx="71.247925"
|
|
||||||
inkscape:cy="33.339093"
|
|
||||||
inkscape:document-units="px"
|
|
||||||
inkscape:current-layer="layer1"
|
|
||||||
showgrid="false"
|
|
||||||
inkscape:window-width="1412"
|
|
||||||
inkscape:window-height="1067"
|
|
||||||
inkscape:window-x="2116"
|
|
||||||
inkscape:window-y="261"
|
|
||||||
inkscape:window-maximized="0"
|
|
||||||
borderlayer="true"
|
|
||||||
inkscape:showpageshadow="false"
|
|
||||||
inkscape:snap-nodes="false"
|
|
||||||
inkscape:snap-bbox="true"
|
|
||||||
showborder="false">
|
|
||||||
<inkscape:grid
|
|
||||||
type="xygrid"
|
|
||||||
id="grid14843"
|
|
||||||
empspacing="5"
|
|
||||||
visible="true"
|
|
||||||
enabled="true"
|
|
||||||
snapvisiblegridlinesonly="true" />
|
|
||||||
</sodipodi:namedview>
|
|
||||||
<metadata
|
|
||||||
id="metadata3204">
|
|
||||||
<rdf:RDF>
|
|
||||||
<cc:Work
|
|
||||||
rdf:about="">
|
|
||||||
<dc:format>image/svg+xml</dc:format>
|
|
||||||
<dc:type
|
|
||||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
|
||||||
<dc:title></dc:title>
|
|
||||||
</cc:Work>
|
|
||||||
</rdf:RDF>
|
|
||||||
</metadata>
|
|
||||||
<g
|
|
||||||
inkscape:label="Layer 1"
|
|
||||||
inkscape:groupmode="layer"
|
|
||||||
id="layer1"
|
|
||||||
transform="translate(-342.5,-521.36218)">
|
|
||||||
<g
|
|
||||||
transform="matrix(0.84337,0,0,0.84337,-110.16632,-503.56182)"
|
|
||||||
id="g14586">
|
|
||||||
<g
|
|
||||||
inkscape:export-ydpi="90"
|
|
||||||
inkscape:export-xdpi="90"
|
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
|
||||||
transform="matrix(1.9969286,0,0,1.9969286,-397.05491,877.00482)"
|
|
||||||
id="g15291-9"
|
|
||||||
style="display:inline;enable-background:new">
|
|
||||||
<g
|
|
||||||
transform="translate(877.50354,-102.83507)"
|
|
||||||
id="g16853-4"
|
|
||||||
style="enable-background:new">
|
|
||||||
<rect
|
|
||||||
transform="scale(1,-1)"
|
|
||||||
style="color:#000000;fill:url(#linearGradient14219);fill-opacity:1;fill-rule:nonzero;stroke:#868686;stroke-width:0.59377144999999998;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:new"
|
|
||||||
id="rect6506-6"
|
|
||||||
width="11.281681"
|
|
||||||
height="11.26221"
|
|
||||||
x="-409.59354"
|
|
||||||
y="-284.40115"
|
|
||||||
rx="0.95632279"
|
|
||||||
ry="0.95632273" />
|
|
||||||
</g>
|
|
||||||
</g>
|
|
||||||
<g
|
|
||||||
inkscape:export-ydpi="90"
|
|
||||||
inkscape:export-xdpi="90"
|
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
|
||||||
transform="translate(343.99999,987.99997)"
|
|
||||||
id="g5886"
|
|
||||||
style="display:inline;enable-background:new" />
|
|
||||||
</g>
|
|
||||||
</g>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 6.8 KiB |
@ -1,243 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
|
||||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
|
||||||
|
|
||||||
<svg
|
|
||||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
|
||||||
xmlns:cc="http://creativecommons.org/ns#"
|
|
||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
|
||||||
xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
||||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
|
||||||
width="24"
|
|
||||||
height="22"
|
|
||||||
id="svg3199"
|
|
||||||
version="1.1"
|
|
||||||
inkscape:version="0.48.1 r9760"
|
|
||||||
sodipodi:docname="checkbox-focused.svg">
|
|
||||||
<defs
|
|
||||||
id="defs3201">
|
|
||||||
<linearGradient
|
|
||||||
id="linearGradient15404"
|
|
||||||
inkscape:collect="always">
|
|
||||||
<stop
|
|
||||||
id="stop15406"
|
|
||||||
offset="0"
|
|
||||||
style="stop-color:#515151;stop-opacity:1" />
|
|
||||||
<stop
|
|
||||||
id="stop15408"
|
|
||||||
offset="1"
|
|
||||||
style="stop-color:#292929;stop-opacity:1" />
|
|
||||||
</linearGradient>
|
|
||||||
<inkscape:perspective
|
|
||||||
sodipodi:type="inkscape:persp3d"
|
|
||||||
inkscape:vp_x="0 : 526.18109 : 1"
|
|
||||||
inkscape:vp_y="0 : 1000 : 0"
|
|
||||||
inkscape:vp_z="744.09448 : 526.18109 : 1"
|
|
||||||
inkscape:persp3d-origin="372.04724 : 350.78739 : 1"
|
|
||||||
id="perspective3207" />
|
|
||||||
<inkscape:perspective
|
|
||||||
id="perspective3187"
|
|
||||||
inkscape:persp3d-origin="0.5 : 0.33333333 : 1"
|
|
||||||
inkscape:vp_z="1 : 0.5 : 1"
|
|
||||||
inkscape:vp_y="0 : 1000 : 0"
|
|
||||||
inkscape:vp_x="0 : 0.5 : 1"
|
|
||||||
sodipodi:type="inkscape:persp3d" />
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
xlink:href="#linearGradient5872-5-1"
|
|
||||||
id="linearGradient5891-0-4"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
x1="205.84143"
|
|
||||||
y1="246.7094"
|
|
||||||
x2="206.74803"
|
|
||||||
y2="231.24142" />
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
id="linearGradient5872-5-1">
|
|
||||||
<stop
|
|
||||||
style="stop-color:#0b2e52;stop-opacity:1"
|
|
||||||
offset="0"
|
|
||||||
id="stop5874-4-4" />
|
|
||||||
<stop
|
|
||||||
style="stop-color:#1862af;stop-opacity:1"
|
|
||||||
offset="1"
|
|
||||||
id="stop5876-0-5" />
|
|
||||||
</linearGradient>
|
|
||||||
<inkscape:path-effect
|
|
||||||
effect="spiro"
|
|
||||||
id="path-effect5837-4-6"
|
|
||||||
is_visible="true" />
|
|
||||||
<inkscape:path-effect
|
|
||||||
effect="spiro"
|
|
||||||
id="path-effect14768"
|
|
||||||
is_visible="true" />
|
|
||||||
<inkscape:path-effect
|
|
||||||
effect="spiro"
|
|
||||||
id="path-effect5884-4-7"
|
|
||||||
is_visible="true" />
|
|
||||||
<linearGradient
|
|
||||||
y2="-388.72955"
|
|
||||||
x2="-93.031357"
|
|
||||||
y1="-396.34738"
|
|
||||||
x1="-93.031357"
|
|
||||||
gradientTransform="matrix(1.5918367,0,0,0.85714285,-256.56122,59.685418)"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
id="linearGradient14219"
|
|
||||||
xlink:href="#linearGradient15404"
|
|
||||||
inkscape:collect="always" />
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
id="linearGradient10013-4-63-6">
|
|
||||||
<stop
|
|
||||||
style="stop-color:#333333;stop-opacity:1;"
|
|
||||||
offset="0"
|
|
||||||
id="stop10015-2-76-1" />
|
|
||||||
<stop
|
|
||||||
style="stop-color:#292929;stop-opacity:1"
|
|
||||||
offset="1"
|
|
||||||
id="stop10017-46-15-8" />
|
|
||||||
</linearGradient>
|
|
||||||
<linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
id="linearGradient10597-5">
|
|
||||||
<stop
|
|
||||||
style="stop-color:#16191a;stop-opacity:1;"
|
|
||||||
offset="0"
|
|
||||||
id="stop10599-2" />
|
|
||||||
<stop
|
|
||||||
style="stop-color:#2b3133;stop-opacity:1"
|
|
||||||
offset="1"
|
|
||||||
id="stop10601-5" />
|
|
||||||
</linearGradient>
|
|
||||||
<linearGradient
|
|
||||||
y2="-322.16354"
|
|
||||||
x2="921.22498"
|
|
||||||
y1="-330.05121"
|
|
||||||
x1="921.32812"
|
|
||||||
gradientTransform="matrix(1.5918367,0,0,0.85714285,-1456.5464,275.45191)"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
id="linearGradient15374"
|
|
||||||
xlink:href="#linearGradient10013-4-63-6"
|
|
||||||
inkscape:collect="always" />
|
|
||||||
<linearGradient
|
|
||||||
gradientTransform="translate(-1199.9852,216.38048)"
|
|
||||||
y2="-227.07961"
|
|
||||||
x2="1203.9177"
|
|
||||||
y1="-217.56708"
|
|
||||||
x1="1203.9177"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
id="linearGradient15376"
|
|
||||||
xlink:href="#linearGradient10597-5"
|
|
||||||
inkscape:collect="always" />
|
|
||||||
</defs>
|
|
||||||
<sodipodi:namedview
|
|
||||||
id="base"
|
|
||||||
pagecolor="#000000"
|
|
||||||
bordercolor="#2d2d2d"
|
|
||||||
borderopacity="1"
|
|
||||||
inkscape:pageopacity="1"
|
|
||||||
inkscape:pageshadow="2"
|
|
||||||
inkscape:zoom="1"
|
|
||||||
inkscape:cx="64.516955"
|
|
||||||
inkscape:cy="13.871056"
|
|
||||||
inkscape:document-units="px"
|
|
||||||
inkscape:current-layer="layer1"
|
|
||||||
showgrid="false"
|
|
||||||
inkscape:window-width="1412"
|
|
||||||
inkscape:window-height="1067"
|
|
||||||
inkscape:window-x="2635"
|
|
||||||
inkscape:window-y="226"
|
|
||||||
inkscape:window-maximized="0"
|
|
||||||
borderlayer="true"
|
|
||||||
inkscape:showpageshadow="false"
|
|
||||||
inkscape:snap-nodes="false"
|
|
||||||
inkscape:snap-bbox="true"
|
|
||||||
showborder="false">
|
|
||||||
<inkscape:grid
|
|
||||||
type="xygrid"
|
|
||||||
id="grid14843"
|
|
||||||
empspacing="5"
|
|
||||||
visible="true"
|
|
||||||
enabled="true"
|
|
||||||
snapvisiblegridlinesonly="true" />
|
|
||||||
</sodipodi:namedview>
|
|
||||||
<metadata
|
|
||||||
id="metadata3204">
|
|
||||||
<rdf:RDF>
|
|
||||||
<cc:Work
|
|
||||||
rdf:about="">
|
|
||||||
<dc:format>image/svg+xml</dc:format>
|
|
||||||
<dc:type
|
|
||||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
|
||||||
<dc:title></dc:title>
|
|
||||||
</cc:Work>
|
|
||||||
</rdf:RDF>
|
|
||||||
</metadata>
|
|
||||||
<g
|
|
||||||
inkscape:label="Layer 1"
|
|
||||||
inkscape:groupmode="layer"
|
|
||||||
id="layer1"
|
|
||||||
transform="translate(-342.5,-521.36218)">
|
|
||||||
<g
|
|
||||||
transform="matrix(0.84337,0,0,0.84337,-110.16632,-503.56182)"
|
|
||||||
id="g14586">
|
|
||||||
<g
|
|
||||||
inkscape:export-ydpi="90"
|
|
||||||
inkscape:export-xdpi="90"
|
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
|
||||||
transform="matrix(1.9969286,0,0,1.9969286,-397.05491,877.00482)"
|
|
||||||
id="g15291-9"
|
|
||||||
style="display:inline;enable-background:new">
|
|
||||||
<g
|
|
||||||
transform="translate(877.50354,-102.83507)"
|
|
||||||
id="g16853-4"
|
|
||||||
style="enable-background:new">
|
|
||||||
<rect
|
|
||||||
transform="scale(1,-1)"
|
|
||||||
style="color:#000000;fill:url(#linearGradient14219);fill-opacity:1;fill-rule:nonzero;stroke:#868686;stroke-width:0.59377144999999998;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:new"
|
|
||||||
id="rect6506-6"
|
|
||||||
width="11.281681"
|
|
||||||
height="11.26221"
|
|
||||||
x="-409.59354"
|
|
||||||
y="-284.40115"
|
|
||||||
rx="0.95632279"
|
|
||||||
ry="0.95632273" />
|
|
||||||
</g>
|
|
||||||
</g>
|
|
||||||
<g
|
|
||||||
inkscape:export-ydpi="90"
|
|
||||||
inkscape:export-xdpi="90"
|
|
||||||
inkscape:export-filename="/home/jimmac/SparkleShare/gnome-mockups/boxes/interactive/img/checkbox-on.png"
|
|
||||||
transform="translate(343.99999,987.99997)"
|
|
||||||
id="g5886"
|
|
||||||
style="display:inline;enable-background:new">
|
|
||||||
<path
|
|
||||||
style="fill:none;stroke:url(#linearGradient5891-0-4);stroke-width:7.11431503;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
|
|
||||||
d="m 198.5,240 5.25,5.25 13.98616,-14.43081"
|
|
||||||
id="path5835"
|
|
||||||
inkscape:path-effect="#path-effect5837-4-6"
|
|
||||||
inkscape:original-d="m 198.5,240 5.25,5.25 13.98616,-14.43081"
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
sodipodi:nodetypes="ccc" />
|
|
||||||
<path
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
inkscape:original-d="m 198.5,240 5.25,5.25 13.91205,-14.31964"
|
|
||||||
inkscape:path-effect="#path-effect5837-4-6"
|
|
||||||
id="path5880"
|
|
||||||
d="m 198.5,240 5.25,5.25 13.91205,-14.31964"
|
|
||||||
style="fill:none;stroke:#4787c8;stroke-width:3.55715752;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
|
|
||||||
sodipodi:nodetypes="ccc" />
|
|
||||||
<path
|
|
||||||
style="fill:none;stroke:#7ea7d3;stroke-width:1.18571913px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
|
|
||||||
d="m 197.45937,240.47455 c -0.17828,-0.29362 -0.20087,-0.67548 -0.0603,-0.98892 0.14055,-0.31344 0.43739,-0.54812 0.77144,-0.62817 0.33405,-0.08 0.69314,-0.01 0.99635,0.15175 0.30321,0.16144 0.55146,0.40727 0.79165,0.65284 l 3.66429,3.74643 12.87946,-12.98973 c 0.20796,-0.20974 0.42306,-0.41969 0.68548,-0.55522 0.26242,-0.13553 0.57293,-0.19052 0.85827,-0.11426 0.14267,0.0381 0.27708,0.10787 0.38874,0.20452 0.11167,0.0966 0.20021,0.22004 0.25479,0.35726 0.0546,0.13722 0.075,0.28793 0.0585,0.43468 -0.0165,0.14674 -0.07,0.28919 -0.15422,0.41052"
|
|
||||||
id="path5882"
|
|
||||||
inkscape:path-effect="#path-effect5884-4-7"
|
|
||||||
inkscape:original-d="m 197.45937,240.47455 c 0.65604,-0.56057 2.02485,-1.34847 2.49911,-0.8125 l 3.66429,3.74643 12.87946,-12.98973 c 0.6875,-0.6875 2.09152,0.7375 2.09152,0.7375"
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
sodipodi:nodetypes="csccc" />
|
|
||||||
</g>
|
|
||||||
</g>
|
|
||||||
</g>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 8.8 KiB |
@ -1,130 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
|
||||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
|
||||||
|
|
||||||
<svg
|
|
||||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
|
||||||
xmlns:cc="http://creativecommons.org/ns#"
|
|
||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
|
||||||
xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
||||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
|
||||||
width="300"
|
|
||||||
height="80"
|
|
||||||
id="svg7355"
|
|
||||||
version="1.1"
|
|
||||||
inkscape:version="0.48.2 r9819"
|
|
||||||
sodipodi:docname="logged-in-indicator.svg">
|
|
||||||
<metadata
|
|
||||||
id="metadata4175">
|
|
||||||
<rdf:RDF>
|
|
||||||
<cc:Work
|
|
||||||
rdf:about="">
|
|
||||||
<dc:format>image/svg+xml</dc:format>
|
|
||||||
<dc:type
|
|
||||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
|
||||||
</cc:Work>
|
|
||||||
</rdf:RDF>
|
|
||||||
</metadata>
|
|
||||||
<sodipodi:namedview
|
|
||||||
pagecolor="#2c1cff"
|
|
||||||
bordercolor="#666666"
|
|
||||||
borderopacity="1"
|
|
||||||
objecttolerance="10"
|
|
||||||
gridtolerance="10"
|
|
||||||
guidetolerance="10"
|
|
||||||
inkscape:pageopacity="1"
|
|
||||||
inkscape:pageshadow="2"
|
|
||||||
inkscape:window-width="1440"
|
|
||||||
inkscape:window-height="843"
|
|
||||||
id="namedview4173"
|
|
||||||
showgrid="false"
|
|
||||||
inkscape:zoom="2.8760889"
|
|
||||||
inkscape:cx="106.00403"
|
|
||||||
inkscape:cy="80.68078"
|
|
||||||
inkscape:window-x="0"
|
|
||||||
inkscape:window-y="27"
|
|
||||||
inkscape:window-maximized="1"
|
|
||||||
inkscape:current-layer="g30864" />
|
|
||||||
<defs
|
|
||||||
id="defs7357">
|
|
||||||
<radialGradient
|
|
||||||
xlink:href="#linearGradient36429"
|
|
||||||
id="radialGradient7461"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
gradientTransform="matrix(2.5919312,0,0,0.57582113,-20.687059,48.400487)"
|
|
||||||
cx="47.428951"
|
|
||||||
cy="167.16817"
|
|
||||||
fx="47.428951"
|
|
||||||
fy="167.16817"
|
|
||||||
r="37" />
|
|
||||||
<linearGradient
|
|
||||||
id="linearGradient36429">
|
|
||||||
<stop
|
|
||||||
id="stop36431"
|
|
||||||
offset="0"
|
|
||||||
style="stop-color:#ffffff;stop-opacity:1;" />
|
|
||||||
<stop
|
|
||||||
id="stop36433"
|
|
||||||
offset="1"
|
|
||||||
style="stop-color:#ffffff;stop-opacity:0;" />
|
|
||||||
</linearGradient>
|
|
||||||
<radialGradient
|
|
||||||
xlink:href="#linearGradient36471"
|
|
||||||
id="radialGradient7463"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
gradientTransform="matrix(1.1891549,0,0,0.55513246,-9.281289,36.12653)"
|
|
||||||
cx="49.067139"
|
|
||||||
cy="242.50381"
|
|
||||||
fx="49.067139"
|
|
||||||
fy="242.50381"
|
|
||||||
r="37.00671" />
|
|
||||||
<linearGradient
|
|
||||||
id="linearGradient36471">
|
|
||||||
<stop
|
|
||||||
id="stop36473"
|
|
||||||
offset="0"
|
|
||||||
style="stop-color:#ffffff;stop-opacity:1;" />
|
|
||||||
<stop
|
|
||||||
id="stop36475"
|
|
||||||
offset="1"
|
|
||||||
style="stop-color:#ffffff;stop-opacity:0;" />
|
|
||||||
</linearGradient>
|
|
||||||
<radialGradient
|
|
||||||
r="37.00671"
|
|
||||||
fy="242.50381"
|
|
||||||
fx="49.067139"
|
|
||||||
cy="242.50381"
|
|
||||||
cx="49.067139"
|
|
||||||
gradientTransform="matrix(3.4218418,0,0,0.03365337,-61.309005,138.5071)"
|
|
||||||
gradientUnits="userSpaceOnUse"
|
|
||||||
id="radialGradient7488"
|
|
||||||
xlink:href="#linearGradient36471" />
|
|
||||||
</defs>
|
|
||||||
<g
|
|
||||||
id="layer1"
|
|
||||||
transform="matrix(1.6213276,0,0,1.6213276,-431.6347,-272.5745)">
|
|
||||||
<g
|
|
||||||
style="display:inline"
|
|
||||||
id="g30864"
|
|
||||||
transform="translate(255.223,70.118091)">
|
|
||||||
<rect
|
|
||||||
ry="3.4593496"
|
|
||||||
rx="8.8641119"
|
|
||||||
y="76.159348"
|
|
||||||
x="12.596948"
|
|
||||||
height="71.116341"
|
|
||||||
width="182.22595"
|
|
||||||
id="rect14000"
|
|
||||||
style="opacity:0.371875;fill:url(#radialGradient7461);fill-opacity:1;stroke:none" />
|
|
||||||
<path
|
|
||||||
id="rect34520"
|
|
||||||
d="m 194.80022,146.83551 -182.559919,0"
|
|
||||||
style="opacity:0.35;fill:none;stroke:url(#radialGradient7488);stroke-width:0.61184424;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
|
|
||||||
connector-curvature="0"
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
sodipodi:nodetypes="cc" />
|
|
||||||
</g>
|
|
||||||
</g>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 3.8 KiB |
Before Width: | Height: | Size: 25 KiB |
113
data/theme/mosaic-view-active.svg
Normal file
@ -0,0 +1,113 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="24"
|
||||||
|
height="16"
|
||||||
|
id="svg6503"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.47pre4 r22446"
|
||||||
|
sodipodi:docname="mosaic-view-active.svg">
|
||||||
|
<defs
|
||||||
|
id="defs6505">
|
||||||
|
<inkscape:perspective
|
||||||
|
sodipodi:type="inkscape:persp3d"
|
||||||
|
inkscape:vp_x="0 : 16 : 1"
|
||||||
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
|
inkscape:vp_z="32 : 16 : 1"
|
||||||
|
inkscape:persp3d-origin="16 : 10.666667 : 1"
|
||||||
|
id="perspective6511" />
|
||||||
|
<inkscape:perspective
|
||||||
|
id="perspective6494"
|
||||||
|
inkscape:persp3d-origin="0.5 : 0.33333333 : 1"
|
||||||
|
inkscape:vp_z="1 : 0.5 : 1"
|
||||||
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
|
inkscape:vp_x="0 : 0.5 : 1"
|
||||||
|
sodipodi:type="inkscape:persp3d" />
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
id="base"
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1.0"
|
||||||
|
inkscape:pageopacity="0.0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:zoom="11.197802"
|
||||||
|
inkscape:cx="-15.97056"
|
||||||
|
inkscape:cy="16"
|
||||||
|
inkscape:current-layer="layer1"
|
||||||
|
showgrid="true"
|
||||||
|
inkscape:grid-bbox="true"
|
||||||
|
inkscape:document-units="px"
|
||||||
|
inkscape:window-width="1680"
|
||||||
|
inkscape:window-height="997"
|
||||||
|
inkscape:window-x="0"
|
||||||
|
inkscape:window-y="26"
|
||||||
|
inkscape:window-maximized="1" />
|
||||||
|
<metadata
|
||||||
|
id="metadata6508">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title />
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<g
|
||||||
|
id="layer1"
|
||||||
|
inkscape:label="Layer 1"
|
||||||
|
inkscape:groupmode="layer"
|
||||||
|
transform="translate(0,-16)">
|
||||||
|
<g
|
||||||
|
style="display:inline;fill:#cbcbcb;fill-opacity:1"
|
||||||
|
transform="translate(-449.85476,-685.85869)"
|
||||||
|
id="g5306">
|
||||||
|
<rect
|
||||||
|
style="fill:#cbcbcb;fill-opacity:1;stroke:#000000;stroke-width:0.99999970000000005;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:0.44262299999999999;stroke-dasharray:none"
|
||||||
|
id="rect5308"
|
||||||
|
width="11"
|
||||||
|
height="7"
|
||||||
|
x="450.5"
|
||||||
|
y="710.5"
|
||||||
|
rx="0.99999958"
|
||||||
|
ry="1" />
|
||||||
|
<rect
|
||||||
|
style="fill:#cbcbcb;fill-opacity:1;stroke:#000000;stroke-width:0.99999970000000005;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:0.44262299999999999;stroke-dasharray:none;display:inline"
|
||||||
|
id="rect5310"
|
||||||
|
width="11"
|
||||||
|
height="7"
|
||||||
|
x="462.5"
|
||||||
|
y="702.5"
|
||||||
|
rx="0.99999958"
|
||||||
|
ry="1" />
|
||||||
|
<rect
|
||||||
|
style="fill:#cbcbcb;fill-opacity:1;stroke:#000000;stroke-width:0.99999976000000002;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:0.44262299999999999;stroke-dasharray:none;display:inline"
|
||||||
|
id="rect5312"
|
||||||
|
width="11"
|
||||||
|
height="7"
|
||||||
|
x="450.5"
|
||||||
|
y="702.5"
|
||||||
|
rx="0.99999958"
|
||||||
|
ry="1" />
|
||||||
|
<rect
|
||||||
|
style="fill:#cbcbcb;fill-opacity:1;stroke:#000000;stroke-width:0.99999970000000005;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:0.44262299999999999;stroke-dasharray:none;display:inline"
|
||||||
|
id="rect5314"
|
||||||
|
width="11"
|
||||||
|
height="7"
|
||||||
|
x="462.5"
|
||||||
|
y="710.5"
|
||||||
|
rx="0.99999958"
|
||||||
|
ry="1" />
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 3.7 KiB |
113
data/theme/mosaic-view.svg
Normal file
@ -0,0 +1,113 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="24"
|
||||||
|
height="16"
|
||||||
|
id="svg6503"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.47pre4 r22446"
|
||||||
|
sodipodi:docname="New document 19">
|
||||||
|
<defs
|
||||||
|
id="defs6505">
|
||||||
|
<inkscape:perspective
|
||||||
|
sodipodi:type="inkscape:persp3d"
|
||||||
|
inkscape:vp_x="0 : 16 : 1"
|
||||||
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
|
inkscape:vp_z="32 : 16 : 1"
|
||||||
|
inkscape:persp3d-origin="16 : 10.666667 : 1"
|
||||||
|
id="perspective6511" />
|
||||||
|
<inkscape:perspective
|
||||||
|
id="perspective6494"
|
||||||
|
inkscape:persp3d-origin="0.5 : 0.33333333 : 1"
|
||||||
|
inkscape:vp_z="1 : 0.5 : 1"
|
||||||
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
|
inkscape:vp_x="0 : 0.5 : 1"
|
||||||
|
sodipodi:type="inkscape:persp3d" />
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
id="base"
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1.0"
|
||||||
|
inkscape:pageopacity="0.0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:zoom="11.197802"
|
||||||
|
inkscape:cx="16"
|
||||||
|
inkscape:cy="16"
|
||||||
|
inkscape:current-layer="layer1"
|
||||||
|
showgrid="true"
|
||||||
|
inkscape:grid-bbox="true"
|
||||||
|
inkscape:document-units="px"
|
||||||
|
inkscape:window-width="1680"
|
||||||
|
inkscape:window-height="997"
|
||||||
|
inkscape:window-x="0"
|
||||||
|
inkscape:window-y="26"
|
||||||
|
inkscape:window-maximized="1" />
|
||||||
|
<metadata
|
||||||
|
id="metadata6508">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title></dc:title>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<g
|
||||||
|
id="layer1"
|
||||||
|
inkscape:label="Layer 1"
|
||||||
|
inkscape:groupmode="layer"
|
||||||
|
transform="translate(0,-16)">
|
||||||
|
<g
|
||||||
|
style="display:inline"
|
||||||
|
transform="translate(-449.85476,-685.85869)"
|
||||||
|
id="g5306">
|
||||||
|
<rect
|
||||||
|
style="fill:#666666;fill-opacity:1;stroke:#000000;stroke-width:0.9999997;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:0.442623;stroke-dasharray:none"
|
||||||
|
id="rect5308"
|
||||||
|
width="11"
|
||||||
|
height="7"
|
||||||
|
x="450.5"
|
||||||
|
y="710.5"
|
||||||
|
rx="0.99999958"
|
||||||
|
ry="1" />
|
||||||
|
<rect
|
||||||
|
style="fill:#666666;fill-opacity:1;stroke:#000000;stroke-width:0.9999997;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:0.442623;stroke-dasharray:none;display:inline"
|
||||||
|
id="rect5310"
|
||||||
|
width="11"
|
||||||
|
height="7"
|
||||||
|
x="462.5"
|
||||||
|
y="702.5"
|
||||||
|
rx="0.99999958"
|
||||||
|
ry="1" />
|
||||||
|
<rect
|
||||||
|
style="fill:#666666;fill-opacity:1;stroke:#000000;stroke-width:0.99999976;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:0.442623;stroke-dasharray:none;display:inline"
|
||||||
|
id="rect5312"
|
||||||
|
width="11"
|
||||||
|
height="7"
|
||||||
|
x="450.5"
|
||||||
|
y="702.5"
|
||||||
|
rx="0.99999958"
|
||||||
|
ry="1" />
|
||||||
|
<rect
|
||||||
|
style="fill:#666666;fill-opacity:1;stroke:#000000;stroke-width:0.9999997;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:0.442623;stroke-dasharray:none;display:inline"
|
||||||
|
id="rect5314"
|
||||||
|
width="11"
|
||||||
|
height="7"
|
||||||
|
x="462.5"
|
||||||
|
y="710.5"
|
||||||
|
rx="0.99999958"
|
||||||
|
ry="1" />
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 3.6 KiB |
89
data/theme/move-window-on-new.svg
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="98"
|
||||||
|
height="98"
|
||||||
|
id="svg6375"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.47 r22583"
|
||||||
|
sodipodi:docname="add-workspace.svg">
|
||||||
|
<defs
|
||||||
|
id="defs6377">
|
||||||
|
<inkscape:perspective
|
||||||
|
sodipodi:type="inkscape:persp3d"
|
||||||
|
inkscape:vp_x="0 : 16 : 1"
|
||||||
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
|
inkscape:vp_z="32 : 16 : 1"
|
||||||
|
inkscape:persp3d-origin="16 : 10.666667 : 1"
|
||||||
|
id="perspective6383" />
|
||||||
|
<inkscape:perspective
|
||||||
|
id="perspective6366"
|
||||||
|
inkscape:persp3d-origin="0.5 : 0.33333333 : 1"
|
||||||
|
inkscape:vp_z="1 : 0.5 : 1"
|
||||||
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
|
inkscape:vp_x="0 : 0.5 : 1"
|
||||||
|
sodipodi:type="inkscape:persp3d" />
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
id="base"
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1.0"
|
||||||
|
inkscape:pageopacity="0.0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:zoom="3.9590209"
|
||||||
|
inkscape:cx="56.650687"
|
||||||
|
inkscape:cy="20.635343"
|
||||||
|
inkscape:current-layer="layer1"
|
||||||
|
showgrid="true"
|
||||||
|
inkscape:grid-bbox="true"
|
||||||
|
inkscape:document-units="px"
|
||||||
|
inkscape:window-width="1680"
|
||||||
|
inkscape:window-height="997"
|
||||||
|
inkscape:window-x="0"
|
||||||
|
inkscape:window-y="26"
|
||||||
|
inkscape:window-maximized="1" />
|
||||||
|
<metadata
|
||||||
|
id="metadata6380">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title></dc:title>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<g
|
||||||
|
id="layer1"
|
||||||
|
inkscape:label="Layer 1"
|
||||||
|
inkscape:groupmode="layer"
|
||||||
|
transform="translate(0,66)">
|
||||||
|
<g
|
||||||
|
id="g2824"
|
||||||
|
transform="matrix(11.568551,0,0,11.698271,-78.828159,-304.81518)">
|
||||||
|
<path
|
||||||
|
style="fill:none;stroke:#666666;stroke-width:1.99999952;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none"
|
||||||
|
d="m 11.07363,21.36834 0,6.43903"
|
||||||
|
id="path5322" />
|
||||||
|
<path
|
||||||
|
style="fill:none;stroke:#666666;stroke-width:1.99999952;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
|
||||||
|
d="m 14.29314,24.58786 -6.43902,0"
|
||||||
|
id="path5324" />
|
||||||
|
</g>
|
||||||
|
<path
|
||||||
|
style="fill:#000000;fill-opacity:0.98823529"
|
||||||
|
d="m 48.239516,97.908047 c -0.41677,-0.05102 -1.269253,-0.222408 -1.894408,-0.380859 -4.088493,-1.036262 -7.520781,-4.753234 -8.330163,-9.021094 -0.154947,-0.817026 -0.257819,-6.68112 -0.257819,-14.696556 l 0,-13.337088 -13.829177,-0.08909 C 10.802042,60.298796 10.026884,60.268266 8.6851548,59.783022 3.6288503,57.954375 0.62673331,53.828648 0.62673331,48.708554 c 0,-5.625522 4.25936019,-10.425065 9.97721469,-11.242548 0.987903,-0.141242 7.368912,-0.254994 14.460646,-0.257791 l 12.692532,-0.005 0,-13.586668 c 0,-14.6441583 0.03287,-15.0698926 1.364686,-17.6753047 2.185477,-4.2754229 6.938193,-6.75739913 11.687647,-6.10355607 3.382776,0.46569661 6.737962,2.72496967 8.414081,5.66577137 1.480816,2.5981315 1.519067,3.0522448 1.519067,18.0333334 l 0,13.666424 12.692533,0.005 c 7.091733,0.0028 13.472742,0.116549 14.460646,0.257791 6.395303,0.914337 10.804785,6.623716 9.941157,12.871766 -0.698243,5.051565 -4.792685,9.104635 -9.941157,9.840713 -0.987904,0.141242 -7.368913,0.254995 -14.460646,0.257791 l -12.692533,0.005 0,13.801945 c 0,13.031417 -0.02798,13.895893 -0.501177,15.484801 -1.526902,5.127058 -6.919246,8.802262 -12.001914,8.18002 z"
|
||||||
|
id="path2828"
|
||||||
|
transform="translate(0,-66)" />
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 4.0 KiB |
Before Width: | Height: | Size: 78 KiB |
33
data/theme/panel-border.svg
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
width="3"
|
||||||
|
height="10"
|
||||||
|
id="svg2"
|
||||||
|
version="1.1">
|
||||||
|
<defs
|
||||||
|
id="defs4" />
|
||||||
|
<metadata
|
||||||
|
id="metadata7">
|
||||||
|
</metadata>
|
||||||
|
<g
|
||||||
|
id="layer1">
|
||||||
|
<rect
|
||||||
|
style="fill:#000000;fill-opacity:1;stroke-width:0.43599999000000000;stroke-miterlimit:4;stroke-dasharray:none"
|
||||||
|
id="rect3779"
|
||||||
|
width="3"
|
||||||
|
height="10"
|
||||||
|
x="0"
|
||||||
|
y="0" />
|
||||||
|
<rect
|
||||||
|
style="fill:#536272;fill-opacity:1;stroke-width:0.43599999;stroke-miterlimit:4;stroke-dasharray:none"
|
||||||
|
id="rect3796"
|
||||||
|
width="3"
|
||||||
|
height="1"
|
||||||
|
x="0"
|
||||||
|
y="9" />
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 787 B |
@ -9,7 +9,7 @@
|
|||||||
xmlns="http://www.w3.org/2000/svg"
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
width="17"
|
width="21"
|
||||||
height="10"
|
height="10"
|
||||||
id="svg2"
|
id="svg2"
|
||||||
version="1.1"
|
version="1.1"
|
||||||
@ -66,9 +66,9 @@
|
|||||||
<rect
|
<rect
|
||||||
style="opacity:0.8;fill:#ffffff;fill-opacity:1;stroke-width:0.43599999;stroke-miterlimit:4;stroke-dasharray:none"
|
style="opacity:0.8;fill:#ffffff;fill-opacity:1;stroke-width:0.43599999;stroke-miterlimit:4;stroke-dasharray:none"
|
||||||
id="rect3796"
|
id="rect3796"
|
||||||
width="7"
|
width="3"
|
||||||
height="2"
|
height="2"
|
||||||
x="5"
|
x="9"
|
||||||
y="8" />
|
y="8" />
|
||||||
</g>
|
</g>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 2.0 KiB After Width: | Height: | Size: 2.0 KiB |
@ -2,62 +2,24 @@
|
|||||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||||
|
|
||||||
<svg
|
<svg
|
||||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
|
||||||
xmlns:cc="http://creativecommons.org/ns#"
|
|
||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
xmlns:xlink="http://www.w3.org/1999/xlink"
|
xmlns:xlink="http://www.w3.org/1999/xlink"
|
||||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
|
||||||
width="119.97824"
|
width="119.97824"
|
||||||
height="119.97824"
|
height="119.97824"
|
||||||
id="svg7355"
|
id="svg7355"
|
||||||
version="1.1"
|
version="1.1">
|
||||||
inkscape:version="0.48.1 r9760"
|
|
||||||
sodipodi:docname="running-indicator.svg">
|
|
||||||
<metadata
|
|
||||||
id="metadata4175">
|
|
||||||
<rdf:RDF>
|
|
||||||
<cc:Work
|
|
||||||
rdf:about="">
|
|
||||||
<dc:format>image/svg+xml</dc:format>
|
|
||||||
<dc:type
|
|
||||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
|
||||||
</cc:Work>
|
|
||||||
</rdf:RDF>
|
|
||||||
</metadata>
|
|
||||||
<sodipodi:namedview
|
|
||||||
pagecolor="#2c1cff"
|
|
||||||
bordercolor="#666666"
|
|
||||||
borderopacity="1"
|
|
||||||
objecttolerance="10"
|
|
||||||
gridtolerance="10"
|
|
||||||
guidetolerance="10"
|
|
||||||
inkscape:pageopacity="1"
|
|
||||||
inkscape:pageshadow="2"
|
|
||||||
inkscape:window-width="1920"
|
|
||||||
inkscape:window-height="1141"
|
|
||||||
id="namedview4173"
|
|
||||||
showgrid="false"
|
|
||||||
inkscape:zoom="8.1348081"
|
|
||||||
inkscape:cx="81.120662"
|
|
||||||
inkscape:cy="58.117986"
|
|
||||||
inkscape:window-x="0"
|
|
||||||
inkscape:window-y="26"
|
|
||||||
inkscape:window-maximized="1"
|
|
||||||
inkscape:current-layer="g30864" />
|
|
||||||
<defs
|
<defs
|
||||||
id="defs7357">
|
id="defs7357">
|
||||||
<radialGradient
|
<radialGradient
|
||||||
xlink:href="#linearGradient36429"
|
xlink:href="#linearGradient36429"
|
||||||
id="radialGradient7461"
|
id="radialGradient7461"
|
||||||
gradientUnits="userSpaceOnUse"
|
gradientUnits="userSpaceOnUse"
|
||||||
gradientTransform="matrix(1.011539,0,0,0.57582113,-0.39262194,71.83807)"
|
gradientTransform="matrix(1.0525552,0,0,1.0525552,-2.5162753,-9.0000838)"
|
||||||
cx="47.428951"
|
cx="47.878681"
|
||||||
cy="167.16817"
|
cy="171.25"
|
||||||
fx="47.428951"
|
fx="47.878681"
|
||||||
fy="167.16817"
|
fy="171.25"
|
||||||
r="37" />
|
r="37" />
|
||||||
<linearGradient
|
<linearGradient
|
||||||
id="linearGradient36429">
|
id="linearGradient36429">
|
||||||
@ -97,7 +59,7 @@
|
|||||||
fx="49.067139"
|
fx="49.067139"
|
||||||
cy="242.50381"
|
cy="242.50381"
|
||||||
cx="49.067139"
|
cx="49.067139"
|
||||||
gradientTransform="matrix(1.1891549,0,0,0.15252127,-9.281289,132.52772)"
|
gradientTransform="matrix(1.1891549,0,0,0.55513246,-9.281289,36.12653)"
|
||||||
gradientUnits="userSpaceOnUse"
|
gradientUnits="userSpaceOnUse"
|
||||||
id="radialGradient7488"
|
id="radialGradient7488"
|
||||||
xlink:href="#linearGradient36471" />
|
xlink:href="#linearGradient36471" />
|
||||||
@ -110,21 +72,19 @@
|
|||||||
id="g30864"
|
id="g30864"
|
||||||
transform="translate(255.223,70.118091)">
|
transform="translate(255.223,70.118091)">
|
||||||
<rect
|
<rect
|
||||||
ry="3.4593496"
|
ry="3.5996203"
|
||||||
rx="3.4593496"
|
rx="3.5996203"
|
||||||
y="99.596962"
|
y="98"
|
||||||
x="12.596948"
|
x="11"
|
||||||
height="71.116341"
|
height="74"
|
||||||
width="71.116341"
|
width="74"
|
||||||
id="rect14000"
|
id="rect14000"
|
||||||
style="opacity:0.37187500000000001;fill:url(#radialGradient7461);fill-opacity:1;stroke:none" />
|
style="opacity:0.371875;fill:url(#radialGradient7461);fill-opacity:1;stroke:none" />
|
||||||
<path
|
<path
|
||||||
id="rect34520"
|
id="rect34520"
|
||||||
d="m 83.273151,166.72152 c 0,1.96759 -1.584022,3.55163 -3.551629,3.55163 l -63.443032,0 c -1.967608,0 -3.551648,-1.58402 -3.551643,-3.55164 0,-5.85318 0,-5.85318 0,0"
|
d="m 84.506708,167.95508 c 6e-6,1.96759 -1.584022,3.55162 -3.551629,3.55163 l -65.910146,0 c -1.967608,-1e-5 -3.551648,-1.58402 -3.551643,-3.55164"
|
||||||
style="opacity:0.35;fill:none;stroke:url(#radialGradient7488);stroke-width:1;stroke-opacity:1"
|
style="opacity:0.2;fill:none;stroke:url(#radialGradient7488);stroke-width:1;stroke-opacity:1"
|
||||||
connector-curvature="0"
|
inkscape:connector-curvature="0" />
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
sodipodi:nodetypes="ccscc" />
|
|
||||||
</g>
|
</g>
|
||||||
</g>
|
</g>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 3.9 KiB After Width: | Height: | Size: 2.7 KiB |
BIN
data/theme/scroll-button-down-hover.png
Normal file
After Width: | Height: | Size: 225 B |
BIN
data/theme/scroll-button-down.png
Normal file
After Width: | Height: | Size: 225 B |
BIN
data/theme/scroll-button-up-hover.png
Normal file
After Width: | Height: | Size: 211 B |
BIN
data/theme/scroll-button-up.png
Normal file
After Width: | Height: | Size: 211 B |
64
data/theme/scroll-hhandle.svg
Normal file
@ -0,0 +1,64 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:xlink="http://www.w3.org/1999/xlink"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="10"
|
||||||
|
height="4"
|
||||||
|
id="svg2"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.47 r22583"
|
||||||
|
sodipodi:docname="scroll-hhandle.svg">
|
||||||
|
<defs
|
||||||
|
id="defs4">
|
||||||
|
</defs>
|
||||||
|
<metadata
|
||||||
|
id="metadata7">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title />
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<g
|
||||||
|
inkscape:label="Layer 1"
|
||||||
|
inkscape:groupmode="layer"
|
||||||
|
id="layer1">
|
||||||
|
<rect
|
||||||
|
style="fill:#323232;fill-opacity:1;fill-rule:evenodd;stroke:none"
|
||||||
|
id="rect3592"
|
||||||
|
width="2"
|
||||||
|
height="4"
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
rx="0"
|
||||||
|
ry="0" />
|
||||||
|
<use
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
xlink:href="#rect3592"
|
||||||
|
id="use2825"
|
||||||
|
transform="translate(8,0)"
|
||||||
|
width="10"
|
||||||
|
height="4" />
|
||||||
|
<use
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
xlink:href="#use2825"
|
||||||
|
id="use2827"
|
||||||
|
transform="translate(-4,0)"
|
||||||
|
width="10"
|
||||||
|
height="4" />
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 1.6 KiB |
62
data/theme/scroll-vhandle.svg
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:xlink="http://www.w3.org/1999/xlink"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="4"
|
||||||
|
height="10"
|
||||||
|
id="svg2"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.47 r22583"
|
||||||
|
sodipodi:docname="scroll-hhandle.svg">
|
||||||
|
<metadata
|
||||||
|
id="metadata7">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title></dc:title>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<g
|
||||||
|
inkscape:label="Layer 1"
|
||||||
|
inkscape:groupmode="layer"
|
||||||
|
id="layer1">
|
||||||
|
<rect
|
||||||
|
style="fill:#323232;fill-opacity:1;fill-rule:evenodd;stroke:none"
|
||||||
|
id="rect3592"
|
||||||
|
width="2"
|
||||||
|
height="4"
|
||||||
|
x="0"
|
||||||
|
y="-4"
|
||||||
|
rx="0"
|
||||||
|
ry="0"
|
||||||
|
transform="matrix(0,1,-1,0,0,0)" />
|
||||||
|
<use
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
xlink:href="#rect3592"
|
||||||
|
id="use3705"
|
||||||
|
transform="translate(0,4)"
|
||||||
|
width="4"
|
||||||
|
height="10" />
|
||||||
|
<use
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
xlink:href="#use3705"
|
||||||
|
id="use3707"
|
||||||
|
transform="translate(0,4)"
|
||||||
|
width="4"
|
||||||
|
height="10" />
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 1.6 KiB |
87
data/theme/section-more-open.svg
Normal file
@ -0,0 +1,87 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="5.8600588"
|
||||||
|
height="9"
|
||||||
|
id="svg3647"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.47 r22583"
|
||||||
|
sodipodi:docname="section-more.svg">
|
||||||
|
<defs
|
||||||
|
id="defs3649">
|
||||||
|
<inkscape:perspective
|
||||||
|
sodipodi:type="inkscape:persp3d"
|
||||||
|
inkscape:vp_x="0 : 526.18109 : 1"
|
||||||
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
|
inkscape:vp_z="744.09448 : 526.18109 : 1"
|
||||||
|
inkscape:persp3d-origin="372.04724 : 350.78739 : 1"
|
||||||
|
id="perspective3655" />
|
||||||
|
<inkscape:perspective
|
||||||
|
id="perspective3603"
|
||||||
|
inkscape:persp3d-origin="0.5 : 0.33333333 : 1"
|
||||||
|
inkscape:vp_z="1 : 0.5 : 1"
|
||||||
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
|
inkscape:vp_x="0 : 0.5 : 1"
|
||||||
|
sodipodi:type="inkscape:persp3d" />
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
id="base"
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1.0"
|
||||||
|
inkscape:pageopacity="0.0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:zoom="82.777778"
|
||||||
|
inkscape:cx="2.9300294"
|
||||||
|
inkscape:cy="5.466443"
|
||||||
|
inkscape:document-units="px"
|
||||||
|
inkscape:current-layer="layer1"
|
||||||
|
showgrid="false"
|
||||||
|
inkscape:window-width="1680"
|
||||||
|
inkscape:window-height="997"
|
||||||
|
inkscape:window-x="0"
|
||||||
|
inkscape:window-y="26"
|
||||||
|
inkscape:window-maximized="1" />
|
||||||
|
<metadata
|
||||||
|
id="metadata3652">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title></dc:title>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<g
|
||||||
|
inkscape:label="Layer 1"
|
||||||
|
inkscape:groupmode="layer"
|
||||||
|
id="layer1"
|
||||||
|
transform="translate(-262.78425,-490.71933)">
|
||||||
|
<path
|
||||||
|
transform="matrix(0,-0.98149546,0.71467449,0,25.404986,578.15569)"
|
||||||
|
d="M 88.830127,340 80.169873,340 84.5,332.5 88.830127,340 z"
|
||||||
|
inkscape:randomized="0"
|
||||||
|
inkscape:rounded="0"
|
||||||
|
inkscape:flatsided="true"
|
||||||
|
sodipodi:arg2="1.5707963"
|
||||||
|
sodipodi:arg1="0.52359878"
|
||||||
|
sodipodi:r2="2.5"
|
||||||
|
sodipodi:r1="5"
|
||||||
|
sodipodi:cy="337.5"
|
||||||
|
sodipodi:cx="84.5"
|
||||||
|
sodipodi:sides="3"
|
||||||
|
id="path5497-5"
|
||||||
|
style="fill:#ffffff;fill-opacity:1;stroke:#ffffff;stroke-width:0.59699643;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
|
||||||
|
sodipodi:type="star" />
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 2.8 KiB |
87
data/theme/section-more.svg
Executable file
@ -0,0 +1,87 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="5.8600588"
|
||||||
|
height="9"
|
||||||
|
id="svg3647"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.46+devel"
|
||||||
|
sodipodi:docname="New document 6">
|
||||||
|
<defs
|
||||||
|
id="defs3649">
|
||||||
|
<inkscape:perspective
|
||||||
|
sodipodi:type="inkscape:persp3d"
|
||||||
|
inkscape:vp_x="0 : 526.18109 : 1"
|
||||||
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
|
inkscape:vp_z="744.09448 : 526.18109 : 1"
|
||||||
|
inkscape:persp3d-origin="372.04724 : 350.78739 : 1"
|
||||||
|
id="perspective3655" />
|
||||||
|
<inkscape:perspective
|
||||||
|
id="perspective3603"
|
||||||
|
inkscape:persp3d-origin="0.5 : 0.33333333 : 1"
|
||||||
|
inkscape:vp_z="1 : 0.5 : 1"
|
||||||
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
|
inkscape:vp_x="0 : 0.5 : 1"
|
||||||
|
sodipodi:type="inkscape:persp3d" />
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
id="base"
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1.0"
|
||||||
|
inkscape:pageopacity="0.0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:zoom="0.35"
|
||||||
|
inkscape:cx="112.21575"
|
||||||
|
inkscape:cy="-32.642856"
|
||||||
|
inkscape:document-units="px"
|
||||||
|
inkscape:current-layer="layer1"
|
||||||
|
showgrid="false"
|
||||||
|
inkscape:window-width="609"
|
||||||
|
inkscape:window-height="501"
|
||||||
|
inkscape:window-x="164"
|
||||||
|
inkscape:window-y="26"
|
||||||
|
inkscape:window-maximized="0" />
|
||||||
|
<metadata
|
||||||
|
id="metadata3652">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title></dc:title>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<g
|
||||||
|
inkscape:label="Layer 1"
|
||||||
|
inkscape:groupmode="layer"
|
||||||
|
id="layer1"
|
||||||
|
transform="translate(-262.78425,-490.71933)">
|
||||||
|
<path
|
||||||
|
transform="matrix(0,0.98149546,-0.71467449,0,506.02358,412.28296)"
|
||||||
|
d="M 88.830127,340 80.169873,340 84.5,332.5 88.830127,340 z"
|
||||||
|
inkscape:randomized="0"
|
||||||
|
inkscape:rounded="0"
|
||||||
|
inkscape:flatsided="true"
|
||||||
|
sodipodi:arg2="1.5707963"
|
||||||
|
sodipodi:arg1="0.52359878"
|
||||||
|
sodipodi:r2="2.5"
|
||||||
|
sodipodi:r1="5"
|
||||||
|
sodipodi:cy="337.5"
|
||||||
|
sodipodi:cx="84.5"
|
||||||
|
sodipodi:sides="3"
|
||||||
|
id="path5497-5"
|
||||||
|
style="fill:#5f5f5f;fill-opacity:1;stroke:#5f5f5f;stroke-width:0.59699643;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline"
|
||||||
|
sodipodi:type="star" />
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 2.8 KiB |
BIN
data/theme/separator-white.png
Normal file
After Width: | Height: | Size: 531 B |
81
data/theme/single-view-active.svg
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="24"
|
||||||
|
height="16"
|
||||||
|
id="svg6446"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.47pre4 r22446"
|
||||||
|
sodipodi:docname="single-view-active.svg">
|
||||||
|
<defs
|
||||||
|
id="defs6448">
|
||||||
|
<inkscape:perspective
|
||||||
|
sodipodi:type="inkscape:persp3d"
|
||||||
|
inkscape:vp_x="0 : 16 : 1"
|
||||||
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
|
inkscape:vp_z="32 : 16 : 1"
|
||||||
|
inkscape:persp3d-origin="16 : 10.666667 : 1"
|
||||||
|
id="perspective6454" />
|
||||||
|
<inkscape:perspective
|
||||||
|
id="perspective6441"
|
||||||
|
inkscape:persp3d-origin="0.5 : 0.33333333 : 1"
|
||||||
|
inkscape:vp_z="1 : 0.5 : 1"
|
||||||
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
|
inkscape:vp_x="0 : 0.5 : 1"
|
||||||
|
sodipodi:type="inkscape:persp3d" />
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
id="base"
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1.0"
|
||||||
|
inkscape:pageopacity="0.0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:zoom="11.197802"
|
||||||
|
inkscape:cx="0.014720032"
|
||||||
|
inkscape:cy="16"
|
||||||
|
inkscape:current-layer="layer1"
|
||||||
|
showgrid="true"
|
||||||
|
inkscape:grid-bbox="true"
|
||||||
|
inkscape:document-units="px"
|
||||||
|
inkscape:window-width="1680"
|
||||||
|
inkscape:window-height="997"
|
||||||
|
inkscape:window-x="0"
|
||||||
|
inkscape:window-y="26"
|
||||||
|
inkscape:window-maximized="1" />
|
||||||
|
<metadata
|
||||||
|
id="metadata6451">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title />
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<g
|
||||||
|
id="layer1"
|
||||||
|
inkscape:label="Layer 1"
|
||||||
|
inkscape:groupmode="layer"
|
||||||
|
transform="translate(0,-17)">
|
||||||
|
<rect
|
||||||
|
ry="0.5"
|
||||||
|
rx="0.49999979"
|
||||||
|
y="17.483809"
|
||||||
|
x="0.53483802"
|
||||||
|
height="15"
|
||||||
|
width="23"
|
||||||
|
id="rect5304"
|
||||||
|
style="fill:#cccccc;fill-opacity:1;stroke:#cccccc;stroke-width:1;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 2.4 KiB |
81
data/theme/single-view.svg
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="24"
|
||||||
|
height="16"
|
||||||
|
id="svg6446"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.47pre4 r22446"
|
||||||
|
sodipodi:docname="single-view.svg">
|
||||||
|
<defs
|
||||||
|
id="defs6448">
|
||||||
|
<inkscape:perspective
|
||||||
|
sodipodi:type="inkscape:persp3d"
|
||||||
|
inkscape:vp_x="0 : 16 : 1"
|
||||||
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
|
inkscape:vp_z="32 : 16 : 1"
|
||||||
|
inkscape:persp3d-origin="16 : 10.666667 : 1"
|
||||||
|
id="perspective6454" />
|
||||||
|
<inkscape:perspective
|
||||||
|
id="perspective6441"
|
||||||
|
inkscape:persp3d-origin="0.5 : 0.33333333 : 1"
|
||||||
|
inkscape:vp_z="1 : 0.5 : 1"
|
||||||
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
|
inkscape:vp_x="0 : 0.5 : 1"
|
||||||
|
sodipodi:type="inkscape:persp3d" />
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
id="base"
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1.0"
|
||||||
|
inkscape:pageopacity="0.0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:zoom="11.197802"
|
||||||
|
inkscape:cx="0.014720032"
|
||||||
|
inkscape:cy="16"
|
||||||
|
inkscape:current-layer="layer1"
|
||||||
|
showgrid="true"
|
||||||
|
inkscape:grid-bbox="true"
|
||||||
|
inkscape:document-units="px"
|
||||||
|
inkscape:window-width="1680"
|
||||||
|
inkscape:window-height="997"
|
||||||
|
inkscape:window-x="0"
|
||||||
|
inkscape:window-y="26"
|
||||||
|
inkscape:window-maximized="1" />
|
||||||
|
<metadata
|
||||||
|
id="metadata6451">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title />
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<g
|
||||||
|
id="layer1"
|
||||||
|
inkscape:label="Layer 1"
|
||||||
|
inkscape:groupmode="layer"
|
||||||
|
transform="translate(0,-17)">
|
||||||
|
<rect
|
||||||
|
ry="0.5"
|
||||||
|
rx="0.49999979"
|
||||||
|
y="17.483809"
|
||||||
|
x="0.53483802"
|
||||||
|
height="15"
|
||||||
|
width="23"
|
||||||
|
id="rect5304"
|
||||||
|
style="fill:#626262;fill-opacity:1;stroke:#cccccc;stroke-width:1;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" />
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 2.4 KiB |
@ -1,120 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
|
||||||
<!-- Generator: Adobe Illustrator 13.0.2, SVG Export Plug-In . SVG Version: 6.00 Build 14948) -->
|
|
||||||
|
|
||||||
<svg
|
|
||||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
|
||||||
xmlns:cc="http://creativecommons.org/ns#"
|
|
||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
|
||||||
xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
||||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
|
||||||
version="1.0"
|
|
||||||
id="Foreground"
|
|
||||||
x="0px"
|
|
||||||
y="0px"
|
|
||||||
width="32"
|
|
||||||
height="32"
|
|
||||||
viewBox="0 0 23.272727 23.272727"
|
|
||||||
enable-background="new 0 0 16 16"
|
|
||||||
xml:space="preserve"
|
|
||||||
sodipodi:version="0.32"
|
|
||||||
inkscape:version="0.48.2 r9819"
|
|
||||||
sodipodi:docname="summary-counter.svg"
|
|
||||||
inkscape:output_extension="org.inkscape.output.svg.inkscape"><metadata
|
|
||||||
id="metadata2399"><rdf:RDF><cc:Work
|
|
||||||
rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
|
|
||||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs
|
|
||||||
id="defs2397"><linearGradient
|
|
||||||
id="linearGradient3173"><stop
|
|
||||||
style="stop-color:#c4c4c4;stop-opacity:1;"
|
|
||||||
offset="0"
|
|
||||||
id="stop3175" /><stop
|
|
||||||
style="stop-color:#ffffff;stop-opacity:1;"
|
|
||||||
offset="1"
|
|
||||||
id="stop3177" /></linearGradient><inkscape:perspective
|
|
||||||
sodipodi:type="inkscape:persp3d"
|
|
||||||
inkscape:vp_x="0 : 8 : 1"
|
|
||||||
inkscape:vp_y="0 : 1000 : 0"
|
|
||||||
inkscape:vp_z="16 : 8 : 1"
|
|
||||||
inkscape:persp3d-origin="8 : 5.3333333 : 1"
|
|
||||||
id="perspective2401" /><filter
|
|
||||||
color-interpolation-filters="sRGB"
|
|
||||||
inkscape:collect="always"
|
|
||||||
id="filter16494-4"
|
|
||||||
x="-0.20989846"
|
|
||||||
width="1.4197969"
|
|
||||||
y="-0.20903821"
|
|
||||||
height="1.4180764"><feGaussianBlur
|
|
||||||
inkscape:collect="always"
|
|
||||||
stdDeviation="1.3282637"
|
|
||||||
id="feGaussianBlur16496-8" /></filter><radialGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
xlink:href="#linearGradient16498-6"
|
|
||||||
id="radialGradient16504-1"
|
|
||||||
cx="7.6582627"
|
|
||||||
cy="5.8191104"
|
|
||||||
fx="7.6582627"
|
|
||||||
fy="5.8191104"
|
|
||||||
r="8.6928644"
|
|
||||||
gradientTransform="matrix(1.0474339,0,0,1.0517402,-0.3632615,-0.42032492)"
|
|
||||||
gradientUnits="userSpaceOnUse" /><linearGradient
|
|
||||||
inkscape:collect="always"
|
|
||||||
id="linearGradient16498-6"><stop
|
|
||||||
style="stop-color:#9FD0FF;stop-opacity:1"
|
|
||||||
offset="0"
|
|
||||||
id="stop16500-8" /><stop
|
|
||||||
style="stop-color:#3465A4;stop-opacity:1"
|
|
||||||
offset="1"
|
|
||||||
id="stop16502-0" /></linearGradient></defs><sodipodi:namedview
|
|
||||||
inkscape:window-height="709"
|
|
||||||
inkscape:window-width="1366"
|
|
||||||
inkscape:pageshadow="2"
|
|
||||||
inkscape:pageopacity="0"
|
|
||||||
guidetolerance="10.0"
|
|
||||||
gridtolerance="10.0"
|
|
||||||
objecttolerance="10.0"
|
|
||||||
borderopacity="1.0"
|
|
||||||
bordercolor="#666666"
|
|
||||||
pagecolor="#000000"
|
|
||||||
id="base"
|
|
||||||
showgrid="false"
|
|
||||||
inkscape:zoom="11.313708"
|
|
||||||
inkscape:cx="15.386407"
|
|
||||||
inkscape:cy="13.739577"
|
|
||||||
inkscape:window-x="0"
|
|
||||||
inkscape:window-y="1179"
|
|
||||||
inkscape:current-layer="g16402-8"
|
|
||||||
showguides="true"
|
|
||||||
inkscape:guide-bbox="true"
|
|
||||||
borderlayer="true"
|
|
||||||
inkscape:showpageshadow="false"
|
|
||||||
inkscape:window-maximized="1"><inkscape:grid
|
|
||||||
type="xygrid"
|
|
||||||
id="grid11246"
|
|
||||||
empspacing="5"
|
|
||||||
visible="true"
|
|
||||||
enabled="true"
|
|
||||||
snapvisiblegridlinesonly="true" /></sodipodi:namedview><g
|
|
||||||
style="display:inline"
|
|
||||||
id="g16402-8"
|
|
||||||
transform="translate(4.7533483,2.8238929)"><g
|
|
||||||
id="g3175-4"
|
|
||||||
transform="translate(-0.89995416,0.94028614)"><path
|
|
||||||
sodipodi:type="inkscape:offset"
|
|
||||||
inkscape:radius="0"
|
|
||||||
inkscape:original="M 7.65625 0.125 C 3.2589349 0.125 -0.3125 3.7070002 -0.3125 8.125 C -0.3125 12.543001 3.2589349 16.125 7.65625 16.125 C 12.053566 16.125 15.625 12.543001 15.625 8.125 C 15.625 3.7070002 12.053566 0.125 7.65625 0.125 z "
|
|
||||||
xlink:href="#path2394-32"
|
|
||||||
style="opacity:0.52994014;color:#000000;fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:2.18181825;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;filter:url(#filter16494-4);enable-background:accumulate"
|
|
||||||
id="path16480-5"
|
|
||||||
inkscape:href="#path2394-32"
|
|
||||||
d="m 7.65625,0.125 c -4.3973151,0 -7.96875,3.5820002 -7.96875,8 0,4.418001 3.5714349,8 7.96875,8 4.397316,0 7.96875,-3.581999 7.96875,-8 0,-4.4179998 -3.571434,-8 -7.96875,-8 z"
|
|
||||||
transform="translate(0,1.028519)" /><path
|
|
||||||
clip-rule="evenodd"
|
|
||||||
d="m -0.30428257,8.1237596 c 0,-4.4179998 3.56522987,-7.9999996 7.96254497,-7.9999996 4.3973156,0 7.9625456,3.5819998 7.9625456,7.9999996 0,4.4180014 -3.56523,8.0000004 -7.9625456,8.0000004 -4.3973151,0 -7.96254497,-3.581999 -7.96254497,-8.0000004 z"
|
|
||||||
id="path2394-32"
|
|
||||||
style="color:#000000;fill:url(#radialGradient16504-1);fill-opacity:1;fill-rule:nonzero;stroke:#eeeeec;stroke-width:1.4545455;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
|
||||||
sodipodi:nodetypes="csssc"
|
|
||||||
inkscape:connector-curvature="0" /><g
|
|
||||||
id="g3172-6" /></g></g></svg>
|
|
Before Width: | Height: | Size: 5.4 KiB |
@ -9,7 +9,7 @@
|
|||||||
xmlns="http://www.w3.org/2000/svg"
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
width="65"
|
width="64"
|
||||||
height="22"
|
height="22"
|
||||||
id="svg3273"
|
id="svg3273"
|
||||||
version="1.1"
|
version="1.1"
|
||||||
|
Before Width: | Height: | Size: 4.7 KiB After Width: | Height: | Size: 4.7 KiB |
@ -9,7 +9,7 @@
|
|||||||
xmlns="http://www.w3.org/2000/svg"
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
width="65"
|
width="64"
|
||||||
height="22"
|
height="22"
|
||||||
id="svg3012"
|
id="svg3012"
|
||||||
version="1.1"
|
version="1.1"
|
||||||
|
Before Width: | Height: | Size: 7.2 KiB After Width: | Height: | Size: 7.2 KiB |
@ -13,8 +13,8 @@
|
|||||||
height="22"
|
height="22"
|
||||||
id="svg3199"
|
id="svg3199"
|
||||||
version="1.1"
|
version="1.1"
|
||||||
inkscape:version="0.48.1 r9760"
|
inkscape:version="0.47 r22583"
|
||||||
sodipodi:docname="toggle-on-intl.svg">
|
sodipodi:docname="New document 11">
|
||||||
<defs
|
<defs
|
||||||
id="defs3201">
|
id="defs3201">
|
||||||
<inkscape:perspective
|
<inkscape:perspective
|
||||||
@ -39,14 +39,14 @@
|
|||||||
borderopacity="1.0"
|
borderopacity="1.0"
|
||||||
inkscape:pageopacity="0.0"
|
inkscape:pageopacity="0.0"
|
||||||
inkscape:pageshadow="2"
|
inkscape:pageshadow="2"
|
||||||
inkscape:zoom="1"
|
inkscape:zoom="0.35"
|
||||||
inkscape:cx="49.147112"
|
inkscape:cx="32.500004"
|
||||||
inkscape:cy="17.532036"
|
inkscape:cy="10.999997"
|
||||||
inkscape:document-units="px"
|
inkscape:document-units="px"
|
||||||
inkscape:current-layer="layer1"
|
inkscape:current-layer="layer1"
|
||||||
showgrid="false"
|
showgrid="false"
|
||||||
inkscape:window-width="1412"
|
inkscape:window-width="609"
|
||||||
inkscape:window-height="1067"
|
inkscape:window-height="501"
|
||||||
inkscape:window-x="0"
|
inkscape:window-x="0"
|
||||||
inkscape:window-y="26"
|
inkscape:window-y="26"
|
||||||
inkscape:window-maximized="0" />
|
inkscape:window-maximized="0" />
|
||||||
@ -58,7 +58,7 @@
|
|||||||
<dc:format>image/svg+xml</dc:format>
|
<dc:format>image/svg+xml</dc:format>
|
||||||
<dc:type
|
<dc:type
|
||||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
<dc:title />
|
<dc:title></dc:title>
|
||||||
</cc:Work>
|
</cc:Work>
|
||||||
</rdf:RDF>
|
</rdf:RDF>
|
||||||
</metadata>
|
</metadata>
|
||||||
@ -72,7 +72,7 @@
|
|||||||
transform="translate(-453.5,448.36218)"
|
transform="translate(-453.5,448.36218)"
|
||||||
id="g16453">
|
id="g16453">
|
||||||
<rect
|
<rect
|
||||||
style="color:#000000;fill:#4a90d9;fill-opacity:1;fill-rule:nonzero;stroke:#3465a4;stroke-width:0.99999994000000003;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
style="color:#000000;fill:#204a87;fill-opacity:1;fill-rule:nonzero;stroke:#3465a4;stroke-width:0.99999994;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
||||||
id="rect16256-9-4"
|
id="rect16256-9-4"
|
||||||
width="63.000004"
|
width="63.000004"
|
||||||
height="19"
|
height="19"
|
||||||
|
Before Width: | Height: | Size: 4.5 KiB After Width: | Height: | Size: 4.5 KiB |
@ -13,8 +13,8 @@
|
|||||||
height="22"
|
height="22"
|
||||||
id="svg2857"
|
id="svg2857"
|
||||||
version="1.1"
|
version="1.1"
|
||||||
inkscape:version="0.48.1 r9760"
|
inkscape:version="0.47 r22583"
|
||||||
sodipodi:docname="toggle-on-us.svg">
|
sodipodi:docname="New document 2">
|
||||||
<defs
|
<defs
|
||||||
id="defs2859">
|
id="defs2859">
|
||||||
<inkscape:perspective
|
<inkscape:perspective
|
||||||
@ -40,18 +40,16 @@
|
|||||||
inkscape:pageopacity="0.0"
|
inkscape:pageopacity="0.0"
|
||||||
inkscape:pageshadow="2"
|
inkscape:pageshadow="2"
|
||||||
inkscape:zoom="1"
|
inkscape:zoom="1"
|
||||||
inkscape:cx="19.689855"
|
inkscape:cx="-69.642856"
|
||||||
inkscape:cy="2.0517979"
|
inkscape:cy="42.428569"
|
||||||
inkscape:document-units="px"
|
inkscape:document-units="px"
|
||||||
inkscape:current-layer="layer1"
|
inkscape:current-layer="layer1"
|
||||||
showgrid="false"
|
showgrid="false"
|
||||||
inkscape:window-width="941"
|
inkscape:window-width="609"
|
||||||
inkscape:window-height="751"
|
inkscape:window-height="501"
|
||||||
inkscape:window-x="2577"
|
inkscape:window-x="0"
|
||||||
inkscape:window-y="206"
|
inkscape:window-y="26"
|
||||||
inkscape:window-maximized="0"
|
inkscape:window-maximized="0" />
|
||||||
borderlayer="true"
|
|
||||||
inkscape:showpageshadow="false" />
|
|
||||||
<metadata
|
<metadata
|
||||||
id="metadata2862">
|
id="metadata2862">
|
||||||
<rdf:RDF>
|
<rdf:RDF>
|
||||||
@ -60,7 +58,7 @@
|
|||||||
<dc:format>image/svg+xml</dc:format>
|
<dc:format>image/svg+xml</dc:format>
|
||||||
<dc:type
|
<dc:type
|
||||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
<dc:title />
|
<dc:title></dc:title>
|
||||||
</cc:Work>
|
</cc:Work>
|
||||||
</rdf:RDF>
|
</rdf:RDF>
|
||||||
</metadata>
|
</metadata>
|
||||||
@ -74,7 +72,7 @@
|
|||||||
transform="translate(-351.35714,708.36218)"
|
transform="translate(-351.35714,708.36218)"
|
||||||
id="g16453">
|
id="g16453">
|
||||||
<rect
|
<rect
|
||||||
style="color:#000000;fill:#4a90d9;fill-opacity:1;fill-rule:nonzero;stroke:#3465a4;stroke-width:0.99999994000000003;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
style="color:#000000;fill:#204a87;fill-opacity:1;fill-rule:nonzero;stroke:#3465a4;stroke-width:0.99999994;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
|
||||||
id="rect16256-9-4"
|
id="rect16256-9-4"
|
||||||
width="63.000004"
|
width="63.000004"
|
||||||
height="19"
|
height="19"
|
||||||
|
Before Width: | Height: | Size: 6.8 KiB After Width: | Height: | Size: 6.7 KiB |
Before Width: | Height: | Size: 850 B |
376
data/theme/ws-switch-arrow-down.svg
Normal file
@ -0,0 +1,376 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:xlink="http://www.w3.org/1999/xlink"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
version="1.1"
|
||||||
|
width="96"
|
||||||
|
height="96"
|
||||||
|
id="svg25070"
|
||||||
|
inkscape:version="0.48.0 r9654"
|
||||||
|
sodipodi:docname="ws-switch-arrow-down.svg">
|
||||||
|
<metadata
|
||||||
|
id="metadata3353">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<sodipodi:namedview
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1"
|
||||||
|
objecttolerance="10"
|
||||||
|
gridtolerance="10"
|
||||||
|
guidetolerance="10"
|
||||||
|
inkscape:pageopacity="0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:window-width="718"
|
||||||
|
inkscape:window-height="480"
|
||||||
|
id="namedview3351"
|
||||||
|
showgrid="false"
|
||||||
|
inkscape:zoom="2.6979167"
|
||||||
|
inkscape:cx="48"
|
||||||
|
inkscape:cy="48"
|
||||||
|
inkscape:window-x="0"
|
||||||
|
inkscape:window-y="26"
|
||||||
|
inkscape:window-maximized="0"
|
||||||
|
inkscape:current-layer="svg25070" />
|
||||||
|
<defs
|
||||||
|
id="defs25072">
|
||||||
|
<linearGradient
|
||||||
|
x1="-86.552246"
|
||||||
|
y1="185.439"
|
||||||
|
x2="-83.37072"
|
||||||
|
y2="197.31261"
|
||||||
|
id="linearGradient24957"
|
||||||
|
xlink:href="#linearGradient4034-0-4"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="translate(6,0)" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient4034-0-4">
|
||||||
|
<stop
|
||||||
|
id="stop4036-5-7"
|
||||||
|
style="stop-color:#eeeeec;stop-opacity:1"
|
||||||
|
offset="0" />
|
||||||
|
<stop
|
||||||
|
id="stop4038-9-6"
|
||||||
|
style="stop-color:#babdb6;stop-opacity:1"
|
||||||
|
offset="1" />
|
||||||
|
</linearGradient>
|
||||||
|
<filter
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="1"
|
||||||
|
height="1"
|
||||||
|
color-interpolation-filters="sRGB"
|
||||||
|
id="filter24765">
|
||||||
|
<feColorMatrix
|
||||||
|
result="fbSourceGraphic"
|
||||||
|
values="1"
|
||||||
|
type="saturate"
|
||||||
|
id="feColorMatrix24767" />
|
||||||
|
<feColorMatrix
|
||||||
|
values="-1 0 0 0 1 0 -1 0 0 1 0 0 -1 0 1 0 0 0 1 0"
|
||||||
|
in="fbSourceGraphic"
|
||||||
|
id="feColorMatrix24769" />
|
||||||
|
</filter>
|
||||||
|
<linearGradient
|
||||||
|
x1="-74.520325"
|
||||||
|
y1="169.06032"
|
||||||
|
x2="-74.520325"
|
||||||
|
y2="205.94189"
|
||||||
|
id="linearGradient24955"
|
||||||
|
xlink:href="#linearGradient4632-1-3-9-3-2"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="translate(-5,0)" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient4632-1-3-9-3-2">
|
||||||
|
<stop
|
||||||
|
id="stop4634-1-8-3-9-0"
|
||||||
|
style="stop-color:#eeeeec;stop-opacity:1"
|
||||||
|
offset="0" />
|
||||||
|
<stop
|
||||||
|
id="stop4636-1-9-9-8-8"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1"
|
||||||
|
offset="0.0274937" />
|
||||||
|
<stop
|
||||||
|
id="stop4638-8-3-9-6-6"
|
||||||
|
style="stop-color:#f2f2f2;stop-opacity:1"
|
||||||
|
offset="0.274937" />
|
||||||
|
<stop
|
||||||
|
id="stop4640-8-5-7-8-9"
|
||||||
|
style="stop-color:#eeeeec;stop-opacity:1"
|
||||||
|
offset="0.38707438" />
|
||||||
|
<stop
|
||||||
|
id="stop4642-5-41-9-6-9"
|
||||||
|
style="stop-color:#d9dad8;stop-opacity:1"
|
||||||
|
offset="0.66528589" />
|
||||||
|
<stop
|
||||||
|
id="stop4644-5-2-7-9-2"
|
||||||
|
style="stop-color:#dfe0dd;stop-opacity:1"
|
||||||
|
offset="0.76745707" />
|
||||||
|
<stop
|
||||||
|
id="stop4646-3-2-3-7-3"
|
||||||
|
style="stop-color:#f0f0f0;stop-opacity:1"
|
||||||
|
offset="1" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
cx="-33.412369"
|
||||||
|
cy="185.74171"
|
||||||
|
r="2.3554697"
|
||||||
|
fx="-33.412369"
|
||||||
|
fy="185.74171"
|
||||||
|
id="radialGradient24959"
|
||||||
|
xlink:href="#linearGradient4869-4-1"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.0075,0,0,1.0075,-5.4544,-1.25141)" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient4869-4-1">
|
||||||
|
<stop
|
||||||
|
id="stop4871-6-2"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1"
|
||||||
|
offset="0" />
|
||||||
|
<stop
|
||||||
|
id="stop4879-7-4"
|
||||||
|
style="stop-color:#eeeeec;stop-opacity:1"
|
||||||
|
offset="0.31807542" />
|
||||||
|
<stop
|
||||||
|
id="stop4877-6-1"
|
||||||
|
style="stop-color:#c8c9c6;stop-opacity:1"
|
||||||
|
offset="0.74691135" />
|
||||||
|
<stop
|
||||||
|
id="stop4873-1-0"
|
||||||
|
style="stop-color:#d3d7cf;stop-opacity:1"
|
||||||
|
offset="1" />
|
||||||
|
</linearGradient>
|
||||||
|
<filter
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="1"
|
||||||
|
height="1"
|
||||||
|
color-interpolation-filters="sRGB"
|
||||||
|
id="filter25011">
|
||||||
|
<feColorMatrix
|
||||||
|
result="fbSourceGraphic"
|
||||||
|
values="1"
|
||||||
|
type="saturate"
|
||||||
|
id="feColorMatrix25013" />
|
||||||
|
<feColorMatrix
|
||||||
|
values="-1 0 0 0 1 0 -1 0 0 1 0 0 -1 0 1 0 0 0 1 0"
|
||||||
|
in="fbSourceGraphic"
|
||||||
|
id="feColorMatrix25015" />
|
||||||
|
</filter>
|
||||||
|
<radialGradient
|
||||||
|
cx="-33.412369"
|
||||||
|
cy="185.74171"
|
||||||
|
r="2.3554697"
|
||||||
|
fx="-33.412369"
|
||||||
|
fy="185.74171"
|
||||||
|
id="radialGradient24961"
|
||||||
|
xlink:href="#linearGradient4869-4-0"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.0075,0,0,1.0075,-5.4544,-1.25141)" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient4869-4-0">
|
||||||
|
<stop
|
||||||
|
id="stop4871-6-8"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1"
|
||||||
|
offset="0" />
|
||||||
|
<stop
|
||||||
|
id="stop4879-7-5"
|
||||||
|
style="stop-color:#eeeeec;stop-opacity:1"
|
||||||
|
offset="0.31807542" />
|
||||||
|
<stop
|
||||||
|
id="stop4877-6-5"
|
||||||
|
style="stop-color:#c8c9c6;stop-opacity:1"
|
||||||
|
offset="0.74691135" />
|
||||||
|
<stop
|
||||||
|
id="stop4873-1-4"
|
||||||
|
style="stop-color:#d3d7cf;stop-opacity:1"
|
||||||
|
offset="1" />
|
||||||
|
</linearGradient>
|
||||||
|
<filter
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="1"
|
||||||
|
height="1"
|
||||||
|
color-interpolation-filters="sRGB"
|
||||||
|
id="filter25023">
|
||||||
|
<feColorMatrix
|
||||||
|
result="fbSourceGraphic"
|
||||||
|
values="1"
|
||||||
|
type="saturate"
|
||||||
|
id="feColorMatrix25025" />
|
||||||
|
<feColorMatrix
|
||||||
|
values="-1 0 0 0 1 0 -1 0 0 1 0 0 -1 0 1 0 0 0 1 0"
|
||||||
|
in="fbSourceGraphic"
|
||||||
|
id="feColorMatrix25027" />
|
||||||
|
</filter>
|
||||||
|
<linearGradient
|
||||||
|
x1="-39.858727"
|
||||||
|
y1="184.61784"
|
||||||
|
x2="-38.244785"
|
||||||
|
y2="188.84898"
|
||||||
|
id="linearGradient24963"
|
||||||
|
xlink:href="#linearGradient4941"
|
||||||
|
gradientUnits="userSpaceOnUse" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient4941">
|
||||||
|
<stop
|
||||||
|
id="stop4943"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1"
|
||||||
|
offset="0" />
|
||||||
|
<stop
|
||||||
|
id="stop4945"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0"
|
||||||
|
offset="1" />
|
||||||
|
</linearGradient>
|
||||||
|
<filter
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="1"
|
||||||
|
height="1"
|
||||||
|
color-interpolation-filters="sRGB"
|
||||||
|
id="filter25033">
|
||||||
|
<feColorMatrix
|
||||||
|
result="fbSourceGraphic"
|
||||||
|
values="1"
|
||||||
|
type="saturate"
|
||||||
|
id="feColorMatrix25035" />
|
||||||
|
<feColorMatrix
|
||||||
|
values="-1 0 0 0 1 0 -1 0 0 1 0 0 -1 0 1 0 0 0 1 0"
|
||||||
|
in="fbSourceGraphic"
|
||||||
|
id="feColorMatrix25037" />
|
||||||
|
</filter>
|
||||||
|
<linearGradient
|
||||||
|
x1="-39.858727"
|
||||||
|
y1="184.61784"
|
||||||
|
x2="-38.244785"
|
||||||
|
y2="188.84898"
|
||||||
|
id="linearGradient24965"
|
||||||
|
xlink:href="#linearGradient4941-7"
|
||||||
|
gradientUnits="userSpaceOnUse" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient4941-7">
|
||||||
|
<stop
|
||||||
|
id="stop4943-2"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:1"
|
||||||
|
offset="0" />
|
||||||
|
<stop
|
||||||
|
id="stop4945-5"
|
||||||
|
style="stop-color:#ffffff;stop-opacity:0"
|
||||||
|
offset="1" />
|
||||||
|
</linearGradient>
|
||||||
|
<filter
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="1"
|
||||||
|
height="1"
|
||||||
|
color-interpolation-filters="sRGB"
|
||||||
|
id="filter25043">
|
||||||
|
<feColorMatrix
|
||||||
|
result="fbSourceGraphic"
|
||||||
|
values="1"
|
||||||
|
type="saturate"
|
||||||
|
id="feColorMatrix25045" />
|
||||||
|
<feColorMatrix
|
||||||
|
values="-1 0 0 0 1 0 -1 0 0 1 0 0 -1 0 1 0 0 0 1 0"
|
||||||
|
in="fbSourceGraphic"
|
||||||
|
id="feColorMatrix25047" />
|
||||||
|
</filter>
|
||||||
|
<filter
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="1"
|
||||||
|
height="1"
|
||||||
|
color-interpolation-filters="sRGB"
|
||||||
|
id="filter25049">
|
||||||
|
<feColorMatrix
|
||||||
|
result="fbSourceGraphic"
|
||||||
|
values="1"
|
||||||
|
type="saturate"
|
||||||
|
id="feColorMatrix25051" />
|
||||||
|
<feColorMatrix
|
||||||
|
values="-1 0 0 0 1 0 -1 0 0 1 0 0 -1 0 1 0 0 0 1 0"
|
||||||
|
in="fbSourceGraphic"
|
||||||
|
id="feColorMatrix25053" />
|
||||||
|
</filter>
|
||||||
|
<filter
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="1"
|
||||||
|
height="1"
|
||||||
|
color-interpolation-filters="sRGB"
|
||||||
|
id="filter25055">
|
||||||
|
<feColorMatrix
|
||||||
|
result="fbSourceGraphic"
|
||||||
|
values="1"
|
||||||
|
type="saturate"
|
||||||
|
id="feColorMatrix25057" />
|
||||||
|
<feColorMatrix
|
||||||
|
values="-1 0 0 0 1 0 -1 0 0 1 0 0 -1 0 1 0 0 0 1 0"
|
||||||
|
in="fbSourceGraphic"
|
||||||
|
id="feColorMatrix25059" />
|
||||||
|
</filter>
|
||||||
|
</defs>
|
||||||
|
<g
|
||||||
|
transform="matrix(0,1,-1,0,48.0003,4.1307112e-7)"
|
||||||
|
id="layer1">
|
||||||
|
<g
|
||||||
|
transform="matrix(-2,0,0,2,-97.2497,-374.967)"
|
||||||
|
id="g4030-1-8"
|
||||||
|
style="stroke:#000000;stroke-opacity:1;display:inline">
|
||||||
|
<path
|
||||||
|
d="m -72.5,173.5 -14,14 14,14"
|
||||||
|
id="path3165-7-3"
|
||||||
|
style="color:#000000;fill:none;stroke:#000000;stroke-width:7;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible"
|
||||||
|
inkscape:connector-curvature="0" />
|
||||||
|
</g>
|
||||||
|
<path
|
||||||
|
d="m -36.5,186.40625 a 2.09375,2.09375 0 1 1 -4.1875,0 2.09375,2.09375 0 1 1 4.1875,0 z"
|
||||||
|
transform="matrix(-3.34328,0,0,3.34328,-89.2797,-623.176)"
|
||||||
|
id="path4050-2-7-9-4"
|
||||||
|
style="color:#000000;fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.52343899;marker:none;visibility:visible;display:inline;overflow:visible"
|
||||||
|
inkscape:connector-curvature="0" />
|
||||||
|
<path
|
||||||
|
d="m -36.5,186.40625 a 2.09375,2.09375 0 1 1 -4.1875,0 2.09375,2.09375 0 1 1 4.1875,0 z"
|
||||||
|
transform="matrix(-3.34328,0,0,3.34328,-111.2797,-623.176)"
|
||||||
|
id="path4050-2-7-9-4-8"
|
||||||
|
style="color:#000000;fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.52343899;marker:none;visibility:visible;display:inline;overflow:visible"
|
||||||
|
inkscape:connector-curvature="0" />
|
||||||
|
<path
|
||||||
|
d="m -36.5,186.40625 a 2.09375,2.09375 0 1 1 -4.1875,0 2.09375,2.09375 0 1 1 4.1875,0 z"
|
||||||
|
transform="matrix(-2.86565,0,0,2.86565,-70.8457,-534.143)"
|
||||||
|
id="path4050-2-7-9-4-0"
|
||||||
|
style="color:#000000;fill:none;stroke:#000000;stroke-width:0.69792098;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible"
|
||||||
|
inkscape:connector-curvature="0" />
|
||||||
|
<path
|
||||||
|
d="m -36.5,186.40625 a 2.09375,2.09375 0 1 1 -4.1875,0 2.09375,2.09375 0 1 1 4.1875,0 z"
|
||||||
|
transform="matrix(-2.86565,0,0,2.86565,-92.8457,-534.143)"
|
||||||
|
id="path4050-2-7-9-4-0-9"
|
||||||
|
style="color:#000000;fill:none;stroke:#000000;stroke-width:0.69792098;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible"
|
||||||
|
inkscape:connector-curvature="0" />
|
||||||
|
<path
|
||||||
|
d="m 47.87528,-34.0295 c 1.53896,0.0448 3.0511,0.70928 4.125,1.8125 l 32.25,32.25 -32.25,32.25 c -2.2253,2.2253 -6.2747,2.2253 -8.5,0 -2.2253,-2.22528 -2.2253,-6.2747 0,-8.5 l 23.75,-23.75 -23.75,-23.75 c -1.73168,-1.6731 -2.295,-4.44228 -1.3546,-6.65894 0.94042,-2.21668 3.32312,-3.73604 5.7296,-3.65356 z"
|
||||||
|
id="path3165-7-3-1"
|
||||||
|
style="font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-indent:0pt;text-align:start;text-decoration:none;line-height:normal;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;text-anchor:start;opacity:0.35;color:#000000;fill:none;stroke:#000000;stroke-width:2;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker:none;visibility:visible;display:inline;overflow:visible;font-family:Bitstream Vera Sans"
|
||||||
|
inkscape:connector-curvature="0" />
|
||||||
|
<path
|
||||||
|
d="m 41.8316,28.09418 c -0.014,-1.58898 0.54158,-3.18406 1.66868,-4.31118 l 23.75,-23.75 m -25.1046,-30.40894 c 0.94042,-2.21668 3.32312,-3.73604 5.7296,-3.65356 1.53896,0.0448 3.0511,0.70928 4.125,1.8125 l 32.25,32.25"
|
||||||
|
id="path3165-7-3-1-9"
|
||||||
|
style="font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-indent:0pt;text-align:start;text-decoration:none;line-height:normal;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;text-anchor:start;color:#000000;fill:none;stroke:#000000;stroke-width:2;stroke-linecap:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker:none;visibility:visible;display:inline;overflow:visible;font-family:Bitstream Vera Sans"
|
||||||
|
inkscape:connector-curvature="0" />
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 13 KiB |
Before Width: | Height: | Size: 841 B |
447
data/theme/ws-switch-arrow-up.svg
Normal file
@ -0,0 +1,447 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||||
|
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:xlink="http://www.w3.org/1999/xlink"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="96"
|
||||||
|
height="96"
|
||||||
|
id="svg25070"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.48.0 r9654"
|
||||||
|
sodipodi:docname="ws-switch-arrow-up.svg">
|
||||||
|
<defs
|
||||||
|
id="defs25072">
|
||||||
|
<inkscape:perspective
|
||||||
|
sodipodi:type="inkscape:persp3d"
|
||||||
|
inkscape:vp_x="0 : 24 : 1"
|
||||||
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
|
inkscape:vp_z="48 : 24 : 1"
|
||||||
|
inkscape:persp3d-origin="24 : 16 : 1"
|
||||||
|
id="perspective25078" />
|
||||||
|
<inkscape:perspective
|
||||||
|
id="perspective24985"
|
||||||
|
inkscape:persp3d-origin="0.5 : 0.33333333 : 1"
|
||||||
|
inkscape:vp_z="1 : 0.5 : 1"
|
||||||
|
inkscape:vp_y="0 : 1000 : 0"
|
||||||
|
inkscape:vp_x="0 : 0.5 : 1"
|
||||||
|
sodipodi:type="inkscape:persp3d" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient4034-0-4"
|
||||||
|
id="linearGradient24957"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="translate(6)"
|
||||||
|
x1="-86.552246"
|
||||||
|
y1="185.439"
|
||||||
|
x2="-83.37072"
|
||||||
|
y2="197.31261" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
id="linearGradient4034-0-4">
|
||||||
|
<stop
|
||||||
|
style="stop-color: rgb(238, 238, 236); stop-opacity: 1;"
|
||||||
|
offset="0"
|
||||||
|
id="stop4036-5-7" />
|
||||||
|
<stop
|
||||||
|
style="stop-color: rgb(186, 189, 182); stop-opacity: 1;"
|
||||||
|
offset="1"
|
||||||
|
id="stop4038-9-6" />
|
||||||
|
</linearGradient>
|
||||||
|
<filter
|
||||||
|
id="filter24765"
|
||||||
|
inkscape:label="Invert"
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="1"
|
||||||
|
height="1"
|
||||||
|
inkscape:menu="Color"
|
||||||
|
inkscape:menu-tooltip="Invert colors"
|
||||||
|
color-interpolation-filters="sRGB">
|
||||||
|
<feColorMatrix
|
||||||
|
id="feColorMatrix24767"
|
||||||
|
type="saturate"
|
||||||
|
values="1"
|
||||||
|
result="fbSourceGraphic" />
|
||||||
|
<feColorMatrix
|
||||||
|
id="feColorMatrix24769"
|
||||||
|
in="fbSourceGraphic"
|
||||||
|
values="-1 0 0 0 1 0 -1 0 0 1 0 0 -1 0 1 0 0 0 1 0" />
|
||||||
|
</filter>
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient4632-1-3-9-3-2"
|
||||||
|
id="linearGradient24955"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="translate(-5)"
|
||||||
|
x1="-74.520325"
|
||||||
|
y1="169.06032"
|
||||||
|
x2="-74.520325"
|
||||||
|
y2="205.94189" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient4632-1-3-9-3-2">
|
||||||
|
<stop
|
||||||
|
style="stop-color: rgb(238, 238, 236); stop-opacity: 1;"
|
||||||
|
offset="0"
|
||||||
|
id="stop4634-1-8-3-9-0" />
|
||||||
|
<stop
|
||||||
|
id="stop4636-1-9-9-8-8"
|
||||||
|
offset="0.0274937"
|
||||||
|
style="stop-color: rgb(255, 255, 255); stop-opacity: 1;" />
|
||||||
|
<stop
|
||||||
|
id="stop4638-8-3-9-6-6"
|
||||||
|
offset="0.274937"
|
||||||
|
style="stop-color: rgb(242, 242, 242); stop-opacity: 1;" />
|
||||||
|
<stop
|
||||||
|
id="stop4640-8-5-7-8-9"
|
||||||
|
offset="0.38707438"
|
||||||
|
style="stop-color: rgb(238, 238, 236); stop-opacity: 1;" />
|
||||||
|
<stop
|
||||||
|
id="stop4642-5-41-9-6-9"
|
||||||
|
offset="0.66528589"
|
||||||
|
style="stop-color: rgb(217, 218, 216); stop-opacity: 1;" />
|
||||||
|
<stop
|
||||||
|
id="stop4644-5-2-7-9-2"
|
||||||
|
offset="0.76745707"
|
||||||
|
style="stop-color: rgb(223, 224, 221); stop-opacity: 1;" />
|
||||||
|
<stop
|
||||||
|
style="stop-color: rgb(240, 240, 240); stop-opacity: 1;"
|
||||||
|
offset="1"
|
||||||
|
id="stop4646-3-2-3-7-3" />
|
||||||
|
</linearGradient>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient4869-4-1"
|
||||||
|
id="radialGradient24959"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.0075, 0, 0, 1.0075, -5.4544, -1.25141)"
|
||||||
|
cx="-33.412369"
|
||||||
|
cy="185.74171"
|
||||||
|
fx="-33.412369"
|
||||||
|
fy="185.74171"
|
||||||
|
r="2.3554697" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient4869-4-1">
|
||||||
|
<stop
|
||||||
|
style="stop-color: rgb(255, 255, 255); stop-opacity: 1;"
|
||||||
|
offset="0"
|
||||||
|
id="stop4871-6-2" />
|
||||||
|
<stop
|
||||||
|
id="stop4879-7-4"
|
||||||
|
offset="0.31807542"
|
||||||
|
style="stop-color: rgb(238, 238, 236); stop-opacity: 1;" />
|
||||||
|
<stop
|
||||||
|
id="stop4877-6-1"
|
||||||
|
offset="0.74691135"
|
||||||
|
style="stop-color: rgb(200, 201, 198); stop-opacity: 1;" />
|
||||||
|
<stop
|
||||||
|
style="stop-color: rgb(211, 215, 207); stop-opacity: 1;"
|
||||||
|
offset="1"
|
||||||
|
id="stop4873-1-0" />
|
||||||
|
</linearGradient>
|
||||||
|
<filter
|
||||||
|
id="filter25011"
|
||||||
|
inkscape:label="Invert"
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="1"
|
||||||
|
height="1"
|
||||||
|
inkscape:menu="Color"
|
||||||
|
inkscape:menu-tooltip="Invert colors"
|
||||||
|
color-interpolation-filters="sRGB">
|
||||||
|
<feColorMatrix
|
||||||
|
id="feColorMatrix25013"
|
||||||
|
type="saturate"
|
||||||
|
values="1"
|
||||||
|
result="fbSourceGraphic" />
|
||||||
|
<feColorMatrix
|
||||||
|
id="feColorMatrix25015"
|
||||||
|
in="fbSourceGraphic"
|
||||||
|
values="-1 0 0 0 1 0 -1 0 0 1 0 0 -1 0 1 0 0 0 1 0" />
|
||||||
|
</filter>
|
||||||
|
<radialGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient4869-4-0"
|
||||||
|
id="radialGradient24961"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
gradientTransform="matrix(1.0075, 0, 0, 1.0075, -5.4544, -1.25141)"
|
||||||
|
cx="-33.412369"
|
||||||
|
cy="185.74171"
|
||||||
|
fx="-33.412369"
|
||||||
|
fy="185.74171"
|
||||||
|
r="2.3554697" />
|
||||||
|
<linearGradient
|
||||||
|
id="linearGradient4869-4-0">
|
||||||
|
<stop
|
||||||
|
style="stop-color: rgb(255, 255, 255); stop-opacity: 1;"
|
||||||
|
offset="0"
|
||||||
|
id="stop4871-6-8" />
|
||||||
|
<stop
|
||||||
|
id="stop4879-7-5"
|
||||||
|
offset="0.31807542"
|
||||||
|
style="stop-color: rgb(238, 238, 236); stop-opacity: 1;" />
|
||||||
|
<stop
|
||||||
|
id="stop4877-6-5"
|
||||||
|
offset="0.74691135"
|
||||||
|
style="stop-color: rgb(200, 201, 198); stop-opacity: 1;" />
|
||||||
|
<stop
|
||||||
|
style="stop-color: rgb(211, 215, 207); stop-opacity: 1;"
|
||||||
|
offset="1"
|
||||||
|
id="stop4873-1-4" />
|
||||||
|
</linearGradient>
|
||||||
|
<filter
|
||||||
|
id="filter25023"
|
||||||
|
inkscape:label="Invert"
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="1"
|
||||||
|
height="1"
|
||||||
|
inkscape:menu="Color"
|
||||||
|
inkscape:menu-tooltip="Invert colors"
|
||||||
|
color-interpolation-filters="sRGB">
|
||||||
|
<feColorMatrix
|
||||||
|
id="feColorMatrix25025"
|
||||||
|
type="saturate"
|
||||||
|
values="1"
|
||||||
|
result="fbSourceGraphic" />
|
||||||
|
<feColorMatrix
|
||||||
|
id="feColorMatrix25027"
|
||||||
|
in="fbSourceGraphic"
|
||||||
|
values="-1 0 0 0 1 0 -1 0 0 1 0 0 -1 0 1 0 0 0 1 0" />
|
||||||
|
</filter>
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient4941"
|
||||||
|
id="linearGradient24963"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
x1="-39.858727"
|
||||||
|
y1="184.61784"
|
||||||
|
x2="-38.244785"
|
||||||
|
y2="188.84898" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
id="linearGradient4941">
|
||||||
|
<stop
|
||||||
|
style="stop-color: rgb(255, 255, 255); stop-opacity: 1;"
|
||||||
|
offset="0"
|
||||||
|
id="stop4943" />
|
||||||
|
<stop
|
||||||
|
style="stop-color: rgb(255, 255, 255); stop-opacity: 0;"
|
||||||
|
offset="1"
|
||||||
|
id="stop4945" />
|
||||||
|
</linearGradient>
|
||||||
|
<filter
|
||||||
|
id="filter25033"
|
||||||
|
inkscape:label="Invert"
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="1"
|
||||||
|
height="1"
|
||||||
|
inkscape:menu="Color"
|
||||||
|
inkscape:menu-tooltip="Invert colors"
|
||||||
|
color-interpolation-filters="sRGB">
|
||||||
|
<feColorMatrix
|
||||||
|
id="feColorMatrix25035"
|
||||||
|
type="saturate"
|
||||||
|
values="1"
|
||||||
|
result="fbSourceGraphic" />
|
||||||
|
<feColorMatrix
|
||||||
|
id="feColorMatrix25037"
|
||||||
|
in="fbSourceGraphic"
|
||||||
|
values="-1 0 0 0 1 0 -1 0 0 1 0 0 -1 0 1 0 0 0 1 0" />
|
||||||
|
</filter>
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
xlink:href="#linearGradient4941-7"
|
||||||
|
id="linearGradient24965"
|
||||||
|
gradientUnits="userSpaceOnUse"
|
||||||
|
x1="-39.858727"
|
||||||
|
y1="184.61784"
|
||||||
|
x2="-38.244785"
|
||||||
|
y2="188.84898" />
|
||||||
|
<linearGradient
|
||||||
|
inkscape:collect="always"
|
||||||
|
id="linearGradient4941-7">
|
||||||
|
<stop
|
||||||
|
style="stop-color: rgb(255, 255, 255); stop-opacity: 1;"
|
||||||
|
offset="0"
|
||||||
|
id="stop4943-2" />
|
||||||
|
<stop
|
||||||
|
style="stop-color: rgb(255, 255, 255); stop-opacity: 0;"
|
||||||
|
offset="1"
|
||||||
|
id="stop4945-5" />
|
||||||
|
</linearGradient>
|
||||||
|
<filter
|
||||||
|
id="filter25043"
|
||||||
|
inkscape:label="Invert"
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="1"
|
||||||
|
height="1"
|
||||||
|
inkscape:menu="Color"
|
||||||
|
inkscape:menu-tooltip="Invert colors"
|
||||||
|
color-interpolation-filters="sRGB">
|
||||||
|
<feColorMatrix
|
||||||
|
id="feColorMatrix25045"
|
||||||
|
type="saturate"
|
||||||
|
values="1"
|
||||||
|
result="fbSourceGraphic" />
|
||||||
|
<feColorMatrix
|
||||||
|
id="feColorMatrix25047"
|
||||||
|
in="fbSourceGraphic"
|
||||||
|
values="-1 0 0 0 1 0 -1 0 0 1 0 0 -1 0 1 0 0 0 1 0" />
|
||||||
|
</filter>
|
||||||
|
<filter
|
||||||
|
id="filter25049"
|
||||||
|
inkscape:label="Invert"
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="1"
|
||||||
|
height="1"
|
||||||
|
inkscape:menu="Color"
|
||||||
|
inkscape:menu-tooltip="Invert colors"
|
||||||
|
color-interpolation-filters="sRGB">
|
||||||
|
<feColorMatrix
|
||||||
|
id="feColorMatrix25051"
|
||||||
|
type="saturate"
|
||||||
|
values="1"
|
||||||
|
result="fbSourceGraphic" />
|
||||||
|
<feColorMatrix
|
||||||
|
id="feColorMatrix25053"
|
||||||
|
in="fbSourceGraphic"
|
||||||
|
values="-1 0 0 0 1 0 -1 0 0 1 0 0 -1 0 1 0 0 0 1 0" />
|
||||||
|
</filter>
|
||||||
|
<filter
|
||||||
|
id="filter25055"
|
||||||
|
inkscape:label="Invert"
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
width="1"
|
||||||
|
height="1"
|
||||||
|
inkscape:menu="Color"
|
||||||
|
inkscape:menu-tooltip="Invert colors"
|
||||||
|
color-interpolation-filters="sRGB">
|
||||||
|
<feColorMatrix
|
||||||
|
id="feColorMatrix25057"
|
||||||
|
type="saturate"
|
||||||
|
values="1"
|
||||||
|
result="fbSourceGraphic" />
|
||||||
|
<feColorMatrix
|
||||||
|
id="feColorMatrix25059"
|
||||||
|
in="fbSourceGraphic"
|
||||||
|
values="-1 0 0 0 1 0 -1 0 0 1 0 0 -1 0 1 0 0 0 1 0" />
|
||||||
|
</filter>
|
||||||
|
</defs>
|
||||||
|
<sodipodi:namedview
|
||||||
|
id="base"
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1.0"
|
||||||
|
inkscape:pageopacity="0.0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:zoom="2.8284271"
|
||||||
|
inkscape:cx="-12.356322"
|
||||||
|
inkscape:cy="57.536221"
|
||||||
|
inkscape:current-layer="layer1"
|
||||||
|
showgrid="true"
|
||||||
|
inkscape:grid-bbox="true"
|
||||||
|
inkscape:document-units="px"
|
||||||
|
inkscape:window-width="1200"
|
||||||
|
inkscape:window-height="840"
|
||||||
|
inkscape:window-x="0"
|
||||||
|
inkscape:window-y="26"
|
||||||
|
inkscape:window-maximized="0" />
|
||||||
|
<metadata
|
||||||
|
id="metadata25075">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title />
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<g
|
||||||
|
id="layer1"
|
||||||
|
inkscape:label="Layer 1"
|
||||||
|
inkscape:groupmode="layer"
|
||||||
|
transform="translate(0, 48)">
|
||||||
|
<g
|
||||||
|
id="g3181"
|
||||||
|
transform="matrix(0,1,-1,0,48.0003,-48)">
|
||||||
|
<g
|
||||||
|
style="stroke:#000000;stroke-opacity:1;display:inline"
|
||||||
|
transform="matrix(2,0,0,2,193.25,-374.967)"
|
||||||
|
id="g4030-1-8">
|
||||||
|
<path
|
||||||
|
style="color:#000000;fill:none;stroke:#000000;stroke-width:7;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible"
|
||||||
|
d="m -72.5,173.5 -14,14 14,14"
|
||||||
|
id="path3165-7-3"
|
||||||
|
sodipodi:nodetypes="ccc"
|
||||||
|
inkscape:connector-curvature="0" />
|
||||||
|
</g>
|
||||||
|
<path
|
||||||
|
transform="matrix(3.34328,0,0,3.34328,185.28,-623.176)"
|
||||||
|
d="m -36.5,186.40625 c 0,1.15635 -0.937404,2.09375 -2.09375,2.09375 -1.156346,0 -2.09375,-0.9374 -2.09375,-2.09375 0,-1.15635 0.937404,-2.09375 2.09375,-2.09375 1.156346,0 2.09375,0.9374 2.09375,2.09375 z"
|
||||||
|
sodipodi:ry="2.09375"
|
||||||
|
sodipodi:rx="2.09375"
|
||||||
|
sodipodi:cy="186.40625"
|
||||||
|
sodipodi:cx="-38.59375"
|
||||||
|
id="path4050-2-7-9-4"
|
||||||
|
style="color:#000000;fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.52343899;marker:none;visibility:visible;display:inline;overflow:visible"
|
||||||
|
sodipodi:type="arc" />
|
||||||
|
<path
|
||||||
|
transform="matrix(3.34328,0,0,3.34328,207.28,-623.176)"
|
||||||
|
d="m -36.5,186.40625 c 0,1.15635 -0.937404,2.09375 -2.09375,2.09375 -1.156346,0 -2.09375,-0.9374 -2.09375,-2.09375 0,-1.15635 0.937404,-2.09375 2.09375,-2.09375 1.156346,0 2.09375,0.9374 2.09375,2.09375 z"
|
||||||
|
sodipodi:ry="2.09375"
|
||||||
|
sodipodi:rx="2.09375"
|
||||||
|
sodipodi:cy="186.40625"
|
||||||
|
sodipodi:cx="-38.59375"
|
||||||
|
id="path4050-2-7-9-4-8"
|
||||||
|
style="color:#000000;fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.52343899;marker:none;visibility:visible;display:inline;overflow:visible"
|
||||||
|
sodipodi:type="arc" />
|
||||||
|
<path
|
||||||
|
transform="matrix(2.86565,0,0,2.86565,166.846,-534.143)"
|
||||||
|
d="m -36.5,186.40625 c 0,1.15635 -0.937404,2.09375 -2.09375,2.09375 -1.156346,0 -2.09375,-0.9374 -2.09375,-2.09375 0,-1.15635 0.937404,-2.09375 2.09375,-2.09375 1.156346,0 2.09375,0.9374 2.09375,2.09375 z"
|
||||||
|
sodipodi:ry="2.09375"
|
||||||
|
sodipodi:rx="2.09375"
|
||||||
|
sodipodi:cy="186.40625"
|
||||||
|
sodipodi:cx="-38.59375"
|
||||||
|
id="path4050-2-7-9-4-0"
|
||||||
|
style="color:#000000;fill:none;stroke:#000000;stroke-width:0.69792098;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible"
|
||||||
|
sodipodi:type="arc" />
|
||||||
|
<path
|
||||||
|
transform="matrix(2.86565,0,0,2.86565,188.846,-534.143)"
|
||||||
|
d="m -36.5,186.40625 c 0,1.15635 -0.937404,2.09375 -2.09375,2.09375 -1.156346,0 -2.09375,-0.9374 -2.09375,-2.09375 0,-1.15635 0.937404,-2.09375 2.09375,-2.09375 1.156346,0 2.09375,0.9374 2.09375,2.09375 z"
|
||||||
|
sodipodi:ry="2.09375"
|
||||||
|
sodipodi:rx="2.09375"
|
||||||
|
sodipodi:cy="186.40625"
|
||||||
|
sodipodi:cx="-38.59375"
|
||||||
|
id="path4050-2-7-9-4-0-9"
|
||||||
|
style="color:#000000;fill:none;stroke:#000000;stroke-width:0.69792098;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible"
|
||||||
|
sodipodi:type="arc" />
|
||||||
|
<path
|
||||||
|
transform="matrix(2,0,0,2,-586,-765.967)"
|
||||||
|
sodipodi:nodetypes="ccccscccsc"
|
||||||
|
id="path3165-7-3-1"
|
||||||
|
d="m 317.06251,365.96875 c -0.76948,0.0224 -1.52555,0.35464 -2.0625,0.90625 l -16.125,16.125 16.125,16.125 c 1.11265,1.11265 3.13735,1.11265 4.25,0 1.11265,-1.11264 1.11265,-3.13735 0,-4.25 l -11.875,-11.875 11.875,-11.875 c 0.86584,-0.83655 1.1475,-2.22114 0.6773,-3.32947 -0.47021,-1.10834 -1.66156,-1.86802 -2.8648,-1.82678 z"
|
||||||
|
style="font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-indent:0pt;text-align:start;text-decoration:none;line-height:normal;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;text-anchor:start;opacity:0.35;color:#000000;fill:none;stroke:#000000;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker:none;visibility:visible;display:inline;overflow:visible;font-family:Bitstream Vera Sans"
|
||||||
|
inkscape:connector-curvature="0" />
|
||||||
|
<path
|
||||||
|
transform="matrix(2,0,0,2,-586,-765.967)"
|
||||||
|
sodipodi:nodetypes="ccccccc"
|
||||||
|
id="path3165-7-3-1-9"
|
||||||
|
d="m 320.08435,397.03059 c 0.007,-0.79449 -0.27079,-1.59203 -0.83434,-2.15559 L 307.37501,383 m 12.5523,-15.20447 c -0.47021,-1.10834 -1.66156,-1.86802 -2.8648,-1.82678 -0.76948,0.0224 -1.52555,0.35464 -2.0625,0.90625 L 298.87501,383"
|
||||||
|
style="font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-indent:0pt;text-align:start;text-decoration:none;line-height:normal;letter-spacing:normal;word-spacing:normal;text-transform:none;direction:ltr;text-anchor:start;color:#000000;fill:none;stroke:#000000;stroke-width:1;stroke-linecap:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;marker:none;visibility:visible;display:inline;overflow:visible;font-family:Bitstream Vera Sans"
|
||||||
|
inkscape:connector-curvature="0" />
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 16 KiB |
@ -1 +0,0 @@
|
|||||||
SUBDIRS = reference
|
|
@ -1 +0,0 @@
|
|||||||
SUBDIRS = shell st
|
|
@ -1,117 +0,0 @@
|
|||||||
## Process this file with automake to produce Makefile.in
|
|
||||||
|
|
||||||
# We require automake 1.6 at least.
|
|
||||||
AUTOMAKE_OPTIONS = 1.6
|
|
||||||
|
|
||||||
# This is a blank Makefile.am for using gtk-doc.
|
|
||||||
# Copy this to your project's API docs directory and modify the variables to
|
|
||||||
# suit your project. See the GTK+ Makefiles in gtk+/docs/reference for examples
|
|
||||||
# of using the various options.
|
|
||||||
|
|
||||||
# The name of the module, e.g. 'glib'.
|
|
||||||
DOC_MODULE=shell
|
|
||||||
|
|
||||||
# Uncomment for versioned docs and specify the version of the module, e.g. '2'.
|
|
||||||
#DOC_MODULE_VERSION=2
|
|
||||||
|
|
||||||
|
|
||||||
# The top-level SGML file. You can change this if you want to.
|
|
||||||
DOC_MAIN_SGML_FILE=$(DOC_MODULE)-docs.sgml
|
|
||||||
|
|
||||||
# Directories containing the source code
|
|
||||||
# gtk-doc will search all .c and .h files beneath these paths
|
|
||||||
# for inline comments documenting functions and macros.
|
|
||||||
DOC_SOURCE_DIR=$(top_srcdir)/src
|
|
||||||
|
|
||||||
# Extra options to pass to gtkdoc-scangobj. Not normally needed.
|
|
||||||
SCANGOBJ_OPTIONS=
|
|
||||||
|
|
||||||
# Extra options to supply to gtkdoc-scan.
|
|
||||||
# e.g. SCAN_OPTIONS=--deprecated-guards="GTK_DISABLE_DEPRECATED"
|
|
||||||
SCAN_OPTIONS=--rebuild-types
|
|
||||||
|
|
||||||
# Extra options to supply to gtkdoc-mkdb.
|
|
||||||
# e.g. MKDB_OPTIONS=--xml-mode --output-format=xml
|
|
||||||
MKDB_OPTIONS=--xml-mode --output-format=xml
|
|
||||||
|
|
||||||
# Extra options to supply to gtkdoc-mktmpl
|
|
||||||
# e.g. MKTMPL_OPTIONS=--only-section-tmpl
|
|
||||||
MKTMPL_OPTIONS=
|
|
||||||
|
|
||||||
# Extra options to supply to gtkdoc-mkhtml
|
|
||||||
MKHTML_OPTIONS=
|
|
||||||
|
|
||||||
# Extra options to supply to gtkdoc-fixref. Not normally needed.
|
|
||||||
# e.g. FIXXREF_OPTIONS=--extra-dir=../gdk-pixbuf/html --extra-dir=../gdk/html
|
|
||||||
FIXXREF_OPTIONS=
|
|
||||||
|
|
||||||
# Used for dependencies. The docs will be rebuilt if any of these change.
|
|
||||||
# e.g. HFILE_GLOB=$(top_srcdir)/gtk/*.h
|
|
||||||
# e.g. CFILE_GLOB=$(top_srcdir)/gtk/*.c
|
|
||||||
HFILE_GLOB=$(top_srcdir)/src/*.h
|
|
||||||
CFILE_GLOB=$(top_srcdir)/src/*.c
|
|
||||||
|
|
||||||
# Extra header to include when scanning, which are not under DOC_SOURCE_DIR
|
|
||||||
# e.g. EXTRA_HFILES=$(top_srcdir}/contrib/extra.h
|
|
||||||
EXTRA_HFILES=
|
|
||||||
|
|
||||||
# Header files or dirs to ignore when scanning. Use base file/dir names
|
|
||||||
# e.g. IGNORE_HFILES=gtkdebug.h gtkintl.h private_code
|
|
||||||
IGNORE_HFILES= \
|
|
||||||
calendar-server \
|
|
||||||
gvc \
|
|
||||||
hotplug-sniffer \
|
|
||||||
st \
|
|
||||||
tray \
|
|
||||||
gactionmuxer.h \
|
|
||||||
gactionobservable.h \
|
|
||||||
gactionobserver.h \
|
|
||||||
shell-recorder-src.h
|
|
||||||
|
|
||||||
if !BUILD_RECORDER
|
|
||||||
IGNORE_HFILES += shell-recorder.h
|
|
||||||
endif
|
|
||||||
|
|
||||||
# Images to copy into HTML directory.
|
|
||||||
# e.g. HTML_IMAGES=$(top_srcdir)/gtk/stock-icons/stock_about_24.png
|
|
||||||
HTML_IMAGES=
|
|
||||||
|
|
||||||
# Extra SGML files that are included by $(DOC_MAIN_SGML_FILE).
|
|
||||||
# e.g. content_files=running.sgml building.sgml changes-2.0.sgml
|
|
||||||
content_files=
|
|
||||||
|
|
||||||
# SGML files where gtk-doc abbrevations (#GtkWidget) are expanded
|
|
||||||
# These files must be listed here *and* in content_files
|
|
||||||
# e.g. expand_content_files=running.sgml
|
|
||||||
expand_content_files=
|
|
||||||
|
|
||||||
# CFLAGS and LDFLAGS for compiling gtkdoc-scangobj with your library.
|
|
||||||
# Only needed if you are using gtkdoc-scangobj to dynamically query widget
|
|
||||||
# signals and properties.
|
|
||||||
# e.g. GTKDOC_CFLAGS=-I$(top_srcdir) -I$(top_builddir) $(GTK_DEBUG_FLAGS)
|
|
||||||
# e.g. GTKDOC_LIBS=$(top_builddir)/gtk/$(gtktargetlib)
|
|
||||||
GTKDOC_CFLAGS=$(GNOME_SHELL_CFLAGS)
|
|
||||||
GTKDOC_LIBS=$(GNOME_SHELL_LIBS) $(BLUETOOTH_LIBS) $(top_builddir)/src/libgnome-shell.la
|
|
||||||
|
|
||||||
# This includes the standard gtk-doc make rules, copied by gtkdocize.
|
|
||||||
include $(top_srcdir)/gtk-doc.make
|
|
||||||
|
|
||||||
# Other files to distribute
|
|
||||||
# e.g. EXTRA_DIST += version.xml.in
|
|
||||||
EXTRA_DIST +=
|
|
||||||
|
|
||||||
# Files not to distribute
|
|
||||||
# for --rebuild-types in $(SCAN_OPTIONS), e.g. $(DOC_MODULE).types
|
|
||||||
# for --rebuild-sections in $(SCAN_OPTIONS) e.g. $(DOC_MODULE)-sections.txt
|
|
||||||
DISTCLEANFILES = $(DOC_MODULES).types
|
|
||||||
|
|
||||||
# Comment this out if you want 'make check' to test you doc status
|
|
||||||
# and run some sanity checks
|
|
||||||
if ENABLE_GTK_DOC
|
|
||||||
TESTS_ENVIRONMENT = cd $(srcdir) && \
|
|
||||||
DOC_MODULE=$(DOC_MODULE) DOC_MAIN_SGML_FILE=$(DOC_MAIN_SGML_FILE) \
|
|
||||||
SRCDIR=$(abs_srcdir) BUILDDIR=$(abs_builddir)
|
|
||||||
#TESTS = $(GTKDOC_CHECK)
|
|
||||||
endif
|
|
||||||
|
|
||||||
-include $(top_srcdir)/git.mk
|
|
@ -1,70 +0,0 @@
|
|||||||
<?xml version="1.0"?>
|
|
||||||
<!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook XML V4.3//EN"
|
|
||||||
"http://www.oasis-open.org/docbook/xml/4.3/docbookx.dtd"
|
|
||||||
[
|
|
||||||
<!ENTITY % local.common.attrib "xmlns:xi CDATA #FIXED 'http://www.w3.org/2003/XInclude'">
|
|
||||||
]>
|
|
||||||
<book id="index">
|
|
||||||
<bookinfo>
|
|
||||||
<title>Shell Reference Manual</title>
|
|
||||||
<releaseinfo>
|
|
||||||
for Shell @VERSION@.
|
|
||||||
<!--The latest version of this documentation can be found on-line at
|
|
||||||
<ulink role="online-location" url="http://[SERVER]/shell/index.html">http://[SERVER]/shell/</ulink>.-->
|
|
||||||
</releaseinfo>
|
|
||||||
</bookinfo>
|
|
||||||
|
|
||||||
<chapter>
|
|
||||||
<title>Actors</title>
|
|
||||||
<xi:include href="xml/shell-generic-container.xml"/>
|
|
||||||
<xi:include href="xml/shell-slicer.xml"/>
|
|
||||||
<xi:include href="xml/shell-stack.xml"/>
|
|
||||||
</chapter>
|
|
||||||
<chapter>
|
|
||||||
<title>Application tracking</title>
|
|
||||||
<xi:include href="xml/shell-app.xml"/>
|
|
||||||
<xi:include href="xml/shell-app-usage.xml"/>
|
|
||||||
<xi:include href="xml/shell-window-tracker.xml"/>
|
|
||||||
</chapter>
|
|
||||||
<chapter>
|
|
||||||
<title>Search</title>
|
|
||||||
<xi:include href="xml/shell-app-system.xml"/>
|
|
||||||
</chapter>
|
|
||||||
<chapter>
|
|
||||||
<title>Tray Icons</title>
|
|
||||||
<xi:include href="xml/shell-embedded-window.xml"/>
|
|
||||||
<xi:include href="xml/shell-gtk-embed.xml"/>
|
|
||||||
<xi:include href="xml/shell-tray-icon.xml"/>
|
|
||||||
<xi:include href="xml/shell-tray-manager.xml"/>
|
|
||||||
</chapter>
|
|
||||||
<chapter>
|
|
||||||
<title>Recorder</title>
|
|
||||||
<xi:include href="xml/shell-recorder.xml"/>
|
|
||||||
</chapter>
|
|
||||||
<chapter>
|
|
||||||
<title>Integration helpers and utilities</title>
|
|
||||||
<xi:include href="xml/shell-global.xml"/>
|
|
||||||
<xi:include href="xml/shell-wm.xml"/>
|
|
||||||
<xi:include href="xml/shell-xfixes-cursor.xml"/>
|
|
||||||
<xi:include href="xml/shell-util.xml"/>
|
|
||||||
<xi:include href="xml/shell-mount-operation.xml"/>
|
|
||||||
<xi:include href="xml/shell-mobile-providers.xml"/>
|
|
||||||
<xi:include href="xml/shell-network-agent.xml"/>
|
|
||||||
<xi:include href="xml/shell-polkit-authentication-agent.xml"/>
|
|
||||||
<xi:include href="xml/shell-tp-client.xml"/>
|
|
||||||
</chapter>
|
|
||||||
<chapter id="object-tree">
|
|
||||||
<title>Object Hierarchy</title>
|
|
||||||
<xi:include href="xml/tree_index.sgml"/>
|
|
||||||
</chapter>
|
|
||||||
<index id="api-index-full">
|
|
||||||
<title>API Index</title>
|
|
||||||
<xi:include href="xml/api-index-full.xml"><xi:fallback /></xi:include>
|
|
||||||
</index>
|
|
||||||
<index id="deprecated-api-index" role="deprecated">
|
|
||||||
<title>Index of deprecated API</title>
|
|
||||||
<xi:include href="xml/api-index-deprecated.xml"><xi:fallback /></xi:include>
|
|
||||||
</index>
|
|
||||||
|
|
||||||
<xi:include href="xml/annotation-glossary.xml"><xi:fallback /></xi:include>
|
|
||||||
</book>
|
|
@ -1,104 +0,0 @@
|
|||||||
## Process this file with automake to produce Makefile.in
|
|
||||||
|
|
||||||
# We require automake 1.6 at least.
|
|
||||||
AUTOMAKE_OPTIONS = 1.6
|
|
||||||
|
|
||||||
# This is a blank Makefile.am for using gtk-doc.
|
|
||||||
# Copy this to your project's API docs directory and modify the variables to
|
|
||||||
# suit your project. See the GTK+ Makefiles in gtk+/docs/reference for examples
|
|
||||||
# of using the various options.
|
|
||||||
|
|
||||||
# The name of the module, e.g. 'glib'.
|
|
||||||
DOC_MODULE=st
|
|
||||||
|
|
||||||
# Uncomment for versioned docs and specify the version of the module, e.g. '2'.
|
|
||||||
#DOC_MODULE_VERSION=2
|
|
||||||
|
|
||||||
|
|
||||||
# The top-level SGML file. You can change this if you want to.
|
|
||||||
DOC_MAIN_SGML_FILE=$(DOC_MODULE)-docs.sgml
|
|
||||||
|
|
||||||
# Directories containing the source code
|
|
||||||
# gtk-doc will search all .c and .h files beneath these paths
|
|
||||||
# for inline comments documenting functions and macros.
|
|
||||||
DOC_SOURCE_DIR=$(top_srcdir)/src/st
|
|
||||||
|
|
||||||
# Extra options to pass to gtkdoc-scangobj. Not normally needed.
|
|
||||||
SCANGOBJ_OPTIONS=
|
|
||||||
|
|
||||||
# Extra options to supply to gtkdoc-scan.
|
|
||||||
# e.g. SCAN_OPTIONS=--deprecated-guards="GTK_DISABLE_DEPRECATED"
|
|
||||||
SCAN_OPTIONS=--rebuild-types --rebuild-sections
|
|
||||||
|
|
||||||
# Extra options to supply to gtkdoc-mkdb.
|
|
||||||
# e.g. MKDB_OPTIONS=--xml-mode --output-format=xml
|
|
||||||
MKDB_OPTIONS=--xml-mode --output-format=xml
|
|
||||||
|
|
||||||
# Extra options to supply to gtkdoc-mktmpl
|
|
||||||
# e.g. MKTMPL_OPTIONS=--only-section-tmpl
|
|
||||||
MKTMPL_OPTIONS=
|
|
||||||
|
|
||||||
# Extra options to supply to gtkdoc-mkhtml
|
|
||||||
MKHTML_OPTIONS=
|
|
||||||
|
|
||||||
# Extra options to supply to gtkdoc-fixref. Not normally needed.
|
|
||||||
# e.g. FIXXREF_OPTIONS=--extra-dir=../gdk-pixbuf/html --extra-dir=../gdk/html
|
|
||||||
FIXXREF_OPTIONS=
|
|
||||||
|
|
||||||
# Used for dependencies. The docs will be rebuilt if any of these change.
|
|
||||||
# e.g. HFILE_GLOB=$(top_srcdir)/gtk/*.h
|
|
||||||
# e.g. CFILE_GLOB=$(top_srcdir)/gtk/*.c
|
|
||||||
HFILE_GLOB=$(top_srcdir)/src/st/*.h
|
|
||||||
CFILE_GLOB=$(top_srcdir)/src/st/*.c
|
|
||||||
|
|
||||||
# Extra header to include when scanning, which are not under DOC_SOURCE_DIR
|
|
||||||
# e.g. EXTRA_HFILES=$(top_srcdir}/contrib/extra.h
|
|
||||||
EXTRA_HFILES=
|
|
||||||
|
|
||||||
# Header files or dirs to ignore when scanning. Use base file/dir names
|
|
||||||
# e.g. IGNORE_HFILES=gtkdebug.h gtkintl.h private_code
|
|
||||||
IGNORE_HFILES=st-private.h st-theme-node-private.h
|
|
||||||
|
|
||||||
# Images to copy into HTML directory.
|
|
||||||
# e.g. HTML_IMAGES=$(top_srcdir)/gtk/stock-icons/stock_about_24.png
|
|
||||||
HTML_IMAGES=
|
|
||||||
|
|
||||||
# Extra SGML files that are included by $(DOC_MAIN_SGML_FILE).
|
|
||||||
# e.g. content_files=running.sgml building.sgml changes-2.0.sgml
|
|
||||||
content_files=
|
|
||||||
|
|
||||||
# SGML files where gtk-doc abbrevations (#GtkWidget) are expanded
|
|
||||||
# These files must be listed here *and* in content_files
|
|
||||||
# e.g. expand_content_files=running.sgml
|
|
||||||
expand_content_files=
|
|
||||||
|
|
||||||
# CFLAGS and LDFLAGS for compiling gtkdoc-scangobj with your library.
|
|
||||||
# Only needed if you are using gtkdoc-scangobj to dynamically query widget
|
|
||||||
# signals and properties.
|
|
||||||
# e.g. GTKDOC_CFLAGS=-I$(top_srcdir) -I$(top_builddir) $(GTK_DEBUG_FLAGS)
|
|
||||||
# e.g. GTKDOC_LIBS=$(top_builddir)/gtk/$(gtktargetlib)
|
|
||||||
GTKDOC_CFLAGS=
|
|
||||||
GTKDOC_LIBS=$(top_builddir)/src/libst-1.0.la
|
|
||||||
|
|
||||||
# This includes the standard gtk-doc make rules, copied by gtkdocize.
|
|
||||||
include $(top_srcdir)/gtk-doc.make
|
|
||||||
|
|
||||||
# Other files to distribute
|
|
||||||
# e.g. EXTRA_DIST += version.xml.in
|
|
||||||
EXTRA_DIST +=
|
|
||||||
|
|
||||||
# Files not to distribute
|
|
||||||
# for --rebuild-types in $(SCAN_OPTIONS), e.g. $(DOC_MODULE).types
|
|
||||||
# for --rebuild-sections in $(SCAN_OPTIONS) e.g. $(DOC_MODULE)-sections.txt
|
|
||||||
DISTCLEANFILES = $(DOC_MODULE).types $(DOC_MODULE)-sections.txt
|
|
||||||
|
|
||||||
# Comment this out if you want 'make check' to test you doc status
|
|
||||||
# and run some sanity checks
|
|
||||||
if ENABLE_GTK_DOC
|
|
||||||
TESTS_ENVIRONMENT = cd $(srcdir) && \
|
|
||||||
DOC_MODULE=$(DOC_MODULE) DOC_MAIN_SGML_FILE=$(DOC_MAIN_SGML_FILE) \
|
|
||||||
SRCDIR=$(abs_srcdir) BUILDDIR=$(abs_builddir)
|
|
||||||
#TESTS = $(GTKDOC_CHECK)
|
|
||||||
endif
|
|
||||||
|
|
||||||
-include $(top_srcdir)/git.mk
|
|
@ -1,64 +0,0 @@
|
|||||||
<?xml version="1.0"?>
|
|
||||||
<!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook XML V4.3//EN"
|
|
||||||
"http://www.oasis-open.org/docbook/xml/4.3/docbookx.dtd"
|
|
||||||
[
|
|
||||||
<!ENTITY % local.common.attrib "xmlns:xi CDATA #FIXED 'http://www.w3.org/2003/XInclude'">
|
|
||||||
]>
|
|
||||||
<book id="index">
|
|
||||||
<bookinfo>
|
|
||||||
<title>St Reference Manual</title>
|
|
||||||
<releaseinfo>
|
|
||||||
for St @VERSION@.
|
|
||||||
<!--The latest version of this documentation can be found on-line at
|
|
||||||
<ulink role="online-location" url="http://[SERVER]/st/index.html">http://[SERVER]/st/</ulink>.-->
|
|
||||||
</releaseinfo>
|
|
||||||
</bookinfo>
|
|
||||||
|
|
||||||
<part>
|
|
||||||
<title>API reference</title>
|
|
||||||
<chapter id="base">
|
|
||||||
<title>Abstract classes and Interfaces</title>
|
|
||||||
<xi:include href="xml/st-widget.xml"/>
|
|
||||||
<xi:include href="xml/st-widget-accessible.xml"/>
|
|
||||||
<xi:include href="xml/st-scrollable.xml"/>
|
|
||||||
</chapter>
|
|
||||||
<chapter id="widgets">
|
|
||||||
<title>Widgets</title>
|
|
||||||
<xi:include href="xml/st-button.xml"/>
|
|
||||||
<xi:include href="xml/st-drawing-area.xml"/>
|
|
||||||
<xi:include href="xml/st-entry.xml"/>
|
|
||||||
<xi:include href="xml/st-icon.xml"/>
|
|
||||||
<xi:include href="xml/st-label.xml"/>
|
|
||||||
</chapter>
|
|
||||||
<chapter id="containers">
|
|
||||||
<title>Containers</title>
|
|
||||||
<xi:include href="xml/st-bin.xml"/>
|
|
||||||
<xi:include href="xml/st-box-layout.xml"/>
|
|
||||||
<xi:include href="xml/st-scroll-view.xml"/>
|
|
||||||
<xi:include href="xml/st-table.xml"/>
|
|
||||||
</chapter>
|
|
||||||
|
|
||||||
<chapter id="styling">
|
|
||||||
<title>Styling</title>
|
|
||||||
<xi:include href="xml/st-theme.xml"/>
|
|
||||||
<xi:include href="xml/st-theme-context.xml"/>
|
|
||||||
<xi:include href="xml/st-theme-node.xml"/>
|
|
||||||
<xi:include href="xml/st-theme-node-transition.xml"/>
|
|
||||||
<xi:include href="xml/st-texture-cache.xml"/>
|
|
||||||
</chapter>
|
|
||||||
</part>
|
|
||||||
<chapter id="object-tree">
|
|
||||||
<title>Object Hierarchy</title>
|
|
||||||
<xi:include href="xml/tree_index.sgml"/>
|
|
||||||
</chapter>
|
|
||||||
<index id="api-index-full">
|
|
||||||
<title>API Index</title>
|
|
||||||
<xi:include href="xml/api-index-full.xml"><xi:fallback /></xi:include>
|
|
||||||
</index>
|
|
||||||
<index id="deprecated-api-index" role="deprecated">
|
|
||||||
<title>Index of deprecated API</title>
|
|
||||||
<xi:include href="xml/api-index-deprecated.xml"><xi:fallback /></xi:include>
|
|
||||||
</index>
|
|
||||||
|
|
||||||
<xi:include href="xml/annotation-glossary.xml"><xi:fallback /></xi:include>
|
|
||||||
</book>
|
|
@ -66,11 +66,4 @@ its dependencies to build from tarballs.</description>
|
|||||||
<gnome:userid>marinaz</gnome:userid>
|
<gnome:userid>marinaz</gnome:userid>
|
||||||
</foaf:Person>
|
</foaf:Person>
|
||||||
</maintainer>
|
</maintainer>
|
||||||
<maintainer>
|
|
||||||
<foaf:Person>
|
|
||||||
<foaf:name>Florian Müllner</foaf:name>
|
|
||||||
<foaf:mbox rdf:resource="mailto:fmuellner@gnome.org" />
|
|
||||||
<gnome:userid>fmuellner</gnome:userid>
|
|
||||||
</foaf:Person>
|
|
||||||
</maintainer>
|
|
||||||
</Project>
|
</Project>
|
||||||
|
@ -1,36 +1,13 @@
|
|||||||
NULL =
|
|
||||||
|
|
||||||
EXTRA_DIST = misc/config.js.in
|
|
||||||
CLEANFILES = misc/config.js
|
|
||||||
|
|
||||||
misc/config.js: misc/config.js.in Makefile
|
|
||||||
[ -d $(@D) ] || $(mkdir_p) $(@D) ; \
|
|
||||||
sed -e "s|[@]PACKAGE_NAME@|$(PACKAGE_NAME)|g" \
|
|
||||||
-e "s|[@]PACKAGE_VERSION@|$(PACKAGE_VERSION)|g" \
|
|
||||||
-e "s|[@]HAVE_BLUETOOTH@|$(HAVE_BLUETOOTH)|g" \
|
|
||||||
-e "s|[@]GETTEXT_PACKAGE@|$(GETTEXT_PACKAGE)|g" \
|
|
||||||
-e "s|[@]datadir@|$(datadir)|g" \
|
|
||||||
-e "s|[@]libexecdir@|$(libexecdir)|g" \
|
|
||||||
-e "s|[@]sysconfdir@|$(sysconfdir)|g" \
|
|
||||||
$< > $@
|
|
||||||
|
|
||||||
jsdir = $(pkgdatadir)/js
|
jsdir = $(pkgdatadir)/js
|
||||||
|
|
||||||
nobase_dist_js_DATA = \
|
nobase_dist_js_DATA = \
|
||||||
gdm/batch.js \
|
|
||||||
gdm/fingerprint.js \
|
|
||||||
gdm/loginDialog.js \
|
|
||||||
gdm/powerMenu.js \
|
|
||||||
gdm/realmd.js \
|
|
||||||
gdm/util.js \
|
|
||||||
extensionPrefs/main.js \
|
|
||||||
misc/config.js \
|
misc/config.js \
|
||||||
misc/extensionUtils.js \
|
misc/docInfo.js \
|
||||||
misc/fileUtils.js \
|
misc/fileUtils.js \
|
||||||
|
misc/format.js \
|
||||||
misc/gnomeSession.js \
|
misc/gnomeSession.js \
|
||||||
misc/history.js \
|
misc/history.js \
|
||||||
misc/jsParse.js \
|
|
||||||
misc/loginManager.js \
|
|
||||||
misc/modemManager.js \
|
misc/modemManager.js \
|
||||||
misc/params.js \
|
misc/params.js \
|
||||||
misc/util.js \
|
misc/util.js \
|
||||||
@ -40,69 +17,51 @@ nobase_dist_js_DATA = \
|
|||||||
ui/appFavorites.js \
|
ui/appFavorites.js \
|
||||||
ui/boxpointer.js \
|
ui/boxpointer.js \
|
||||||
ui/calendar.js \
|
ui/calendar.js \
|
||||||
ui/checkBox.js \
|
ui/chrome.js \
|
||||||
ui/ctrlAltTab.js \
|
ui/ctrlAltTab.js \
|
||||||
ui/dash.js \
|
ui/dash.js \
|
||||||
ui/dateMenu.js \
|
ui/dateMenu.js \
|
||||||
ui/dnd.js \
|
ui/dnd.js \
|
||||||
|
ui/docDisplay.js \
|
||||||
ui/endSessionDialog.js \
|
ui/endSessionDialog.js \
|
||||||
ui/extensionSystem.js \
|
|
||||||
ui/extensionDownloader.js \
|
|
||||||
ui/environment.js \
|
ui/environment.js \
|
||||||
ui/flashspot.js \
|
ui/extensionSystem.js \
|
||||||
ui/ibusCandidatePopup.js\
|
|
||||||
ui/grabHelper.js \
|
|
||||||
ui/iconGrid.js \
|
ui/iconGrid.js \
|
||||||
ui/keyboard.js \
|
|
||||||
ui/layout.js \
|
|
||||||
ui/lightbox.js \
|
ui/lightbox.js \
|
||||||
|
ui/link.js \
|
||||||
ui/lookingGlass.js \
|
ui/lookingGlass.js \
|
||||||
ui/magnifier.js \
|
ui/magnifier.js \
|
||||||
ui/magnifierDBus.js \
|
ui/magnifierDBus.js \
|
||||||
ui/main.js \
|
ui/main.js \
|
||||||
ui/messageTray.js \
|
ui/messageTray.js \
|
||||||
ui/modalDialog.js \
|
ui/modalDialog.js \
|
||||||
ui/sessionMode.js \
|
|
||||||
ui/shellEntry.js \
|
|
||||||
ui/shellMountOperation.js \
|
|
||||||
ui/notificationDaemon.js \
|
ui/notificationDaemon.js \
|
||||||
ui/overview.js \
|
ui/overview.js \
|
||||||
ui/panel.js \
|
ui/panel.js \
|
||||||
ui/panelMenu.js \
|
ui/panelMenu.js \
|
||||||
ui/pointerWatcher.js \
|
ui/placeDisplay.js \
|
||||||
|
ui/polkitAuthenticationAgent.js \
|
||||||
ui/popupMenu.js \
|
ui/popupMenu.js \
|
||||||
ui/remoteSearch.js \
|
|
||||||
ui/runDialog.js \
|
ui/runDialog.js \
|
||||||
ui/screenShield.js \
|
|
||||||
ui/scripting.js \
|
ui/scripting.js \
|
||||||
ui/search.js \
|
ui/search.js \
|
||||||
ui/searchDisplay.js \
|
ui/searchDisplay.js \
|
||||||
ui/shellDBus.js \
|
ui/shellDBus.js \
|
||||||
|
ui/statusIconDispatcher.js \
|
||||||
|
ui/statusMenu.js \
|
||||||
ui/status/accessibility.js \
|
ui/status/accessibility.js \
|
||||||
ui/status/keyboard.js \
|
ui/status/keyboard.js \
|
||||||
ui/status/lockScreenMenu.js \
|
|
||||||
ui/status/network.js \
|
ui/status/network.js \
|
||||||
ui/status/power.js \
|
ui/status/power.js \
|
||||||
ui/status/volume.js \
|
ui/status/volume.js \
|
||||||
ui/status/bluetooth.js \
|
ui/status/bluetooth.js \
|
||||||
|
ui/telepathyClient.js \
|
||||||
ui/tweener.js \
|
ui/tweener.js \
|
||||||
ui/unlockDialog.js \
|
|
||||||
ui/userMenu.js \
|
|
||||||
ui/viewSelector.js \
|
ui/viewSelector.js \
|
||||||
ui/wanda.js \
|
|
||||||
ui/windowAttentionHandler.js \
|
ui/windowAttentionHandler.js \
|
||||||
ui/windowManager.js \
|
ui/windowManager.js \
|
||||||
ui/workspace.js \
|
ui/workspace.js \
|
||||||
ui/workspaceThumbnail.js \
|
ui/workspaceThumbnail.js \
|
||||||
ui/workspacesView.js \
|
ui/workspacesView.js \
|
||||||
ui/workspaceSwitcherPopup.js \
|
ui/workspaceSwitcherPopup.js \
|
||||||
ui/xdndHandler.js \
|
ui/xdndHandler.js
|
||||||
ui/components/__init__.js \
|
|
||||||
ui/components/autorunManager.js \
|
|
||||||
ui/components/automountManager.js \
|
|
||||||
ui/components/networkAgent.js \
|
|
||||||
ui/components/polkitAgent.js \
|
|
||||||
ui/components/recorder.js \
|
|
||||||
ui/components/telepathyClient.js \
|
|
||||||
ui/components/keyring.js \
|
|
||||||
$(NULL)
|
|
||||||
|
@ -1,270 +0,0 @@
|
|||||||
|
|
||||||
const Lang = imports.lang;
|
|
||||||
const Gettext = imports.gettext;
|
|
||||||
const GLib = imports.gi.GLib;
|
|
||||||
const GObject = imports.gi.GObject;
|
|
||||||
const Gio = imports.gi.Gio;
|
|
||||||
const Gtk = imports.gi.Gtk;
|
|
||||||
const Pango = imports.gi.Pango;
|
|
||||||
const Format = imports.format;
|
|
||||||
|
|
||||||
const _ = Gettext.gettext;
|
|
||||||
|
|
||||||
const Config = imports.misc.config;
|
|
||||||
const ExtensionUtils = imports.misc.extensionUtils;
|
|
||||||
|
|
||||||
const GnomeShellIface = <interface name="org.gnome.Shell.Extensions">
|
|
||||||
<signal name="ExtensionStatusChanged">
|
|
||||||
<arg type="s" name="uuid"/>
|
|
||||||
<arg type="i" name="state"/>
|
|
||||||
<arg type="s" name="error"/>
|
|
||||||
</signal>
|
|
||||||
</interface>;
|
|
||||||
|
|
||||||
const GnomeShellProxy = Gio.DBusProxy.makeProxyWrapper(GnomeShellIface);
|
|
||||||
|
|
||||||
function stripPrefix(string, prefix) {
|
|
||||||
if (string.slice(0, prefix.length) == prefix)
|
|
||||||
return string.slice(prefix.length);
|
|
||||||
return string;
|
|
||||||
}
|
|
||||||
|
|
||||||
const Application = new Lang.Class({
|
|
||||||
Name: 'Application',
|
|
||||||
_init: function() {
|
|
||||||
GLib.set_prgname('gnome-shell-extension-prefs');
|
|
||||||
this.application = new Gtk.Application({
|
|
||||||
application_id: 'org.gnome.shell.ExtensionPrefs',
|
|
||||||
flags: Gio.ApplicationFlags.HANDLES_COMMAND_LINE
|
|
||||||
});
|
|
||||||
|
|
||||||
this.application.connect('activate', Lang.bind(this, this._onActivate));
|
|
||||||
this.application.connect('command-line', Lang.bind(this, this._onCommandLine));
|
|
||||||
this.application.connect('startup', Lang.bind(this, this._onStartup));
|
|
||||||
|
|
||||||
this._extensionPrefsModules = {};
|
|
||||||
|
|
||||||
this._extensionIters = {};
|
|
||||||
},
|
|
||||||
|
|
||||||
_buildModel: function() {
|
|
||||||
this._model = new Gtk.ListStore();
|
|
||||||
this._model.set_column_types([GObject.TYPE_STRING, GObject.TYPE_STRING]);
|
|
||||||
},
|
|
||||||
|
|
||||||
_extensionAvailable: function(uuid) {
|
|
||||||
let extension = ExtensionUtils.extensions[uuid];
|
|
||||||
|
|
||||||
if (!extension)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if (ExtensionUtils.isOutOfDate(extension))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if (!extension.dir.get_child('prefs.js').query_exists(null))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
},
|
|
||||||
|
|
||||||
_setExtensionInsensitive: function(layout, cell, model, iter, data) {
|
|
||||||
let uuid = model.get_value(iter, 0);
|
|
||||||
cell.set_sensitive(this._extensionAvailable(uuid));
|
|
||||||
},
|
|
||||||
|
|
||||||
_getExtensionPrefsModule: function(extension) {
|
|
||||||
let uuid = extension.metadata.uuid;
|
|
||||||
|
|
||||||
if (this._extensionPrefsModules.hasOwnProperty(uuid))
|
|
||||||
return this._extensionPrefsModules[uuid];
|
|
||||||
|
|
||||||
ExtensionUtils.installImporter(extension);
|
|
||||||
|
|
||||||
let prefsModule = extension.imports.prefs;
|
|
||||||
prefsModule.init(extension.metadata);
|
|
||||||
|
|
||||||
this._extensionPrefsModules[uuid] = prefsModule;
|
|
||||||
return prefsModule;
|
|
||||||
},
|
|
||||||
|
|
||||||
_selectExtension: function(uuid) {
|
|
||||||
if (!this._extensionAvailable(uuid))
|
|
||||||
return;
|
|
||||||
|
|
||||||
let extension = ExtensionUtils.extensions[uuid];
|
|
||||||
let widget;
|
|
||||||
|
|
||||||
try {
|
|
||||||
let prefsModule = this._getExtensionPrefsModule(extension);
|
|
||||||
widget = prefsModule.buildPrefsWidget();
|
|
||||||
} catch (e) {
|
|
||||||
widget = this._buildErrorUI(extension, e);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Destroy the current prefs widget, if it exists
|
|
||||||
if (this._extensionPrefsBin.get_child())
|
|
||||||
this._extensionPrefsBin.get_child().destroy();
|
|
||||||
|
|
||||||
this._extensionPrefsBin.add(widget);
|
|
||||||
this._extensionSelector.set_active_iter(this._extensionIters[uuid]);
|
|
||||||
},
|
|
||||||
|
|
||||||
_extensionSelected: function() {
|
|
||||||
let [success, iter] = this._extensionSelector.get_active_iter();
|
|
||||||
if (!success)
|
|
||||||
return;
|
|
||||||
|
|
||||||
let uuid = this._model.get_value(iter, 0);
|
|
||||||
this._selectExtension(uuid);
|
|
||||||
},
|
|
||||||
|
|
||||||
_buildErrorUI: function(extension, exc) {
|
|
||||||
let box = new Gtk.Box({ orientation: Gtk.Orientation.VERTICAL });
|
|
||||||
let label = new Gtk.Label({
|
|
||||||
label: _("There was an error loading the preferences dialog for %s:").format(extension.metadata.name)
|
|
||||||
});
|
|
||||||
box.add(label);
|
|
||||||
|
|
||||||
let errortext = '';
|
|
||||||
errortext += exc;
|
|
||||||
errortext += '\n\n';
|
|
||||||
errortext += 'Stack trace:\n';
|
|
||||||
|
|
||||||
// Indent stack trace.
|
|
||||||
errortext += exc.stack.split('\n').map(function(line) {
|
|
||||||
return ' ' + line;
|
|
||||||
}).join('\n');
|
|
||||||
|
|
||||||
let scroll = new Gtk.ScrolledWindow({ vexpand: true });
|
|
||||||
let buffer = new Gtk.TextBuffer({ text: errortext });
|
|
||||||
let textview = new Gtk.TextView({ buffer: buffer });
|
|
||||||
textview.override_font(Pango.font_description_from_string('monospace'));
|
|
||||||
scroll.add(textview);
|
|
||||||
box.add(scroll);
|
|
||||||
|
|
||||||
box.show_all();
|
|
||||||
return box;
|
|
||||||
},
|
|
||||||
|
|
||||||
_buildUI: function(app) {
|
|
||||||
this._window = new Gtk.ApplicationWindow({ application: app,
|
|
||||||
window_position: Gtk.WindowPosition.CENTER,
|
|
||||||
title: _("GNOME Shell Extension Preferences") });
|
|
||||||
|
|
||||||
this._window.set_size_request(600, 400);
|
|
||||||
|
|
||||||
let vbox = new Gtk.Box({ orientation: Gtk.Orientation.VERTICAL });
|
|
||||||
this._window.add(vbox);
|
|
||||||
|
|
||||||
let toolbar = new Gtk.Toolbar();
|
|
||||||
toolbar.get_style_context().add_class(Gtk.STYLE_CLASS_PRIMARY_TOOLBAR);
|
|
||||||
vbox.add(toolbar);
|
|
||||||
let toolitem;
|
|
||||||
|
|
||||||
let label = new Gtk.Label({ label: '<b>' + _("Extension") + '</b>',
|
|
||||||
use_markup: true });
|
|
||||||
toolitem = new Gtk.ToolItem({ child: label });
|
|
||||||
toolbar.add(toolitem);
|
|
||||||
|
|
||||||
this._extensionSelector = new Gtk.ComboBox({ model: this._model,
|
|
||||||
margin_left: 8,
|
|
||||||
hexpand: true });
|
|
||||||
this._extensionSelector.get_style_context().add_class(Gtk.STYLE_CLASS_RAISED);
|
|
||||||
|
|
||||||
let renderer = new Gtk.CellRendererText();
|
|
||||||
this._extensionSelector.pack_start(renderer, true);
|
|
||||||
this._extensionSelector.add_attribute(renderer, 'text', 1);
|
|
||||||
this._extensionSelector.set_cell_data_func(renderer, Lang.bind(this, this._setExtensionInsensitive));
|
|
||||||
this._extensionSelector.connect('changed', Lang.bind(this, this._extensionSelected));
|
|
||||||
|
|
||||||
toolitem = new Gtk.ToolItem({ child: this._extensionSelector });
|
|
||||||
toolitem.set_expand(true);
|
|
||||||
toolbar.add(toolitem);
|
|
||||||
|
|
||||||
this._extensionPrefsBin = new Gtk.Frame();
|
|
||||||
vbox.add(this._extensionPrefsBin);
|
|
||||||
|
|
||||||
let label = new Gtk.Label({
|
|
||||||
label: _("Select an extension to configure using the combobox above."),
|
|
||||||
vexpand: true
|
|
||||||
});
|
|
||||||
|
|
||||||
this._extensionPrefsBin.add(label);
|
|
||||||
|
|
||||||
this._shellProxy = new GnomeShellProxy(Gio.DBus.session, 'org.gnome.Shell', '/org/gnome/Shell');
|
|
||||||
this._shellProxy.connectSignal('ExtensionStatusChanged', Lang.bind(this, function(proxy, senderName, [uuid, state, error]) {
|
|
||||||
if (ExtensionUtils.extensions[uuid] !== undefined)
|
|
||||||
this._scanExtensions();
|
|
||||||
}));
|
|
||||||
|
|
||||||
this._window.show_all();
|
|
||||||
},
|
|
||||||
|
|
||||||
_scanExtensions: function() {
|
|
||||||
let finder = new ExtensionUtils.ExtensionFinder();
|
|
||||||
finder.connect('extension-found', Lang.bind(this, this._extensionFound));
|
|
||||||
finder.scanExtensions();
|
|
||||||
},
|
|
||||||
|
|
||||||
_extensionFound: function(signals, extension) {
|
|
||||||
let iter = this._model.append();
|
|
||||||
this._model.set(iter, [0, 1], [extension.uuid, extension.metadata.name]);
|
|
||||||
this._extensionIters[extension.uuid] = iter;
|
|
||||||
},
|
|
||||||
|
|
||||||
|
|
||||||
_onActivate: function() {
|
|
||||||
this._window.present();
|
|
||||||
},
|
|
||||||
|
|
||||||
_onStartup: function(app) {
|
|
||||||
this._buildModel();
|
|
||||||
this._buildUI(app);
|
|
||||||
this._scanExtensions();
|
|
||||||
},
|
|
||||||
|
|
||||||
_onCommandLine: function(app, commandLine) {
|
|
||||||
app.activate();
|
|
||||||
let args = commandLine.get_arguments();
|
|
||||||
if (args.length) {
|
|
||||||
let uuid = args[0];
|
|
||||||
|
|
||||||
// Strip off "extension:///" prefix which fakes a URI, if it exists
|
|
||||||
uuid = stripPrefix(uuid, "extension:///");
|
|
||||||
|
|
||||||
if (!this._extensionAvailable(uuid))
|
|
||||||
return 1;
|
|
||||||
|
|
||||||
this._selectExtension(uuid);
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
function initEnvironment() {
|
|
||||||
// Monkey-patch in a "global" object that fakes some Shell utilities
|
|
||||||
// that ExtensionUtils depends on.
|
|
||||||
window.global = {
|
|
||||||
log: function() {
|
|
||||||
print([].join.call(arguments, ', '));
|
|
||||||
},
|
|
||||||
|
|
||||||
logError: function(s) {
|
|
||||||
log('ERROR: ' + s);
|
|
||||||
},
|
|
||||||
|
|
||||||
userdatadir: GLib.build_filenamev([GLib.get_user_data_dir(), 'gnome-shell'])
|
|
||||||
};
|
|
||||||
|
|
||||||
String.prototype.format = Format.format;
|
|
||||||
}
|
|
||||||
|
|
||||||
function main(argv) {
|
|
||||||
initEnvironment();
|
|
||||||
|
|
||||||
Gettext.bindtextdomain(Config.GETTEXT_PACKAGE, Config.LOCALEDIR);
|
|
||||||
Gettext.textdomain(Config.GETTEXT_PACKAGE);
|
|
||||||
|
|
||||||
let app = new Application();
|
|
||||||
app.application.run(argv);
|
|
||||||
}
|
|
203
js/gdm/batch.js
@ -1,203 +0,0 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
|
||||||
/*
|
|
||||||
* Copyright 2011 Red Hat, Inc
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
* any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write to the Free Software
|
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
|
||||||
|
|
||||||
const Lang = imports.lang;
|
|
||||||
const Signals = imports.signals;
|
|
||||||
|
|
||||||
const Task = new Lang.Class({
|
|
||||||
Name: 'Task',
|
|
||||||
|
|
||||||
_init: function(scope, handler) {
|
|
||||||
if (scope)
|
|
||||||
this.scope = scope;
|
|
||||||
else
|
|
||||||
this.scope = this;
|
|
||||||
|
|
||||||
this.handler = handler;
|
|
||||||
},
|
|
||||||
|
|
||||||
run: function() {
|
|
||||||
if (this.handler)
|
|
||||||
return this.handler.call(this.scope);
|
|
||||||
|
|
||||||
return null;
|
|
||||||
},
|
|
||||||
});
|
|
||||||
Signals.addSignalMethods(Task.prototype);
|
|
||||||
|
|
||||||
const Hold = new Lang.Class({
|
|
||||||
Name: 'Hold',
|
|
||||||
Extends: Task,
|
|
||||||
|
|
||||||
_init: function() {
|
|
||||||
this.parent(this, function () {
|
|
||||||
return this;
|
|
||||||
});
|
|
||||||
|
|
||||||
this._acquisitions = 1;
|
|
||||||
},
|
|
||||||
|
|
||||||
acquire: function() {
|
|
||||||
if (this._acquisitions <= 0)
|
|
||||||
throw new Error("Cannot acquire hold after it's been released");
|
|
||||||
this._acquisitions++;
|
|
||||||
},
|
|
||||||
|
|
||||||
acquireUntilAfter: function(hold) {
|
|
||||||
if (!hold.isAcquired())
|
|
||||||
return;
|
|
||||||
|
|
||||||
this.acquire();
|
|
||||||
let signalId = hold.connect('release', Lang.bind(this, function() {
|
|
||||||
hold.disconnect(signalId);
|
|
||||||
this.release();
|
|
||||||
}));
|
|
||||||
},
|
|
||||||
|
|
||||||
release: function() {
|
|
||||||
this._acquisitions--;
|
|
||||||
|
|
||||||
if (this._acquisitions == 0)
|
|
||||||
this.emit('release');
|
|
||||||
},
|
|
||||||
|
|
||||||
isAcquired: function() {
|
|
||||||
return this._acquisitions > 0;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
Signals.addSignalMethods(Hold.prototype);
|
|
||||||
|
|
||||||
const Batch = new Lang.Class({
|
|
||||||
Name: 'Batch',
|
|
||||||
Extends: Task,
|
|
||||||
|
|
||||||
_init: function(scope, tasks) {
|
|
||||||
this.parent();
|
|
||||||
|
|
||||||
this.tasks = [];
|
|
||||||
|
|
||||||
for (let i = 0; i < tasks.length; i++) {
|
|
||||||
let task;
|
|
||||||
|
|
||||||
if (tasks[i] instanceof Task) {
|
|
||||||
task = tasks[i];
|
|
||||||
} else if (typeof tasks[i] == 'function') {
|
|
||||||
task = new Task(scope, tasks[i]);
|
|
||||||
} else {
|
|
||||||
throw new Error('Batch tasks must be functions or Task, Hold or Batch objects');
|
|
||||||
}
|
|
||||||
|
|
||||||
this.tasks.push(task);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
process: function() {
|
|
||||||
throw new Error('Not implemented');
|
|
||||||
},
|
|
||||||
|
|
||||||
runTask: function() {
|
|
||||||
if (!(this._currentTaskIndex in this.tasks)) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return this.tasks[this._currentTaskIndex].run();
|
|
||||||
},
|
|
||||||
|
|
||||||
_finish: function() {
|
|
||||||
this.hold.release();
|
|
||||||
},
|
|
||||||
|
|
||||||
nextTask: function() {
|
|
||||||
this._currentTaskIndex++;
|
|
||||||
|
|
||||||
// if the entire batch of tasks is finished, release
|
|
||||||
// the hold and notify anyone waiting on the batch
|
|
||||||
if (this._currentTaskIndex >= this.tasks.length) {
|
|
||||||
this._finish();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this.process();
|
|
||||||
},
|
|
||||||
|
|
||||||
_start: function() {
|
|
||||||
// acquire a hold to get released when the entire
|
|
||||||
// batch of tasks is finished
|
|
||||||
this.hold = new Hold();
|
|
||||||
this._currentTaskIndex = 0;
|
|
||||||
this.process();
|
|
||||||
},
|
|
||||||
|
|
||||||
run: function() {
|
|
||||||
this._start();
|
|
||||||
|
|
||||||
// hold may be destroyed at this point
|
|
||||||
// if we're already done running
|
|
||||||
return this.hold;
|
|
||||||
},
|
|
||||||
|
|
||||||
cancel: function() {
|
|
||||||
this.tasks = this.tasks.splice(0, this._currentTaskIndex + 1);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
Signals.addSignalMethods(Batch.prototype);
|
|
||||||
|
|
||||||
const ConcurrentBatch = new Lang.Class({
|
|
||||||
Name: 'ConcurrentBatch',
|
|
||||||
Extends: Batch,
|
|
||||||
|
|
||||||
process: function() {
|
|
||||||
let hold = this.runTask();
|
|
||||||
|
|
||||||
if (hold) {
|
|
||||||
this.hold.acquireUntilAfter(hold);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Regardless of the state of the just run task,
|
|
||||||
// fire off the next one, so all the tasks can run
|
|
||||||
// concurrently.
|
|
||||||
this.nextTask();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
Signals.addSignalMethods(ConcurrentBatch.prototype);
|
|
||||||
|
|
||||||
const ConsecutiveBatch = new Lang.Class({
|
|
||||||
Name: 'ConsecutiveBatch',
|
|
||||||
Extends: Batch,
|
|
||||||
|
|
||||||
process: function() {
|
|
||||||
let hold = this.runTask();
|
|
||||||
|
|
||||||
if (hold && hold.isAcquired()) {
|
|
||||||
// This task is inhibiting the batch. Wait on it
|
|
||||||
// before processing the next one.
|
|
||||||
let signalId = hold.connect('release',
|
|
||||||
Lang.bind(this, function() {
|
|
||||||
hold.disconnect(signalId);
|
|
||||||
this.nextTask();
|
|
||||||
}));
|
|
||||||
return;
|
|
||||||
} else {
|
|
||||||
// This task finished, process the next one
|
|
||||||
this.nextTask();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
Signals.addSignalMethods(ConsecutiveBatch.prototype);
|
|
@ -1,26 +0,0 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
|
||||||
|
|
||||||
const Gio = imports.gi.Gio;
|
|
||||||
const Lang = imports.lang;
|
|
||||||
const Shell = imports.gi.Shell;
|
|
||||||
const Signals = imports.signals;
|
|
||||||
|
|
||||||
const FprintManagerIface = <interface name='net.reactivated.Fprint.Manager'>
|
|
||||||
<method name='GetDefaultDevice'>
|
|
||||||
<arg type='o' direction='out' />
|
|
||||||
</method>
|
|
||||||
</interface>;
|
|
||||||
|
|
||||||
const FprintManagerInfo = Gio.DBusInterfaceInfo.new_for_xml(FprintManagerIface);
|
|
||||||
|
|
||||||
function FprintManager() {
|
|
||||||
var self = new Gio.DBusProxy({ g_connection: Gio.DBus.system,
|
|
||||||
g_interface_name: FprintManagerInfo.name,
|
|
||||||
g_interface_info: FprintManagerInfo,
|
|
||||||
g_name: 'net.reactivated.Fprint',
|
|
||||||
g_object_path: '/net/reactivated/Fprint/Manager',
|
|
||||||
g_flags: (Gio.DBusProxyFlags.DO_NOT_LOAD_PROPERTIES) });
|
|
||||||
|
|
||||||
self.init(null);
|
|
||||||
return self;
|
|
||||||
}
|
|
@ -1,123 +0,0 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
|
||||||
/*
|
|
||||||
* Copyright 2011 Red Hat, Inc
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
* any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write to the Free Software
|
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
|
||||||
|
|
||||||
const Lang = imports.lang;
|
|
||||||
const UPowerGlib = imports.gi.UPowerGlib;
|
|
||||||
|
|
||||||
const LoginManager = imports.misc.loginManager;
|
|
||||||
|
|
||||||
const PanelMenu = imports.ui.panelMenu;
|
|
||||||
const PopupMenu = imports.ui.popupMenu;
|
|
||||||
|
|
||||||
const PowerMenuButton = new Lang.Class({
|
|
||||||
Name: 'PowerMenuButton',
|
|
||||||
Extends: PanelMenu.SystemStatusButton,
|
|
||||||
|
|
||||||
_init: function() {
|
|
||||||
/* Translators: accessible name of the power menu in the login screen */
|
|
||||||
this.parent('system-shutdown-symbolic', _("Power"));
|
|
||||||
this._upClient = new UPowerGlib.Client();
|
|
||||||
|
|
||||||
this._loginManager = LoginManager.getLoginManager();
|
|
||||||
|
|
||||||
this._createSubMenu();
|
|
||||||
|
|
||||||
this._upClient.connect('notify::can-suspend',
|
|
||||||
Lang.bind(this, this._updateHaveSuspend));
|
|
||||||
this._updateHaveSuspend();
|
|
||||||
|
|
||||||
// ConsoleKit doesn't send notifications when shutdown/reboot
|
|
||||||
// are disabled, so we update the menu item each time the menu opens
|
|
||||||
this.menu.connect('open-state-changed', Lang.bind(this,
|
|
||||||
function(menu, open) {
|
|
||||||
if (open) {
|
|
||||||
this._updateHaveShutdown();
|
|
||||||
this._updateHaveRestart();
|
|
||||||
}
|
|
||||||
}));
|
|
||||||
this._updateHaveShutdown();
|
|
||||||
this._updateHaveRestart();
|
|
||||||
},
|
|
||||||
|
|
||||||
_updateVisibility: function() {
|
|
||||||
let shouldBeVisible = (this._haveSuspend || this._haveShutdown || this._haveRestart);
|
|
||||||
this.actor.visible = shouldBeVisible;
|
|
||||||
},
|
|
||||||
|
|
||||||
_updateHaveShutdown: function() {
|
|
||||||
this._loginManager.canPowerOff(Lang.bind(this, function(result) {
|
|
||||||
this._haveShutdown = result;
|
|
||||||
this._powerOffItem.actor.visible = this._haveShutdown;
|
|
||||||
this._updateVisibility();
|
|
||||||
}));
|
|
||||||
},
|
|
||||||
|
|
||||||
_updateHaveRestart: function() {
|
|
||||||
this._loginManager.canReboot(Lang.bind(this, function(result) {
|
|
||||||
this._haveRestart = result;
|
|
||||||
this._restartItem.actor.visible = this._haveRestart;
|
|
||||||
this._updateVisibility();
|
|
||||||
}));
|
|
||||||
},
|
|
||||||
|
|
||||||
_updateHaveSuspend: function() {
|
|
||||||
this._haveSuspend = this._upClient.get_can_suspend();
|
|
||||||
this._suspendItem.actor.visible = this._haveSuspend;
|
|
||||||
this._updateVisibility();
|
|
||||||
},
|
|
||||||
|
|
||||||
_createSubMenu: function() {
|
|
||||||
let item;
|
|
||||||
|
|
||||||
item = new PopupMenu.PopupMenuItem(_("Suspend"));
|
|
||||||
item.connect('activate', Lang.bind(this, this._onActivateSuspend));
|
|
||||||
this.menu.addMenuItem(item);
|
|
||||||
this._suspendItem = item;
|
|
||||||
|
|
||||||
item = new PopupMenu.PopupMenuItem(_("Restart"));
|
|
||||||
item.connect('activate', Lang.bind(this, this._onActivateRestart));
|
|
||||||
this.menu.addMenuItem(item);
|
|
||||||
this._restartItem = item;
|
|
||||||
|
|
||||||
item = new PopupMenu.PopupMenuItem(_("Power Off"));
|
|
||||||
item.connect('activate', Lang.bind(this, this._onActivatePowerOff));
|
|
||||||
this.menu.addMenuItem(item);
|
|
||||||
this._powerOffItem = item;
|
|
||||||
},
|
|
||||||
|
|
||||||
_onActivateSuspend: function() {
|
|
||||||
if (this._haveSuspend)
|
|
||||||
this._upClient.suspend_sync(null);
|
|
||||||
},
|
|
||||||
|
|
||||||
_onActivateRestart: function() {
|
|
||||||
if (!this._haveRestart)
|
|
||||||
return;
|
|
||||||
|
|
||||||
this._loginManager.reboot();
|
|
||||||
},
|
|
||||||
|
|
||||||
_onActivatePowerOff: function() {
|
|
||||||
if (!this._haveShutdown)
|
|
||||||
return;
|
|
||||||
|
|
||||||
this._loginManager.powerOff();
|
|
||||||
}
|
|
||||||
});
|
|
139
js/gdm/realmd.js
@ -1,139 +0,0 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
|
||||||
|
|
||||||
const Gio = imports.gi.Gio;
|
|
||||||
const Lang = imports.lang;
|
|
||||||
const Shell = imports.gi.Shell;
|
|
||||||
const Signals = imports.signals;
|
|
||||||
|
|
||||||
const ProviderIface = <interface name='org.freedesktop.realmd.Provider'>
|
|
||||||
<property name="Name" type="s" access="read"/>
|
|
||||||
<property name="Version" type="s" access="read"/>
|
|
||||||
<property name="Realms" type="ao" access="read"/>
|
|
||||||
<method name="Discover">
|
|
||||||
<arg name="string" type="s" direction="in"/>
|
|
||||||
<arg name="options" type="a{sv}" direction="in"/>
|
|
||||||
<arg name="relevance" type="i" direction="out"/>
|
|
||||||
<arg name="realm" type="ao" direction="out"/>
|
|
||||||
</method>
|
|
||||||
</interface>;
|
|
||||||
const Provider = Gio.DBusProxy.makeProxyWrapper(ProviderIface);
|
|
||||||
|
|
||||||
const ServiceIface = <interface name="org.freedesktop.realmd.Service">
|
|
||||||
<method name="Cancel">
|
|
||||||
<arg name="operation" type="s" direction="in"/>
|
|
||||||
</method>
|
|
||||||
<method name="Release" />
|
|
||||||
<method name="SetLocale">
|
|
||||||
<arg name="locale" type="s" direction="in"/>
|
|
||||||
</method>
|
|
||||||
<signal name="Diagnostics">
|
|
||||||
<arg name="data" type="s"/>
|
|
||||||
<arg name="operation" type="s"/>
|
|
||||||
</signal>
|
|
||||||
</interface>;
|
|
||||||
const Service = Gio.DBusProxy.makeProxyWrapper(ServiceIface);
|
|
||||||
|
|
||||||
const RealmIface = <interface name="org.freedesktop.realmd.Realm">
|
|
||||||
<property name="Name" type="s" access="read"/>
|
|
||||||
<property name="Configured" type="s" access="read"/>
|
|
||||||
<property name="Details" type="a(ss)" access="read"/>
|
|
||||||
<property name="LoginFormats" type="as" access="read"/>
|
|
||||||
<property name="LoginPolicy" type="s" access="read"/>
|
|
||||||
<property name="PermittedLogins" type="as" access="read"/>
|
|
||||||
<property name="SupportedInterfaces" type="as" access="read"/>
|
|
||||||
<method name="ChangeLoginPolicy">
|
|
||||||
<arg name="login_policy" type="s" direction="in"/>
|
|
||||||
<arg name="permitted_add" type="as" direction="in"/>
|
|
||||||
<arg name="permitted_remove" type="as" direction="in"/>
|
|
||||||
<arg name="options" type="a{sv}" direction="in"/>
|
|
||||||
</method>
|
|
||||||
<method name="Deconfigure">
|
|
||||||
<arg name="options" type="a{sv}" direction="in"/>
|
|
||||||
</method>
|
|
||||||
</interface>;
|
|
||||||
const Realm = Gio.DBusProxy.makeProxyWrapper(RealmIface);
|
|
||||||
|
|
||||||
const Manager = new Lang.Class({
|
|
||||||
Name: 'Manager',
|
|
||||||
|
|
||||||
_init: function(parentActor) {
|
|
||||||
this._aggregateProvider = Provider(Gio.DBus.system,
|
|
||||||
'org.freedesktop.realmd',
|
|
||||||
'/org/freedesktop/realmd',
|
|
||||||
Lang.bind(this, this._reloadRealms))
|
|
||||||
this._realms = {};
|
|
||||||
|
|
||||||
this._aggregateProvider.connect('g-properties-changed',
|
|
||||||
Lang.bind(this, function(proxy, properties) {
|
|
||||||
if ('Realms' in properties.deep_unpack())
|
|
||||||
this._reloadRealms();
|
|
||||||
}));
|
|
||||||
},
|
|
||||||
|
|
||||||
_reloadRealms: function() {
|
|
||||||
let realmPaths = this._aggregateProvider.Realms;
|
|
||||||
|
|
||||||
if (!realmPaths)
|
|
||||||
return;
|
|
||||||
|
|
||||||
for (let i = 0; i < realmPaths.length; i++) {
|
|
||||||
let realm = Realm(Gio.DBus.system,
|
|
||||||
'org.freedesktop.realmd',
|
|
||||||
realmPaths[i],
|
|
||||||
Lang.bind(this, this._onRealmLoaded));
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_reloadRealm: function(realm) {
|
|
||||||
if (!realm.Configured) {
|
|
||||||
if (this._realms[realm.get_object_path()])
|
|
||||||
delete this._realms[realm.get_object_path()];
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._realms[realm.get_object_path()] = realm;
|
|
||||||
|
|
||||||
this._updateLoginFormat();
|
|
||||||
},
|
|
||||||
|
|
||||||
_onRealmLoaded: function(realm, error) {
|
|
||||||
if (error)
|
|
||||||
return;
|
|
||||||
|
|
||||||
this._reloadRealm(realm);
|
|
||||||
|
|
||||||
realm.connect('g-properties-changed',
|
|
||||||
Lang.bind(this, function(proxy, properties) {
|
|
||||||
if ('Configured' in properties.deep_unpack())
|
|
||||||
this._reloadRealm();
|
|
||||||
}));
|
|
||||||
},
|
|
||||||
|
|
||||||
_updateLoginFormat: function() {
|
|
||||||
let newLoginFormat;
|
|
||||||
|
|
||||||
for (let realmPath in this._realms) {
|
|
||||||
let realm = this._realms[realmPath];
|
|
||||||
if (realm.LoginFormats && realm.LoginFormats.length > 0) {
|
|
||||||
newLoginFormat = realm.LoginFormats[0];
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._loginFormat != newLoginFormat) {
|
|
||||||
this._loginFormat = newLoginFormat;
|
|
||||||
this.emit('login-format-changed', newLoginFormat);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
get loginFormat() {
|
|
||||||
if (this._loginFormat !== undefined)
|
|
||||||
return this._loginFormat;
|
|
||||||
|
|
||||||
this._updateLoginFormat();
|
|
||||||
|
|
||||||
return this._loginFormat;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
Signals.addSignalMethods(Manager.prototype)
|
|
369
js/gdm/util.js
@ -1,369 +0,0 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
|
||||||
|
|
||||||
const Gio = imports.gi.Gio;
|
|
||||||
const Lang = imports.lang;
|
|
||||||
const Mainloop = imports.mainloop;
|
|
||||||
const Signals = imports.signals;
|
|
||||||
|
|
||||||
const Batch = imports.gdm.batch;
|
|
||||||
const Fprint = imports.gdm.fingerprint;
|
|
||||||
const Realmd = imports.gdm.realmd;
|
|
||||||
const Main = imports.ui.main;
|
|
||||||
const Params = imports.misc.params;
|
|
||||||
const Tweener = imports.ui.tweener;
|
|
||||||
|
|
||||||
const PASSWORD_SERVICE_NAME = 'gdm-password';
|
|
||||||
const FINGERPRINT_SERVICE_NAME = 'gdm-fingerprint';
|
|
||||||
const FADE_ANIMATION_TIME = 0.16;
|
|
||||||
|
|
||||||
const LOGIN_SCREEN_SCHEMA = 'org.gnome.login-screen';
|
|
||||||
const FINGERPRINT_AUTHENTICATION_KEY = 'enable-fingerprint-authentication';
|
|
||||||
const BANNER_MESSAGE_KEY = 'banner-message-enable';
|
|
||||||
const BANNER_MESSAGE_TEXT_KEY = 'banner-message-text';
|
|
||||||
const ALLOWED_FAILURES_KEY = 'allowed-failures';
|
|
||||||
|
|
||||||
const LOGO_KEY = 'logo';
|
|
||||||
|
|
||||||
function fadeInActor(actor) {
|
|
||||||
if (actor.opacity == 255 && actor.visible)
|
|
||||||
return null;
|
|
||||||
|
|
||||||
let hold = new Batch.Hold();
|
|
||||||
actor.show();
|
|
||||||
let [minHeight, naturalHeight] = actor.get_preferred_height(-1);
|
|
||||||
|
|
||||||
actor.opacity = 0;
|
|
||||||
actor.set_height(0);
|
|
||||||
Tweener.addTween(actor,
|
|
||||||
{ opacity: 255,
|
|
||||||
height: naturalHeight,
|
|
||||||
time: FADE_ANIMATION_TIME,
|
|
||||||
transition: 'easeOutQuad',
|
|
||||||
onComplete: function() {
|
|
||||||
this.set_height(-1);
|
|
||||||
hold.release();
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
return hold;
|
|
||||||
}
|
|
||||||
|
|
||||||
function fadeOutActor(actor) {
|
|
||||||
if (!actor.visible || actor.opacity == 0) {
|
|
||||||
actor.opacity = 0;
|
|
||||||
actor.hide();
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
let hold = new Batch.Hold();
|
|
||||||
Tweener.addTween(actor,
|
|
||||||
{ opacity: 0,
|
|
||||||
height: 0,
|
|
||||||
time: FADE_ANIMATION_TIME,
|
|
||||||
transition: 'easeOutQuad',
|
|
||||||
onComplete: function() {
|
|
||||||
this.hide();
|
|
||||||
this.set_height(-1);
|
|
||||||
hold.release();
|
|
||||||
},
|
|
||||||
});
|
|
||||||
return hold;
|
|
||||||
}
|
|
||||||
|
|
||||||
const ShellUserVerifier = new Lang.Class({
|
|
||||||
Name: 'ShellUserVerifier',
|
|
||||||
|
|
||||||
_init: function(client, params) {
|
|
||||||
params = Params.parse(params, { reauthenticationOnly: false });
|
|
||||||
this._reauthOnly = params.reauthenticationOnly;
|
|
||||||
|
|
||||||
this._client = client;
|
|
||||||
|
|
||||||
this._settings = new Gio.Settings({ schema: LOGIN_SCREEN_SCHEMA });
|
|
||||||
|
|
||||||
this._fprintManager = new Fprint.FprintManager();
|
|
||||||
this._realmManager = new Realmd.Manager();
|
|
||||||
|
|
||||||
this._failCounter = 0;
|
|
||||||
},
|
|
||||||
|
|
||||||
begin: function(userName, hold) {
|
|
||||||
this._cancellable = new Gio.Cancellable();
|
|
||||||
this._hold = hold;
|
|
||||||
this._userName = userName;
|
|
||||||
|
|
||||||
this._checkForFingerprintReader();
|
|
||||||
|
|
||||||
if (userName) {
|
|
||||||
// If possible, reauthenticate an already running session,
|
|
||||||
// so any session specific credentials get updated appropriately
|
|
||||||
this._client.open_reauthentication_channel(userName, this._cancellable,
|
|
||||||
Lang.bind(this, this._reauthenticationChannelOpened));
|
|
||||||
} else {
|
|
||||||
this._client.get_user_verifier(this._cancellable, Lang.bind(this, this._userVerifierGot));
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
cancel: function() {
|
|
||||||
if (this._cancellable)
|
|
||||||
this._cancellable.cancel();
|
|
||||||
|
|
||||||
if (this._userVerifier)
|
|
||||||
this._userVerifier.call_cancel_sync(null);
|
|
||||||
},
|
|
||||||
|
|
||||||
clear: function() {
|
|
||||||
if (this._cancellable) {
|
|
||||||
this._cancellable.cancel();
|
|
||||||
this._cancellable = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._userVerifier) {
|
|
||||||
this._userVerifier.run_dispose();
|
|
||||||
this._userVerifier = null;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
answerQuery: function(serviceName, answer) {
|
|
||||||
this._userVerifier.call_answer_query(serviceName, answer, this._cancellable, null);
|
|
||||||
},
|
|
||||||
|
|
||||||
_checkForFingerprintReader: function() {
|
|
||||||
this._haveFingerprintReader = false;
|
|
||||||
|
|
||||||
if (!this._settings.get_boolean(FINGERPRINT_AUTHENTICATION_KEY))
|
|
||||||
return;
|
|
||||||
|
|
||||||
this._fprintManager.GetDefaultDeviceRemote(Gio.DBusCallFlags.NONE, this._cancellable, Lang.bind(this,
|
|
||||||
function(device, error) {
|
|
||||||
if (!error && device)
|
|
||||||
this._haveFingerprintReader = true;
|
|
||||||
}));
|
|
||||||
},
|
|
||||||
|
|
||||||
_reportInitError: function(where, error) {
|
|
||||||
logError(error, where);
|
|
||||||
this._hold.release();
|
|
||||||
|
|
||||||
this.emit('show-message', _("Authentication error"), 'login-dialog-message-warning');
|
|
||||||
this._verificationFailed(false);
|
|
||||||
},
|
|
||||||
|
|
||||||
_reauthenticationChannelOpened: function(client, result) {
|
|
||||||
try {
|
|
||||||
this._userVerifier = client.open_reauthentication_channel_finish(result);
|
|
||||||
} catch(e if e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.CANCELLED)) {
|
|
||||||
return;
|
|
||||||
} catch(e if e.matches(Gio.DBusError, Gio.DBusError.ACCESS_DENIED) &&
|
|
||||||
!this._reauthOnly) {
|
|
||||||
// Gdm emits org.freedesktop.DBus.Error.AccessDenied when there is
|
|
||||||
// no session to reauthenticate. Fall back to performing verification
|
|
||||||
// from this login session
|
|
||||||
client.get_user_verifier(this._cancellable, Lang.bind(this, this._userVerifierGot));
|
|
||||||
return;
|
|
||||||
} catch(e) {
|
|
||||||
this._reportInitError('Failed to open reauthentication channel', e);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._connectSignals();
|
|
||||||
this._beginVerification();
|
|
||||||
this._hold.release();
|
|
||||||
},
|
|
||||||
|
|
||||||
_userVerifierGot: function(client, result) {
|
|
||||||
try {
|
|
||||||
this._userVerifier = client.get_user_verifier_finish(result);
|
|
||||||
} catch(e if e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.CANCELLED)) {
|
|
||||||
return;
|
|
||||||
} catch(e) {
|
|
||||||
this._reportInitError('Failed to obtain user verifier', e);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._connectSignals();
|
|
||||||
this._beginVerification();
|
|
||||||
this._hold.release();
|
|
||||||
},
|
|
||||||
|
|
||||||
_connectSignals: function() {
|
|
||||||
this._userVerifier.connect('info', Lang.bind(this, this._onInfo));
|
|
||||||
this._userVerifier.connect('problem', Lang.bind(this, this._onProblem));
|
|
||||||
this._userVerifier.connect('info-query', Lang.bind(this, this._onInfoQuery));
|
|
||||||
this._userVerifier.connect('secret-info-query', Lang.bind(this, this._onSecretInfoQuery));
|
|
||||||
this._userVerifier.connect('conversation-stopped', Lang.bind(this, this._onConversationStopped));
|
|
||||||
this._userVerifier.connect('reset', Lang.bind(this, this._onReset));
|
|
||||||
this._userVerifier.connect('verification-complete', Lang.bind(this, this._onVerificationComplete));
|
|
||||||
},
|
|
||||||
|
|
||||||
_beginVerification: function() {
|
|
||||||
this._hold.acquire();
|
|
||||||
|
|
||||||
if (this._userName) {
|
|
||||||
this._userVerifier.call_begin_verification_for_user(PASSWORD_SERVICE_NAME,
|
|
||||||
this._userName,
|
|
||||||
this._cancellable,
|
|
||||||
Lang.bind(this, function(obj, result) {
|
|
||||||
try {
|
|
||||||
obj.call_begin_verification_for_user_finish(result);
|
|
||||||
} catch(e if e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.CANCELLED)) {
|
|
||||||
return;
|
|
||||||
} catch(e) {
|
|
||||||
this._reportInitError('Failed to start verification for user', e);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._hold.release();
|
|
||||||
}));
|
|
||||||
|
|
||||||
if (this._haveFingerprintReader) {
|
|
||||||
this._hold.acquire();
|
|
||||||
|
|
||||||
this._userVerifier.call_begin_verification_for_user(FINGERPRINT_SERVICE_NAME,
|
|
||||||
this._userName,
|
|
||||||
this._cancellable,
|
|
||||||
Lang.bind(this, function(obj, result) {
|
|
||||||
try {
|
|
||||||
obj.call_begin_verification_for_user_finish(result);
|
|
||||||
} catch(e if e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.CANCELLED)) {
|
|
||||||
return;
|
|
||||||
} catch(e) {
|
|
||||||
this._reportInitError('Failed to start fingerprint verification for user', e);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._hold.release();
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
this._userVerifier.call_begin_verification(PASSWORD_SERVICE_NAME,
|
|
||||||
this._cancellable,
|
|
||||||
Lang.bind(this, function(obj, result) {
|
|
||||||
try {
|
|
||||||
obj.call_begin_verification_finish(result);
|
|
||||||
} catch(e if e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.CANCELLED)) {
|
|
||||||
return;
|
|
||||||
} catch(e) {
|
|
||||||
this._reportInitError('Failed to start verification', e);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._hold.release();
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_onInfo: function(client, serviceName, info) {
|
|
||||||
// We don't display fingerprint messages, because they
|
|
||||||
// have words like UPEK in them. Instead we use the messages
|
|
||||||
// as a cue to display our own message.
|
|
||||||
if (serviceName == FINGERPRINT_SERVICE_NAME &&
|
|
||||||
this._haveFingerprintReader) {
|
|
||||||
|
|
||||||
// Translators: this message is shown below the password entry field
|
|
||||||
// to indicate the user can swipe their finger instead
|
|
||||||
this.emit('show-login-hint', _("(or swipe finger)"));
|
|
||||||
} else if (serviceName == PASSWORD_SERVICE_NAME) {
|
|
||||||
this.emit('show-message', info, 'login-dialog-message-info');
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_onProblem: function(client, serviceName, problem) {
|
|
||||||
// we don't want to show auth failed messages to
|
|
||||||
// users who haven't enrolled their fingerprint.
|
|
||||||
if (serviceName != PASSWORD_SERVICE_NAME)
|
|
||||||
return;
|
|
||||||
this.emit('show-message', problem, 'login-dialog-message-warning');
|
|
||||||
},
|
|
||||||
|
|
||||||
_showRealmLoginHint: function() {
|
|
||||||
if (this._realmManager.loginFormat) {
|
|
||||||
let hint = this._realmManager.loginFormat;
|
|
||||||
|
|
||||||
hint = hint.replace(/%U/g, 'user');
|
|
||||||
hint = hint.replace(/%D/g, 'DOMAIN');
|
|
||||||
hint = hint.replace(/%[^UD]/g, '');
|
|
||||||
|
|
||||||
// Translators: this message is shown below the username entry field
|
|
||||||
// to clue the user in on how to login to the local network realm
|
|
||||||
this.emit('show-login-hint',
|
|
||||||
_("(e.g., user or %s)").format(hint));
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_onInfoQuery: function(client, serviceName, question) {
|
|
||||||
// We only expect questions to come from the main auth service
|
|
||||||
if (serviceName != PASSWORD_SERVICE_NAME)
|
|
||||||
return;
|
|
||||||
|
|
||||||
this._showRealmLoginHint();
|
|
||||||
this._realmLoginHintSignalId = this._realmManager.connect('login-format-changed',
|
|
||||||
Lang.bind(this, this._showRealmLoginHint));
|
|
||||||
|
|
||||||
this.emit('ask-question', serviceName, question, '');
|
|
||||||
},
|
|
||||||
|
|
||||||
_onSecretInfoQuery: function(client, serviceName, secretQuestion) {
|
|
||||||
// We only expect secret requests to come from the main auth service
|
|
||||||
if (serviceName != PASSWORD_SERVICE_NAME)
|
|
||||||
return;
|
|
||||||
|
|
||||||
this.emit('ask-question', serviceName, secretQuestion, '\u25cf');
|
|
||||||
},
|
|
||||||
|
|
||||||
_onReset: function() {
|
|
||||||
this.clear();
|
|
||||||
|
|
||||||
// Clear previous attempts to authenticate
|
|
||||||
this._failCounter = 0;
|
|
||||||
|
|
||||||
this.emit('reset');
|
|
||||||
},
|
|
||||||
|
|
||||||
_onVerificationComplete: function() {
|
|
||||||
this.emit('verification-complete');
|
|
||||||
},
|
|
||||||
|
|
||||||
_verificationFailed: function(retry) {
|
|
||||||
// For Not Listed / enterprise logins, immediately reset
|
|
||||||
// the dialog
|
|
||||||
// Otherwise, we allow ALLOWED_FAILURES attempts. After that, we
|
|
||||||
// go back to the welcome screen.
|
|
||||||
|
|
||||||
let canRetry = retry && this._userName &&
|
|
||||||
this._failCounter < this._settings.get_int(ALLOWED_FAILURES_KEY);
|
|
||||||
|
|
||||||
if (canRetry) {
|
|
||||||
this._failCounter++;
|
|
||||||
|
|
||||||
this.clear();
|
|
||||||
this.begin(this._userName, new Batch.Hold());
|
|
||||||
} else {
|
|
||||||
// Allow some time to see the message, then reset everything
|
|
||||||
Mainloop.timeout_add(3000, Lang.bind(this, function() {
|
|
||||||
this.cancel();
|
|
||||||
|
|
||||||
this._onReset();
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
|
|
||||||
this.emit('verification-failed');
|
|
||||||
},
|
|
||||||
|
|
||||||
_onConversationStopped: function(client, serviceName) {
|
|
||||||
// if the password service fails, then cancel everything.
|
|
||||||
// But if, e.g., fingerprint fails, still give
|
|
||||||
// password authentication a chance to succeed
|
|
||||||
if (serviceName == PASSWORD_SERVICE_NAME) {
|
|
||||||
this._verificationFailed(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.emit('hide-login-hint');
|
|
||||||
|
|
||||||
if (this._realmLoginHintSignalId) {
|
|
||||||
this._realmManager.disconnect(this._realmLoginHintSignalId);
|
|
||||||
this._realmLoginHintSignalId = 0;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
});
|
|
||||||
Signals.addSignalMethods(ShellUserVerifier.prototype);
|
|
@ -1,15 +1,10 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
/* mode: js2; indent-tabs-mode: nil; tab-size: 4 */
|
||||||
|
|
||||||
/* The name of this package (not localized) */
|
/* The name of this package (not localized) */
|
||||||
const PACKAGE_NAME = '@PACKAGE_NAME@';
|
const PACKAGE_NAME = '@PACKAGE_NAME@';
|
||||||
/* The version of this package */
|
/* The version of this package */
|
||||||
const PACKAGE_VERSION = '@PACKAGE_VERSION@';
|
const PACKAGE_VERSION = '@PACKAGE_VERSION@';
|
||||||
|
/* The version of GJS we're linking to */
|
||||||
|
const GJS_VERSION = '@GJS_VERSION@';
|
||||||
/* 1 if gnome-bluetooth is available, 0 otherwise */
|
/* 1 if gnome-bluetooth is available, 0 otherwise */
|
||||||
const HAVE_BLUETOOTH = @HAVE_BLUETOOTH@;
|
const HAVE_BLUETOOTH = @HAVE_BLUETOOTH@;
|
||||||
/* gettext package */
|
|
||||||
const GETTEXT_PACKAGE = '@GETTEXT_PACKAGE@';
|
|
||||||
/* locale dir */
|
|
||||||
const LOCALEDIR = '@datadir@/locale';
|
|
||||||
/* other standard directories */
|
|
||||||
const LIBEXECDIR = '@libexecdir@';
|
|
||||||
const SYSCONFDIR = '@sysconfdir@';
|
|
||||||
|
140
js/misc/docInfo.js
Normal file
@ -0,0 +1,140 @@
|
|||||||
|
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
|
||||||
|
|
||||||
|
const St = imports.gi.St;
|
||||||
|
const Shell = imports.gi.Shell;
|
||||||
|
const Lang = imports.lang;
|
||||||
|
const Signals = imports.signals;
|
||||||
|
const Search = imports.ui.search;
|
||||||
|
|
||||||
|
const THUMBNAIL_ICON_MARGIN = 2;
|
||||||
|
|
||||||
|
function DocInfo(recentInfo) {
|
||||||
|
this._init(recentInfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
DocInfo.prototype = {
|
||||||
|
_init : function(recentInfo) {
|
||||||
|
this.recentInfo = recentInfo;
|
||||||
|
// We actually used get_modified() instead of get_visited()
|
||||||
|
// here, as GtkRecentInfo doesn't updated get_visited()
|
||||||
|
// correctly. See http://bugzilla.gnome.org/show_bug.cgi?id=567094
|
||||||
|
this.timestamp = recentInfo.get_modified();
|
||||||
|
this.name = recentInfo.get_display_name();
|
||||||
|
this._lowerName = this.name.toLowerCase();
|
||||||
|
this.uri = recentInfo.get_uri();
|
||||||
|
this.mimeType = recentInfo.get_mime_type();
|
||||||
|
},
|
||||||
|
|
||||||
|
createIcon : function(size) {
|
||||||
|
return St.TextureCache.get_default().load_recent_thumbnail(size, this.recentInfo);
|
||||||
|
},
|
||||||
|
|
||||||
|
launch : function(workspaceIndex) {
|
||||||
|
Shell.DocSystem.get_default().open(this.recentInfo, workspaceIndex);
|
||||||
|
},
|
||||||
|
|
||||||
|
matchTerms: function(terms) {
|
||||||
|
let mtype = Search.MatchType.NONE;
|
||||||
|
for (let i = 0; i < terms.length; i++) {
|
||||||
|
let term = terms[i];
|
||||||
|
let idx = this._lowerName.indexOf(term);
|
||||||
|
if (idx == 0) {
|
||||||
|
mtype = Search.MatchType.PREFIX;
|
||||||
|
} else if (idx > 0) {
|
||||||
|
if (mtype == Search.MatchType.NONE)
|
||||||
|
mtype = Search.MatchType.SUBSTRING;
|
||||||
|
} else {
|
||||||
|
return Search.MatchType.NONE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return mtype;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var docManagerInstance = null;
|
||||||
|
|
||||||
|
function getDocManager() {
|
||||||
|
if (docManagerInstance == null)
|
||||||
|
docManagerInstance = new DocManager();
|
||||||
|
return docManagerInstance;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* DocManager wraps the DocSystem, primarily to expose DocInfo objects.
|
||||||
|
*/
|
||||||
|
function DocManager() {
|
||||||
|
this._init();
|
||||||
|
}
|
||||||
|
|
||||||
|
DocManager.prototype = {
|
||||||
|
_init: function() {
|
||||||
|
this._docSystem = Shell.DocSystem.get_default();
|
||||||
|
this._infosByTimestamp = [];
|
||||||
|
this._infosByUri = {};
|
||||||
|
this._docSystem.connect('changed', Lang.bind(this, this._reload));
|
||||||
|
this._reload();
|
||||||
|
},
|
||||||
|
|
||||||
|
_reload: function() {
|
||||||
|
let docs = this._docSystem.get_all();
|
||||||
|
this._infosByTimestamp = [];
|
||||||
|
this._infosByUri = {};
|
||||||
|
for (let i = 0; i < docs.length; i++) {
|
||||||
|
let recentInfo = docs[i];
|
||||||
|
|
||||||
|
let docInfo = new DocInfo(recentInfo);
|
||||||
|
this._infosByTimestamp.push(docInfo);
|
||||||
|
this._infosByUri[docInfo.uri] = docInfo;
|
||||||
|
}
|
||||||
|
this.emit('changed');
|
||||||
|
},
|
||||||
|
|
||||||
|
getTimestampOrderedInfos: function() {
|
||||||
|
return this._infosByTimestamp;
|
||||||
|
},
|
||||||
|
|
||||||
|
getInfosByUri: function() {
|
||||||
|
return this._infosByUri;
|
||||||
|
},
|
||||||
|
|
||||||
|
lookupByUri: function(uri) {
|
||||||
|
return this._infosByUri[uri];
|
||||||
|
},
|
||||||
|
|
||||||
|
queueExistenceCheck: function(count) {
|
||||||
|
return this._docSystem.queue_existence_check(count);
|
||||||
|
},
|
||||||
|
|
||||||
|
_searchDocs: function(items, terms) {
|
||||||
|
let multiplePrefixMatches = [];
|
||||||
|
let prefixMatches = [];
|
||||||
|
let multipleSubtringMatches = [];
|
||||||
|
let substringMatches = [];
|
||||||
|
for (let i = 0; i < items.length; i++) {
|
||||||
|
let item = items[i];
|
||||||
|
let mtype = item.matchTerms(terms);
|
||||||
|
if (mtype == Search.MatchType.MULTIPLE_PREFIX)
|
||||||
|
multiplePrefixMatches.push(item.uri);
|
||||||
|
else if (mtype == Search.MatchType.PREFIX)
|
||||||
|
prefixMatches.push(item.uri);
|
||||||
|
else if (mtype == Search.MatchType.MULTIPLE_SUBSTRING)
|
||||||
|
multipleSubtringMatches.push(item.uri);
|
||||||
|
else if (mtype == Search.MatchType.SUBSTRING)
|
||||||
|
substringMatches.push(item.uri);
|
||||||
|
}
|
||||||
|
return multiplePrefixMatches.concat(prefixMatches.concat(multipleSubtringMatches.concat(substringMatches)));
|
||||||
|
},
|
||||||
|
|
||||||
|
initialSearch: function(terms) {
|
||||||
|
return this._searchDocs(this._infosByTimestamp, terms);
|
||||||
|
},
|
||||||
|
|
||||||
|
subsearch: function(previousResults, terms) {
|
||||||
|
return this._searchDocs(previousResults.map(Lang.bind(this,
|
||||||
|
function(url) {
|
||||||
|
return this._infosByUri[url];
|
||||||
|
})), terms);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
Signals.addSignalMethods(DocManager.prototype);
|
@ -1,202 +0,0 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
|
||||||
|
|
||||||
// Common utils for the extension system and the extension
|
|
||||||
// preferences tool
|
|
||||||
|
|
||||||
const Lang = imports.lang;
|
|
||||||
const Signals = imports.signals;
|
|
||||||
|
|
||||||
const GLib = imports.gi.GLib;
|
|
||||||
const Gio = imports.gi.Gio;
|
|
||||||
const ShellJS = imports.gi.ShellJS;
|
|
||||||
|
|
||||||
const Config = imports.misc.config;
|
|
||||||
|
|
||||||
const ExtensionType = {
|
|
||||||
SYSTEM: 1,
|
|
||||||
PER_USER: 2
|
|
||||||
};
|
|
||||||
|
|
||||||
// Maps uuid -> metadata object
|
|
||||||
const extensions = {};
|
|
||||||
|
|
||||||
function getCurrentExtension() {
|
|
||||||
let stack = (new Error()).stack;
|
|
||||||
|
|
||||||
// Assuming we're importing this directly from an extension (and we shouldn't
|
|
||||||
// ever not be), its UUID should be directly in the path here.
|
|
||||||
let extensionStackLine = stack.split('\n')[1];
|
|
||||||
if (!extensionStackLine)
|
|
||||||
throw new Error('Could not find current extension');
|
|
||||||
|
|
||||||
// The stack line is like:
|
|
||||||
// init([object Object])@/home/user/data/gnome-shell/extensions/u@u.id/prefs.js:8
|
|
||||||
//
|
|
||||||
// In the case that we're importing from
|
|
||||||
// module scope, the first field is blank:
|
|
||||||
// @/home/user/data/gnome-shell/extensions/u@u.id/prefs.js:8
|
|
||||||
let match = new RegExp('@(.+):\\d+').exec(extensionStackLine);
|
|
||||||
if (!match)
|
|
||||||
throw new Error('Could not find current extension');
|
|
||||||
|
|
||||||
let path = match[1];
|
|
||||||
let file = Gio.File.new_for_path(path);
|
|
||||||
|
|
||||||
// Walk up the directory tree, looking for an extesion with
|
|
||||||
// the same UUID as a directory name.
|
|
||||||
while (file != null) {
|
|
||||||
let extension = extensions[file.get_basename()];
|
|
||||||
if (extension !== undefined)
|
|
||||||
return extension;
|
|
||||||
file = file.get_parent();
|
|
||||||
}
|
|
||||||
|
|
||||||
throw new Error('Could not find current extension');
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* versionCheck:
|
|
||||||
* @required: an array of versions we're compatible with
|
|
||||||
* @current: the version we have
|
|
||||||
*
|
|
||||||
* Check if a component is compatible for an extension.
|
|
||||||
* @required is an array, and at least one version must match.
|
|
||||||
* @current must be in the format <major>.<minor>.<point>.<micro>
|
|
||||||
* <micro> is always ignored
|
|
||||||
* <point> is ignored if <minor> is even (so you can target the
|
|
||||||
* whole stable release)
|
|
||||||
* <minor> and <major> must match
|
|
||||||
* Each target version must be at least <major> and <minor>
|
|
||||||
*/
|
|
||||||
function versionCheck(required, current) {
|
|
||||||
let currentArray = current.split('.');
|
|
||||||
let major = currentArray[0];
|
|
||||||
let minor = currentArray[1];
|
|
||||||
let point = currentArray[2];
|
|
||||||
for (let i = 0; i < required.length; i++) {
|
|
||||||
let requiredArray = required[i].split('.');
|
|
||||||
if (requiredArray[0] == major &&
|
|
||||||
requiredArray[1] == minor &&
|
|
||||||
(requiredArray[2] == point ||
|
|
||||||
(requiredArray[2] == undefined && parseInt(minor) % 2 == 0)))
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
function isOutOfDate(extension) {
|
|
||||||
if (!versionCheck(extension.metadata['shell-version'], Config.PACKAGE_VERSION))
|
|
||||||
return true;
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
function createExtensionObject(uuid, dir, type) {
|
|
||||||
let info;
|
|
||||||
|
|
||||||
let metadataFile = dir.get_child('metadata.json');
|
|
||||||
if (!metadataFile.query_exists(null)) {
|
|
||||||
throw new Error('Missing metadata.json');
|
|
||||||
}
|
|
||||||
|
|
||||||
let metadataContents, success, tag;
|
|
||||||
try {
|
|
||||||
[success, metadataContents, tag] = metadataFile.load_contents(null);
|
|
||||||
} catch (e) {
|
|
||||||
throw new Error('Failed to load metadata.json: ' + e);
|
|
||||||
}
|
|
||||||
let meta;
|
|
||||||
try {
|
|
||||||
meta = JSON.parse(metadataContents);
|
|
||||||
} catch (e) {
|
|
||||||
throw new Error('Failed to parse metadata.json: ' + e);
|
|
||||||
}
|
|
||||||
|
|
||||||
let requiredProperties = ['uuid', 'name', 'description', 'shell-version'];
|
|
||||||
for (let i = 0; i < requiredProperties.length; i++) {
|
|
||||||
let prop = requiredProperties[i];
|
|
||||||
if (!meta[prop]) {
|
|
||||||
throw new Error('missing "' + prop + '" property in metadata.json');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (uuid != meta.uuid) {
|
|
||||||
throw new Error('uuid "' + meta.uuid + '" from metadata.json does not match directory name "' + uuid + '"');
|
|
||||||
}
|
|
||||||
|
|
||||||
let extension = {};
|
|
||||||
|
|
||||||
extension.metadata = meta;
|
|
||||||
extension.uuid = meta.uuid;
|
|
||||||
extension.type = type;
|
|
||||||
extension.dir = dir;
|
|
||||||
extension.path = dir.get_path();
|
|
||||||
extension.error = '';
|
|
||||||
extension.hasPrefs = dir.get_child('prefs.js').query_exists(null);
|
|
||||||
|
|
||||||
extensions[uuid] = extension;
|
|
||||||
|
|
||||||
return extension;
|
|
||||||
}
|
|
||||||
|
|
||||||
var _extension = null;
|
|
||||||
|
|
||||||
function installImporter(extension) {
|
|
||||||
_extension = extension;
|
|
||||||
ShellJS.add_extension_importer('imports.misc.extensionUtils._extension', 'imports', extension.path);
|
|
||||||
_extension = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
const ExtensionFinder = new Lang.Class({
|
|
||||||
Name: 'ExtensionFinder',
|
|
||||||
|
|
||||||
_scanExtensionsInDirectory: function(dir, type) {
|
|
||||||
let fileEnum;
|
|
||||||
let file, info;
|
|
||||||
try {
|
|
||||||
fileEnum = dir.enumerate_children('standard::*', Gio.FileQueryInfoFlags.NONE, null);
|
|
||||||
} catch(e) {
|
|
||||||
if (e.domain != Gio.io_error_quark() || e.code != Gio.IOErrorEnum.NOT_FOUND)
|
|
||||||
logError(e, 'Could not enumerate extensions directory');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
while ((info = fileEnum.next_file(null)) != null) {
|
|
||||||
let fileType = info.get_file_type();
|
|
||||||
if (fileType != Gio.FileType.DIRECTORY)
|
|
||||||
continue;
|
|
||||||
let uuid = info.get_name();
|
|
||||||
let extensionDir = dir.get_child(uuid);
|
|
||||||
|
|
||||||
let existing = extensions[uuid];
|
|
||||||
if (existing) {
|
|
||||||
log('Extension %s already installed in %s. %s will not be loaded'.format(uuid, existing.path, extensionDir.get_path()));
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
let extension;
|
|
||||||
try {
|
|
||||||
extension = createExtensionObject(uuid, extensionDir, type);
|
|
||||||
} catch(e) {
|
|
||||||
logError(e, 'Could not load extension %s'.format(uuid));
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
this.emit('extension-found', extension);
|
|
||||||
}
|
|
||||||
fileEnum.close(null);
|
|
||||||
},
|
|
||||||
|
|
||||||
scanExtensions: function() {
|
|
||||||
let userExtensionsDir = Gio.File.new_for_path(GLib.build_filenamev([global.userdatadir, 'extensions']));
|
|
||||||
this._scanExtensionsInDirectory(userExtensionsDir, ExtensionType.PER_USER);
|
|
||||||
|
|
||||||
let systemDataDirs = GLib.get_system_data_dirs();
|
|
||||||
for (let i = 0; i < systemDataDirs.length; i++) {
|
|
||||||
let dirPath = GLib.build_filenamev([systemDataDirs[i], 'gnome-shell', 'extensions']);
|
|
||||||
let dir = Gio.file_new_for_path(dirPath);
|
|
||||||
if (dir.query_exists(null))
|
|
||||||
this._scanExtensionsInDirectory(dir, ExtensionType.SYSTEM);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
Signals.addSignalMethods(ExtensionFinder.prototype);
|
|
@ -1,5 +1,3 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
|
||||||
|
|
||||||
const Gio = imports.gi.Gio;
|
const Gio = imports.gi.Gio;
|
||||||
const GLib = imports.gi.GLib;
|
const GLib = imports.gi.GLib;
|
||||||
|
|
||||||
@ -22,46 +20,3 @@ function listDirAsync(file, callback) {
|
|||||||
enumerator.next_files_async(100, GLib.PRIORITY_LOW, null, onNextFileComplete);
|
enumerator.next_files_async(100, GLib.PRIORITY_LOW, null, onNextFileComplete);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
function deleteGFile(file) {
|
|
||||||
// Work around 'delete' being a keyword in JS.
|
|
||||||
return file['delete'](null);
|
|
||||||
}
|
|
||||||
|
|
||||||
function recursivelyDeleteDir(dir, deleteParent) {
|
|
||||||
let children = dir.enumerate_children('standard::name,standard::type',
|
|
||||||
Gio.FileQueryInfoFlags.NONE, null);
|
|
||||||
|
|
||||||
let info, child;
|
|
||||||
while ((info = children.next_file(null)) != null) {
|
|
||||||
let type = info.get_file_type();
|
|
||||||
let child = dir.get_child(info.get_name());
|
|
||||||
if (type == Gio.FileType.REGULAR)
|
|
||||||
deleteGFile(child);
|
|
||||||
else if (type == Gio.FileType.DIRECTORY)
|
|
||||||
recursivelyDeleteDir(child, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (deleteParent)
|
|
||||||
deleteGFile(dir);
|
|
||||||
}
|
|
||||||
|
|
||||||
function recursivelyMoveDir(srcDir, destDir) {
|
|
||||||
let children = srcDir.enumerate_children('standard::name,standard::type',
|
|
||||||
Gio.FileQueryInfoFlags.NONE, null);
|
|
||||||
|
|
||||||
if (!destDir.query_exists(null))
|
|
||||||
destDir.make_directory_with_parents(null);
|
|
||||||
|
|
||||||
let info, child;
|
|
||||||
while ((info = children.next_file(null)) != null) {
|
|
||||||
let type = info.get_file_type();
|
|
||||||
let srcChild = srcDir.get_child(info.get_name());
|
|
||||||
let destChild = destDir.get_child(info.get_name());
|
|
||||||
log([srcChild.get_path(), destChild.get_path()]);
|
|
||||||
if (type == Gio.FileType.REGULAR)
|
|
||||||
srcChild.move(destChild, Gio.FileCopyFlags.NONE, null, null);
|
|
||||||
else if (type == Gio.FileType.DIRECTORY)
|
|
||||||
recursivelyMoveDir(srcChild, destChild);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
60
js/misc/format.js
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This function is intended to extend the String object and provide
|
||||||
|
* an String.format API for string formatting.
|
||||||
|
* It has to be set up using String.prototype.format = Format.format;
|
||||||
|
* Usage:
|
||||||
|
* "somestring %s %d".format('hello', 5);
|
||||||
|
* It supports %s, %d, %x and %f, for %f it also support precisions like
|
||||||
|
* "%.2f".format(1.526). All specifiers can be prefixed with a minimum
|
||||||
|
* field width, e.g. "%5s".format("foo"). Unless the width is prefixed
|
||||||
|
* with '0', the formatted string will be padded with spaces.
|
||||||
|
*/
|
||||||
|
|
||||||
|
function format() {
|
||||||
|
let str = this;
|
||||||
|
let i = 0;
|
||||||
|
let args = arguments;
|
||||||
|
|
||||||
|
return str.replace(/%([0-9]+)?(?:\.([0-9]+))?(.)/g, function (str, widthGroup, precisionGroup, genericGroup) {
|
||||||
|
|
||||||
|
if (precisionGroup != '' && genericGroup != 'f')
|
||||||
|
throw new Error("Precision can only be specified for 'f'");
|
||||||
|
|
||||||
|
let fillChar = (widthGroup[0] == '0') ? '0' : ' ';
|
||||||
|
let width = parseInt(widthGroup, 10) || 0;
|
||||||
|
|
||||||
|
function fillWidth(s, c, w) {
|
||||||
|
let fill = '';
|
||||||
|
for (let i = 0; i < w; i++)
|
||||||
|
fill += c;
|
||||||
|
return fill.substr(s.length) + s;
|
||||||
|
}
|
||||||
|
|
||||||
|
let s = '';
|
||||||
|
switch (genericGroup) {
|
||||||
|
case '%':
|
||||||
|
return '%';
|
||||||
|
break;
|
||||||
|
case 's':
|
||||||
|
s = args[i++].toString();
|
||||||
|
break;
|
||||||
|
case 'd':
|
||||||
|
s = parseInt(args[i++]).toString();
|
||||||
|
break;
|
||||||
|
case 'x':
|
||||||
|
s = parseInt(args[i++]).toString(16);
|
||||||
|
break;
|
||||||
|
case 'f':
|
||||||
|
if (precisionGroup == '')
|
||||||
|
s = parseFloat(args[i++]).toString();
|
||||||
|
else
|
||||||
|
s = parseFloat(args[i++]).toFixed(parseInt(precisionGroup));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
throw new Error('Unsupported conversion character %' + genericGroup);
|
||||||
|
}
|
||||||
|
return fillWidth(s, fillChar, width);
|
||||||
|
});
|
||||||
|
}
|
@ -1,18 +1,20 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
|
||||||
|
|
||||||
const Gio = imports.gi.Gio;
|
const DBus = imports.dbus;
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
const Signals = imports.signals;
|
const Signals = imports.signals;
|
||||||
|
|
||||||
const PresenceIface = <interface name="org.gnome.SessionManager.Presence">
|
const PresenceIface = {
|
||||||
<method name="SetStatus">
|
name: 'org.gnome.SessionManager.Presence',
|
||||||
<arg type="u" direction="in"/>
|
methods: [{ name: 'SetStatus',
|
||||||
</method>
|
inSignature: 'u',
|
||||||
<property name="status" type="u" access="readwrite"/>
|
outSignature: '' }],
|
||||||
<signal name="StatusChanged">
|
properties: [{ name: 'status',
|
||||||
<arg type="u" direction="out"/>
|
signature: 'u',
|
||||||
</signal>
|
access: 'readwrite' }],
|
||||||
</interface>;
|
signals: [{ name: 'StatusChanged',
|
||||||
|
inSignature: 'u' }]
|
||||||
|
};
|
||||||
|
|
||||||
const PresenceStatus = {
|
const PresenceStatus = {
|
||||||
AVAILABLE: 0,
|
AVAILABLE: 0,
|
||||||
@ -21,52 +23,103 @@ const PresenceStatus = {
|
|||||||
IDLE: 3
|
IDLE: 3
|
||||||
};
|
};
|
||||||
|
|
||||||
var PresenceProxy = Gio.DBusProxy.makeProxyWrapper(PresenceIface);
|
function Presence() {
|
||||||
function Presence(initCallback, cancellable) {
|
this._init();
|
||||||
return new PresenceProxy(Gio.DBus.session, 'org.gnome.SessionManager',
|
|
||||||
'/org/gnome/SessionManager/Presence', initCallback, cancellable);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Presence.prototype = {
|
||||||
|
_init: function() {
|
||||||
|
DBus.session.proxifyObject(this, 'org.gnome.SessionManager', '/org/gnome/SessionManager/Presence', this);
|
||||||
|
},
|
||||||
|
|
||||||
|
getStatus: function(callback) {
|
||||||
|
this.GetRemote('status', Lang.bind(this,
|
||||||
|
function(status, ex) {
|
||||||
|
if (!ex)
|
||||||
|
callback(this, status);
|
||||||
|
}));
|
||||||
|
},
|
||||||
|
|
||||||
|
setStatus: function(status) {
|
||||||
|
this.SetStatusRemote(status);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
DBus.proxifyPrototype(Presence.prototype, PresenceIface);
|
||||||
|
|
||||||
// Note inhibitors are immutable objects, so they don't
|
// Note inhibitors are immutable objects, so they don't
|
||||||
// change at runtime (changes always come in the form
|
// change at runtime (changes always come in the form
|
||||||
// of new inhibitors)
|
// of new inhibitors)
|
||||||
const InhibitorIface = <interface name="org.gnome.SessionManager.Inhibitor">
|
const InhibitorIface = {
|
||||||
<method name="GetAppId">
|
name: 'org.gnome.SessionManager.Inhibitor',
|
||||||
<arg type="s" direction="out" />
|
properties: [{ name: 'app_id',
|
||||||
</method>
|
signature: 's',
|
||||||
<method name="GetReason">
|
access: 'readonly' },
|
||||||
<arg type="s" direction="out" />
|
{ name: 'client_id',
|
||||||
</method>
|
signature: 's',
|
||||||
</interface>;
|
access: 'readonly' },
|
||||||
|
{ name: 'reason',
|
||||||
|
signature: 's',
|
||||||
|
access: 'readonly' },
|
||||||
|
{ name: 'flags',
|
||||||
|
signature: 'u',
|
||||||
|
access: 'readonly' },
|
||||||
|
{ name: 'toplevel_xid',
|
||||||
|
signature: 'u',
|
||||||
|
access: 'readonly' },
|
||||||
|
{ name: 'cookie',
|
||||||
|
signature: 'u',
|
||||||
|
access: 'readonly' }],
|
||||||
|
};
|
||||||
|
|
||||||
var InhibitorProxy = Gio.DBusProxy.makeProxyWrapper(InhibitorIface);
|
function Inhibitor(objectPath) {
|
||||||
function Inhibitor(objectPath, initCallback, cancellable) {
|
this._init(objectPath);
|
||||||
return new InhibitorProxy(Gio.DBus.session, 'org.gnome.SessionManager', objectPath, initCallback, cancellable);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Inhibitor.prototype = {
|
||||||
|
_init: function(objectPath) {
|
||||||
|
DBus.session.proxifyObject(this,
|
||||||
|
"org.gnome.SessionManager",
|
||||||
|
objectPath);
|
||||||
|
this.isLoaded = false;
|
||||||
|
this._loadingPropertiesCount = InhibitorIface.properties.length;
|
||||||
|
for (let i = 0; i < InhibitorIface.properties.length; i++) {
|
||||||
|
let propertyName = InhibitorIface.properties[i].name;
|
||||||
|
this.GetRemote(propertyName, Lang.bind(this,
|
||||||
|
function(value, exception) {
|
||||||
|
if (exception)
|
||||||
|
return;
|
||||||
|
|
||||||
|
this[propertyName] = value;
|
||||||
|
this._loadingPropertiesCount--;
|
||||||
|
|
||||||
|
if (this._loadingPropertiesCount == 0) {
|
||||||
|
this.isLoaded = true;
|
||||||
|
this.emit("is-loaded");
|
||||||
|
}
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
},
|
||||||
|
};
|
||||||
|
DBus.proxifyPrototype(Inhibitor.prototype, InhibitorIface);
|
||||||
|
Signals.addSignalMethods(Inhibitor.prototype);
|
||||||
|
|
||||||
|
|
||||||
// Not the full interface, only the methods we use
|
// Not the full interface, only the methods we use
|
||||||
const SessionManagerIface = <interface name="org.gnome.SessionManager">
|
const SessionManagerIface = {
|
||||||
<method name="Logout">
|
name: 'org.gnome.SessionManager',
|
||||||
<arg type="u" direction="in" />
|
methods: [
|
||||||
</method>
|
{ name: 'Logout', inSignature: 'u', outSignature: '' },
|
||||||
<method name="Shutdown" />
|
{ name: 'Shutdown', inSignature: '', outSignature: '' }
|
||||||
<method name="Reboot" />
|
]
|
||||||
<method name="CanShutdown">
|
};
|
||||||
<arg type="b" direction="out" />
|
|
||||||
</method>
|
|
||||||
<method name="IsInhibited">
|
|
||||||
<arg type="u" direction="in" />
|
|
||||||
<arg type="b" direction="out" />
|
|
||||||
</method>
|
|
||||||
<signal name="InhibitorAdded">
|
|
||||||
<arg type="o" direction="out"/>
|
|
||||||
</signal>
|
|
||||||
<signal name="InhibitorRemoved">
|
|
||||||
<arg type="o" direction="out"/>
|
|
||||||
</signal>
|
|
||||||
</interface>;
|
|
||||||
|
|
||||||
var SessionManagerProxy = Gio.DBusProxy.makeProxyWrapper(SessionManagerIface);
|
function SessionManager() {
|
||||||
function SessionManager(initCallback, cancellable) {
|
this._init();
|
||||||
return new SessionManagerProxy(Gio.DBus.session, 'org.gnome.SessionManager', '/org/gnome/SessionManager', initCallback, cancellable);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SessionManager.prototype = {
|
||||||
|
_init: function() {
|
||||||
|
DBus.session.proxifyObject(this, 'org.gnome.SessionManager', '/org/gnome/SessionManager');
|
||||||
|
}
|
||||||
|
};
|
||||||
|
DBus.proxifyPrototype(SessionManager.prototype, SessionManagerIface);
|
@ -1,4 +1,4 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
|
||||||
|
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
const Signals = imports.signals;
|
const Signals = imports.signals;
|
||||||
@ -7,9 +7,11 @@ const Params = imports.misc.params;
|
|||||||
|
|
||||||
const DEFAULT_LIMIT = 512;
|
const DEFAULT_LIMIT = 512;
|
||||||
|
|
||||||
const HistoryManager = new Lang.Class({
|
function HistoryManager(params) {
|
||||||
Name: 'HistoryManager',
|
this._init(params);
|
||||||
|
}
|
||||||
|
|
||||||
|
HistoryManager.prototype = {
|
||||||
_init: function(params) {
|
_init: function(params) {
|
||||||
params = Params.parse(params, { gsettingsKey: null,
|
params = Params.parse(params, { gsettingsKey: null,
|
||||||
limit: DEFAULT_LIMIT,
|
limit: DEFAULT_LIMIT,
|
||||||
@ -41,26 +43,24 @@ const HistoryManager = new Lang.Class({
|
|||||||
this._historyIndex = this._history.length;
|
this._historyIndex = this._history.length;
|
||||||
},
|
},
|
||||||
|
|
||||||
_setPrevItem: function(text) {
|
prevItem: function(text) {
|
||||||
if (this._historyIndex <= 0)
|
if (this._historyIndex <= 0)
|
||||||
return false;
|
return text;
|
||||||
|
|
||||||
if (text)
|
if (text)
|
||||||
this._history[this._historyIndex] = text;
|
this._history[this._historyIndex] = text;
|
||||||
this._historyIndex--;
|
this._historyIndex--;
|
||||||
this._indexChanged();
|
return this._indexChanged();
|
||||||
return true;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_setNextItem: function(text) {
|
nextItem: function(text) {
|
||||||
if (this._historyIndex >= this._history.length)
|
if (this._historyIndex >= this._history.length)
|
||||||
return false;
|
return text;
|
||||||
|
|
||||||
if (text)
|
if (text)
|
||||||
this._history[this._historyIndex] = text;
|
this._history[this._historyIndex] = text;
|
||||||
this._historyIndex++;
|
this._historyIndex++;
|
||||||
this._indexChanged();
|
return this._indexChanged();
|
||||||
return true;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
lastItem: function() {
|
lastItem: function() {
|
||||||
@ -85,9 +85,11 @@ const HistoryManager = new Lang.Class({
|
|||||||
_onEntryKeyPress: function(entry, event) {
|
_onEntryKeyPress: function(entry, event) {
|
||||||
let symbol = event.get_key_symbol();
|
let symbol = event.get_key_symbol();
|
||||||
if (symbol == Clutter.KEY_Up) {
|
if (symbol == Clutter.KEY_Up) {
|
||||||
return this._setPrevItem(entry.get_text());
|
this.prevItem(entry.get_text());
|
||||||
|
return true;
|
||||||
} else if (symbol == Clutter.KEY_Down) {
|
} else if (symbol == Clutter.KEY_Down) {
|
||||||
return this._setNextItem(entry.get_text());
|
this.nextItem(entry.get_text());
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
},
|
},
|
||||||
@ -98,6 +100,8 @@ const HistoryManager = new Lang.Class({
|
|||||||
|
|
||||||
if (this._entry)
|
if (this._entry)
|
||||||
this._entry.set_text(current);
|
this._entry.set_text(current);
|
||||||
|
|
||||||
|
return current;
|
||||||
},
|
},
|
||||||
|
|
||||||
_save: function() {
|
_save: function() {
|
||||||
@ -107,5 +111,5 @@ const HistoryManager = new Lang.Class({
|
|||||||
if (this._key)
|
if (this._key)
|
||||||
global.settings.set_strv(this._key, this._history);
|
global.settings.set_strv(this._key, this._history);
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
Signals.addSignalMethods(HistoryManager.prototype);
|
Signals.addSignalMethods(HistoryManager.prototype);
|
||||||
|
@ -1,246 +0,0 @@
|
|||||||
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
|
|
||||||
|
|
||||||
// Returns a list of potential completions for text. Completions either
|
|
||||||
// follow a dot (e.g. foo.ba -> bar) or they are picked from globalCompletionList (e.g. fo -> foo)
|
|
||||||
// commandHeader is prefixed on any expression before it is eval'ed. It will most likely
|
|
||||||
// consist of global constants that might not carry over from the calling environment.
|
|
||||||
//
|
|
||||||
// This function is likely the one you want to call from external modules
|
|
||||||
function getCompletions(text, commandHeader, globalCompletionList) {
|
|
||||||
let methods = [];
|
|
||||||
let expr, base;
|
|
||||||
let attrHead = '';
|
|
||||||
if (globalCompletionList == null) {
|
|
||||||
globalCompletionList = [];
|
|
||||||
}
|
|
||||||
|
|
||||||
let offset = getExpressionOffset(text, text.length - 1);
|
|
||||||
if (offset >= 0) {
|
|
||||||
text = text.slice(offset);
|
|
||||||
|
|
||||||
// Look for expressions like "Main.panel.foo" and match Main.panel and foo
|
|
||||||
let matches = text.match(/(.*)\.(.*)/);
|
|
||||||
if (matches) {
|
|
||||||
[expr, base, attrHead] = matches;
|
|
||||||
|
|
||||||
methods = getPropertyNamesFromExpression(base, commandHeader).filter(function(attr) {
|
|
||||||
return attr.slice(0, attrHead.length) == attrHead;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// Look for the empty expression or partially entered words
|
|
||||||
// not proceeded by a dot and match them against global constants
|
|
||||||
matches = text.match(/^(\w*)$/);
|
|
||||||
if (text == '' || matches) {
|
|
||||||
[expr, attrHead] = matches;
|
|
||||||
methods = globalCompletionList.filter(function(attr) {
|
|
||||||
return attr.slice(0, attrHead.length) == attrHead;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return [methods, attrHead];
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//
|
|
||||||
// A few functions for parsing strings of javascript code.
|
|
||||||
//
|
|
||||||
|
|
||||||
// Identify characters that delimit an expression. That is,
|
|
||||||
// if we encounter anything that isn't a letter, '.', ')', or ']',
|
|
||||||
// we should stop parsing.
|
|
||||||
function isStopChar(c) {
|
|
||||||
return !c.match(/[\w\.\)\]]/);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Given the ending position of a quoted string, find where it starts
|
|
||||||
function findMatchingQuote(expr, offset) {
|
|
||||||
let quoteChar = expr.charAt(offset);
|
|
||||||
for (let i = offset - 1; i >= 0; --i) {
|
|
||||||
if (expr.charAt(i) == quoteChar && expr.charAt(i-1) != '\\'){
|
|
||||||
return i;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Given the ending position of a regex, find where it starts
|
|
||||||
function findMatchingSlash(expr, offset) {
|
|
||||||
for (let i = offset - 1; i >= 0; --i) {
|
|
||||||
if (expr.charAt(i) == '/' && expr.charAt(i-1) != '\\'){
|
|
||||||
return i;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
// If expr.charAt(offset) is ')' or ']',
|
|
||||||
// return the position of the corresponding '(' or '[' bracket.
|
|
||||||
// This function does not check for syntactic correctness. e.g.,
|
|
||||||
// findMatchingBrace("[(])", 3) returns 1.
|
|
||||||
function findMatchingBrace(expr, offset) {
|
|
||||||
let closeBrace = expr.charAt(offset);
|
|
||||||
let openBrace = ({')': '(', ']': '['})[closeBrace];
|
|
||||||
|
|
||||||
function findTheBrace(expr, offset) {
|
|
||||||
if (offset < 0) {
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (expr.charAt(offset) == openBrace) {
|
|
||||||
return offset;
|
|
||||||
}
|
|
||||||
if (expr.charAt(offset).match(/['"]/)) {
|
|
||||||
return findTheBrace(expr, findMatchingQuote(expr, offset) - 1);
|
|
||||||
}
|
|
||||||
if (expr.charAt(offset) == '/') {
|
|
||||||
return findTheBrace(expr, findMatchingSlash(expr, offset) - 1);
|
|
||||||
}
|
|
||||||
if (expr.charAt(offset) == closeBrace) {
|
|
||||||
return findTheBrace(expr, findTheBrace(expr, offset - 1) - 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
return findTheBrace(expr, offset - 1);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
return findTheBrace(expr, offset - 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Walk expr backwards from offset looking for the beginning of an
|
|
||||||
// expression suitable for passing to eval.
|
|
||||||
// There is no guarantee of correct javascript syntax between the return
|
|
||||||
// value and offset. This function is meant to take a string like
|
|
||||||
// "foo(Obj.We.Are.Completing" and allow you to extract "Obj.We.Are.Completing"
|
|
||||||
function getExpressionOffset(expr, offset) {
|
|
||||||
while (offset >= 0) {
|
|
||||||
let currChar = expr.charAt(offset);
|
|
||||||
|
|
||||||
if (isStopChar(currChar)){
|
|
||||||
return offset + 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (currChar.match(/[\)\]]/)) {
|
|
||||||
offset = findMatchingBrace(expr, offset);
|
|
||||||
}
|
|
||||||
|
|
||||||
--offset;
|
|
||||||
}
|
|
||||||
|
|
||||||
return offset + 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Things with non-word characters or that start with a number
|
|
||||||
// are not accessible via .foo notation and so aren't returned
|
|
||||||
function isValidPropertyName(w) {
|
|
||||||
return !(w.match(/\W/) || w.match(/^\d/));
|
|
||||||
}
|
|
||||||
|
|
||||||
// To get all properties (enumerable and not), we need to walk
|
|
||||||
// the prototype chain ourselves
|
|
||||||
function getAllProps(obj) {
|
|
||||||
if (obj === null || obj === undefined) {
|
|
||||||
return [];
|
|
||||||
}
|
|
||||||
return Object.getOwnPropertyNames(obj).concat( getAllProps(Object.getPrototypeOf(obj)) );
|
|
||||||
}
|
|
||||||
|
|
||||||
// Given a string _expr_, returns all methods
|
|
||||||
// that can be accessed via '.' notation.
|
|
||||||
// e.g., expr="({ foo: null, bar: null, 4: null })" will
|
|
||||||
// return ["foo", "bar", ...] but the list will not include "4",
|
|
||||||
// since methods accessed with '.' notation must star with a letter or _.
|
|
||||||
function getPropertyNamesFromExpression(expr, commandHeader) {
|
|
||||||
if (commandHeader == null) {
|
|
||||||
commandHeader = '';
|
|
||||||
}
|
|
||||||
|
|
||||||
let obj = {};
|
|
||||||
if (!isUnsafeExpression(expr)) {
|
|
||||||
try {
|
|
||||||
obj = eval(commandHeader + expr);
|
|
||||||
} catch (e) {
|
|
||||||
return [];
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return [];
|
|
||||||
}
|
|
||||||
|
|
||||||
let propsUnique = {};
|
|
||||||
if (typeof obj === 'object'){
|
|
||||||
let allProps = getAllProps(obj);
|
|
||||||
// Get only things we are allowed to complete following a '.'
|
|
||||||
allProps = allProps.filter( isValidPropertyName );
|
|
||||||
|
|
||||||
// Make sure propsUnique contains one key for every
|
|
||||||
// property so we end up with a unique list of properties
|
|
||||||
allProps.map(function(p){ propsUnique[p] = null; });
|
|
||||||
}
|
|
||||||
return Object.keys(propsUnique).sort();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Given a list of words, returns the longest prefix they all have in common
|
|
||||||
function getCommonPrefix(words) {
|
|
||||||
let word = words[0];
|
|
||||||
for (let i = 0; i < word.length; i++) {
|
|
||||||
for (let w = 1; w < words.length; w++) {
|
|
||||||
if (words[w].charAt(i) != word.charAt(i))
|
|
||||||
return word.slice(0, i);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return word;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Returns true if there is reason to think that eval(str)
|
|
||||||
// will modify the global scope
|
|
||||||
function isUnsafeExpression(str) {
|
|
||||||
// Remove any blocks that are quoted or are in a regex
|
|
||||||
function removeLiterals(str) {
|
|
||||||
if (str.length == 0) {
|
|
||||||
return '';
|
|
||||||
}
|
|
||||||
|
|
||||||
let currChar = str.charAt(str.length - 1);
|
|
||||||
if (currChar == '"' || currChar == '\'') {
|
|
||||||
return removeLiterals(str.slice(0, findMatchingQuote(str, str.length - 1)));
|
|
||||||
} else if (currChar == '/') {
|
|
||||||
return removeLiterals(str.slice(0, findMatchingSlash(str, str.length - 1)));
|
|
||||||
}
|
|
||||||
|
|
||||||
return removeLiterals(str.slice(0, str.length - 1)) + currChar;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check for any sort of assignment
|
|
||||||
// The strategy used is dumb: remove any quotes
|
|
||||||
// or regexs and comparison operators and see if there is an '=' character.
|
|
||||||
// If there is, it might be an unsafe assignment.
|
|
||||||
|
|
||||||
let prunedStr = removeLiterals(str);
|
|
||||||
prunedStr = prunedStr.replace(/[=!]==/g, ''); //replace === and !== with nothing
|
|
||||||
prunedStr = prunedStr.replace(/[=<>!]=/g, ''); //replace ==, <=, >=, != with nothing
|
|
||||||
|
|
||||||
if (prunedStr.match(/=/)) {
|
|
||||||
return true;
|
|
||||||
} else if (prunedStr.match(/;/)) {
|
|
||||||
// If we contain a semicolon not inside of a quote/regex, assume we're unsafe as well
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Returns a list of global keywords derived from str
|
|
||||||
function getDeclaredConstants(str) {
|
|
||||||
let ret = [];
|
|
||||||
str.split(';').forEach(function(s) {
|
|
||||||
let base, keyword;
|
|
||||||
let match = s.match(/const\s+(\w+)\s*=/);
|
|
||||||
if (match) {
|
|
||||||
[base, keyword] = match;
|
|
||||||
ret.push(keyword);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
@ -1,197 +0,0 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
|
||||||
|
|
||||||
const GLib = imports.gi.GLib;
|
|
||||||
const Gio = imports.gi.Gio;
|
|
||||||
const Lang = imports.lang;
|
|
||||||
const Shell = imports.gi.Shell;
|
|
||||||
|
|
||||||
const SystemdLoginManagerIface = <interface name='org.freedesktop.login1.Manager'>
|
|
||||||
<method name='PowerOff'>
|
|
||||||
<arg type='b' direction='in'/>
|
|
||||||
</method>
|
|
||||||
<method name='Reboot'>
|
|
||||||
<arg type='b' direction='in'/>
|
|
||||||
</method>
|
|
||||||
<method name='CanPowerOff'>
|
|
||||||
<arg type='s' direction='out'/>
|
|
||||||
</method>
|
|
||||||
<method name='CanReboot'>
|
|
||||||
<arg type='s' direction='out'/>
|
|
||||||
</method>
|
|
||||||
</interface>;
|
|
||||||
|
|
||||||
const SystemdLoginSessionIface = <interface name='org.freedesktop.login1.Session'>
|
|
||||||
<signal name='Lock' />
|
|
||||||
<signal name='Unlock' />
|
|
||||||
</interface>;
|
|
||||||
|
|
||||||
const SystemdLoginManager = Gio.DBusProxy.makeProxyWrapper(SystemdLoginManagerIface);
|
|
||||||
const SystemdLoginSession = Gio.DBusProxy.makeProxyWrapper(SystemdLoginSessionIface);
|
|
||||||
|
|
||||||
const ConsoleKitManagerIface = <interface name='org.freedesktop.ConsoleKit.Manager'>
|
|
||||||
<method name='CanRestart'>
|
|
||||||
<arg type='b' direction='out'/>
|
|
||||||
</method>
|
|
||||||
<method name='CanStop'>
|
|
||||||
<arg type='b' direction='out'/>
|
|
||||||
</method>
|
|
||||||
<method name='Restart' />
|
|
||||||
<method name='Stop' />
|
|
||||||
<method name='GetCurrentSession'>
|
|
||||||
<arg type='o' direction='out' />
|
|
||||||
</method>
|
|
||||||
</interface>;
|
|
||||||
|
|
||||||
const ConsoleKitSessionIface = <interface name='org.freedesktop.ConsoleKit.Session'>
|
|
||||||
<method name='IsActive'>
|
|
||||||
<arg type='b' direction='out' />
|
|
||||||
</method>
|
|
||||||
<signal name='ActiveChanged'>
|
|
||||||
<arg type='b' direction='out' />
|
|
||||||
</signal>
|
|
||||||
<signal name='Lock' />
|
|
||||||
<signal name='Unlock' />
|
|
||||||
</interface>;
|
|
||||||
|
|
||||||
const ConsoleKitSession = Gio.DBusProxy.makeProxyWrapper(ConsoleKitSessionIface);
|
|
||||||
const ConsoleKitManager = Gio.DBusProxy.makeProxyWrapper(ConsoleKitManagerIface);
|
|
||||||
|
|
||||||
function haveSystemd() {
|
|
||||||
return GLib.access("/sys/fs/cgroup/systemd", 0) >= 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
let _loginManager = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* LoginManager:
|
|
||||||
* An abstraction over systemd/logind and ConsoleKit.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
function getLoginManager() {
|
|
||||||
if (_loginManager == null) {
|
|
||||||
if (haveSystemd())
|
|
||||||
_loginManager = new LoginManagerSystemd();
|
|
||||||
else
|
|
||||||
_loginManager = new LoginManagerConsoleKit();
|
|
||||||
}
|
|
||||||
|
|
||||||
return _loginManager;
|
|
||||||
}
|
|
||||||
|
|
||||||
const LoginManagerSystemd = new Lang.Class({
|
|
||||||
Name: 'LoginManagerSystemd',
|
|
||||||
|
|
||||||
_init: function() {
|
|
||||||
this._proxy = new SystemdLoginManager(Gio.DBus.system,
|
|
||||||
'org.freedesktop.login1',
|
|
||||||
'/org/freedesktop/login1');
|
|
||||||
},
|
|
||||||
|
|
||||||
// Having this function is a bit of a hack since the Systemd and ConsoleKit
|
|
||||||
// session objects have different interfaces - but in both cases there are
|
|
||||||
// Lock/Unlock signals, and that's all we count upon at the moment.
|
|
||||||
getCurrentSessionProxy: function() {
|
|
||||||
if (!this._currentSession) {
|
|
||||||
this._currentSession = new SystemdLoginSession(Gio.DBus.system,
|
|
||||||
'org.freedesktop.login1',
|
|
||||||
'/org/freedesktop/login1/session/' +
|
|
||||||
GLib.getenv('XDG_SESSION_ID'));
|
|
||||||
}
|
|
||||||
|
|
||||||
return this._currentSession;
|
|
||||||
},
|
|
||||||
|
|
||||||
get sessionActive() {
|
|
||||||
return Shell.session_is_active_for_systemd();
|
|
||||||
},
|
|
||||||
|
|
||||||
canPowerOff: function(asyncCallback) {
|
|
||||||
this._proxy.CanPowerOffRemote(function(result, error) {
|
|
||||||
if (error)
|
|
||||||
asyncCallback(false);
|
|
||||||
else
|
|
||||||
asyncCallback(result[0] != 'no');
|
|
||||||
});
|
|
||||||
},
|
|
||||||
|
|
||||||
canReboot: function(asyncCallback) {
|
|
||||||
this._proxy.CanRebootRemote(function(result, error) {
|
|
||||||
if (error)
|
|
||||||
asyncCallback(false);
|
|
||||||
else
|
|
||||||
asyncCallback(result[0] != 'no');
|
|
||||||
});
|
|
||||||
},
|
|
||||||
|
|
||||||
powerOff: function() {
|
|
||||||
this._proxy.PowerOffRemote(true);
|
|
||||||
},
|
|
||||||
|
|
||||||
reboot: function() {
|
|
||||||
this._proxy.RebootRemote(true);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
const LoginManagerConsoleKit = new Lang.Class({
|
|
||||||
Name: 'LoginManagerConsoleKit',
|
|
||||||
|
|
||||||
_init: function() {
|
|
||||||
this._proxy = new ConsoleKitManager(Gio.DBus.system,
|
|
||||||
'org.freedesktop.ConsoleKit',
|
|
||||||
'/org/freedesktop/ConsoleKit/Manager');
|
|
||||||
},
|
|
||||||
|
|
||||||
// Having this function is a bit of a hack since the Systemd and ConsoleKit
|
|
||||||
// session objects have different interfaces - but in both cases there are
|
|
||||||
// Lock/Unlock signals, and that's all we count upon at the moment.
|
|
||||||
getCurrentSessionProxy: function() {
|
|
||||||
if (!this._currentSession) {
|
|
||||||
let [currentSessionId] = this._proxy.GetCurrentSessionSync();
|
|
||||||
this._currentSession = new ConsoleKitSession(Gio.DBus.system,
|
|
||||||
'org.freedesktop.ConsoleKit',
|
|
||||||
currentSessionId);
|
|
||||||
}
|
|
||||||
|
|
||||||
return this._currentSession;
|
|
||||||
},
|
|
||||||
|
|
||||||
get sessionActive() {
|
|
||||||
if (this._sessionActive !== undefined)
|
|
||||||
return this._sessionActive;
|
|
||||||
|
|
||||||
let session = this.getCurrentSessionProxy();
|
|
||||||
session.connectSignal('ActiveChanged', Lang.bind(this, function(object, senderName, [isActive]) {
|
|
||||||
this._sessionActive = isActive;
|
|
||||||
}));
|
|
||||||
[this._sessionActive] = session.IsActiveSync();
|
|
||||||
|
|
||||||
return this._sessionActive;
|
|
||||||
},
|
|
||||||
|
|
||||||
canPowerOff: function(asyncCallback) {
|
|
||||||
this._proxy.CanStopRemote(function(result, error) {
|
|
||||||
if (error)
|
|
||||||
asyncCallback(false);
|
|
||||||
else
|
|
||||||
asyncCallback(result[0]);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
|
|
||||||
canReboot: function(asyncCallback) {
|
|
||||||
this._proxy.CanRestartRemote(function(result, error) {
|
|
||||||
if (error)
|
|
||||||
asyncCallback(false);
|
|
||||||
else
|
|
||||||
asyncCallback(result[0]);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
|
|
||||||
powerOff: function() {
|
|
||||||
this._proxy.StopRemote();
|
|
||||||
},
|
|
||||||
|
|
||||||
reboot: function() {
|
|
||||||
this._proxy.RestartRemote();
|
|
||||||
}
|
|
||||||
|
|
||||||
});
|
|
@ -1,6 +1,6 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
// -*- mode: js2; indent-tabs-mode: nil; js2-basic-offset: 4 -*-
|
||||||
|
|
||||||
const Gio = imports.gi.Gio;
|
const DBus = imports.dbus;
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
const Shell = imports.gi.Shell;
|
const Shell = imports.gi.Shell;
|
||||||
const Signals = imports.signals;
|
const Signals = imports.signals;
|
||||||
@ -8,39 +8,33 @@ const Signals = imports.signals;
|
|||||||
// The following are not the complete interfaces, just the methods we need
|
// The following are not the complete interfaces, just the methods we need
|
||||||
// (or may need in the future)
|
// (or may need in the future)
|
||||||
|
|
||||||
const ModemGsmNetworkInterface = <interface name="org.freedesktop.ModemManager.Modem.Gsm.Network">
|
const ModemGsmNetworkInterface = {
|
||||||
<method name="GetRegistrationInfo">
|
name: 'org.freedesktop.ModemManager.Modem.Gsm.Network',
|
||||||
<arg type="(uss)" direction="out" />
|
methods: [
|
||||||
</method>
|
{ name: 'GetRegistrationInfo', inSignature: '', outSignature: 'uss' },
|
||||||
<method name="GetSignalQuality">
|
{ name: 'GetSignalQuality', inSignature: '', outSignature: 'u' }
|
||||||
<arg type="u" direction="out" />
|
],
|
||||||
</method>
|
properties: [
|
||||||
<property name="AccessTechnology" type="u" access="read" />
|
{ name: 'AccessTechnology', signature: 'u', access: 'read' }
|
||||||
<signal name="SignalQuality">
|
],
|
||||||
<arg type="u" direction="out" />
|
signals: [
|
||||||
</signal>
|
{ name: 'SignalQuality', inSignature: 'u' },
|
||||||
<signal name="RegistrationInfo">
|
{ name: 'RegistrationInfo', inSignature: 'uss' }
|
||||||
<arg type="u" direction="out" />
|
]
|
||||||
<arg type="s" direction="out" />
|
};
|
||||||
<arg type="s" direction="out" />
|
const ModemGsmNetworkProxy = DBus.makeProxyClass(ModemGsmNetworkInterface);
|
||||||
</signal>
|
|
||||||
</interface>;
|
|
||||||
|
|
||||||
const ModemGsmNetworkProxy = Gio.DBusProxy.makeProxyWrapper(ModemGsmNetworkInterface);
|
const ModemCdmaInterface = {
|
||||||
|
name: 'org.freedesktop.ModemManager.Modem.Cdma',
|
||||||
const ModemCdmaInterface = <interface name="org.freedesktop.ModemManager.Modem.Cdma">
|
methods: [
|
||||||
<method name="GetSignalQuality">
|
{ name: 'GetSignalQuality', inSignature: '', outSignature: 'u' },
|
||||||
<arg type="u" direction="out" />
|
{ name: 'GetServingSystem', inSignature: '', outSignature: 'usu' }
|
||||||
</method>
|
],
|
||||||
<method name="GetServingSystem">
|
signals: [
|
||||||
<arg type="(usu)" direction="out" />
|
{ name: 'SignalQuality', inSignature: 'u' }
|
||||||
</method>
|
]
|
||||||
<signal name="SignalQuality">
|
};
|
||||||
<arg type="u" direction="out" />
|
const ModemCdmaProxy = DBus.makeProxyClass(ModemCdmaInterface);
|
||||||
</signal>
|
|
||||||
</interface>;
|
|
||||||
|
|
||||||
const ModemCdmaProxy = Gio.DBusProxy.makeProxyWrapper(ModemCdmaInterface);
|
|
||||||
|
|
||||||
let _providersTable;
|
let _providersTable;
|
||||||
function _getProvidersTable() {
|
function _getProvidersTable() {
|
||||||
@ -50,25 +44,27 @@ function _getProvidersTable() {
|
|||||||
return _providersTable = providers;
|
return _providersTable = providers;
|
||||||
}
|
}
|
||||||
|
|
||||||
const ModemGsm = new Lang.Class({
|
function ModemGsm() {
|
||||||
Name: 'ModemGsm',
|
this._init.apply(this, arguments);
|
||||||
|
}
|
||||||
|
|
||||||
|
ModemGsm.prototype = {
|
||||||
_init: function(path) {
|
_init: function(path) {
|
||||||
this._proxy = new ModemGsmNetworkProxy(Gio.DBus.system, 'org.freedesktop.ModemManager', path);
|
this._proxy = new ModemGsmNetworkProxy(DBus.system, 'org.freedesktop.ModemManager', path);
|
||||||
|
|
||||||
this.signal_quality = 0;
|
this.signal_quality = 0;
|
||||||
this.operator_name = null;
|
this.operator_name = null;
|
||||||
|
|
||||||
// Code is duplicated because the function have different signatures
|
// Code is duplicated because the function have different signatures
|
||||||
this._proxy.connectSignal('SignalQuality', Lang.bind(this, function(proxy, sender, [quality]) {
|
this._proxy.connect('SignalQuality', Lang.bind(this, function(proxy, quality) {
|
||||||
this.signal_quality = quality;
|
this.signal_quality = quality;
|
||||||
this.emit('notify::signal-quality');
|
this.emit('notify::signal-quality');
|
||||||
}));
|
}));
|
||||||
this._proxy.connectSignal('RegistrationInfo', Lang.bind(this, function(proxy, sender, [status, code, name]) {
|
this._proxy.connect('RegistrationInfo', Lang.bind(this, function(proxy, status, code, name) {
|
||||||
this.operator_name = this._findOperatorName(name, code);
|
this.operator_name = this._findOperatorName(name, code);
|
||||||
this.emit('notify::operator-name');
|
this.emit('notify::operator-name');
|
||||||
}));
|
}));
|
||||||
this._proxy.GetRegistrationInfoRemote(Lang.bind(this, function([result], err) {
|
this._proxy.GetRegistrationInfoRemote(Lang.bind(this, function(result, err) {
|
||||||
if (err) {
|
if (err) {
|
||||||
log(err);
|
log(err);
|
||||||
return;
|
return;
|
||||||
@ -150,19 +146,21 @@ const ModemGsm = new Lang.Class({
|
|||||||
|
|
||||||
return name3 || name2 || null;
|
return name3 || name2 || null;
|
||||||
}
|
}
|
||||||
});
|
}
|
||||||
Signals.addSignalMethods(ModemGsm.prototype);
|
Signals.addSignalMethods(ModemGsm.prototype);
|
||||||
|
|
||||||
const ModemCdma = new Lang.Class({
|
function ModemCdma() {
|
||||||
Name: 'ModemCdma',
|
this._init.apply(this, arguments);
|
||||||
|
}
|
||||||
|
|
||||||
|
ModemCdma.prototype = {
|
||||||
_init: function(path) {
|
_init: function(path) {
|
||||||
this._proxy = new ModemCdmaProxy(Gio.DBus.system, 'org.freedesktop.ModemManager', path);
|
this._proxy = new ModemCdmaProxy(DBus.system, 'org.freedesktop.ModemManager', path);
|
||||||
|
|
||||||
this.signal_quality = 0;
|
this.signal_quality = 0;
|
||||||
this.operator_name = null;
|
this.operator_name = null;
|
||||||
this._proxy.connectSignal('SignalQuality', Lang.bind(this, function(proxy, sender, params) {
|
this._proxy.connect('SignalQuality', Lang.bind(this, function(proxy, quality) {
|
||||||
this.signal_quality = params[0];
|
this.signal_quality = quality;
|
||||||
this.emit('notify::signal-quality');
|
this.emit('notify::signal-quality');
|
||||||
|
|
||||||
// receiving this signal means the device got activated
|
// receiving this signal means the device got activated
|
||||||
@ -183,7 +181,7 @@ const ModemCdma = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_refreshServingSystem: function() {
|
_refreshServingSystem: function() {
|
||||||
this._proxy.GetServingSystemRemote(Lang.bind(this, function([result], err) {
|
this._proxy.GetServingSystemRemote(Lang.bind(this, function(result, err) {
|
||||||
if (err) {
|
if (err) {
|
||||||
// it will return an error if the device is not connected
|
// it will return an error if the device is not connected
|
||||||
this.operator_name = null;
|
this.operator_name = null;
|
||||||
@ -223,5 +221,5 @@ const ModemCdma = new Lang.Class({
|
|||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
Signals.addSignalMethods(ModemCdma.prototype);
|
Signals.addSignalMethods(ModemCdma.prototype);
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
|
||||||
|
|
||||||
// parse:
|
// parse:
|
||||||
// @params: caller-provided parameter object, or %null
|
// @params: caller-provided parameter object, or %null
|
||||||
|
121
js/misc/util.js
@ -1,35 +1,17 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
|
||||||
|
|
||||||
|
const Gdk = imports.gi.Gdk;
|
||||||
|
const Gio = imports.gi.Gio;
|
||||||
const GLib = imports.gi.GLib;
|
const GLib = imports.gi.GLib;
|
||||||
|
const Shell = imports.gi.Shell;
|
||||||
|
|
||||||
const Main = imports.ui.main;
|
const Main = imports.ui.main;
|
||||||
|
|
||||||
// http://daringfireball.net/2010/07/improved_regex_for_matching_urls
|
const Gettext = imports.gettext.domain('gnome-shell');
|
||||||
const _balancedParens = '\\((?:[^\\s()<>]+|(?:\\(?:[^\\s()<>]+\\)))*\\)';
|
const _ = Gettext.gettext;
|
||||||
const _leadingJunk = '[\\s`(\\[{\'\\"<\u00AB\u201C\u2018]';
|
|
||||||
const _notTrailingJunk = '[^\\s`!()\\[\\]{};:\'\\".,<>?\u00AB\u00BB\u201C\u201D\u2018\u2019]';
|
|
||||||
|
|
||||||
const _urlRegexp = new RegExp(
|
/* http://daringfireball.net/2010/07/improved_regex_for_matching_urls */
|
||||||
'(^|' + _leadingJunk + ')' +
|
const _urlRegexp = new RegExp('\\b(([a-z][\\w-]+:(/{1,3}|[a-z0-9%])|www\\d{0,3}[.]|[a-z0-9.\\-]+[.][a-z]{2,4}/)([^\\s()<>]+|\\(([^\\s()<>]+|(\\([^\\s()<>]+\\)))*\\))+(\\(([^\\s()<>]+|(\\([^\\s()<>]+\\)))*\\)|[^\\s`!()\\[\\]{};:\'\\".,<>?«»“”‘’]))', 'gi');
|
||||||
'(' +
|
|
||||||
'(?:' +
|
|
||||||
'[a-z][\\w-]+://' + // scheme://
|
|
||||||
'|' +
|
|
||||||
'www\\d{0,3}[.]' + // www.
|
|
||||||
'|' +
|
|
||||||
'[a-z0-9.\\-]+[.][a-z]{2,4}/' + // foo.xx/
|
|
||||||
')' +
|
|
||||||
'(?:' + // one or more:
|
|
||||||
'[^\\s()<>]+' + // run of non-space non-()
|
|
||||||
'|' + // or
|
|
||||||
_balancedParens + // balanced parens
|
|
||||||
')+' +
|
|
||||||
'(?:' + // end with:
|
|
||||||
_balancedParens + // balanced parens
|
|
||||||
'|' + // or
|
|
||||||
_notTrailingJunk + // last non-junk char
|
|
||||||
')' +
|
|
||||||
')', 'gi');
|
|
||||||
|
|
||||||
// findUrls:
|
// findUrls:
|
||||||
// @str: string to find URLs in
|
// @str: string to find URLs in
|
||||||
@ -42,7 +24,7 @@ const _urlRegexp = new RegExp(
|
|||||||
function findUrls(str) {
|
function findUrls(str) {
|
||||||
let res = [], match;
|
let res = [], match;
|
||||||
while ((match = _urlRegexp.exec(str)))
|
while ((match = _urlRegexp.exec(str)))
|
||||||
res.push({ url: match[2], pos: match.index + match[1].length });
|
res.push({ url: match[0], pos: match.index });
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -66,7 +48,7 @@ function spawn(argv) {
|
|||||||
// occur when trying to parse or start the program.
|
// occur when trying to parse or start the program.
|
||||||
function spawnCommandLine(command_line) {
|
function spawnCommandLine(command_line) {
|
||||||
try {
|
try {
|
||||||
let [success, argv] = GLib.shell_parse_argv(command_line);
|
let [success, argc, argv] = GLib.shell_parse_argv(command_line);
|
||||||
trySpawn(argv);
|
trySpawn(argv);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
_handleSpawnError(command_line, err);
|
_handleSpawnError(command_line, err);
|
||||||
@ -80,33 +62,24 @@ function spawnCommandLine(command_line) {
|
|||||||
// this will throw an error.
|
// this will throw an error.
|
||||||
function trySpawn(argv)
|
function trySpawn(argv)
|
||||||
{
|
{
|
||||||
var success, pid;
|
|
||||||
try {
|
try {
|
||||||
[success, pid] = GLib.spawn_async(null, argv, null,
|
GLib.spawn_async(null, argv, null,
|
||||||
GLib.SpawnFlags.SEARCH_PATH | GLib.SpawnFlags.DO_NOT_REAP_CHILD,
|
GLib.SpawnFlags.SEARCH_PATH,
|
||||||
null);
|
null, null);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
/* Rewrite the error in case of ENOENT */
|
if (err.code == GLib.SpawnError.G_SPAWN_ERROR_NOENT) {
|
||||||
if (err.matches(GLib.SpawnError, GLib.SpawnError.NOENT)) {
|
err.message = _("Command not found");
|
||||||
throw new GLib.SpawnError({ code: GLib.SpawnError.NOENT,
|
} else {
|
||||||
message: _("Command not found") });
|
|
||||||
} else if (err instanceof GLib.Error) {
|
|
||||||
// The exception from gjs contains an error string like:
|
// The exception from gjs contains an error string like:
|
||||||
// Error invoking GLib.spawn_command_line_async: Failed to
|
// Error invoking GLib.spawn_command_line_async: Failed to
|
||||||
// execute child process "foo" (No such file or directory)
|
// execute child process "foo" (No such file or directory)
|
||||||
// We are only interested in the part in the parentheses. (And
|
// We are only interested in the part in the parentheses. (And
|
||||||
// we can't pattern match the text, since it gets localized.)
|
// we can't pattern match the text, since it gets localized.)
|
||||||
let message = err.message.replace(/.*\((.+)\)/, '$1');
|
err.message = err.message.replace(/.*\((.+)\)/, '$1');
|
||||||
throw new (err.constructor)({ code: err.code,
|
|
||||||
message: message });
|
|
||||||
} else {
|
|
||||||
throw err;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
throw err;
|
||||||
}
|
}
|
||||||
// Dummy child watch; we don't want to double-fork internally
|
|
||||||
// because then we lose the parent-child relationship, which
|
|
||||||
// can break polkit. See https://bugzilla.redhat.com//show_bug.cgi?id=819275
|
|
||||||
GLib.child_watch_add(GLib.PRIORITY_DEFAULT, pid, function () {}, null);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// trySpawnCommandLine:
|
// trySpawnCommandLine:
|
||||||
@ -115,10 +88,10 @@ function trySpawn(argv)
|
|||||||
// Runs @command_line in the background. If launching @command_line
|
// Runs @command_line in the background. If launching @command_line
|
||||||
// fails, this will throw an error.
|
// fails, this will throw an error.
|
||||||
function trySpawnCommandLine(command_line) {
|
function trySpawnCommandLine(command_line) {
|
||||||
let success, argv;
|
let success, argc, argv;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
[success, argv] = GLib.shell_parse_argv(command_line);
|
[success, argc, argv] = GLib.shell_parse_argv(command_line);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
// Replace "Error invoking GLib.shell_parse_argv: " with
|
// Replace "Error invoking GLib.shell_parse_argv: " with
|
||||||
// something nicer
|
// something nicer
|
||||||
@ -150,7 +123,7 @@ function killall(processName) {
|
|||||||
// whatever...
|
// whatever...
|
||||||
|
|
||||||
let argv = ['pkill', '-f', '^([^ ]*/)?' + processName + '($| )'];
|
let argv = ['pkill', '-f', '^([^ ]*/)?' + processName + '($| )'];
|
||||||
GLib.spawn_sync(null, argv, null, GLib.SpawnFlags.SEARCH_PATH, null);
|
GLib.spawn_sync(null, argv, null, GLib.SpawnFlags.SEARCH_PATH, null, null);
|
||||||
// It might be useful to return success/failure, but we'd need
|
// It might be useful to return success/failure, but we'd need
|
||||||
// a wrapper around WIFEXITED and WEXITSTATUS. Since none of
|
// a wrapper around WIFEXITED and WEXITSTATUS. Since none of
|
||||||
// the current callers care, we don't bother.
|
// the current callers care, we don't bother.
|
||||||
@ -238,53 +211,3 @@ function fixupPCIDescription(desc) {
|
|||||||
|
|
||||||
return out.join(' ');
|
return out.join(' ');
|
||||||
}
|
}
|
||||||
|
|
||||||
// lowerBound:
|
|
||||||
// @array: an array or array-like object, already sorted
|
|
||||||
// according to @cmp
|
|
||||||
// @val: the value to add
|
|
||||||
// @cmp: a comparator (or undefined to compare as numbers)
|
|
||||||
//
|
|
||||||
// Returns the position of the first element that is not
|
|
||||||
// lower than @val, according to @cmp.
|
|
||||||
// That is, returns the first position at which it
|
|
||||||
// is possible to insert @val without violating the
|
|
||||||
// order.
|
|
||||||
// This is quite like an ordinary binary search, except
|
|
||||||
// that it doesn't stop at first element comparing equal.
|
|
||||||
|
|
||||||
function lowerBound(array, val, cmp) {
|
|
||||||
let min, max, mid, v;
|
|
||||||
cmp = cmp || function(a, b) { return a - b; };
|
|
||||||
|
|
||||||
if (array.length == 0)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
min = 0; max = array.length;
|
|
||||||
while (min < (max - 1)) {
|
|
||||||
mid = Math.floor((min + max) / 2);
|
|
||||||
v = cmp(array[mid], val);
|
|
||||||
|
|
||||||
if (v < 0)
|
|
||||||
min = mid + 1;
|
|
||||||
else
|
|
||||||
max = mid;
|
|
||||||
}
|
|
||||||
|
|
||||||
return (min == max || cmp(array[min], val) < 0) ? max : min;
|
|
||||||
}
|
|
||||||
|
|
||||||
// insertSorted:
|
|
||||||
// @array: an array sorted according to @cmp
|
|
||||||
// @val: a value to insert
|
|
||||||
// @cmp: the sorting function
|
|
||||||
//
|
|
||||||
// Inserts @val into @array, preserving the
|
|
||||||
// sorting invariants.
|
|
||||||
// Returns the position at which it was inserted
|
|
||||||
function insertSorted(array, val, cmp) {
|
|
||||||
let pos = lowerBound(array, val, cmp);
|
|
||||||
array.splice(pos, 0, val);
|
|
||||||
|
|
||||||
return pos;
|
|
||||||
}
|
|
||||||
|
@ -1,6 +1,4 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
|
||||||
|
|
||||||
const System = imports.system;
|
|
||||||
|
|
||||||
const Main = imports.ui.main;
|
const Main = imports.ui.main;
|
||||||
const Scripting = imports.ui.scripting;
|
const Scripting = imports.ui.scripting;
|
||||||
@ -101,7 +99,7 @@ function run() {
|
|||||||
Main.overview.hide();
|
Main.overview.hide();
|
||||||
yield Scripting.waitLeisure();
|
yield Scripting.waitLeisure();
|
||||||
|
|
||||||
System.gc();
|
global.gc();
|
||||||
yield Scripting.sleep(1000);
|
yield Scripting.sleep(1000);
|
||||||
Scripting.collectStatistics();
|
Scripting.collectStatistics();
|
||||||
Scripting.scriptEvent('afterShowHide');
|
Scripting.scriptEvent('afterShowHide');
|
||||||
@ -115,10 +113,10 @@ function run() {
|
|||||||
|
|
||||||
for (let i = 0; i < 2; i++) {
|
for (let i = 0; i < 2; i++) {
|
||||||
Scripting.scriptEvent('applicationsShowStart');
|
Scripting.scriptEvent('applicationsShowStart');
|
||||||
Main.overview._dash.showAppsButton.checked = true;
|
Main.overview.viewSelector.switchTab('applications');
|
||||||
yield Scripting.waitLeisure();
|
yield Scripting.waitLeisure();
|
||||||
Scripting.scriptEvent('applicationsShowDone');
|
Scripting.scriptEvent('applicationsShowDone');
|
||||||
Main.overview._dash.showAppsButton.checked = false;
|
Main.overview.viewSelector.switchTab('windows');
|
||||||
yield Scripting.waitLeisure();
|
yield Scripting.waitLeisure();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
391
js/ui/altTab.js
@ -1,23 +1,20 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
|
||||||
|
|
||||||
const Clutter = imports.gi.Clutter;
|
const Clutter = imports.gi.Clutter;
|
||||||
const Gdk = imports.gi.Gdk;
|
const Gdk = imports.gi.Gdk;
|
||||||
const Gtk = imports.gi.Gtk;
|
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
const Mainloop = imports.mainloop;
|
const Mainloop = imports.mainloop;
|
||||||
const Meta = imports.gi.Meta;
|
const Meta = imports.gi.Meta;
|
||||||
const Shell = imports.gi.Shell;
|
const Shell = imports.gi.Shell;
|
||||||
const Signals = imports.signals;
|
const Signals = imports.signals;
|
||||||
const St = imports.gi.St;
|
const St = imports.gi.St;
|
||||||
const Atk = imports.gi.Atk;
|
|
||||||
|
|
||||||
const Main = imports.ui.main;
|
const Main = imports.ui.main;
|
||||||
const Tweener = imports.ui.tweener;
|
const Tweener = imports.ui.tweener;
|
||||||
|
|
||||||
const POPUP_APPICON_SIZE = 96;
|
const POPUP_APPICON_SIZE = 96;
|
||||||
const POPUP_SCROLL_TIME = 0.10; // seconds
|
const POPUP_SCROLL_TIME = 0.10; // seconds
|
||||||
const POPUP_DELAY_TIMEOUT = 150; // milliseconds
|
const POPUP_FADE_TIME = 0.1; // seconds
|
||||||
const POPUP_FADE_OUT_TIME = 0.1; // seconds
|
|
||||||
|
|
||||||
const APP_ICON_HOVER_TIMEOUT = 200; // milliseconds
|
const APP_ICON_HOVER_TIMEOUT = 200; // milliseconds
|
||||||
|
|
||||||
@ -33,21 +30,11 @@ function mod(a, b) {
|
|||||||
return (a + b) % b;
|
return (a + b) % b;
|
||||||
}
|
}
|
||||||
|
|
||||||
function primaryModifier(mask) {
|
function AltTabPopup() {
|
||||||
if (mask == 0)
|
this._init();
|
||||||
return 0;
|
|
||||||
|
|
||||||
let primary = 1;
|
|
||||||
while (mask > 1) {
|
|
||||||
mask >>= 1;
|
|
||||||
primary <<= 1;
|
|
||||||
}
|
|
||||||
return primary;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const AltTabPopup = new Lang.Class({
|
AltTabPopup.prototype = {
|
||||||
Name: 'AltTabPopup',
|
|
||||||
|
|
||||||
_init : function() {
|
_init : function() {
|
||||||
this.actor = new Shell.GenericContainer({ name: 'altTabPopup',
|
this.actor = new Shell.GenericContainer({ name: 'altTabPopup',
|
||||||
reactive: true,
|
reactive: true,
|
||||||
@ -60,13 +47,11 @@ const AltTabPopup = new Lang.Class({
|
|||||||
this.actor.connect('destroy', Lang.bind(this, this._onDestroy));
|
this.actor.connect('destroy', Lang.bind(this, this._onDestroy));
|
||||||
|
|
||||||
this._haveModal = false;
|
this._haveModal = false;
|
||||||
this._modifierMask = 0;
|
|
||||||
|
|
||||||
this._currentApp = 0;
|
this._currentApp = 0;
|
||||||
this._currentWindow = -1;
|
this._currentWindow = -1;
|
||||||
this._thumbnailTimeoutId = 0;
|
this._thumbnailTimeoutId = 0;
|
||||||
this._motionTimeoutId = 0;
|
this._motionTimeoutId = 0;
|
||||||
this._initialDelayTimeoutId = 0;
|
|
||||||
|
|
||||||
this.thumbnailsVisible = false;
|
this.thumbnailsVisible = false;
|
||||||
|
|
||||||
@ -89,7 +74,7 @@ const AltTabPopup = new Lang.Class({
|
|||||||
|
|
||||||
_allocate: function (actor, box, flags) {
|
_allocate: function (actor, box, flags) {
|
||||||
let childBox = new Clutter.ActorBox();
|
let childBox = new Clutter.ActorBox();
|
||||||
let primary = Main.layoutManager.primaryMonitor;
|
let primary = global.get_primary_monitor();
|
||||||
|
|
||||||
let leftPadding = this.actor.get_theme_node().get_padding(St.Side.LEFT);
|
let leftPadding = this.actor.get_theme_node().get_padding(St.Side.LEFT);
|
||||||
let rightPadding = this.actor.get_theme_node().get_padding(St.Side.RIGHT);
|
let rightPadding = this.actor.get_theme_node().get_padding(St.Side.RIGHT);
|
||||||
@ -102,7 +87,7 @@ const AltTabPopup = new Lang.Class({
|
|||||||
let [childMinHeight, childNaturalHeight] = this._appSwitcher.actor.get_preferred_height(primary.width - hPadding);
|
let [childMinHeight, childNaturalHeight] = this._appSwitcher.actor.get_preferred_height(primary.width - hPadding);
|
||||||
let [childMinWidth, childNaturalWidth] = this._appSwitcher.actor.get_preferred_width(childNaturalHeight);
|
let [childMinWidth, childNaturalWidth] = this._appSwitcher.actor.get_preferred_width(childNaturalHeight);
|
||||||
childBox.x1 = Math.max(primary.x + leftPadding, primary.x + Math.floor((primary.width - childNaturalWidth) / 2));
|
childBox.x1 = Math.max(primary.x + leftPadding, primary.x + Math.floor((primary.width - childNaturalWidth) / 2));
|
||||||
childBox.x2 = Math.min(primary.x + primary.width - rightPadding, childBox.x1 + childNaturalWidth);
|
childBox.x2 = Math.min(primary.x + primary.width - hPadding, childBox.x1 + childNaturalWidth);
|
||||||
childBox.y1 = primary.y + Math.floor((primary.height - childNaturalHeight) / 2);
|
childBox.y1 = primary.y + Math.floor((primary.height - childNaturalHeight) / 2);
|
||||||
childBox.y2 = childBox.y1 + childNaturalHeight;
|
childBox.y2 = childBox.y1 + childNaturalHeight;
|
||||||
this._appSwitcher.actor.allocate(childBox, flags);
|
this._appSwitcher.actor.allocate(childBox, flags);
|
||||||
@ -112,6 +97,8 @@ const AltTabPopup = new Lang.Class({
|
|||||||
// those calculations
|
// those calculations
|
||||||
if (this._thumbnails) {
|
if (this._thumbnails) {
|
||||||
let icon = this._appIcons[this._currentApp].actor;
|
let icon = this._appIcons[this._currentApp].actor;
|
||||||
|
// Force a stage relayout to make sure we get the correct position
|
||||||
|
global.stage.get_actor_at_pos(Clutter.PickMode.REACTIVE, 0, 0);
|
||||||
let [posX, posY] = icon.get_transformed_position();
|
let [posX, posY] = icon.get_transformed_position();
|
||||||
let thumbnailCenter = posX + icon.width / 2;
|
let thumbnailCenter = posX + icon.width / 2;
|
||||||
let [childMinWidth, childNaturalWidth] = this._thumbnails.actor.get_preferred_width(-1);
|
let [childMinWidth, childNaturalWidth] = this._thumbnails.actor.get_preferred_width(-1);
|
||||||
@ -127,57 +114,23 @@ const AltTabPopup = new Lang.Class({
|
|||||||
if (childBox.x2 > primary.x + primary.width - rightPadding)
|
if (childBox.x2 > primary.x + primary.width - rightPadding)
|
||||||
childBox.x2 = primary.x + primary.width - rightPadding;
|
childBox.x2 = primary.x + primary.width - rightPadding;
|
||||||
childBox.y1 = this._appSwitcher.actor.allocation.y2 + spacing;
|
childBox.y1 = this._appSwitcher.actor.allocation.y2 + spacing;
|
||||||
this._thumbnails.addClones(primary.y + primary.height - bottomPadding - childBox.y1);
|
this._thumbnails.addClones(primary.height - bottomPadding - childBox.y1);
|
||||||
let [childMinHeight, childNaturalHeight] = this._thumbnails.actor.get_preferred_height(-1);
|
let [childMinHeight, childNaturalHeight] = this._thumbnails.actor.get_preferred_height(-1);
|
||||||
childBox.y2 = childBox.y1 + childNaturalHeight;
|
childBox.y2 = childBox.y1 + childNaturalHeight;
|
||||||
this._thumbnails.actor.allocate(childBox, flags);
|
this._thumbnails.actor.allocate(childBox, flags);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_getAppLists: function() {
|
show : function(backward, switch_group) {
|
||||||
let tracker = Shell.WindowTracker.get_default();
|
let tracker = Shell.WindowTracker.get_default();
|
||||||
let appSys = Shell.AppSystem.get_default();
|
let apps = tracker.get_running_apps ('');
|
||||||
let allApps = appSys.get_running ();
|
|
||||||
|
|
||||||
let screen = global.screen;
|
if (!apps.length)
|
||||||
let display = screen.get_display();
|
|
||||||
let windows = display.get_tab_list(Meta.TabList.NORMAL_ALL, screen,
|
|
||||||
screen.get_active_workspace());
|
|
||||||
|
|
||||||
// windows is only the windows on the current workspace. For
|
|
||||||
// each one, if it corresponds to an app we know, move that
|
|
||||||
// app from allApps to apps.
|
|
||||||
let apps = [];
|
|
||||||
for (let i = 0; i < windows.length && allApps.length != 0; i++) {
|
|
||||||
let app = tracker.get_window_app(windows[i]);
|
|
||||||
let index = allApps.indexOf(app);
|
|
||||||
if (index != -1) {
|
|
||||||
apps.push(app);
|
|
||||||
allApps.splice(index, 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Now @apps is a list of apps on the current workspace, in
|
|
||||||
// standard Alt+Tab order (MRU except for minimized windows),
|
|
||||||
// and allApps is a list of apps that only appear on other
|
|
||||||
// workspaces, sorted by user_time, which is good enough.
|
|
||||||
return [apps, allApps];
|
|
||||||
},
|
|
||||||
|
|
||||||
show : function(backward, binding, mask) {
|
|
||||||
let [localApps, otherApps] = this._getAppLists();
|
|
||||||
|
|
||||||
if (localApps.length == 0 && otherApps.length == 0)
|
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (!Main.pushModal(this.actor)) {
|
if (!Main.pushModal(this.actor))
|
||||||
// Probably someone else has a pointer grab, try again with keyboard only
|
return false;
|
||||||
if (!Main.pushModal(this.actor, global.get_current_time(), Meta.ModalOptions.POINTER_ALREADY_GRABBED)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
this._haveModal = true;
|
this._haveModal = true;
|
||||||
this._modifierMask = primaryModifier(mask);
|
|
||||||
|
|
||||||
this.actor.connect('key-press-event', Lang.bind(this, this._keyPressEvent));
|
this.actor.connect('key-press-event', Lang.bind(this, this._keyPressEvent));
|
||||||
this.actor.connect('key-release-event', Lang.bind(this, this._keyReleaseEvent));
|
this.actor.connect('key-release-event', Lang.bind(this, this._keyReleaseEvent));
|
||||||
@ -185,21 +138,15 @@ const AltTabPopup = new Lang.Class({
|
|||||||
this.actor.connect('button-press-event', Lang.bind(this, this._clickedOutside));
|
this.actor.connect('button-press-event', Lang.bind(this, this._clickedOutside));
|
||||||
this.actor.connect('scroll-event', Lang.bind(this, this._onScroll));
|
this.actor.connect('scroll-event', Lang.bind(this, this._onScroll));
|
||||||
|
|
||||||
this._appSwitcher = new AppSwitcher(localApps, otherApps, this);
|
this._appSwitcher = new AppSwitcher(apps, this);
|
||||||
this.actor.add_actor(this._appSwitcher.actor);
|
this.actor.add_actor(this._appSwitcher.actor);
|
||||||
this._appSwitcher.connect('item-activated', Lang.bind(this, this._appActivated));
|
this._appSwitcher.connect('item-activated', Lang.bind(this, this._appActivated));
|
||||||
this._appSwitcher.connect('item-entered', Lang.bind(this, this._appEntered));
|
this._appSwitcher.connect('item-entered', Lang.bind(this, this._appEntered));
|
||||||
|
|
||||||
this._appIcons = this._appSwitcher.icons;
|
this._appIcons = this._appSwitcher.icons;
|
||||||
|
|
||||||
// Need to force an allocation so we can figure out whether we
|
|
||||||
// need to scroll when selecting
|
|
||||||
this.actor.opacity = 0;
|
|
||||||
this.actor.show();
|
|
||||||
this.actor.get_allocation_box();
|
|
||||||
|
|
||||||
// Make the initial selection
|
// Make the initial selection
|
||||||
if (binding == 'switch-group') {
|
if (switch_group) {
|
||||||
if (backward) {
|
if (backward) {
|
||||||
this._select(0, this._appIcons[0].cachedWindows.length - 1);
|
this._select(0, this._appIcons[0].cachedWindows.length - 1);
|
||||||
} else {
|
} else {
|
||||||
@ -208,10 +155,6 @@ const AltTabPopup = new Lang.Class({
|
|||||||
else
|
else
|
||||||
this._select(0, 0);
|
this._select(0, 0);
|
||||||
}
|
}
|
||||||
} else if (binding == 'switch-group-backward') {
|
|
||||||
this._select(0, this._appIcons[0].cachedWindows.length - 1);
|
|
||||||
} else if (binding == 'switch-windows-backward') {
|
|
||||||
this._select(this._appIcons.length - 1);
|
|
||||||
} else if (this._appIcons.length == 1) {
|
} else if (this._appIcons.length == 1) {
|
||||||
this._select(0);
|
this._select(0);
|
||||||
} else if (backward) {
|
} else if (backward) {
|
||||||
@ -226,18 +169,18 @@ const AltTabPopup = new Lang.Class({
|
|||||||
// details.) So we check now. (Have to do this after updating
|
// details.) So we check now. (Have to do this after updating
|
||||||
// selection.)
|
// selection.)
|
||||||
let [x, y, mods] = global.get_pointer();
|
let [x, y, mods] = global.get_pointer();
|
||||||
if (!(mods & this._modifierMask)) {
|
if (!(mods & Gdk.ModifierType.MOD1_MASK)) {
|
||||||
this._finish();
|
this._finish();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// We delay showing the popup so that fast Alt+Tab users aren't
|
this.actor.opacity = 0;
|
||||||
// disturbed by the popup briefly flashing.
|
this.actor.show();
|
||||||
this._initialDelayTimeoutId = Mainloop.timeout_add(POPUP_DELAY_TIMEOUT,
|
Tweener.addTween(this.actor,
|
||||||
Lang.bind(this, function () {
|
{ opacity: 255,
|
||||||
this.actor.opacity = 255;
|
time: POPUP_FADE_TIME,
|
||||||
this._initialDelayTimeoutId = 0;
|
transition: 'easeOutQuad'
|
||||||
}));
|
});
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
},
|
},
|
||||||
@ -266,31 +209,39 @@ const AltTabPopup = new Lang.Class({
|
|||||||
|
|
||||||
_keyPressEvent : function(actor, event) {
|
_keyPressEvent : function(actor, event) {
|
||||||
let keysym = event.get_key_symbol();
|
let keysym = event.get_key_symbol();
|
||||||
let event_state = event.get_state();
|
let event_state = Shell.get_event_state(event);
|
||||||
let backwards = event_state & Clutter.ModifierType.SHIFT_MASK;
|
let backwards = event_state & Clutter.ModifierType.SHIFT_MASK;
|
||||||
let action = global.display.get_keybinding_action(event.get_key_code(), event_state);
|
let action = global.screen.get_display().get_keybinding_action(event.get_key_code(), event_state);
|
||||||
|
|
||||||
this._disableHover();
|
this._disableHover();
|
||||||
|
|
||||||
if (keysym == Clutter.Escape) {
|
if (action == Meta.KeyBindingAction.SWITCH_GROUP)
|
||||||
this.destroy();
|
|
||||||
} else if (action == Meta.KeyBindingAction.SWITCH_GROUP) {
|
|
||||||
this._select(this._currentApp, backwards ? this._previousWindow() : this._nextWindow());
|
this._select(this._currentApp, backwards ? this._previousWindow() : this._nextWindow());
|
||||||
} else if (action == Meta.KeyBindingAction.SWITCH_GROUP_BACKWARD) {
|
else if (keysym == Clutter.Escape)
|
||||||
this._select(this._currentApp, this._previousWindow());
|
this.destroy();
|
||||||
} else if (action == Meta.KeyBindingAction.SWITCH_WINDOWS) {
|
else if (this._thumbnailsFocused) {
|
||||||
this._select(backwards ? this._previousApp() : this._nextApp());
|
if (action == Meta.KeyBindingAction.SWITCH_WINDOWS)
|
||||||
} else if (action == Meta.KeyBindingAction.SWITCH_WINDOWS_BACKWARD) {
|
if (backwards) {
|
||||||
this._select(this._previousApp());
|
if (this._currentWindow == 0 || this._currentWindow == -1)
|
||||||
} else if (this._thumbnailsFocused) {
|
this._select(this._previousApp());
|
||||||
if (keysym == Clutter.Left)
|
else
|
||||||
|
this._select(this._currentApp, this._previousWindow());
|
||||||
|
} else {
|
||||||
|
if (this._currentWindow == this._appIcons[this._currentApp].cachedWindows.length - 1)
|
||||||
|
this._select(this._nextApp());
|
||||||
|
else
|
||||||
|
this._select(this._currentApp, this._nextWindow());
|
||||||
|
}
|
||||||
|
else if (keysym == Clutter.Left)
|
||||||
this._select(this._currentApp, this._previousWindow());
|
this._select(this._currentApp, this._previousWindow());
|
||||||
else if (keysym == Clutter.Right)
|
else if (keysym == Clutter.Right)
|
||||||
this._select(this._currentApp, this._nextWindow());
|
this._select(this._currentApp, this._nextWindow());
|
||||||
else if (keysym == Clutter.Up)
|
else if (keysym == Clutter.Up)
|
||||||
this._select(this._currentApp, null, true);
|
this._select(this._currentApp, null, true);
|
||||||
} else {
|
} else {
|
||||||
if (keysym == Clutter.Left)
|
if (action == Meta.KeyBindingAction.SWITCH_WINDOWS)
|
||||||
|
this._select(backwards ? this._previousApp() : this._nextApp());
|
||||||
|
else if (keysym == Clutter.Left)
|
||||||
this._select(this._previousApp());
|
this._select(this._previousApp());
|
||||||
else if (keysym == Clutter.Right)
|
else if (keysym == Clutter.Right)
|
||||||
this._select(this._nextApp());
|
this._select(this._nextApp());
|
||||||
@ -303,7 +254,7 @@ const AltTabPopup = new Lang.Class({
|
|||||||
|
|
||||||
_keyReleaseEvent : function(actor, event) {
|
_keyReleaseEvent : function(actor, event) {
|
||||||
let [x, y, mods] = global.get_pointer();
|
let [x, y, mods] = global.get_pointer();
|
||||||
let state = mods & this._modifierMask;
|
let state = mods & Clutter.ModifierType.MOD1_MASK;
|
||||||
|
|
||||||
if (state == 0)
|
if (state == 0)
|
||||||
this._finish();
|
this._finish();
|
||||||
@ -419,7 +370,7 @@ const AltTabPopup = new Lang.Class({
|
|||||||
if (this.actor.visible) {
|
if (this.actor.visible) {
|
||||||
Tweener.addTween(this.actor,
|
Tweener.addTween(this.actor,
|
||||||
{ opacity: 0,
|
{ opacity: 0,
|
||||||
time: POPUP_FADE_OUT_TIME,
|
time: POPUP_FADE_TIME,
|
||||||
transition: 'easeOutQuad',
|
transition: 'easeOutQuad',
|
||||||
onComplete: Lang.bind(this,
|
onComplete: Lang.bind(this,
|
||||||
function() {
|
function() {
|
||||||
@ -440,8 +391,6 @@ const AltTabPopup = new Lang.Class({
|
|||||||
Mainloop.source_remove(this._motionTimeoutId);
|
Mainloop.source_remove(this._motionTimeoutId);
|
||||||
if (this._thumbnailTimeoutId != 0)
|
if (this._thumbnailTimeoutId != 0)
|
||||||
Mainloop.source_remove(this._thumbnailTimeoutId);
|
Mainloop.source_remove(this._thumbnailTimeoutId);
|
||||||
if (this._initialDelayTimeoutId != 0)
|
|
||||||
Mainloop.source_remove(this._initialDelayTimeoutId);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -519,7 +468,6 @@ const AltTabPopup = new Lang.Class({
|
|||||||
})
|
})
|
||||||
});
|
});
|
||||||
this._thumbnails = null;
|
this._thumbnails = null;
|
||||||
this._appSwitcher._items[this._currentApp].remove_accessible_state (Atk.StateType.EXPANDED);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_createThumbnails : function() {
|
_createThumbnails : function() {
|
||||||
@ -529,10 +477,6 @@ const AltTabPopup = new Lang.Class({
|
|||||||
|
|
||||||
this.actor.add_actor(this._thumbnails.actor);
|
this.actor.add_actor(this._thumbnails.actor);
|
||||||
|
|
||||||
// Need to force an allocation so we can figure out whether we
|
|
||||||
// need to scroll when selecting
|
|
||||||
this._thumbnails.actor.get_allocation_box();
|
|
||||||
|
|
||||||
this._thumbnails.actor.opacity = 0;
|
this._thumbnails.actor.opacity = 0;
|
||||||
Tweener.addTween(this._thumbnails.actor,
|
Tweener.addTween(this._thumbnails.actor,
|
||||||
{ opacity: 255,
|
{ opacity: 255,
|
||||||
@ -540,14 +484,14 @@ const AltTabPopup = new Lang.Class({
|
|||||||
transition: 'easeOutQuad',
|
transition: 'easeOutQuad',
|
||||||
onComplete: Lang.bind(this, function () { this.thumbnailsVisible = true; })
|
onComplete: Lang.bind(this, function () { this.thumbnailsVisible = true; })
|
||||||
});
|
});
|
||||||
|
|
||||||
this._appSwitcher._items[this._currentApp].add_accessible_state (Atk.StateType.EXPANDED);
|
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
|
||||||
const SwitcherList = new Lang.Class({
|
function SwitcherList(squareItems) {
|
||||||
Name: 'SwitcherList',
|
this._init(squareItems);
|
||||||
|
}
|
||||||
|
|
||||||
|
SwitcherList.prototype = {
|
||||||
_init : function(squareItems) {
|
_init : function(squareItems) {
|
||||||
this.actor = new Shell.GenericContainer({ style_class: 'switcher-list' });
|
this.actor = new Shell.GenericContainer({ style_class: 'switcher-list' });
|
||||||
this.actor.connect('get-preferred-width', Lang.bind(this, this._getPreferredWidth));
|
this.actor.connect('get-preferred-width', Lang.bind(this, this._getPreferredWidth));
|
||||||
@ -566,14 +510,14 @@ const SwitcherList = new Lang.Class({
|
|||||||
this._list.connect('get-preferred-height', Lang.bind(this, this._getPreferredHeight));
|
this._list.connect('get-preferred-height', Lang.bind(this, this._getPreferredHeight));
|
||||||
this._list.connect('allocate', Lang.bind(this, this._allocate));
|
this._list.connect('allocate', Lang.bind(this, this._allocate));
|
||||||
|
|
||||||
this._scrollView = new St.ScrollView({ style_class: 'hfade',
|
this._clipBin = new St.Bin({style_class: 'cbin'});
|
||||||
enable_mouse_scrolling: false });
|
this._clipBin.child = this._list;
|
||||||
this._scrollView.set_policy(Gtk.PolicyType.NEVER, Gtk.PolicyType.NEVER);
|
this.actor.add_actor(this._clipBin);
|
||||||
|
|
||||||
let scrollBox = new St.BoxLayout();
|
this._leftGradient = new St.BoxLayout({style_class: 'thumbnail-scroll-gradient-left', vertical: true});
|
||||||
scrollBox.add_actor(this._list);
|
this._rightGradient = new St.BoxLayout({style_class: 'thumbnail-scroll-gradient-right', vertical: true});
|
||||||
this._scrollView.add_actor(scrollBox);
|
this.actor.add_actor(this._leftGradient);
|
||||||
this.actor.add_actor(this._scrollView);
|
this.actor.add_actor(this._rightGradient);
|
||||||
|
|
||||||
// Those arrows indicate whether scrolling in one direction is possible
|
// Those arrows indicate whether scrolling in one direction is possible
|
||||||
this._leftArrow = new St.DrawingArea({ style_class: 'switcher-arrow',
|
this._leftArrow = new St.DrawingArea({ style_class: 'switcher-arrow',
|
||||||
@ -604,9 +548,21 @@ const SwitcherList = new Lang.Class({
|
|||||||
let childBox = new Clutter.ActorBox();
|
let childBox = new Clutter.ActorBox();
|
||||||
let scrollable = this._minSize > box.x2 - box.x1;
|
let scrollable = this._minSize > box.x2 - box.x1;
|
||||||
|
|
||||||
box.y1 -= this.actor.get_theme_node().get_padding(St.Side.TOP);
|
this._clipBin.allocate(box, flags);
|
||||||
box.y2 += this.actor.get_theme_node().get_padding(St.Side.BOTTOM);
|
|
||||||
this._scrollView.allocate(box, flags);
|
childBox.x1 = 0;
|
||||||
|
childBox.y1 = 0;
|
||||||
|
childBox.x2 = this._leftGradient.width;
|
||||||
|
childBox.y2 = this.actor.height;
|
||||||
|
this._leftGradient.allocate(childBox, flags);
|
||||||
|
this._leftGradient.opacity = (this._scrollableLeft && scrollable) ? 255 : 0;
|
||||||
|
|
||||||
|
childBox.x1 = (this.actor.allocation.x2 - this.actor.allocation.x1) - this._rightGradient.width;
|
||||||
|
childBox.y1 = 0;
|
||||||
|
childBox.x2 = childBox.x1 + this._rightGradient.width;
|
||||||
|
childBox.y2 = this.actor.height;
|
||||||
|
this._rightGradient.allocate(childBox, flags);
|
||||||
|
this._rightGradient.opacity = (this._scrollableRight && scrollable) ? 255 : 0;
|
||||||
|
|
||||||
let arrowWidth = Math.floor(leftPadding / 3);
|
let arrowWidth = Math.floor(leftPadding / 3);
|
||||||
let arrowHeight = arrowWidth * 2;
|
let arrowHeight = arrowWidth * 2;
|
||||||
@ -615,7 +571,7 @@ const SwitcherList = new Lang.Class({
|
|||||||
childBox.x2 = childBox.x1 + arrowWidth;
|
childBox.x2 = childBox.x1 + arrowWidth;
|
||||||
childBox.y2 = childBox.y1 + arrowHeight;
|
childBox.y2 = childBox.y1 + arrowHeight;
|
||||||
this._leftArrow.allocate(childBox, flags);
|
this._leftArrow.allocate(childBox, flags);
|
||||||
this._leftArrow.opacity = (this._scrollableLeft && scrollable) ? 255 : 0;
|
this._leftArrow.opacity = this._leftGradient.opacity;
|
||||||
|
|
||||||
arrowWidth = Math.floor(rightPadding / 3);
|
arrowWidth = Math.floor(rightPadding / 3);
|
||||||
arrowHeight = arrowWidth * 2;
|
arrowHeight = arrowWidth * 2;
|
||||||
@ -624,10 +580,10 @@ const SwitcherList = new Lang.Class({
|
|||||||
childBox.x2 = childBox.x1 + arrowWidth;
|
childBox.x2 = childBox.x1 + arrowWidth;
|
||||||
childBox.y2 = childBox.y1 + arrowHeight;
|
childBox.y2 = childBox.y1 + arrowHeight;
|
||||||
this._rightArrow.allocate(childBox, flags);
|
this._rightArrow.allocate(childBox, flags);
|
||||||
this._rightArrow.opacity = (this._scrollableRight && scrollable) ? 255 : 0;
|
this._rightArrow.opacity = this._rightGradient.opacity;
|
||||||
},
|
},
|
||||||
|
|
||||||
addItem : function(item, label) {
|
addItem : function(item) {
|
||||||
let bbox = new St.Button({ style_class: 'item-box',
|
let bbox = new St.Button({ style_class: 'item-box',
|
||||||
reactive: true });
|
reactive: true });
|
||||||
|
|
||||||
@ -638,11 +594,7 @@ const SwitcherList = new Lang.Class({
|
|||||||
bbox.connect('clicked', Lang.bind(this, function() { this._onItemClicked(n); }));
|
bbox.connect('clicked', Lang.bind(this, function() { this._onItemClicked(n); }));
|
||||||
bbox.connect('enter-event', Lang.bind(this, function() { this._onItemEnter(n); }));
|
bbox.connect('enter-event', Lang.bind(this, function() { this._onItemEnter(n); }));
|
||||||
|
|
||||||
bbox.label_actor = label;
|
|
||||||
|
|
||||||
this._items.push(bbox);
|
this._items.push(bbox);
|
||||||
|
|
||||||
return bbox;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_onItemClicked: function (index) {
|
_onItemClicked: function (index) {
|
||||||
@ -674,66 +626,48 @@ const SwitcherList = new Lang.Class({
|
|||||||
this._items[this._highlighted].add_style_pseudo_class('selected');
|
this._items[this._highlighted].add_style_pseudo_class('selected');
|
||||||
}
|
}
|
||||||
|
|
||||||
let adjustment = this._scrollView.hscroll.adjustment;
|
let monitor = global.get_primary_monitor();
|
||||||
let [value, lower, upper, stepIncrement, pageIncrement, pageSize] = adjustment.get_values();
|
let itemSize = this._items[index].allocation.x2 - this._items[index].allocation.x1;
|
||||||
let [absItemX, absItemY] = this._items[index].get_transformed_position();
|
let [posX, posY] = this._items[index].get_transformed_position();
|
||||||
let [result, posX, posY] = this.actor.transform_stage_point(absItemX, 0);
|
posX += this.actor.x;
|
||||||
let [containerWidth, containerHeight] = this.actor.get_transformed_size();
|
if (posX + itemSize > monitor.width + monitor.x)
|
||||||
if (posX + this._items[index].get_width() > containerWidth)
|
|
||||||
this._scrollToRight();
|
this._scrollToRight();
|
||||||
else if (this._items[index].allocation.x1 - value < 0)
|
else if (posX < 0)
|
||||||
this._scrollToLeft();
|
this._scrollToLeft();
|
||||||
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_scrollToLeft : function() {
|
_scrollToLeft : function() {
|
||||||
let adjustment = this._scrollView.hscroll.adjustment;
|
let x = this._items[this._highlighted].allocation.x1;
|
||||||
let [value, lower, upper, stepIncrement, pageIncrement, pageSize] = adjustment.get_values();
|
|
||||||
|
|
||||||
let item = this._items[this._highlighted];
|
|
||||||
|
|
||||||
if (item.allocation.x1 < value)
|
|
||||||
value = Math.min(0, item.allocation.x1);
|
|
||||||
else if (item.allocation.x2 > value + pageSize)
|
|
||||||
value = Math.max(upper, item.allocation.x2 - pageSize);
|
|
||||||
|
|
||||||
this._scrollableRight = true;
|
this._scrollableRight = true;
|
||||||
Tweener.addTween(adjustment,
|
Tweener.addTween(this._list, { anchor_x: x,
|
||||||
{ value: value,
|
time: POPUP_SCROLL_TIME,
|
||||||
time: POPUP_SCROLL_TIME,
|
transition: 'easeOutQuad',
|
||||||
transition: 'easeOutQuad',
|
onComplete: Lang.bind(this, function () {
|
||||||
onComplete: Lang.bind(this, function () {
|
if (this._highlighted == 0) {
|
||||||
if (this._highlighted == 0) {
|
this._scrollableLeft = false;
|
||||||
this._scrollableLeft = false;
|
this.actor.queue_relayout();
|
||||||
this.actor.queue_relayout();
|
}
|
||||||
}
|
})
|
||||||
})
|
});
|
||||||
});
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_scrollToRight : function() {
|
_scrollToRight : function() {
|
||||||
let adjustment = this._scrollView.hscroll.adjustment;
|
|
||||||
let [value, lower, upper, stepIncrement, pageIncrement, pageSize] = adjustment.get_values();
|
|
||||||
|
|
||||||
let item = this._items[this._highlighted];
|
|
||||||
|
|
||||||
if (item.allocation.x1 < value)
|
|
||||||
value = Math.max(0, item.allocation.x1);
|
|
||||||
else if (item.allocation.x2 > value + pageSize)
|
|
||||||
value = Math.min(upper, item.allocation.x2 - pageSize);
|
|
||||||
|
|
||||||
this._scrollableLeft = true;
|
this._scrollableLeft = true;
|
||||||
Tweener.addTween(adjustment,
|
let monitor = global.get_primary_monitor();
|
||||||
{ value: value,
|
let padding = this.actor.get_theme_node().get_horizontal_padding();
|
||||||
time: POPUP_SCROLL_TIME,
|
let parentPadding = this.actor.get_parent().get_theme_node().get_horizontal_padding();
|
||||||
transition: 'easeOutQuad',
|
let x = this._items[this._highlighted].allocation.x2 - monitor.width + padding + parentPadding;
|
||||||
onComplete: Lang.bind(this, function () {
|
Tweener.addTween(this._list, { anchor_x: x,
|
||||||
if (this._highlighted == this._items.length - 1) {
|
time: POPUP_SCROLL_TIME,
|
||||||
this._scrollableRight = false;
|
transition: 'easeOutQuad',
|
||||||
this.actor.queue_relayout();
|
onComplete: Lang.bind(this, function () {
|
||||||
}
|
if (this._highlighted == this._items.length - 1) {
|
||||||
})
|
this._scrollableRight = false;
|
||||||
});
|
this.actor.queue_relayout();
|
||||||
|
}
|
||||||
|
})
|
||||||
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
_itemActivated: function(n) {
|
_itemActivated: function(n) {
|
||||||
@ -817,8 +751,16 @@ const SwitcherList = new Lang.Class({
|
|||||||
let children = this._list.get_children();
|
let children = this._list.get_children();
|
||||||
let childBox = new Clutter.ActorBox();
|
let childBox = new Clutter.ActorBox();
|
||||||
|
|
||||||
let primary = Main.layoutManager.primaryMonitor;
|
let primary = global.get_primary_monitor();
|
||||||
let parentRightPadding = this.actor.get_parent().get_theme_node().get_padding(St.Side.RIGHT);
|
let parentRightPadding = this.actor.get_parent().get_theme_node().get_padding(St.Side.RIGHT);
|
||||||
|
if (this.actor.allocation.x2 == primary.x + primary.width - parentRightPadding) {
|
||||||
|
if (this._squareItems)
|
||||||
|
childWidth = childHeight;
|
||||||
|
else {
|
||||||
|
let [childMin, childNat] = children[0].get_preferred_width(childHeight);
|
||||||
|
childWidth = childMin;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
for (let i = 0; i < children.length; i++) {
|
for (let i = 0; i < children.length; i++) {
|
||||||
if (this._items.indexOf(children[i]) != -1) {
|
if (this._items.indexOf(children[i]) != -1) {
|
||||||
@ -844,14 +786,24 @@ const SwitcherList = new Lang.Class({
|
|||||||
// we don't allocate it.
|
// we don't allocate it.
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let leftPadding = this.actor.get_theme_node().get_padding(St.Side.LEFT);
|
||||||
|
let rightPadding = this.actor.get_theme_node().get_padding(St.Side.RIGHT);
|
||||||
|
let topPadding = this.actor.get_theme_node().get_padding(St.Side.TOP);
|
||||||
|
let bottomPadding = this.actor.get_theme_node().get_padding(St.Side.BOTTOM);
|
||||||
|
|
||||||
|
// Clip the area for scrolling
|
||||||
|
this._clipBin.set_clip(0, -topPadding, (this.actor.allocation.x2 - this.actor.allocation.x1) - leftPadding - rightPadding, this.actor.height + bottomPadding);
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
|
||||||
Signals.addSignalMethods(SwitcherList.prototype);
|
Signals.addSignalMethods(SwitcherList.prototype);
|
||||||
|
|
||||||
const AppIcon = new Lang.Class({
|
function AppIcon(app) {
|
||||||
Name: 'AppIcon',
|
this._init(app);
|
||||||
|
}
|
||||||
|
|
||||||
|
AppIcon.prototype = {
|
||||||
_init: function(app) {
|
_init: function(app) {
|
||||||
this.app = app;
|
this.app = app;
|
||||||
this.actor = new St.BoxLayout({ style_class: 'alt-tab-app',
|
this.actor = new St.BoxLayout({ style_class: 'alt-tab-app',
|
||||||
@ -869,32 +821,36 @@ const AppIcon = new Lang.Class({
|
|||||||
this._iconBin.set_size(size, size);
|
this._iconBin.set_size(size, size);
|
||||||
this._iconBin.child = this.icon;
|
this._iconBin.child = this.icon;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
|
||||||
const AppSwitcher = new Lang.Class({
|
function AppSwitcher(apps, altTabPopup) {
|
||||||
Name: 'AppSwitcher',
|
this._init(apps, altTabPopup);
|
||||||
Extends: SwitcherList,
|
}
|
||||||
|
|
||||||
_init : function(localApps, otherApps, altTabPopup) {
|
AppSwitcher.prototype = {
|
||||||
this.parent(true);
|
__proto__ : SwitcherList.prototype,
|
||||||
|
|
||||||
// Construct the AppIcons, add to the popup
|
_init : function(apps, altTabPopup) {
|
||||||
|
SwitcherList.prototype._init.call(this, true);
|
||||||
|
|
||||||
|
// Construct the AppIcons, sort by time, add to the popup
|
||||||
let activeWorkspace = global.screen.get_active_workspace();
|
let activeWorkspace = global.screen.get_active_workspace();
|
||||||
let workspaceIcons = [];
|
let workspaceIcons = [];
|
||||||
let otherIcons = [];
|
let otherIcons = [];
|
||||||
for (let i = 0; i < localApps.length; i++) {
|
for (let i = 0; i < apps.length; i++) {
|
||||||
let appIcon = new AppIcon(localApps[i]);
|
let appIcon = new AppIcon(apps[i]);
|
||||||
// Cache the window list now; we don't handle dynamic changes here,
|
// Cache the window list now; we don't handle dynamic changes here,
|
||||||
// and we don't want to be continually retrieving it
|
// and we don't want to be continually retrieving it
|
||||||
appIcon.cachedWindows = appIcon.app.get_windows();
|
appIcon.cachedWindows = appIcon.app.get_windows();
|
||||||
workspaceIcons.push(appIcon);
|
if (this._hasWindowsOnWorkspace(appIcon, activeWorkspace))
|
||||||
}
|
workspaceIcons.push(appIcon);
|
||||||
for (let i = 0; i < otherApps.length; i++) {
|
else
|
||||||
let appIcon = new AppIcon(otherApps[i]);
|
otherIcons.push(appIcon);
|
||||||
appIcon.cachedWindows = appIcon.app.get_windows();
|
|
||||||
otherIcons.push(appIcon);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
workspaceIcons.sort(Lang.bind(this, this._sortAppIcon));
|
||||||
|
otherIcons.sort(Lang.bind(this, this._sortAppIcon));
|
||||||
|
|
||||||
this.icons = [];
|
this.icons = [];
|
||||||
this._arrows = [];
|
this._arrows = [];
|
||||||
for (let i = 0; i < workspaceIcons.length; i++)
|
for (let i = 0; i < workspaceIcons.length; i++)
|
||||||
@ -925,7 +881,7 @@ const AppSwitcher = new Lang.Class({
|
|||||||
totalSpacing += this._separator.width + this._list.spacing;
|
totalSpacing += this._separator.width + this._list.spacing;
|
||||||
|
|
||||||
// We just assume the whole screen here due to weirdness happing with the passed width
|
// We just assume the whole screen here due to weirdness happing with the passed width
|
||||||
let primary = Main.layoutManager.primaryMonitor;
|
let primary = global.get_primary_monitor();
|
||||||
let parentPadding = this.actor.get_parent().get_theme_node().get_horizontal_padding();
|
let parentPadding = this.actor.get_parent().get_theme_node().get_horizontal_padding();
|
||||||
let availWidth = primary.width - parentPadding - this.actor.get_theme_node().get_horizontal_padding();
|
let availWidth = primary.width - parentPadding - this.actor.get_theme_node().get_horizontal_padding();
|
||||||
let height = 0;
|
let height = 0;
|
||||||
@ -955,7 +911,7 @@ const AppSwitcher = new Lang.Class({
|
|||||||
|
|
||||||
_allocate: function (actor, box, flags) {
|
_allocate: function (actor, box, flags) {
|
||||||
// Allocate the main list items
|
// Allocate the main list items
|
||||||
this.parent(actor, box, flags);
|
SwitcherList.prototype._allocate.call(this, actor, box, flags);
|
||||||
|
|
||||||
let arrowHeight = Math.floor(this.actor.get_theme_node().get_padding(St.Side.BOTTOM) / 3);
|
let arrowHeight = Math.floor(this.actor.get_theme_node().get_padding(St.Side.BOTTOM) / 3);
|
||||||
let arrowWidth = arrowHeight * 2;
|
let arrowWidth = arrowHeight * 2;
|
||||||
@ -1010,7 +966,7 @@ const AppSwitcher = new Lang.Class({
|
|||||||
this._arrows[this._curApp].remove_style_pseudo_class('highlighted');
|
this._arrows[this._curApp].remove_style_pseudo_class('highlighted');
|
||||||
}
|
}
|
||||||
|
|
||||||
this.parent(n, justOutline);
|
SwitcherList.prototype.highlight.call(this, n, justOutline);
|
||||||
this._curApp = n;
|
this._curApp = n;
|
||||||
|
|
||||||
if (this._curApp != -1) {
|
if (this._curApp != -1) {
|
||||||
@ -1023,7 +979,7 @@ const AppSwitcher = new Lang.Class({
|
|||||||
|
|
||||||
_addIcon : function(appIcon) {
|
_addIcon : function(appIcon) {
|
||||||
this.icons.push(appIcon);
|
this.icons.push(appIcon);
|
||||||
let item = this.addItem(appIcon.actor, appIcon.label);
|
this.addItem(appIcon.actor);
|
||||||
|
|
||||||
let n = this._arrows.length;
|
let n = this._arrows.length;
|
||||||
let arrow = new St.DrawingArea({ style_class: 'switcher-arrow' });
|
let arrow = new St.DrawingArea({ style_class: 'switcher-arrow' });
|
||||||
@ -1033,17 +989,31 @@ const AppSwitcher = new Lang.Class({
|
|||||||
|
|
||||||
if (appIcon.cachedWindows.length == 1)
|
if (appIcon.cachedWindows.length == 1)
|
||||||
arrow.hide();
|
arrow.hide();
|
||||||
else
|
},
|
||||||
item.add_accessible_state (Atk.StateType.EXPANDABLE);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
const ThumbnailList = new Lang.Class({
|
_hasWindowsOnWorkspace: function(appIcon, workspace) {
|
||||||
Name: 'ThumbnailList',
|
let windows = appIcon.cachedWindows;
|
||||||
Extends: SwitcherList,
|
for (let i = 0; i < windows.length; i++) {
|
||||||
|
if (windows[i].get_workspace() == workspace)
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
},
|
||||||
|
|
||||||
|
_sortAppIcon : function(appIcon1, appIcon2) {
|
||||||
|
return appIcon1.app.compare(appIcon2.app);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
function ThumbnailList(windows) {
|
||||||
|
this._init(windows);
|
||||||
|
}
|
||||||
|
|
||||||
|
ThumbnailList.prototype = {
|
||||||
|
__proto__ : SwitcherList.prototype,
|
||||||
|
|
||||||
_init : function(windows) {
|
_init : function(windows) {
|
||||||
this.parent(false);
|
SwitcherList.prototype._init.call(this);
|
||||||
|
|
||||||
let activeWorkspace = global.screen.get_active_workspace();
|
let activeWorkspace = global.screen.get_active_workspace();
|
||||||
|
|
||||||
@ -1079,12 +1049,9 @@ const ThumbnailList = new Lang.Class({
|
|||||||
this._labels.push(bin);
|
this._labels.push(bin);
|
||||||
bin.add_actor(name);
|
bin.add_actor(name);
|
||||||
box.add_actor(bin);
|
box.add_actor(bin);
|
||||||
|
|
||||||
this.addItem(box, name);
|
|
||||||
} else {
|
|
||||||
this.addItem(box, null);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.addItem(box);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -1121,7 +1088,7 @@ const ThumbnailList = new Lang.Class({
|
|||||||
// Make sure we only do this once
|
// Make sure we only do this once
|
||||||
this._thumbnailBins = new Array();
|
this._thumbnailBins = new Array();
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
|
||||||
function _drawArrow(area, side) {
|
function _drawArrow(area, side) {
|
||||||
let themeNode = area.get_theme_node();
|
let themeNode = area.get_theme_node();
|
||||||
|
@ -1,16 +1,16 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
|
||||||
|
|
||||||
const Clutter = imports.gi.Clutter;
|
const Clutter = imports.gi.Clutter;
|
||||||
const GLib = imports.gi.GLib;
|
const GLib = imports.gi.GLib;
|
||||||
const Gtk = imports.gi.Gtk;
|
const Gtk = imports.gi.Gtk;
|
||||||
const GMenu = imports.gi.GMenu;
|
|
||||||
const Shell = imports.gi.Shell;
|
const Shell = imports.gi.Shell;
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
const Signals = imports.signals;
|
const Signals = imports.signals;
|
||||||
const Meta = imports.gi.Meta;
|
const Meta = imports.gi.Meta;
|
||||||
const St = imports.gi.St;
|
const St = imports.gi.St;
|
||||||
const Mainloop = imports.mainloop;
|
const Mainloop = imports.mainloop;
|
||||||
const Atk = imports.gi.Atk;
|
const Gettext = imports.gettext.domain('gnome-shell');
|
||||||
|
const _ = Gettext.gettext;
|
||||||
|
|
||||||
const AppFavorites = imports.ui.appFavorites;
|
const AppFavorites = imports.ui.appFavorites;
|
||||||
const DND = imports.ui.dnd;
|
const DND = imports.ui.dnd;
|
||||||
@ -22,22 +22,23 @@ const Search = imports.ui.search;
|
|||||||
const Tweener = imports.ui.tweener;
|
const Tweener = imports.ui.tweener;
|
||||||
const Workspace = imports.ui.workspace;
|
const Workspace = imports.ui.workspace;
|
||||||
const Params = imports.misc.params;
|
const Params = imports.misc.params;
|
||||||
const Util = imports.misc.util;
|
|
||||||
|
|
||||||
const MAX_APPLICATION_WORK_MILLIS = 75;
|
const MAX_APPLICATION_WORK_MILLIS = 75;
|
||||||
const MENU_POPUP_TIMEOUT = 600;
|
const MENU_POPUP_TIMEOUT = 600;
|
||||||
const SCROLL_TIME = 0.1;
|
const SCROLL_TIME = 0.1;
|
||||||
|
|
||||||
const AlphabeticalView = new Lang.Class({
|
function AlphabeticalView() {
|
||||||
Name: 'AlphabeticalView',
|
this._init();
|
||||||
|
}
|
||||||
|
|
||||||
|
AlphabeticalView.prototype = {
|
||||||
_init: function() {
|
_init: function() {
|
||||||
this._grid = new IconGrid.IconGrid({ xAlign: St.Align.START });
|
this._grid = new IconGrid.IconGrid({ xAlign: St.Align.START });
|
||||||
this._appSystem = Shell.AppSystem.get_default();
|
this._appSystem = Shell.AppSystem.get_default();
|
||||||
|
|
||||||
this._pendingAppLaterId = 0;
|
this._pendingAppLaterId = 0;
|
||||||
this._appIcons = {}; // desktop file id
|
this._apps = [];
|
||||||
this._allApps = [];
|
this._filterApp = null;
|
||||||
|
|
||||||
let box = new St.BoxLayout({ vertical: true });
|
let box = new St.BoxLayout({ vertical: true });
|
||||||
box.add(this._grid.actor, { y_align: St.Align.START, expand: true });
|
box.add(this._grid.actor, { y_align: St.Align.START, expand: true });
|
||||||
@ -45,7 +46,7 @@ const AlphabeticalView = new Lang.Class({
|
|||||||
this.actor = new St.ScrollView({ x_fill: true,
|
this.actor = new St.ScrollView({ x_fill: true,
|
||||||
y_fill: false,
|
y_fill: false,
|
||||||
y_align: St.Align.START,
|
y_align: St.Align.START,
|
||||||
style_class: 'vfade' });
|
vfade: true });
|
||||||
this.actor.add_actor(box);
|
this.actor.add_actor(box);
|
||||||
this.actor.set_policy(Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC);
|
this.actor.set_policy(Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC);
|
||||||
this.actor.connect('notify::mapped', Lang.bind(this,
|
this.actor.connect('notify::mapped', Lang.bind(this,
|
||||||
@ -62,25 +63,22 @@ const AlphabeticalView = new Lang.Class({
|
|||||||
}));
|
}));
|
||||||
},
|
},
|
||||||
|
|
||||||
removeAll: function() {
|
_removeAll: function() {
|
||||||
this._grid.removeAll();
|
this._grid.removeAll();
|
||||||
this._appIcons = {};
|
this._apps = [];
|
||||||
this._allApps = [];
|
|
||||||
},
|
},
|
||||||
|
|
||||||
addApp: function(app) {
|
_addApp: function(appInfo) {
|
||||||
var id = app.get_id();
|
let appIcon = new AppWellIcon(this._appSystem.get_app(appInfo.get_id()));
|
||||||
if (this._appIcons[id] !== undefined)
|
|
||||||
return;
|
|
||||||
|
|
||||||
let appIcon = new AppWellIcon(app);
|
this._grid.addItem(appIcon.actor);
|
||||||
let pos = Util.insertSorted(this._allApps, app, function(a, b) {
|
|
||||||
return a.compare_by_name(b);
|
|
||||||
});
|
|
||||||
this._grid.addItem(appIcon.actor, pos);
|
|
||||||
appIcon.actor.connect('key-focus-in', Lang.bind(this, this._ensureIconVisible));
|
appIcon.actor.connect('key-focus-in', Lang.bind(this, this._ensureIconVisible));
|
||||||
|
|
||||||
this._appIcons[id] = appIcon;
|
appIcon._appInfo = appInfo;
|
||||||
|
if (this._filterApp && !this._filterApp(appInfo))
|
||||||
|
appIcon.actor.hide();
|
||||||
|
|
||||||
|
this._apps.push(appIcon);
|
||||||
},
|
},
|
||||||
|
|
||||||
_ensureIconVisible: function(icon) {
|
_ensureIconVisible: function(icon) {
|
||||||
@ -109,31 +107,60 @@ const AlphabeticalView = new Lang.Class({
|
|||||||
transition: 'easeOutQuad' });
|
transition: 'easeOutQuad' });
|
||||||
},
|
},
|
||||||
|
|
||||||
setVisibleApps: function(apps) {
|
setFilter: function(filter) {
|
||||||
if (apps == null) { // null implies "all"
|
this._filterApp = filter;
|
||||||
for (var id in this._appIcons) {
|
for (let i = 0; i < this._apps.length; i++)
|
||||||
var icon = this._appIcons[id];
|
this._apps[i].actor.visible = filter(this._apps[i]._appInfo);
|
||||||
icon.actor.visible = true;
|
},
|
||||||
}
|
|
||||||
} else {
|
// Create actors for the applications in an idle to avoid blocking
|
||||||
// Set everything to not-visible, then set to visible what we should see
|
// for too long; see bug 647778
|
||||||
for (var id in this._appIcons) {
|
_addPendingApps: function() {
|
||||||
var icon = this._appIcons[id];
|
let i;
|
||||||
icon.actor.visible = false;
|
let startTimeMillis = new Date().getTime();
|
||||||
}
|
for (i = 0; i < this._pendingAppIds.length; i++) {
|
||||||
for (var i = 0; i < apps.length; i++) {
|
let id = this._pendingAppIds[i];
|
||||||
var app = apps[i];
|
this._addApp(this._pendingApps[id]);
|
||||||
var id = app.get_id();
|
|
||||||
var icon = this._appIcons[id];
|
let currentTimeMillis = new Date().getTime();
|
||||||
icon.actor.visible = true;
|
if (currentTimeMillis - startTimeMillis > MAX_APPLICATION_WORK_MILLIS)
|
||||||
}
|
break;
|
||||||
}
|
}
|
||||||
|
this._pendingAppIds.splice(0, i + 1);
|
||||||
|
if (this._pendingAppIds.length > 0) {
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
this._pendingAppLaterId = 0;
|
||||||
|
this._pendingAppIds = null;
|
||||||
|
this._pendingApps = null;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
refresh: function(apps) {
|
||||||
|
let ids = [];
|
||||||
|
for (let i in apps)
|
||||||
|
ids.push(i);
|
||||||
|
ids.sort(function(a, b) {
|
||||||
|
return apps[a].get_name().localeCompare(apps[b].get_name());
|
||||||
|
});
|
||||||
|
|
||||||
|
this._removeAll();
|
||||||
|
|
||||||
|
this._pendingAppIds = ids;
|
||||||
|
this._pendingApps = apps;
|
||||||
|
if (this._pendingAppLaterId)
|
||||||
|
Meta.later_remove(this._pendingAppLaterId);
|
||||||
|
this._pendingAppLaterId = Meta.later_add(Meta.LaterType.BEFORE_REDRAW,
|
||||||
|
Lang.bind(this, this._addPendingApps));
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
|
||||||
const ViewByCategories = new Lang.Class({
|
function ViewByCategories() {
|
||||||
Name: 'ViewByCategories',
|
this._init();
|
||||||
|
}
|
||||||
|
|
||||||
|
ViewByCategories.prototype = {
|
||||||
_init: function() {
|
_init: function() {
|
||||||
this._appSystem = Shell.AppSystem.get_default();
|
this._appSystem = Shell.AppSystem.get_default();
|
||||||
this.actor = new St.BoxLayout({ style_class: 'all-app' });
|
this.actor = new St.BoxLayout({ style_class: 'all-app' });
|
||||||
@ -146,25 +173,21 @@ const ViewByCategories = new Lang.Class({
|
|||||||
// -2 is a flag to indicate that nothing is selected
|
// -2 is a flag to indicate that nothing is selected
|
||||||
// (used only before the actor is mapped the first time)
|
// (used only before the actor is mapped the first time)
|
||||||
this._currentCategory = -2;
|
this._currentCategory = -2;
|
||||||
this._categories = [];
|
this._filters = new St.BoxLayout({ vertical: true, reactive: true });
|
||||||
|
this._filters.connect('scroll-event', Lang.bind(this, this._scrollFilter));
|
||||||
|
|
||||||
this._categoryBox = new St.BoxLayout({ vertical: true,
|
|
||||||
reactive: true,
|
|
||||||
accessible_role: Atk.Role.LIST });
|
|
||||||
this._categoryScroll = new St.ScrollView({ x_fill: false,
|
|
||||||
y_fill: false,
|
|
||||||
style_class: 'vfade' });
|
|
||||||
this._categoryScroll.add_actor(this._categoryBox);
|
|
||||||
this.actor.add(this._view.actor, { expand: true, x_fill: true, y_fill: true });
|
this.actor.add(this._view.actor, { expand: true, x_fill: true, y_fill: true });
|
||||||
this.actor.add(this._categoryScroll, { expand: false, y_fill: false, y_align: St.Align.START });
|
this.actor.add(this._filters, { expand: false, y_fill: false, y_align: St.Align.START });
|
||||||
|
|
||||||
// Always select the "All" filter when switching to the app view
|
// Always select the "All" filter when switching to the app view
|
||||||
this.actor.connect('notify::mapped', Lang.bind(this,
|
this.actor.connect('notify::mapped', Lang.bind(this,
|
||||||
function() {
|
function() {
|
||||||
if (this.actor.mapped && this._allCategoryButton)
|
if (this.actor.mapped && this._allFilter)
|
||||||
this._selectCategory(-1);
|
this._selectCategory(-1);
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
this._sections = [];
|
||||||
|
|
||||||
// We need a dummy actor to catch the keyboard focus if the
|
// We need a dummy actor to catch the keyboard focus if the
|
||||||
// user Ctrl-Alt-Tabs here before the deferred work creates
|
// user Ctrl-Alt-Tabs here before the deferred work creates
|
||||||
// our real contents
|
// our real contents
|
||||||
@ -172,102 +195,78 @@ const ViewByCategories = new Lang.Class({
|
|||||||
this.actor.add(this._focusDummy);
|
this.actor.add(this._focusDummy);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_scrollFilter: function(actor, event) {
|
||||||
|
let direction = event.get_scroll_direction();
|
||||||
|
if (direction == Clutter.ScrollDirection.UP)
|
||||||
|
this._selectCategory(Math.max(this._currentCategory - 1, -1))
|
||||||
|
else if (direction == Clutter.ScrollDirection.DOWN)
|
||||||
|
this._selectCategory(Math.min(this._currentCategory + 1, this._sections.length - 1));
|
||||||
|
},
|
||||||
|
|
||||||
_selectCategory: function(num) {
|
_selectCategory: function(num) {
|
||||||
if (this._currentCategory == num) // nothing to do
|
if (this._currentCategory == num) // nothing to do
|
||||||
return;
|
return;
|
||||||
|
|
||||||
this._currentCategory = num;
|
this._currentCategory = num;
|
||||||
|
|
||||||
if (num != -1) {
|
if (num != -1)
|
||||||
var category = this._categories[num];
|
this._allFilter.remove_style_pseudo_class('selected');
|
||||||
this._allCategoryButton.remove_style_pseudo_class('selected');
|
else
|
||||||
this._view.setVisibleApps(category.apps);
|
this._allFilter.add_style_pseudo_class('selected');
|
||||||
} else {
|
|
||||||
this._allCategoryButton.add_style_pseudo_class('selected');
|
|
||||||
this._view.setVisibleApps(null);
|
|
||||||
}
|
|
||||||
|
|
||||||
for (var i = 0; i < this._categories.length; i++) {
|
this._view.setFilter(Lang.bind(this, function(app) {
|
||||||
|
if (num == -1)
|
||||||
|
return true;
|
||||||
|
return this._sections[num].name == app.get_section();
|
||||||
|
}));
|
||||||
|
|
||||||
|
for (let i = 0; i < this._sections.length; i++) {
|
||||||
if (i == num)
|
if (i == num)
|
||||||
this._categories[i].button.add_style_pseudo_class('selected');
|
this._sections[i].filterActor.add_style_pseudo_class('selected');
|
||||||
else
|
else
|
||||||
this._categories[i].button.remove_style_pseudo_class('selected');
|
this._sections[i].filterActor.remove_style_pseudo_class('selected');
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
// Recursively load a GMenuTreeDirectory; we could put this in ShellAppSystem too
|
_addFilter: function(name, num) {
|
||||||
_loadCategory: function(dir, appList) {
|
|
||||||
var iter = dir.iter();
|
|
||||||
var nextType;
|
|
||||||
while ((nextType = iter.next()) != GMenu.TreeItemType.INVALID) {
|
|
||||||
if (nextType == GMenu.TreeItemType.ENTRY) {
|
|
||||||
var entry = iter.get_entry();
|
|
||||||
var app = this._appSystem.lookup_app_by_tree_entry(entry);
|
|
||||||
if (!entry.get_app_info().get_nodisplay()) {
|
|
||||||
this._view.addApp(app);
|
|
||||||
appList.push(app);
|
|
||||||
}
|
|
||||||
} else if (nextType == GMenu.TreeItemType.DIRECTORY) {
|
|
||||||
var itemDir = iter.get_directory();
|
|
||||||
if (!itemDir.get_is_nodisplay())
|
|
||||||
this._loadCategory(itemDir, appList);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_addCategory: function(name, index, dir) {
|
|
||||||
let button = new St.Button({ label: GLib.markup_escape_text (name, -1),
|
let button = new St.Button({ label: GLib.markup_escape_text (name, -1),
|
||||||
style_class: 'app-filter',
|
style_class: 'app-filter',
|
||||||
x_align: St.Align.START,
|
x_align: St.Align.START,
|
||||||
can_focus: true ,
|
can_focus: true });
|
||||||
accessible_role: Atk.Role.LIST_ITEM });
|
this._filters.add(button, { expand: true, x_fill: true, y_fill: false });
|
||||||
button.connect('clicked', Lang.bind(this, function() {
|
button.connect('clicked', Lang.bind(this, function() {
|
||||||
this._selectCategory(index);
|
this._selectCategory(num);
|
||||||
}));
|
}));
|
||||||
|
|
||||||
var apps;
|
if (num != -1)
|
||||||
if (dir == null) {
|
this._sections[num] = { filterActor: button,
|
||||||
this._allCategoryButton = button;
|
name: name };
|
||||||
} else {
|
else
|
||||||
apps = [];
|
this._allFilter = button;
|
||||||
this._loadCategory(dir, apps);
|
|
||||||
this._categories.push({ apps: apps,
|
|
||||||
name: name,
|
|
||||||
button: button });
|
|
||||||
}
|
|
||||||
|
|
||||||
this._categoryBox.add(button, { expand: true, x_fill: true, y_fill: false });
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_removeAll: function() {
|
_removeAll: function() {
|
||||||
this._view.removeAll();
|
this._sections = [];
|
||||||
this._categories = [];
|
this._filters.destroy_children();
|
||||||
this._categoryBox.destroy_all_children();
|
|
||||||
},
|
},
|
||||||
|
|
||||||
refresh: function() {
|
refresh: function(apps) {
|
||||||
this._removeAll();
|
this._removeAll();
|
||||||
|
|
||||||
|
let sections = this._appSystem.get_sections();
|
||||||
|
this._apps = apps;
|
||||||
|
|
||||||
/* Translators: Filter to display all applications */
|
/* Translators: Filter to display all applications */
|
||||||
this._addCategory(_("All"), -1, null);
|
this._addFilter(_("All"), -1);
|
||||||
|
|
||||||
var tree = this._appSystem.get_tree();
|
if (!sections)
|
||||||
var root = tree.get_root_directory();
|
return;
|
||||||
|
|
||||||
var iter = root.iter();
|
for (let i = 0; i < sections.length; i++)
|
||||||
var nextType;
|
this._addFilter(sections[i], i);
|
||||||
var i = 0;
|
|
||||||
while ((nextType = iter.next()) != GMenu.TreeItemType.INVALID) {
|
|
||||||
if (nextType == GMenu.TreeItemType.DIRECTORY) {
|
|
||||||
var dir = iter.get_directory();
|
|
||||||
if (dir.get_is_nodisplay())
|
|
||||||
continue;
|
|
||||||
this._addCategory(dir.get_name(), i, dir);
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
this._selectCategory(-1);
|
this._selectCategory(-1);
|
||||||
|
this._view.refresh(apps);
|
||||||
|
|
||||||
if (this._focusDummy) {
|
if (this._focusDummy) {
|
||||||
let focused = this._focusDummy.has_key_focus();
|
let focused = this._focusDummy.has_key_focus();
|
||||||
@ -277,14 +276,16 @@ const ViewByCategories = new Lang.Class({
|
|||||||
this.actor.navigate_focus(null, Gtk.DirectionType.TAB_FORWARD, false);
|
this.actor.navigate_focus(null, Gtk.DirectionType.TAB_FORWARD, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
|
||||||
/* This class represents a display containing a collection of application items.
|
/* This class represents a display containing a collection of application items.
|
||||||
* The applications are sorted based on their name.
|
* The applications are sorted based on their name.
|
||||||
*/
|
*/
|
||||||
const AllAppDisplay = new Lang.Class({
|
function AllAppDisplay() {
|
||||||
Name: 'AllAppDisplay',
|
this._init();
|
||||||
|
}
|
||||||
|
|
||||||
|
AllAppDisplay.prototype = {
|
||||||
_init: function() {
|
_init: function() {
|
||||||
this._appSystem = Shell.AppSystem.get_default();
|
this._appSystem = Shell.AppSystem.get_default();
|
||||||
this._appSystem.connect('installed-changed', Lang.bind(this, function() {
|
this._appSystem.connect('installed-changed', Lang.bind(this, function() {
|
||||||
@ -298,142 +299,129 @@ const AllAppDisplay = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_redisplay: function() {
|
_redisplay: function() {
|
||||||
this._appView.refresh();
|
let apps = this._appSystem.get_flattened_apps().filter(function(app) {
|
||||||
|
return !app.get_is_nodisplay();
|
||||||
|
});
|
||||||
|
|
||||||
|
this._appView.refresh(apps);
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
|
||||||
const AppSearchProvider = new Lang.Class({
|
function BaseAppSearchProvider() {
|
||||||
Name: 'AppSearchProvider',
|
this._init();
|
||||||
Extends: Search.SearchProvider,
|
}
|
||||||
|
|
||||||
_init: function() {
|
BaseAppSearchProvider.prototype = {
|
||||||
this.parent(_("APPLICATIONS"));
|
__proto__: Search.SearchProvider.prototype,
|
||||||
|
|
||||||
|
_init: function(name) {
|
||||||
|
Search.SearchProvider.prototype._init.call(this, name);
|
||||||
this._appSys = Shell.AppSystem.get_default();
|
this._appSys = Shell.AppSystem.get_default();
|
||||||
},
|
},
|
||||||
|
|
||||||
getResultMetas: function(apps, callback) {
|
getResultMeta: function(resultId) {
|
||||||
let metas = [];
|
let app = this._appSys.get_app(resultId);
|
||||||
for (let i = 0; i < apps.length; i++) {
|
if (!app)
|
||||||
let app = apps[i];
|
return null;
|
||||||
metas.push({ 'id': app,
|
return { 'id': resultId,
|
||||||
'name': app.get_name(),
|
'name': app.get_name(),
|
||||||
'createIcon': function(size) {
|
'createIcon': function(size) {
|
||||||
return app.create_icon_texture(size);
|
return app.create_icon_texture(size);
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
}
|
|
||||||
callback(metas);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
getInitialResultSet: function(terms) {
|
activateResult: function(id, params) {
|
||||||
this.searchSystem.pushResults(this, this._appSys.initial_search(terms));
|
params = Params.parse(params, { workspace: null,
|
||||||
},
|
timestamp: null });
|
||||||
|
|
||||||
getSubsearchResultSet: function(previousResults, terms) {
|
let app = this._appSys.get_app(id);
|
||||||
this.searchSystem.pushResults(this, this._appSys.subsearch(previousResults, terms));
|
app.activate(params.workspace ? params.workspace.index() : -1);
|
||||||
},
|
|
||||||
|
|
||||||
activateResult: function(app, params) {
|
|
||||||
params = Params.parse(params, { workspace: -1,
|
|
||||||
timestamp: 0 });
|
|
||||||
|
|
||||||
let event = Clutter.get_current_event();
|
|
||||||
let modifiers = event ? event.get_state() : 0;
|
|
||||||
let openNewWindow = modifiers & Clutter.ModifierType.CONTROL_MASK;
|
|
||||||
|
|
||||||
if (openNewWindow)
|
|
||||||
app.open_new_window(params.workspace);
|
|
||||||
else
|
|
||||||
app.activate_full(params.workspace, params.timestamp);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
dragActivateResult: function(id, params) {
|
dragActivateResult: function(id, params) {
|
||||||
params = Params.parse(params, { workspace: -1,
|
params = Params.parse(params, { workspace: null,
|
||||||
timestamp: 0 });
|
timestamp: null });
|
||||||
|
|
||||||
let app = this._appSys.lookup_app(id);
|
let app = this._appSys.get_app(id);
|
||||||
app.open_new_window(workspace);
|
app.open_new_window(params.workspace ? params.workspace.index() : -1);
|
||||||
},
|
|
||||||
|
|
||||||
createResultActor: function (resultMeta, terms) {
|
|
||||||
let app = resultMeta['id'];
|
|
||||||
let icon = new AppWellIcon(app);
|
|
||||||
return icon.actor;
|
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
|
||||||
const SettingsSearchProvider = new Lang.Class({
|
function AppSearchProvider() {
|
||||||
Name: 'SettingsSearchProvider',
|
this._init();
|
||||||
Extends: Search.SearchProvider,
|
}
|
||||||
|
|
||||||
|
AppSearchProvider.prototype = {
|
||||||
|
__proto__: BaseAppSearchProvider.prototype,
|
||||||
|
|
||||||
_init: function() {
|
_init: function() {
|
||||||
this.parent(_("SETTINGS"));
|
BaseAppSearchProvider.prototype._init.call(this, _("APPLICATIONS"));
|
||||||
|
|
||||||
this._appSys = Shell.AppSystem.get_default();
|
|
||||||
this._gnomecc = this._appSys.lookup_app('gnome-control-center.desktop');
|
|
||||||
},
|
|
||||||
|
|
||||||
getResultMetas: function(prefs, callback) {
|
|
||||||
let metas = [];
|
|
||||||
for (let i = 0; i < prefs.length; i++) {
|
|
||||||
let pref = prefs[i];
|
|
||||||
metas.push({ 'id': pref,
|
|
||||||
'name': pref.get_name(),
|
|
||||||
'createIcon': function(size) {
|
|
||||||
return pref.create_icon_texture(size);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
callback(metas);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
getInitialResultSet: function(terms) {
|
getInitialResultSet: function(terms) {
|
||||||
this.searchSystem.pushResults(this, this._appSys.search_settings(terms));
|
return this._appSys.initial_search(false, terms);
|
||||||
},
|
},
|
||||||
|
|
||||||
getSubsearchResultSet: function(previousResults, terms) {
|
getSubsearchResultSet: function(previousResults, terms) {
|
||||||
this.searchSystem.pushResults(this, this._appSys.search_settings(terms));
|
return this._appSys.subsearch(false, previousResults, terms);
|
||||||
},
|
|
||||||
|
|
||||||
activateResult: function(pref, params) {
|
|
||||||
params = Params.parse(params, { workspace: -1,
|
|
||||||
timestamp: 0 });
|
|
||||||
|
|
||||||
pref.activate_full(params.workspace, params.timestamp);
|
|
||||||
},
|
|
||||||
|
|
||||||
dragActivateResult: function(pref, params) {
|
|
||||||
this.activateResult(pref, params);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
createResultActor: function (resultMeta, terms) {
|
createResultActor: function (resultMeta, terms) {
|
||||||
let app = resultMeta['id'];
|
let app = this._appSys.get_app(resultMeta['id']);
|
||||||
let icon = new AppWellIcon(app);
|
let icon = new AppWellIcon(app);
|
||||||
return icon.actor;
|
return icon.actor;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
|
||||||
const AppIcon = new Lang.Class({
|
function PrefsSearchProvider() {
|
||||||
Name: 'AppIcon',
|
this._init();
|
||||||
Extends: IconGrid.BaseIcon,
|
}
|
||||||
|
|
||||||
|
PrefsSearchProvider.prototype = {
|
||||||
|
__proto__: BaseAppSearchProvider.prototype,
|
||||||
|
|
||||||
|
_init: function() {
|
||||||
|
BaseAppSearchProvider.prototype._init.call(this, _("SETTINGS"));
|
||||||
|
},
|
||||||
|
|
||||||
|
getInitialResultSet: function(terms) {
|
||||||
|
return this._appSys.initial_search(true, terms);
|
||||||
|
},
|
||||||
|
|
||||||
|
getSubsearchResultSet: function(previousResults, terms) {
|
||||||
|
return this._appSys.subsearch(true, previousResults, terms);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
function AppIcon(app, params) {
|
||||||
|
this._init(app, params);
|
||||||
|
}
|
||||||
|
|
||||||
|
AppIcon.prototype = {
|
||||||
|
__proto__: IconGrid.BaseIcon.prototype,
|
||||||
|
|
||||||
_init : function(app, params) {
|
_init : function(app, params) {
|
||||||
this.app = app;
|
this.app = app;
|
||||||
|
|
||||||
let label = this.app.get_name();
|
let label = this.app.get_name();
|
||||||
|
|
||||||
this.parent(label, params);
|
IconGrid.BaseIcon.prototype._init.call(this,
|
||||||
|
label,
|
||||||
|
params);
|
||||||
},
|
},
|
||||||
|
|
||||||
createIcon: function(iconSize) {
|
createIcon: function(iconSize) {
|
||||||
return this.app.create_icon_texture(iconSize);
|
return this.app.create_icon_texture(iconSize);
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
|
||||||
const AppWellIcon = new Lang.Class({
|
function AppWellIcon(app, iconParams) {
|
||||||
Name: 'AppWellIcon',
|
this._init(app, iconParams);
|
||||||
|
}
|
||||||
|
|
||||||
_init : function(app, iconParams, onActivateOverride) {
|
AppWellIcon.prototype = {
|
||||||
|
_init : function(app, iconParams) {
|
||||||
this.app = app;
|
this.app = app;
|
||||||
this.actor = new St.Button({ style_class: 'app-well-app',
|
this.actor = new St.Button({ style_class: 'app-well-app',
|
||||||
reactive: true,
|
reactive: true,
|
||||||
@ -446,10 +434,6 @@ const AppWellIcon = new Lang.Class({
|
|||||||
this.icon = new AppIcon(app, iconParams);
|
this.icon = new AppIcon(app, iconParams);
|
||||||
this.actor.set_child(this.icon.actor);
|
this.actor.set_child(this.icon.actor);
|
||||||
|
|
||||||
this.actor.label_actor = this.icon.label;
|
|
||||||
|
|
||||||
// A function callback to override the default "app.activate()"; used by preferences
|
|
||||||
this._onActivateOverride = onActivateOverride;
|
|
||||||
this.actor.connect('button-press-event', Lang.bind(this, this._onButtonPress));
|
this.actor.connect('button-press-event', Lang.bind(this, this._onButtonPress));
|
||||||
this.actor.connect('clicked', Lang.bind(this, this._onClicked));
|
this.actor.connect('clicked', Lang.bind(this, this._onClicked));
|
||||||
this.actor.connect('popup-menu', Lang.bind(this, this._onKeyboardPopupMenu));
|
this.actor.connect('popup-menu', Lang.bind(this, this._onKeyboardPopupMenu));
|
||||||
@ -479,7 +463,6 @@ const AppWellIcon = new Lang.Class({
|
|||||||
Lang.bind(this,
|
Lang.bind(this,
|
||||||
this._onStateChanged));
|
this._onStateChanged));
|
||||||
this._onStateChanged();
|
this._onStateChanged();
|
||||||
this.isMenuUp = false;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_onDestroy: function() {
|
_onDestroy: function() {
|
||||||
@ -552,7 +535,7 @@ const AppWellIcon = new Lang.Class({
|
|||||||
this._menu.connect('activate-window', Lang.bind(this, function (menu, window) {
|
this._menu.connect('activate-window', Lang.bind(this, function (menu, window) {
|
||||||
this.activateWindow(window);
|
this.activateWindow(window);
|
||||||
}));
|
}));
|
||||||
this._menu.connect('open-state-changed', Lang.bind(this, function (menu, isPoppedUp) {
|
this._menu.connect('popup', Lang.bind(this, function (menu, isPoppedUp) {
|
||||||
if (!isPoppedUp)
|
if (!isPoppedUp)
|
||||||
this._onMenuPoppedDown();
|
this._onMenuPoppedDown();
|
||||||
}));
|
}));
|
||||||
@ -561,8 +544,8 @@ const AppWellIcon = new Lang.Class({
|
|||||||
this._menuManager.addMenu(this._menu);
|
this._menuManager.addMenu(this._menu);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.isMenuUp = true;
|
|
||||||
this.actor.set_hover(true);
|
this.actor.set_hover(true);
|
||||||
|
this.actor.show_tooltip();
|
||||||
this._menu.popup();
|
this._menu.popup();
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
@ -578,35 +561,30 @@ const AppWellIcon = new Lang.Class({
|
|||||||
|
|
||||||
_onMenuPoppedDown: function() {
|
_onMenuPoppedDown: function() {
|
||||||
this.actor.sync_hover();
|
this.actor.sync_hover();
|
||||||
this.isMenuUp = false;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_onActivate: function (event) {
|
_onActivate: function (event) {
|
||||||
this.emit('launching');
|
this.emit('launching');
|
||||||
let modifiers = event.get_state();
|
let modifiers = Shell.get_event_state(event);
|
||||||
|
|
||||||
if (this._onActivateOverride) {
|
if (modifiers & Clutter.ModifierType.CONTROL_MASK
|
||||||
this._onActivateOverride(event);
|
&& this.app.state == Shell.AppState.RUNNING) {
|
||||||
|
this.app.open_new_window(-1);
|
||||||
} else {
|
} else {
|
||||||
if (modifiers & Clutter.ModifierType.CONTROL_MASK
|
this.app.activate(-1);
|
||||||
&& this.app.state == Shell.AppState.RUNNING) {
|
|
||||||
this.app.open_new_window(-1);
|
|
||||||
} else {
|
|
||||||
this.app.activate();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
Main.overview.hide();
|
Main.overview.hide();
|
||||||
},
|
},
|
||||||
|
|
||||||
shellWorkspaceLaunch : function(params) {
|
shellWorkspaceLaunch : function(params) {
|
||||||
params = Params.parse(params, { workspace: -1,
|
params = Params.parse(params, { workspace: null,
|
||||||
timestamp: 0 });
|
timestamp: null });
|
||||||
|
|
||||||
this.app.open_new_window(params.workspace);
|
this.app.open_new_window(params.workspace ? params.workspace.index() : -1);
|
||||||
},
|
},
|
||||||
|
|
||||||
getDragActor: function() {
|
getDragActor: function() {
|
||||||
return this.app.create_icon_texture(Main.overview.dashIconSize);
|
return this.app.create_icon_texture(Main.overview.dash.iconSize);
|
||||||
},
|
},
|
||||||
|
|
||||||
// Returns the original actor that should align with the actor
|
// Returns the original actor that should align with the actor
|
||||||
@ -614,19 +592,22 @@ const AppWellIcon = new Lang.Class({
|
|||||||
getDragActorSource: function() {
|
getDragActorSource: function() {
|
||||||
return this.icon.icon;
|
return this.icon.icon;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
Signals.addSignalMethods(AppWellIcon.prototype);
|
Signals.addSignalMethods(AppWellIcon.prototype);
|
||||||
|
|
||||||
const AppIconMenu = new Lang.Class({
|
function AppIconMenu(source) {
|
||||||
Name: 'AppIconMenu',
|
this._init(source);
|
||||||
Extends: PopupMenu.PopupMenu,
|
}
|
||||||
|
|
||||||
|
AppIconMenu.prototype = {
|
||||||
|
__proto__: PopupMenu.PopupMenu.prototype,
|
||||||
|
|
||||||
_init: function(source) {
|
_init: function(source) {
|
||||||
let side = St.Side.LEFT;
|
let side = St.Side.LEFT;
|
||||||
if (Clutter.get_default_text_direction() == Clutter.TextDirection.RTL)
|
if (St.Widget.get_default_direction() == St.TextDirection.RTL)
|
||||||
side = St.Side.RIGHT;
|
side = St.Side.RIGHT;
|
||||||
|
|
||||||
this.parent(source.actor, 0.5, side);
|
PopupMenu.PopupMenu.prototype._init.call(this, source.actor, 0.5, side, 0);
|
||||||
|
|
||||||
// We want to keep the item hovered while the menu is up
|
// We want to keep the item hovered while the menu is up
|
||||||
this.blockSourceEvents = true;
|
this.blockSourceEvents = true;
|
||||||
@ -634,6 +615,7 @@ const AppIconMenu = new Lang.Class({
|
|||||||
this._source = source;
|
this._source = source;
|
||||||
|
|
||||||
this.connect('activate', Lang.bind(this, this._onActivate));
|
this.connect('activate', Lang.bind(this, this._onActivate));
|
||||||
|
this.connect('open-state-changed', Lang.bind(this, this._onOpenStateChanged));
|
||||||
|
|
||||||
this.actor.add_style_class_name('app-well-menu');
|
this.actor.add_style_class_name('app-well-menu');
|
||||||
|
|
||||||
@ -666,18 +648,17 @@ const AppIconMenu = new Lang.Class({
|
|||||||
item._window = windows[i];
|
item._window = windows[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!this._source.app.is_window_backed()) {
|
if (windows.length > 0)
|
||||||
if (windows.length > 0)
|
|
||||||
this._appendSeparator();
|
|
||||||
|
|
||||||
let isFavorite = AppFavorites.getAppFavorites().isFavorite(this._source.app.get_id());
|
|
||||||
|
|
||||||
this._newWindowMenuItem = this._appendMenuItem(_("New Window"));
|
|
||||||
this._appendSeparator();
|
this._appendSeparator();
|
||||||
|
|
||||||
this._toggleFavoriteMenuItem = this._appendMenuItem(isFavorite ? _("Remove from Favorites")
|
let isFavorite = AppFavorites.getAppFavorites().isFavorite(this._source.app.get_id());
|
||||||
: _("Add to Favorites"));
|
|
||||||
}
|
this._newWindowMenuItem = this._appendMenuItem(_("New Window"));
|
||||||
|
this._appendSeparator();
|
||||||
|
|
||||||
|
this._toggleFavoriteMenuItem = this._appendMenuItem(isFavorite ? _("Remove from Favorites")
|
||||||
|
: _("Add to Favorites"));
|
||||||
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_appendSeparator: function () {
|
_appendSeparator: function () {
|
||||||
@ -697,6 +678,14 @@ const AppIconMenu = new Lang.Class({
|
|||||||
this.open();
|
this.open();
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_onOpenStateChanged: function (menu, open) {
|
||||||
|
if (open) {
|
||||||
|
this.emit('popup', true);
|
||||||
|
} else {
|
||||||
|
this.emit('popup', false);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
_onActivate: function (actor, child) {
|
_onActivate: function (actor, child) {
|
||||||
if (child._window) {
|
if (child._window) {
|
||||||
let metaWindow = child._window;
|
let metaWindow = child._window;
|
||||||
@ -714,5 +703,5 @@ const AppIconMenu = new Lang.Class({
|
|||||||
}
|
}
|
||||||
this.close();
|
this.close();
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
Signals.addSignalMethods(AppIconMenu.prototype);
|
Signals.addSignalMethods(AppIconMenu.prototype);
|
||||||
|
@ -1,14 +1,18 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
|
||||||
|
|
||||||
const Shell = imports.gi.Shell;
|
const Shell = imports.gi.Shell;
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
const Signals = imports.signals;
|
const Signals = imports.signals;
|
||||||
|
const Gettext = imports.gettext.domain('gnome-shell');
|
||||||
|
const _ = Gettext.gettext;
|
||||||
|
|
||||||
const Main = imports.ui.main;
|
const Main = imports.ui.main;
|
||||||
|
|
||||||
const AppFavorites = new Lang.Class({
|
function AppFavorites() {
|
||||||
Name: 'AppFavorites',
|
this._init();
|
||||||
|
}
|
||||||
|
|
||||||
|
AppFavorites.prototype = {
|
||||||
FAVORITE_APPS_KEY: 'favorite-apps',
|
FAVORITE_APPS_KEY: 'favorite-apps',
|
||||||
|
|
||||||
_init: function() {
|
_init: function() {
|
||||||
@ -26,7 +30,7 @@ const AppFavorites = new Lang.Class({
|
|||||||
let ids = global.settings.get_strv(this.FAVORITE_APPS_KEY);
|
let ids = global.settings.get_strv(this.FAVORITE_APPS_KEY);
|
||||||
let appSys = Shell.AppSystem.get_default();
|
let appSys = Shell.AppSystem.get_default();
|
||||||
let apps = ids.map(function (id) {
|
let apps = ids.map(function (id) {
|
||||||
return appSys.lookup_app(id);
|
return appSys.get_app(id);
|
||||||
}).filter(function (app) {
|
}).filter(function (app) {
|
||||||
return app != null;
|
return app != null;
|
||||||
});
|
});
|
||||||
@ -63,7 +67,7 @@ const AppFavorites = new Lang.Class({
|
|||||||
if (appId in this._favorites)
|
if (appId in this._favorites)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
let app = Shell.AppSystem.get_default().lookup_app(appId);
|
let app = Shell.AppSystem.get_default().get_app(appId);
|
||||||
|
|
||||||
if (!app)
|
if (!app)
|
||||||
return false;
|
return false;
|
||||||
@ -82,9 +86,9 @@ const AppFavorites = new Lang.Class({
|
|||||||
if (!this._addFavorite(appId, pos))
|
if (!this._addFavorite(appId, pos))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
let app = Shell.AppSystem.get_default().lookup_app(appId);
|
let app = Shell.AppSystem.get_default().get_app(appId);
|
||||||
|
|
||||||
Main.overview.setMessage(_("%s has been added to your favorites.").format(app.get_name()), Lang.bind(this, function () {
|
Main.overview.shellInfo.setMessage(_("%s has been added to your favorites.").format(app.get_name()), Lang.bind(this, function () {
|
||||||
this._removeFavorite(appId);
|
this._removeFavorite(appId);
|
||||||
}));
|
}));
|
||||||
},
|
},
|
||||||
@ -115,12 +119,12 @@ const AppFavorites = new Lang.Class({
|
|||||||
if (!this._removeFavorite(appId))
|
if (!this._removeFavorite(appId))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
Main.overview.setMessage(_("%s has been removed from your favorites.").format(app.get_name()),
|
Main.overview.shellInfo.setMessage(_("%s has been removed from your favorites.").format(app.get_name()),
|
||||||
Lang.bind(this, function () {
|
Lang.bind(this, function () {
|
||||||
this._addFavorite(appId, pos);
|
this._addFavorite(appId, pos);
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
Signals.addSignalMethods(AppFavorites.prototype);
|
Signals.addSignalMethods(AppFavorites.prototype);
|
||||||
|
|
||||||
var appFavoritesInstance = null;
|
var appFavoritesInstance = null;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
|
||||||
|
|
||||||
const Clutter = imports.gi.Clutter;
|
const Clutter = imports.gi.Clutter;
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
@ -6,16 +6,8 @@ const Meta = imports.gi.Meta;
|
|||||||
const St = imports.gi.St;
|
const St = imports.gi.St;
|
||||||
const Shell = imports.gi.Shell;
|
const Shell = imports.gi.Shell;
|
||||||
|
|
||||||
const Main = imports.ui.main;
|
|
||||||
const Tweener = imports.ui.tweener;
|
const Tweener = imports.ui.tweener;
|
||||||
|
|
||||||
const PopupAnimation = {
|
|
||||||
NONE: 0,
|
|
||||||
SLIDE: 1 << 0,
|
|
||||||
FADE: 1 << 1,
|
|
||||||
FULL: ~0,
|
|
||||||
};
|
|
||||||
|
|
||||||
const POPUP_ANIMATION_TIME = 0.15;
|
const POPUP_ANIMATION_TIME = 0.15;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -25,18 +17,16 @@ const POPUP_ANIMATION_TIME = 0.15;
|
|||||||
*
|
*
|
||||||
* An actor which displays a triangle "arrow" pointing to a given
|
* An actor which displays a triangle "arrow" pointing to a given
|
||||||
* side. The .bin property is a container in which content can be
|
* side. The .bin property is a container in which content can be
|
||||||
* placed. The arrow position may be controlled via
|
* placed. The arrow position may be controlled via setArrowOrigin().
|
||||||
* setArrowOrigin(). The arrow side might be temporarily flipped
|
|
||||||
* depending on the box size and source position to keep the box
|
|
||||||
* totally inside the monitor if possible.
|
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
const BoxPointer = new Lang.Class({
|
function BoxPointer(side, binProperties) {
|
||||||
Name: 'BoxPointer',
|
this._init(side, binProperties);
|
||||||
|
}
|
||||||
|
|
||||||
|
BoxPointer.prototype = {
|
||||||
_init: function(arrowSide, binProperties) {
|
_init: function(arrowSide, binProperties) {
|
||||||
this._arrowSide = arrowSide;
|
this._arrowSide = arrowSide;
|
||||||
this._userArrowSide = arrowSide;
|
|
||||||
this._arrowOrigin = 0;
|
this._arrowOrigin = 0;
|
||||||
this.actor = new St.Bin({ x_fill: true,
|
this.actor = new St.Bin({ x_fill: true,
|
||||||
y_fill: true });
|
y_fill: true });
|
||||||
@ -55,37 +45,16 @@ const BoxPointer = new Lang.Class({
|
|||||||
this._yOffset = 0;
|
this._yOffset = 0;
|
||||||
this._xPosition = 0;
|
this._xPosition = 0;
|
||||||
this._yPosition = 0;
|
this._yPosition = 0;
|
||||||
this._sourceAlignment = 0.5;
|
|
||||||
this._capturedEventId = 0;
|
|
||||||
this._muteInput();
|
|
||||||
},
|
|
||||||
|
|
||||||
_muteInput: function() {
|
|
||||||
if (this._capturedEventId == 0)
|
|
||||||
this._capturedEventId = this.actor.connect('captured-event',
|
|
||||||
function() { return true; });
|
|
||||||
},
|
|
||||||
|
|
||||||
_unmuteInput: function() {
|
|
||||||
if (this._capturedEventId != 0) {
|
|
||||||
this.actor.disconnect(this._capturedEventId);
|
|
||||||
this._capturedEventId = 0;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
|
|
||||||
show: function(animate, onComplete) {
|
show: function(animate, onComplete) {
|
||||||
let themeNode = this.actor.get_theme_node();
|
let themeNode = this.actor.get_theme_node();
|
||||||
let rise = themeNode.get_length('-arrow-rise');
|
let rise = themeNode.get_length('-arrow-rise');
|
||||||
let animationTime = (animate & PopupAnimation.FULL) ? POPUP_ANIMATION_TIME : 0;
|
|
||||||
|
|
||||||
if (animate & PopupAnimation.FADE)
|
|
||||||
this.opacity = 0;
|
|
||||||
else
|
|
||||||
this.opacity = 255;
|
|
||||||
|
|
||||||
|
this.opacity = 0;
|
||||||
this.actor.show();
|
this.actor.show();
|
||||||
|
|
||||||
if (animate & PopupAnimation.SLIDE) {
|
if (animate) {
|
||||||
switch (this._arrowSide) {
|
switch (this._arrowSide) {
|
||||||
case St.Side.TOP:
|
case St.Side.TOP:
|
||||||
this.yOffset = -rise;
|
this.yOffset = -rise;
|
||||||
@ -105,13 +74,9 @@ const BoxPointer = new Lang.Class({
|
|||||||
Tweener.addTween(this, { opacity: 255,
|
Tweener.addTween(this, { opacity: 255,
|
||||||
xOffset: 0,
|
xOffset: 0,
|
||||||
yOffset: 0,
|
yOffset: 0,
|
||||||
transition: 'linear',
|
transition: "linear",
|
||||||
onComplete: Lang.bind(this, function() {
|
onComplete: onComplete,
|
||||||
this._unmuteInput();
|
time: POPUP_ANIMATION_TIME });
|
||||||
if (onComplete)
|
|
||||||
onComplete();
|
|
||||||
}),
|
|
||||||
time: animationTime });
|
|
||||||
},
|
},
|
||||||
|
|
||||||
hide: function(animate, onComplete) {
|
hide: function(animate, onComplete) {
|
||||||
@ -119,10 +84,8 @@ const BoxPointer = new Lang.Class({
|
|||||||
let yOffset = 0;
|
let yOffset = 0;
|
||||||
let themeNode = this.actor.get_theme_node();
|
let themeNode = this.actor.get_theme_node();
|
||||||
let rise = themeNode.get_length('-arrow-rise');
|
let rise = themeNode.get_length('-arrow-rise');
|
||||||
let fade = (animate & PopupAnimation.FADE);
|
|
||||||
let animationTime = (animate & PopupAnimation.FULL) ? POPUP_ANIMATION_TIME : 0;
|
|
||||||
|
|
||||||
if (animate & PopupAnimation.SLIDE) {
|
if (animate) {
|
||||||
switch (this._arrowSide) {
|
switch (this._arrowSide) {
|
||||||
case St.Side.TOP:
|
case St.Side.TOP:
|
||||||
yOffset = rise;
|
yOffset = rise;
|
||||||
@ -139,16 +102,13 @@ const BoxPointer = new Lang.Class({
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this._muteInput();
|
Tweener.addTween(this, { opacity: 0,
|
||||||
|
|
||||||
Tweener.addTween(this, { opacity: fade ? 0 : 255,
|
|
||||||
xOffset: xOffset,
|
xOffset: xOffset,
|
||||||
yOffset: yOffset,
|
yOffset: yOffset,
|
||||||
transition: 'linear',
|
transition: "linear",
|
||||||
time: animationTime,
|
time: POPUP_ANIMATION_TIME,
|
||||||
onComplete: Lang.bind(this, function () {
|
onComplete: Lang.bind(this, function () {
|
||||||
this.actor.hide();
|
this.actor.hide();
|
||||||
this.opacity = 0;
|
|
||||||
this.xOffset = 0;
|
this.xOffset = 0;
|
||||||
this.yOffset = 0;
|
this.yOffset = 0;
|
||||||
if (onComplete)
|
if (onComplete)
|
||||||
@ -218,27 +178,8 @@ const BoxPointer = new Lang.Class({
|
|||||||
}
|
}
|
||||||
this.bin.allocate(childBox, flags);
|
this.bin.allocate(childBox, flags);
|
||||||
|
|
||||||
if (this._sourceActor && this._sourceActor.mapped) {
|
if (this._sourceActor && this._sourceActor.mapped)
|
||||||
this._reposition(this._sourceActor, this._arrowAlignment);
|
this._reposition(this._sourceActor, this._gap, this._alignment);
|
||||||
|
|
||||||
if (this._shouldFlip()) {
|
|
||||||
switch (this._arrowSide) {
|
|
||||||
case St.Side.TOP:
|
|
||||||
this._arrowSide = St.Side.BOTTOM;
|
|
||||||
break;
|
|
||||||
case St.Side.BOTTOM:
|
|
||||||
this._arrowSide = St.Side.TOP;
|
|
||||||
break;
|
|
||||||
case St.Side.LEFT:
|
|
||||||
this._arrowSide = St.Side.RIGHT;
|
|
||||||
break;
|
|
||||||
case St.Side.RIGHT:
|
|
||||||
this._arrowSide = St.Side.LEFT;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
this._reposition(this._sourceActor, this._arrowAlignment);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_drawBorder: function(area) {
|
_drawBorder: function(area) {
|
||||||
@ -252,6 +193,7 @@ const BoxPointer = new Lang.Class({
|
|||||||
let halfBorder = borderWidth / 2;
|
let halfBorder = borderWidth / 2;
|
||||||
let halfBase = Math.floor(base/2);
|
let halfBase = Math.floor(base/2);
|
||||||
|
|
||||||
|
let borderColor = themeNode.get_color('-arrow-border-color');
|
||||||
let backgroundColor = themeNode.get_color('-arrow-background-color');
|
let backgroundColor = themeNode.get_color('-arrow-background-color');
|
||||||
|
|
||||||
let [width, height] = area.get_surface_size();
|
let [width, height] = area.get_surface_size();
|
||||||
@ -262,6 +204,7 @@ const BoxPointer = new Lang.Class({
|
|||||||
boxWidth -= rise;
|
boxWidth -= rise;
|
||||||
}
|
}
|
||||||
let cr = area.get_context();
|
let cr = area.get_context();
|
||||||
|
Clutter.cairo_set_source_color(cr, borderColor);
|
||||||
|
|
||||||
// Translate so that box goes from 0,0 to boxWidth,boxHeight,
|
// Translate so that box goes from 0,0 to boxWidth,boxHeight,
|
||||||
// with the arrow poking out of that
|
// with the arrow poking out of that
|
||||||
@ -274,51 +217,14 @@ const BoxPointer = new Lang.Class({
|
|||||||
let [x1, y1] = [halfBorder, halfBorder];
|
let [x1, y1] = [halfBorder, halfBorder];
|
||||||
let [x2, y2] = [boxWidth - halfBorder, boxHeight - halfBorder];
|
let [x2, y2] = [boxWidth - halfBorder, boxHeight - halfBorder];
|
||||||
|
|
||||||
let skipTopLeft = false;
|
|
||||||
let skipTopRight = false;
|
|
||||||
let skipBottomLeft = false;
|
|
||||||
let skipBottomRight = false;
|
|
||||||
|
|
||||||
switch (this._arrowSide) {
|
|
||||||
case St.Side.TOP:
|
|
||||||
if (this._arrowOrigin == x1)
|
|
||||||
skipTopLeft = true;
|
|
||||||
else if (this._arrowOrigin == x2)
|
|
||||||
skipTopRight = true;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case St.Side.RIGHT:
|
|
||||||
if (this._arrowOrigin == y1)
|
|
||||||
skipTopRight = true;
|
|
||||||
else if (this._arrowOrigin == y2)
|
|
||||||
skipBottomRight = true;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case St.Side.BOTTOM:
|
|
||||||
if (this._arrowOrigin == x1)
|
|
||||||
skipBottomLeft = true;
|
|
||||||
else if (this._arrowOrigin == x2)
|
|
||||||
skipBottomRight = true;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case St.Side.LEFT:
|
|
||||||
if (this._arrowOrigin == y1)
|
|
||||||
skipTopLeft = true;
|
|
||||||
else if (this._arrowOrigin == y2)
|
|
||||||
skipBottomLeft = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
cr.moveTo(x1 + borderRadius, y1);
|
cr.moveTo(x1 + borderRadius, y1);
|
||||||
if (this._arrowSide == St.Side.TOP) {
|
if (this._arrowSide == St.Side.TOP) {
|
||||||
if (skipTopLeft) {
|
if (this._arrowOrigin < (x1 + (borderRadius + halfBase))) {
|
||||||
cr.moveTo(x1, y2 - borderRadius);
|
cr.lineTo(this._arrowOrigin, y1 - rise);
|
||||||
cr.lineTo(x1, y1 - rise);
|
cr.lineTo(Math.max(x1 + borderRadius, this._arrowOrigin) + halfBase, y1);
|
||||||
cr.lineTo(x1 + halfBase, y1);
|
} else if (this._arrowOrigin > (x2 - (borderRadius + halfBase))) {
|
||||||
} else if (skipTopRight) {
|
cr.lineTo(Math.min(x2 - borderRadius, this._arrowOrigin) - halfBase, y1);
|
||||||
cr.lineTo(x2 - halfBase, y1);
|
cr.lineTo(this._arrowOrigin, y1 - rise);
|
||||||
cr.lineTo(x2, y1 - rise);
|
|
||||||
cr.lineTo(x2, y1 + borderRadius);
|
|
||||||
} else {
|
} else {
|
||||||
cr.lineTo(this._arrowOrigin - halfBase, y1);
|
cr.lineTo(this._arrowOrigin - halfBase, y1);
|
||||||
cr.lineTo(this._arrowOrigin, y1 - rise);
|
cr.lineTo(this._arrowOrigin, y1 - rise);
|
||||||
@ -326,20 +232,19 @@ const BoxPointer = new Lang.Class({
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!skipTopRight) {
|
cr.lineTo(x2 - borderRadius, y1);
|
||||||
cr.lineTo(x2 - borderRadius, y1);
|
|
||||||
cr.arc(x2 - borderRadius, y1 + borderRadius, borderRadius,
|
// top-right corner
|
||||||
3*Math.PI/2, Math.PI*2);
|
cr.arc(x2 - borderRadius, y1 + borderRadius, borderRadius,
|
||||||
}
|
3*Math.PI/2, Math.PI*2);
|
||||||
|
|
||||||
if (this._arrowSide == St.Side.RIGHT) {
|
if (this._arrowSide == St.Side.RIGHT) {
|
||||||
if (skipTopRight) {
|
if (this._arrowOrigin < (y1 + (borderRadius + halfBase))) {
|
||||||
cr.lineTo(x2 + rise, y1);
|
cr.lineTo(x2 + rise, this._arrowOrigin);
|
||||||
cr.lineTo(x2 + rise, y1 + halfBase);
|
cr.lineTo(x2, Math.max(y1 + borderRadius, this._arrowOrigin) + halfBase);
|
||||||
} else if (skipBottomRight) {
|
} else if (this._arrowOrigin > (y2 - (borderRadius + halfBase))) {
|
||||||
cr.lineTo(x2, y2 - halfBase);
|
cr.lineTo(x2, Math.min(y2 - borderRadius, this._arrowOrigin) - halfBase);
|
||||||
cr.lineTo(x2 + rise, y2);
|
cr.lineTo(x2 + rise, this._arrowOrigin);
|
||||||
cr.lineTo(x2 - borderRadius, y2);
|
|
||||||
} else {
|
} else {
|
||||||
cr.lineTo(x2, this._arrowOrigin - halfBase);
|
cr.lineTo(x2, this._arrowOrigin - halfBase);
|
||||||
cr.lineTo(x2 + rise, this._arrowOrigin);
|
cr.lineTo(x2 + rise, this._arrowOrigin);
|
||||||
@ -347,20 +252,19 @@ const BoxPointer = new Lang.Class({
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!skipBottomRight) {
|
cr.lineTo(x2, y2 - borderRadius);
|
||||||
cr.lineTo(x2, y2 - borderRadius);
|
|
||||||
cr.arc(x2 - borderRadius, y2 - borderRadius, borderRadius,
|
// bottom-right corner
|
||||||
0, Math.PI/2);
|
cr.arc(x2 - borderRadius, y2 - borderRadius, borderRadius,
|
||||||
}
|
0, Math.PI/2);
|
||||||
|
|
||||||
if (this._arrowSide == St.Side.BOTTOM) {
|
if (this._arrowSide == St.Side.BOTTOM) {
|
||||||
if (skipBottomLeft) {
|
if (this._arrowOrigin < (x1 + (borderRadius + halfBase))) {
|
||||||
cr.lineTo(x1 + halfBase, y2);
|
cr.lineTo(Math.max(x1 + borderRadius, this._arrowOrigin) + halfBase, y2);
|
||||||
cr.lineTo(x1, y2 + rise);
|
cr.lineTo(this._arrowOrigin, y2 + rise);
|
||||||
cr.lineTo(x1, y2 - borderRadius);
|
} else if (this._arrowOrigin > (x2 - (borderRadius + halfBase))) {
|
||||||
} else if (skipBottomRight) {
|
cr.lineTo(this._arrowOrigin, y2 + rise);
|
||||||
cr.lineTo(x2, y2 + rise);
|
cr.lineTo(Math.min(x2 - borderRadius, this._arrowOrigin) - halfBase, y2);
|
||||||
cr.lineTo(x2 - halfBase, y2);
|
|
||||||
} else {
|
} else {
|
||||||
cr.lineTo(this._arrowOrigin + halfBase, y2);
|
cr.lineTo(this._arrowOrigin + halfBase, y2);
|
||||||
cr.lineTo(this._arrowOrigin, y2 + rise);
|
cr.lineTo(this._arrowOrigin, y2 + rise);
|
||||||
@ -368,20 +272,19 @@ const BoxPointer = new Lang.Class({
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!skipBottomLeft) {
|
cr.lineTo(x1 + borderRadius, y2);
|
||||||
cr.lineTo(x1 + borderRadius, y2);
|
|
||||||
cr.arc(x1 + borderRadius, y2 - borderRadius, borderRadius,
|
// bottom-left corner
|
||||||
Math.PI/2, Math.PI);
|
cr.arc(x1 + borderRadius, y2 - borderRadius, borderRadius,
|
||||||
}
|
Math.PI/2, Math.PI);
|
||||||
|
|
||||||
if (this._arrowSide == St.Side.LEFT) {
|
if (this._arrowSide == St.Side.LEFT) {
|
||||||
if (skipTopLeft) {
|
if (this._arrowOrigin < (y1 + (borderRadius + halfBase))) {
|
||||||
cr.lineTo(x1, y1 + halfBase);
|
cr.lineTo(x1, Math.max(y1 + borderRadius, this._arrowOrigin) + halfBase);
|
||||||
cr.lineTo(x1 - rise, y1);
|
cr.lineTo(x1 - rise, this._arrowOrigin);
|
||||||
cr.lineTo(x1 + borderRadius, y1);
|
} else if (this._arrowOrigin > (y2 - (borderRadius + halfBase))) {
|
||||||
} else if (skipBottomLeft) {
|
cr.lineTo(x1 - rise, this._arrowOrigin);
|
||||||
cr.lineTo(x1 - rise, y2)
|
cr.lineTo(x1, Math.min(y2 - borderRadius, this._arrowOrigin) - halfBase);
|
||||||
cr.lineTo(x1 - rise, y2 - halfBase);
|
|
||||||
} else {
|
} else {
|
||||||
cr.lineTo(x1, this._arrowOrigin + halfBase);
|
cr.lineTo(x1, this._arrowOrigin + halfBase);
|
||||||
cr.lineTo(x1 - rise, this._arrowOrigin);
|
cr.lineTo(x1 - rise, this._arrowOrigin);
|
||||||
@ -389,66 +292,50 @@ const BoxPointer = new Lang.Class({
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!skipTopLeft) {
|
cr.lineTo(x1, y1 + borderRadius);
|
||||||
cr.lineTo(x1, y1 + borderRadius);
|
|
||||||
cr.arc(x1 + borderRadius, y1 + borderRadius, borderRadius,
|
// top-left corner
|
||||||
Math.PI, 3*Math.PI/2);
|
cr.arc(x1 + borderRadius, y1 + borderRadius, borderRadius,
|
||||||
}
|
Math.PI, 3*Math.PI/2);
|
||||||
|
|
||||||
Clutter.cairo_set_source_color(cr, backgroundColor);
|
Clutter.cairo_set_source_color(cr, backgroundColor);
|
||||||
cr.fillPreserve();
|
cr.fillPreserve();
|
||||||
|
Clutter.cairo_set_source_color(cr, borderColor);
|
||||||
if (borderWidth > 0) {
|
cr.setLineWidth(borderWidth);
|
||||||
let borderColor = themeNode.get_color('-arrow-border-color');
|
cr.stroke();
|
||||||
Clutter.cairo_set_source_color(cr, borderColor);
|
|
||||||
cr.setLineWidth(borderWidth);
|
|
||||||
cr.stroke();
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
|
|
||||||
setPosition: function(sourceActor, alignment) {
|
setPosition: function(sourceActor, gap, alignment) {
|
||||||
this._arrowSide = this._userArrowSide;
|
|
||||||
|
|
||||||
// We need to show it now to force an allocation,
|
// We need to show it now to force an allocation,
|
||||||
// so that we can query the correct size.
|
// so that we can query the correct size.
|
||||||
this.actor.show();
|
this.actor.show();
|
||||||
|
|
||||||
this._sourceActor = sourceActor;
|
this._sourceActor = sourceActor;
|
||||||
this._arrowAlignment = alignment;
|
this._gap = gap;
|
||||||
|
this._alignment = alignment;
|
||||||
|
|
||||||
this._reposition(sourceActor, alignment);
|
this._reposition(sourceActor, gap, alignment);
|
||||||
},
|
},
|
||||||
|
|
||||||
setSourceAlignment: function(alignment) {
|
_reposition: function(sourceActor, gap, alignment) {
|
||||||
this._sourceAlignment = alignment;
|
|
||||||
|
|
||||||
if (!this._sourceActor)
|
|
||||||
return;
|
|
||||||
|
|
||||||
this.setPosition(this._sourceActor, this._arrowAlignment);
|
|
||||||
},
|
|
||||||
|
|
||||||
_reposition: function(sourceActor, alignment) {
|
|
||||||
// Position correctly relative to the sourceActor
|
// Position correctly relative to the sourceActor
|
||||||
let sourceNode = sourceActor.get_theme_node();
|
let sourceNode = sourceActor.get_theme_node();
|
||||||
let sourceContentBox = sourceNode.get_content_box(sourceActor.get_allocation_box());
|
let sourceContentBox = sourceNode.get_content_box(sourceActor.get_allocation_box());
|
||||||
let sourceAllocation = Shell.util_get_transformed_allocation(sourceActor);
|
let sourceAllocation = Shell.util_get_transformed_allocation(sourceActor);
|
||||||
let sourceCenterX = sourceAllocation.x1 + sourceContentBox.x1 + (sourceContentBox.x2 - sourceContentBox.x1) * this._sourceAlignment;
|
let sourceCenterX = sourceAllocation.x1 + sourceContentBox.x1 + (sourceContentBox.x2 - sourceContentBox.x1) / 2;
|
||||||
let sourceCenterY = sourceAllocation.y1 + sourceContentBox.y1 + (sourceContentBox.y2 - sourceContentBox.y1) * this._sourceAlignment;
|
let sourceCenterY = sourceAllocation.y1 + sourceContentBox.y1 + (sourceContentBox.y2 - sourceContentBox.y1) / 2;
|
||||||
let [minWidth, minHeight, natWidth, natHeight] = this.actor.get_preferred_size();
|
let [minWidth, minHeight, natWidth, natHeight] = this.actor.get_preferred_size();
|
||||||
|
|
||||||
// We also want to keep it onscreen, and separated from the
|
// We also want to keep it onscreen, and separated from the
|
||||||
// edge by the same distance as the main part of the box is
|
// edge by the same distance as the main part of the box is
|
||||||
// separated from its sourceActor
|
// separated from its sourceActor
|
||||||
let monitor = Main.layoutManager.findMonitorForActor(sourceActor);
|
let primary = global.get_primary_monitor();
|
||||||
let themeNode = this.actor.get_theme_node();
|
let themeNode = this.actor.get_theme_node();
|
||||||
let borderWidth = themeNode.get_length('-arrow-border-width');
|
let borderWidth = themeNode.get_length('-arrow-border-width');
|
||||||
let arrowBase = themeNode.get_length('-arrow-base');
|
let arrowBase = themeNode.get_length('-arrow-base');
|
||||||
let borderRadius = themeNode.get_length('-arrow-border-radius');
|
let borderRadius = themeNode.get_length('-arrow-border-radius');
|
||||||
let margin = (4 * borderRadius + borderWidth + arrowBase);
|
let margin = (4 * borderRadius + borderWidth + arrowBase);
|
||||||
|
let halfMargin = margin / 2;
|
||||||
let gap = themeNode.get_length('-boxpointer-gap');
|
|
||||||
let padding = themeNode.get_length('-arrow-rise');
|
|
||||||
|
|
||||||
let resX, resY;
|
let resX, resY;
|
||||||
|
|
||||||
@ -467,66 +354,29 @@ const BoxPointer = new Lang.Class({
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Now align and position the pointing axis, making sure it fits on
|
// Now align and position the pointing axis, making sure
|
||||||
// screen. If the arrowOrigin is so close to the edge that the arrow
|
// it fits on screen
|
||||||
// will not be isosceles, we try to compensate as follows:
|
|
||||||
// - We skip the rounded corner and settle for a right angled arrow
|
|
||||||
// as shown below. See _drawBorder for further details.
|
|
||||||
// |\_____
|
|
||||||
// |
|
|
||||||
// |
|
|
||||||
// - If the arrow was going to be acute angled, we move the position
|
|
||||||
// of the box to maintain the arrow's accuracy.
|
|
||||||
|
|
||||||
let arrowOrigin;
|
|
||||||
let halfBase = Math.floor(arrowBase/2);
|
|
||||||
let halfBorder = borderWidth / 2;
|
|
||||||
let halfMargin = margin / 2;
|
|
||||||
let [x1, y1] = [halfBorder, halfBorder];
|
|
||||||
let [x2, y2] = [natWidth - halfBorder, natHeight - halfBorder];
|
|
||||||
|
|
||||||
switch (this._arrowSide) {
|
switch (this._arrowSide) {
|
||||||
case St.Side.TOP:
|
case St.Side.TOP:
|
||||||
case St.Side.BOTTOM:
|
case St.Side.BOTTOM:
|
||||||
resX = sourceCenterX - (halfMargin + (natWidth - margin) * alignment);
|
resX = sourceCenterX - (halfMargin + (natWidth - margin) * alignment);
|
||||||
|
|
||||||
resX = Math.max(resX, monitor.x + padding);
|
resX = Math.max(resX, primary.x + 10);
|
||||||
resX = Math.min(resX, monitor.x + monitor.width - (padding + natWidth));
|
resX = Math.min(resX, primary.x + primary.width - (10 + natWidth));
|
||||||
|
this.setArrowOrigin(sourceCenterX - resX);
|
||||||
arrowOrigin = sourceCenterX - resX;
|
|
||||||
if (arrowOrigin <= (x1 + (borderRadius + halfBase))) {
|
|
||||||
if (arrowOrigin > x1)
|
|
||||||
resX += (arrowOrigin - x1);
|
|
||||||
arrowOrigin = x1;
|
|
||||||
} else if (arrowOrigin >= (x2 - (borderRadius + halfBase))) {
|
|
||||||
if (arrowOrigin < x2)
|
|
||||||
resX -= (x2 - arrowOrigin);
|
|
||||||
arrowOrigin = x2;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case St.Side.LEFT:
|
case St.Side.LEFT:
|
||||||
case St.Side.RIGHT:
|
case St.Side.RIGHT:
|
||||||
resY = sourceCenterY - (halfMargin + (natHeight - margin) * alignment);
|
resY = sourceCenterY - (halfMargin + (natHeight - margin) * alignment);
|
||||||
|
|
||||||
resY = Math.max(resY, monitor.y + padding);
|
resY = Math.max(resY, primary.y + 10);
|
||||||
resY = Math.min(resY, monitor.y + monitor.height - (padding + natHeight));
|
resY = Math.min(resY, primary.y + primary.height - (10 + natHeight));
|
||||||
|
|
||||||
arrowOrigin = sourceCenterY - resY;
|
this.setArrowOrigin(sourceCenterY - resY);
|
||||||
if (arrowOrigin <= (y1 + (borderRadius + halfBase))) {
|
|
||||||
if (arrowOrigin > y1)
|
|
||||||
resY += (arrowOrigin - y1);
|
|
||||||
arrowOrigin = y1;
|
|
||||||
} else if (arrowOrigin >= (y2 - (borderRadius + halfBase))) {
|
|
||||||
if (arrowOrigin < y2)
|
|
||||||
resX -= (y2 - arrowOrigin);
|
|
||||||
arrowOrigin = y2;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.setArrowOrigin(arrowOrigin);
|
|
||||||
|
|
||||||
let parent = this.actor.get_parent();
|
let parent = this.actor.get_parent();
|
||||||
let success, x, y;
|
let success, x, y;
|
||||||
while (!success) {
|
while (!success) {
|
||||||
@ -560,39 +410,6 @@ const BoxPointer = new Lang.Class({
|
|||||||
-(this._yPosition + this._yOffset));
|
-(this._yPosition + this._yOffset));
|
||||||
},
|
},
|
||||||
|
|
||||||
_shouldFlip: function() {
|
|
||||||
let sourceAllocation = Shell.util_get_transformed_allocation(this._sourceActor);
|
|
||||||
let boxAllocation = Shell.util_get_transformed_allocation(this.actor);
|
|
||||||
let boxWidth = boxAllocation.x2 - boxAllocation.x1;
|
|
||||||
let boxHeight = boxAllocation.y2 - boxAllocation.y1;
|
|
||||||
let monitor = Main.layoutManager.findMonitorForActor(this.actor);
|
|
||||||
|
|
||||||
switch (this._arrowSide) {
|
|
||||||
case St.Side.TOP:
|
|
||||||
if (boxAllocation.y2 > monitor.y + monitor.height &&
|
|
||||||
boxHeight < sourceAllocation.y1 - monitor.y)
|
|
||||||
return true;
|
|
||||||
break;
|
|
||||||
case St.Side.BOTTOM:
|
|
||||||
if (boxAllocation.y1 < monitor.y &&
|
|
||||||
boxHeight < monitor.y + monitor.height - sourceAllocation.y2)
|
|
||||||
return true;
|
|
||||||
break;
|
|
||||||
case St.Side.LEFT:
|
|
||||||
if (boxAllocation.x2 > monitor.x + monitor.width &&
|
|
||||||
boxWidth < sourceAllocation.x1 - monitor.x)
|
|
||||||
return true;
|
|
||||||
break;
|
|
||||||
case St.Side.RIGHT:
|
|
||||||
if (boxAllocation.x1 < monitor.x &&
|
|
||||||
boxWidth < monitor.x + monitor.width - sourceAllocation.x2)
|
|
||||||
return true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
},
|
|
||||||
|
|
||||||
set xOffset(offset) {
|
set xOffset(offset) {
|
||||||
this._xOffset = offset;
|
this._xOffset = offset;
|
||||||
this._shiftActor();
|
this._shiftActor();
|
||||||
@ -618,4 +435,4 @@ const BoxPointer = new Lang.Class({
|
|||||||
get opacity() {
|
get opacity() {
|
||||||
return this.actor.opacity;
|
return this.actor.opacity;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
|
||||||
|
|
||||||
|
const DBus = imports.dbus;
|
||||||
const Clutter = imports.gi.Clutter;
|
const Clutter = imports.gi.Clutter;
|
||||||
const Gio = imports.gi.Gio;
|
const Gio = imports.gi.Gio;
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
@ -7,6 +8,9 @@ const St = imports.gi.St;
|
|||||||
const Signals = imports.signals;
|
const Signals = imports.signals;
|
||||||
const Pango = imports.gi.Pango;
|
const Pango = imports.gi.Pango;
|
||||||
const Gettext_gtk30 = imports.gettext.domain('gtk30');
|
const Gettext_gtk30 = imports.gettext.domain('gtk30');
|
||||||
|
const Gettext = imports.gettext.domain('gnome-shell');
|
||||||
|
const _ = Gettext.gettext;
|
||||||
|
const C_ = Gettext.pgettext;
|
||||||
const Mainloop = imports.mainloop;
|
const Mainloop = imports.mainloop;
|
||||||
const Shell = imports.gi.Shell;
|
const Shell = imports.gi.Shell;
|
||||||
|
|
||||||
@ -155,24 +159,28 @@ function _getEventDayAbbreviation(dayNumber) {
|
|||||||
|
|
||||||
// Abstraction for an appointment/event in a calendar
|
// Abstraction for an appointment/event in a calendar
|
||||||
|
|
||||||
const CalendarEvent = new Lang.Class({
|
function CalendarEvent(date, end, summary, allDay) {
|
||||||
Name: 'CalendarEvent',
|
this._init(date, end, summary, allDay);
|
||||||
|
}
|
||||||
|
|
||||||
|
CalendarEvent.prototype = {
|
||||||
_init: function(date, end, summary, allDay) {
|
_init: function(date, end, summary, allDay) {
|
||||||
this.date = date;
|
this.date = date;
|
||||||
this.end = end;
|
this.end = end;
|
||||||
this.summary = summary;
|
this.summary = summary;
|
||||||
this.allDay = allDay;
|
this.allDay = allDay;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
|
||||||
// Interface for appointments/events - e.g. the contents of a calendar
|
// Interface for appointments/events - e.g. the contents of a calendar
|
||||||
//
|
//
|
||||||
|
|
||||||
// First, an implementation with no events
|
// First, an implementation with no events
|
||||||
const EmptyEventSource = new Lang.Class({
|
function EmptyEventSource() {
|
||||||
Name: 'EmptyEventSource',
|
this._init();
|
||||||
|
}
|
||||||
|
|
||||||
|
EmptyEventSource.prototype = {
|
||||||
_init: function() {
|
_init: function() {
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -187,31 +195,33 @@ const EmptyEventSource = new Lang.Class({
|
|||||||
hasEvents: function(day) {
|
hasEvents: function(day) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
Signals.addSignalMethods(EmptyEventSource.prototype);
|
Signals.addSignalMethods(EmptyEventSource.prototype);
|
||||||
|
|
||||||
const CalendarServerIface = <interface name="org.gnome.Shell.CalendarServer">
|
const CalendarServerIface = {
|
||||||
<method name="GetEvents">
|
name: 'org.gnome.Shell.CalendarServer',
|
||||||
<arg type="x" direction="in" />
|
methods: [{ name: 'GetEvents',
|
||||||
<arg type="x" direction="in" />
|
inSignature: 'xxb',
|
||||||
<arg type="b" direction="in" />
|
outSignature: 'a(sssbxxa{sv})' }],
|
||||||
<arg type="a(sssbxxa{sv})" direction="out" />
|
signals: [{ name: 'Changed',
|
||||||
</method>
|
inSignature: '' }]
|
||||||
<signal name="Changed" />
|
};
|
||||||
</interface>;
|
|
||||||
|
|
||||||
const CalendarServerInfo = Gio.DBusInterfaceInfo.new_for_xml(CalendarServerIface);
|
const CalendarServer = function () {
|
||||||
|
this._init();
|
||||||
|
};
|
||||||
|
|
||||||
function CalendarServer() {
|
CalendarServer.prototype = {
|
||||||
var self = new Gio.DBusProxy({ g_connection: Gio.DBus.session,
|
_init: function() {
|
||||||
g_interface_name: CalendarServerInfo.name,
|
DBus.session.proxifyObject(this, 'org.gnome.Shell.CalendarServer', '/org/gnome/Shell/CalendarServer');
|
||||||
g_interface_info: CalendarServerInfo,
|
}
|
||||||
g_name: 'org.gnome.Shell.CalendarServer',
|
};
|
||||||
g_object_path: '/org/gnome/Shell/CalendarServer',
|
|
||||||
g_flags: Gio.DBusProxyFlags.DO_NOT_LOAD_PROPERTIES });
|
|
||||||
|
|
||||||
self.init(null);
|
DBus.proxifyPrototype(CalendarServer.prototype, CalendarServerIface);
|
||||||
return self;
|
|
||||||
|
// an implementation that reads data from a session bus service
|
||||||
|
function DBusEventSource(owner) {
|
||||||
|
this._init(owner);
|
||||||
}
|
}
|
||||||
|
|
||||||
function _datesEqual(a, b) {
|
function _datesEqual(a, b) {
|
||||||
@ -232,22 +242,18 @@ function _dateIntervalsOverlap(a0, a1, b0, b1)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// an implementation that reads data from a session bus service
|
|
||||||
const DBusEventSource = new Lang.Class({
|
|
||||||
Name: 'DBusEventSource',
|
|
||||||
|
|
||||||
_init: function() {
|
DBusEventSource.prototype = {
|
||||||
|
_init: function(owner) {
|
||||||
this._resetCache();
|
this._resetCache();
|
||||||
|
|
||||||
this._dbusProxy = new CalendarServer();
|
this._dbusProxy = new CalendarServer(owner);
|
||||||
this._dbusProxy.connectSignal('Changed', Lang.bind(this, this._onChanged));
|
this._dbusProxy.connect('Changed', Lang.bind(this, this._onChanged));
|
||||||
|
|
||||||
this._dbusProxy.connect('notify::g-name-owner', Lang.bind(this, function() {
|
DBus.session.watch_name('org.gnome.Shell.CalendarServer',
|
||||||
if (this._dbusProxy.g_name_owner)
|
false, // do not launch a name-owner if none exists
|
||||||
this._onNameAppeared();
|
Lang.bind(this, this._onNameAppeared),
|
||||||
else
|
Lang.bind(this, this._onNameVanished));
|
||||||
this._onNameVanished();
|
|
||||||
}));
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_resetCache: function() {
|
_resetCache: function() {
|
||||||
@ -270,7 +276,7 @@ const DBusEventSource = new Lang.Class({
|
|||||||
this._loadEvents(false);
|
this._loadEvents(false);
|
||||||
},
|
},
|
||||||
|
|
||||||
_onEventsReceived: function([appointments]) {
|
_onEventsReceived: function(appointments) {
|
||||||
let newEvents = [];
|
let newEvents = [];
|
||||||
if (appointments != null) {
|
if (appointments != null) {
|
||||||
for (let n = 0; n < appointments.length; n++) {
|
for (let n = 0; n < appointments.length; n++) {
|
||||||
@ -293,9 +299,9 @@ const DBusEventSource = new Lang.Class({
|
|||||||
|
|
||||||
_loadEvents: function(forceReload) {
|
_loadEvents: function(forceReload) {
|
||||||
if (this._curRequestBegin && this._curRequestEnd){
|
if (this._curRequestBegin && this._curRequestEnd){
|
||||||
let callFlags = Gio.DBusCallFlags.NO_AUTO_START;
|
let callFlags = 0;
|
||||||
if (forceReload)
|
if (forceReload)
|
||||||
callFlags = Gio.DBusCallFlags.NONE;
|
callFlags |= DBus.CALL_FLAG_START;
|
||||||
this._dbusProxy.GetEventsRemote(this._curRequestBegin.getTime() / 1000,
|
this._dbusProxy.GetEventsRemote(this._curRequestBegin.getTime() / 1000,
|
||||||
this._curRequestEnd.getTime() / 1000,
|
this._curRequestEnd.getTime() / 1000,
|
||||||
forceReload,
|
forceReload,
|
||||||
@ -336,14 +342,29 @@ const DBusEventSource = new Lang.Class({
|
|||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
Signals.addSignalMethods(DBusEventSource.prototype);
|
Signals.addSignalMethods(DBusEventSource.prototype);
|
||||||
|
|
||||||
const Calendar = new Lang.Class({
|
// Calendar:
|
||||||
Name: 'Calendar',
|
// @eventSource: is an object implementing the EventSource API, e.g. the
|
||||||
|
// requestRange(), getEvents(), hasEvents() methods and the ::changed signal.
|
||||||
|
function Calendar(eventSource) {
|
||||||
|
this._init(eventSource);
|
||||||
|
}
|
||||||
|
|
||||||
_init: function() {
|
Calendar.prototype = {
|
||||||
this._weekStart = Shell.util_get_week_start();
|
_init: function(eventSource) {
|
||||||
|
this._eventSource = eventSource;
|
||||||
|
|
||||||
|
this._eventSource.connect('changed', Lang.bind(this,
|
||||||
|
function() {
|
||||||
|
this._update(false);
|
||||||
|
}));
|
||||||
|
|
||||||
|
// FIXME: This is actually the fallback method for GTK+ for the week start;
|
||||||
|
// GTK+ by preference uses nl_langinfo (NL_TIME_FIRST_WEEKDAY). We probably
|
||||||
|
// should add a C function so we can do the full handling.
|
||||||
|
this._weekStart = NaN;
|
||||||
this._weekdate = NaN;
|
this._weekdate = NaN;
|
||||||
this._digitWidth = NaN;
|
this._digitWidth = NaN;
|
||||||
this._settings = new Gio.Settings({ schema: 'org.gnome.shell.calendar' });
|
this._settings = new Gio.Settings({ schema: 'org.gnome.shell.calendar' });
|
||||||
@ -351,6 +372,16 @@ const Calendar = new Lang.Class({
|
|||||||
this._settings.connect('changed::' + SHOW_WEEKDATE_KEY, Lang.bind(this, this._onSettingsChange));
|
this._settings.connect('changed::' + SHOW_WEEKDATE_KEY, Lang.bind(this, this._onSettingsChange));
|
||||||
this._useWeekdate = this._settings.get_boolean(SHOW_WEEKDATE_KEY);
|
this._useWeekdate = this._settings.get_boolean(SHOW_WEEKDATE_KEY);
|
||||||
|
|
||||||
|
let weekStartString = Gettext_gtk30.gettext('calendar:week_start:0');
|
||||||
|
if (weekStartString.indexOf('calendar:week_start:') == 0) {
|
||||||
|
this._weekStart = parseInt(weekStartString.substring(20));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isNaN(this._weekStart) || this._weekStart < 0 || this._weekStart > 6) {
|
||||||
|
log('Translation of "calendar:week_start:0" in GTK+ is not correct');
|
||||||
|
this._weekStart = 0;
|
||||||
|
}
|
||||||
|
|
||||||
// Find the ordering for month/year in the calendar heading
|
// Find the ordering for month/year in the calendar heading
|
||||||
this._headerFormatWithoutYear = '%B';
|
this._headerFormatWithoutYear = '%B';
|
||||||
switch (Gettext_gtk30.gettext('calendar:MY')) {
|
switch (Gettext_gtk30.gettext('calendar:MY')) {
|
||||||
@ -379,24 +410,6 @@ const Calendar = new Lang.Class({
|
|||||||
this._buildHeader ();
|
this._buildHeader ();
|
||||||
},
|
},
|
||||||
|
|
||||||
// @eventSource: is an object implementing the EventSource API, e.g. the
|
|
||||||
// requestRange(), getEvents(), hasEvents() methods and the ::changed signal.
|
|
||||||
setEventSource: function(eventSource) {
|
|
||||||
if (this._eventSource) {
|
|
||||||
this._eventSource.disconnect(this._eventSourceChangedId);
|
|
||||||
this._eventSource = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._eventSource = eventSource;
|
|
||||||
|
|
||||||
if (this._eventSource) {
|
|
||||||
this._eventSourceChangedId = this._eventSource.connect('changed', Lang.bind(this, function() {
|
|
||||||
this._update(false);
|
|
||||||
}));
|
|
||||||
this._update(true);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
// Sets the calendar to show a specific date
|
// Sets the calendar to show a specific date
|
||||||
setDate: function(date, forceReload) {
|
setDate: function(date, forceReload) {
|
||||||
if (!_sameDay(date, this._selectedDate)) {
|
if (!_sameDay(date, this._selectedDate)) {
|
||||||
@ -411,7 +424,7 @@ const Calendar = new Lang.Class({
|
|||||||
|
|
||||||
_buildHeader: function() {
|
_buildHeader: function() {
|
||||||
let offsetCols = this._useWeekdate ? 1 : 0;
|
let offsetCols = this._useWeekdate ? 1 : 0;
|
||||||
this.actor.destroy_all_children();
|
this.actor.destroy_children();
|
||||||
|
|
||||||
// Top line of the calendar '<| September 2009 |>'
|
// Top line of the calendar '<| September 2009 |>'
|
||||||
this._topBox = new St.BoxLayout();
|
this._topBox = new St.BoxLayout();
|
||||||
@ -453,7 +466,7 @@ const Calendar = new Lang.Class({
|
|||||||
}
|
}
|
||||||
|
|
||||||
// All the children after this are days, and get removed when we update the calendar
|
// All the children after this are days, and get removed when we update the calendar
|
||||||
this._firstDayIndex = this.actor.get_n_children();
|
this._firstDayIndex = this.actor.get_children().length;
|
||||||
},
|
},
|
||||||
|
|
||||||
_onStyleChange: function(actor, event) {
|
_onStyleChange: function(actor, event) {
|
||||||
@ -556,10 +569,6 @@ const Calendar = new Lang.Class({
|
|||||||
let row = 2;
|
let row = 2;
|
||||||
while (true) {
|
while (true) {
|
||||||
let button = new St.Button({ label: iter.getDate().toString() });
|
let button = new St.Button({ label: iter.getDate().toString() });
|
||||||
let rtl = button.get_text_direction() == Clutter.TextDirection.RTL;
|
|
||||||
|
|
||||||
if (!this._eventSource)
|
|
||||||
button.reactive = false;
|
|
||||||
|
|
||||||
let iterStr = iter.toUTCString();
|
let iterStr = iter.toUTCString();
|
||||||
button.connect('clicked', Lang.bind(this, function() {
|
button.connect('clicked', Lang.bind(this, function() {
|
||||||
@ -567,7 +576,7 @@ const Calendar = new Lang.Class({
|
|||||||
this.setDate(newlySelectedDate, false);
|
this.setDate(newlySelectedDate, false);
|
||||||
}));
|
}));
|
||||||
|
|
||||||
let hasEvents = this._eventSource && this._eventSource.hasEvents(iter);
|
let hasEvents = this._eventSource.hasEvents(iter);
|
||||||
let styleClass = 'calendar-day-base calendar-day';
|
let styleClass = 'calendar-day-base calendar-day';
|
||||||
if (_isWorkDay(iter))
|
if (_isWorkDay(iter))
|
||||||
styleClass += ' calendar-work-day'
|
styleClass += ' calendar-work-day'
|
||||||
@ -577,10 +586,7 @@ const Calendar = new Lang.Class({
|
|||||||
// Hack used in lieu of border-collapse - see gnome-shell.css
|
// Hack used in lieu of border-collapse - see gnome-shell.css
|
||||||
if (row == 2)
|
if (row == 2)
|
||||||
styleClass = 'calendar-day-top ' + styleClass;
|
styleClass = 'calendar-day-top ' + styleClass;
|
||||||
|
if (iter.getDay() == this._weekStart)
|
||||||
let leftMost = rtl ? iter.getDay() == (this._weekStart + 6) % 7
|
|
||||||
: iter.getDay() == this._weekStart;
|
|
||||||
if (leftMost)
|
|
||||||
styleClass = 'calendar-day-left ' + styleClass;
|
styleClass = 'calendar-day-left ' + styleClass;
|
||||||
|
|
||||||
if (_sameDay(now, iter))
|
if (_sameDay(now, iter))
|
||||||
@ -617,35 +623,37 @@ const Calendar = new Lang.Class({
|
|||||||
}
|
}
|
||||||
// Signal to the event source that we are interested in events
|
// Signal to the event source that we are interested in events
|
||||||
// only from this date range
|
// only from this date range
|
||||||
if (this._eventSource)
|
this._eventSource.requestRange(beginDate, iter, forceReload);
|
||||||
this._eventSource.requestRange(beginDate, iter, forceReload);
|
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
|
||||||
Signals.addSignalMethods(Calendar.prototype);
|
Signals.addSignalMethods(Calendar.prototype);
|
||||||
|
|
||||||
const EventsList = new Lang.Class({
|
function EventsList(eventSource) {
|
||||||
Name: 'EventsList',
|
this._init(eventSource);
|
||||||
|
}
|
||||||
|
|
||||||
_init: function() {
|
EventsList.prototype = {
|
||||||
|
_init: function(eventSource) {
|
||||||
this.actor = new St.BoxLayout({ vertical: true, style_class: 'events-header-vbox'});
|
this.actor = new St.BoxLayout({ vertical: true, style_class: 'events-header-vbox'});
|
||||||
this._date = new Date();
|
this._date = new Date();
|
||||||
|
this._eventSource = eventSource;
|
||||||
|
this._eventSource.connect('changed', Lang.bind(this, this._update));
|
||||||
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));
|
||||||
this._weekStart = Shell.util_get_week_start();
|
let weekStartString = Gettext_gtk30.gettext('calendar:week_start:0');
|
||||||
},
|
if (weekStartString.indexOf('calendar:week_start:') == 0) {
|
||||||
|
this._weekStart = parseInt(weekStartString.substring(20));
|
||||||
setEventSource: function(eventSource) {
|
|
||||||
if (this._eventSource) {
|
|
||||||
this._eventSource.disconnect(this._eventSourceChangedId);
|
|
||||||
this._eventSource = null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
this._eventSource = eventSource;
|
if (isNaN(this._weekStart) ||
|
||||||
|
this._weekStart < 0 ||
|
||||||
if (this._eventSource) {
|
this._weekStart > 6) {
|
||||||
this._eventSourceChangedId = this._eventSource.connect('changed', Lang.bind(this, this._update));
|
log('Translation of "calendar:week_start:0" in GTK+ is not correct');
|
||||||
|
this._weekStart = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this._update();
|
||||||
},
|
},
|
||||||
|
|
||||||
_addEvent: function(dayNameBox, timeBox, eventTitleBox, includeDayName, day, time, desc) {
|
_addEvent: function(dayNameBox, timeBox, eventTitleBox, includeDayName, day, time, desc) {
|
||||||
@ -662,9 +670,6 @@ const EventsList = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_addPeriod: function(header, begin, end, includeDayName, showNothingScheduled) {
|
_addPeriod: function(header, begin, end, includeDayName, showNothingScheduled) {
|
||||||
if (!this._eventSource)
|
|
||||||
return;
|
|
||||||
|
|
||||||
let events = this._eventSource.getEvents(begin, end);
|
let events = this._eventSource.getEvents(begin, end);
|
||||||
|
|
||||||
let clockFormat = this._desktopSettings.get_string(CLOCK_FORMAT_KEY);;
|
let clockFormat = this._desktopSettings.get_string(CLOCK_FORMAT_KEY);;
|
||||||
@ -703,7 +708,7 @@ const EventsList = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_showOtherDay: function(day) {
|
_showOtherDay: function(day) {
|
||||||
this.actor.destroy_all_children();
|
this.actor.destroy_children();
|
||||||
|
|
||||||
let dayBegin = _getBeginningOfDay(day);
|
let dayBegin = _getBeginningOfDay(day);
|
||||||
let dayEnd = _getEndOfDay(day);
|
let dayEnd = _getEndOfDay(day);
|
||||||
@ -720,7 +725,7 @@ const EventsList = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_showToday: function() {
|
_showToday: function() {
|
||||||
this.actor.destroy_all_children();
|
this.actor.destroy_children();
|
||||||
|
|
||||||
let now = new Date();
|
let now = new Date();
|
||||||
let dayBegin = _getBeginningOfDay(now);
|
let dayBegin = _getBeginningOfDay(now);
|
||||||
@ -731,15 +736,13 @@ const EventsList = new Lang.Class({
|
|||||||
let tomorrowEnd = new Date(dayEnd.getTime() + 86400 * 1000);
|
let tomorrowEnd = new Date(dayEnd.getTime() + 86400 * 1000);
|
||||||
this._addPeriod(_("Tomorrow"), tomorrowBegin, tomorrowEnd, false, true);
|
this._addPeriod(_("Tomorrow"), tomorrowBegin, tomorrowEnd, false, true);
|
||||||
|
|
||||||
let dayInWeek = (dayEnd.getDay() - this._weekStart + 7) % 7;
|
if (dayEnd.getDay() <= 4 + this._weekStart) {
|
||||||
|
|
||||||
if (dayInWeek < 5) {
|
|
||||||
/* If now is within the first 5 days we show "This week" and
|
/* If now is within the first 5 days we show "This week" and
|
||||||
* include events up until and including Saturday/Sunday
|
* include events up until and including Saturday/Sunday
|
||||||
* (depending on whether a week starts on Sunday/Monday).
|
* (depending on whether a week starts on Sunday/Monday).
|
||||||
*/
|
*/
|
||||||
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 + this._weekStart - dayEnd.getDay()) * 86400 * 1000);
|
||||||
this._addPeriod(_("This week"), thisWeekBegin, thisWeekEnd, true, false);
|
this._addPeriod(_("This week"), 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
|
||||||
@ -747,7 +750,7 @@ const EventsList = new Lang.Class({
|
|||||||
* Saturday/Sunday
|
* Saturday/Sunday
|
||||||
*/
|
*/
|
||||||
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 + this._weekStart - dayEnd.getDay()) * 86400 * 1000);
|
||||||
this._addPeriod(_("Next week"), nextWeekBegin, nextWeekEnd, true, false);
|
this._addPeriod(_("Next week"), nextWeekBegin, nextWeekEnd, true, false);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@ -768,4 +771,4 @@ const EventsList = new Lang.Class({
|
|||||||
this._showOtherDay(this._date);
|
this._showOtherDay(this._date);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
@ -1,115 +0,0 @@
|
|||||||
const Clutter = imports.gi.Clutter;
|
|
||||||
const Pango = imports.gi.Pango;
|
|
||||||
const Shell = imports.gi.Shell;
|
|
||||||
const St = imports.gi.St;
|
|
||||||
|
|
||||||
const Lang = imports.lang;
|
|
||||||
|
|
||||||
const CheckBoxContainer = new Lang.Class({
|
|
||||||
Name: 'CheckBoxContainer',
|
|
||||||
|
|
||||||
_init: function() {
|
|
||||||
this.actor = new Shell.GenericContainer();
|
|
||||||
this.actor.connect('get-preferred-width',
|
|
||||||
Lang.bind(this, this._getPreferredWidth));
|
|
||||||
this.actor.connect('get-preferred-height',
|
|
||||||
Lang.bind(this, this._getPreferredHeight));
|
|
||||||
this.actor.connect('allocate',
|
|
||||||
Lang.bind(this, this._allocate));
|
|
||||||
this.actor.connect('style-changed', Lang.bind(this,
|
|
||||||
function() {
|
|
||||||
let node = this.actor.get_theme_node();
|
|
||||||
this._spacing = node.get_length('spacing');
|
|
||||||
}));
|
|
||||||
this.actor.request_mode = Clutter.RequestMode.HEIGHT_FOR_WIDTH;
|
|
||||||
|
|
||||||
this._box = new St.Bin();
|
|
||||||
this.actor.add_actor(this._box);
|
|
||||||
|
|
||||||
this.label = new St.Label();
|
|
||||||
this.label.clutter_text.set_line_wrap(true);
|
|
||||||
this.label.clutter_text.set_ellipsize(Pango.EllipsizeMode.NONE);
|
|
||||||
this.actor.add_actor(this.label);
|
|
||||||
|
|
||||||
this._spacing = 0;
|
|
||||||
},
|
|
||||||
|
|
||||||
_getPreferredWidth: function(actor, forHeight, alloc) {
|
|
||||||
let [minWidth, natWidth] = this._box.get_preferred_width(forHeight);
|
|
||||||
|
|
||||||
alloc.min_size = minWidth + this._spacing;
|
|
||||||
alloc.natural_size = natWidth + this._spacing;
|
|
||||||
},
|
|
||||||
|
|
||||||
_getPreferredHeight: function(actor, forWidth, alloc) {
|
|
||||||
/* FIXME: StBoxlayout currently does not handle
|
|
||||||
height-for-width children correctly, so hard-code
|
|
||||||
two lines for the label until that problem is fixed.
|
|
||||||
|
|
||||||
https://bugzilla.gnome.org/show_bug.cgi?id=672543 */
|
|
||||||
/*
|
|
||||||
let [minBoxHeight, natBoxHeight] =
|
|
||||||
this._box.get_preferred_height(forWidth);
|
|
||||||
let [minLabelHeight, natLabelHeight] =
|
|
||||||
this.label.get_preferred_height(forWidth);
|
|
||||||
|
|
||||||
alloc.min_size = Math.max(minBoxHeight, minLabelHeight);
|
|
||||||
alloc.natural_size = Math.max(natBoxHeight, natLabelHeight);
|
|
||||||
*/
|
|
||||||
let [minBoxHeight, natBoxHeight] =
|
|
||||||
this._box.get_preferred_height(-1);
|
|
||||||
let [minLabelHeight, natLabelHeight] =
|
|
||||||
this.label.get_preferred_height(-1);
|
|
||||||
|
|
||||||
alloc.min_size = Math.max(minBoxHeight, 2 * minLabelHeight);
|
|
||||||
alloc.natural_size = Math.max(natBoxHeight, 2 * natLabelHeight);
|
|
||||||
},
|
|
||||||
|
|
||||||
_allocate: function(actor, box, flags) {
|
|
||||||
let availWidth = box.x2 - box.x1;
|
|
||||||
let availHeight = box.y2 - box.y1;
|
|
||||||
|
|
||||||
let childBox = new Clutter.ActorBox();
|
|
||||||
let [minBoxWidth, natBoxWidth] =
|
|
||||||
this._box.get_preferred_width(-1);
|
|
||||||
let [minBoxHeight, natBoxHeight] =
|
|
||||||
this._box.get_preferred_height(-1);
|
|
||||||
childBox.x1 = box.x1;
|
|
||||||
childBox.x2 = box.x1 + natBoxWidth;
|
|
||||||
childBox.y1 = box.y1;
|
|
||||||
childBox.y2 = box.y1 + natBoxHeight;
|
|
||||||
this._box.allocate(childBox, flags);
|
|
||||||
|
|
||||||
childBox.x1 = box.x1 + natBoxWidth + this._spacing;
|
|
||||||
childBox.x2 = availWidth - childBox.x1;
|
|
||||||
childBox.y1 = box.y1;
|
|
||||||
childBox.y2 = box.y2;
|
|
||||||
this.label.allocate(childBox, flags);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
const CheckBox = new Lang.Class({
|
|
||||||
Name: 'CheckBox',
|
|
||||||
|
|
||||||
_init: function(label) {
|
|
||||||
this.actor = new St.Button({ style_class: 'check-box',
|
|
||||||
button_mask: St.ButtonMask.ONE,
|
|
||||||
toggle_mode: true,
|
|
||||||
can_focus: true,
|
|
||||||
x_fill: true,
|
|
||||||
y_fill: true });
|
|
||||||
this._container = new CheckBoxContainer();
|
|
||||||
this.actor.set_child(this._container.actor);
|
|
||||||
|
|
||||||
if (label)
|
|
||||||
this.setLabel(label);
|
|
||||||
},
|
|
||||||
|
|
||||||
setLabel: function(label) {
|
|
||||||
this._container.label.set_text(label);
|
|
||||||
},
|
|
||||||
|
|
||||||
getLabelActor: function() {
|
|
||||||
return this._container.label;
|
|
||||||
}
|
|
||||||
});
|
|
454
js/ui/chrome.js
Normal file
@ -0,0 +1,454 @@
|
|||||||
|
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
|
||||||
|
|
||||||
|
const Lang = imports.lang;
|
||||||
|
const Mainloop = imports.mainloop;
|
||||||
|
const Meta = imports.gi.Meta;
|
||||||
|
const Shell = imports.gi.Shell;
|
||||||
|
const Signals = imports.signals;
|
||||||
|
|
||||||
|
const Main = imports.ui.main;
|
||||||
|
const Params = imports.misc.params;
|
||||||
|
|
||||||
|
// This manages the shell "chrome"; the UI that's visible in the
|
||||||
|
// normal mode (ie, outside the Overview), that surrounds the main
|
||||||
|
// workspace content.
|
||||||
|
|
||||||
|
const defaultParams = {
|
||||||
|
visibleInOverview: false,
|
||||||
|
visibleInFullscreen: false,
|
||||||
|
affectsStruts: true,
|
||||||
|
affectsInputRegion: true
|
||||||
|
};
|
||||||
|
|
||||||
|
function Chrome() {
|
||||||
|
this._init();
|
||||||
|
}
|
||||||
|
|
||||||
|
Chrome.prototype = {
|
||||||
|
_init: function() {
|
||||||
|
// The group itself has zero size so it doesn't interfere with DND
|
||||||
|
this.actor = new Shell.GenericContainer({ width: 0, height: 0 });
|
||||||
|
Main.uiGroup.add_actor(this.actor);
|
||||||
|
this.actor.connect('allocate', Lang.bind(this, this._allocated));
|
||||||
|
|
||||||
|
this._monitors = [];
|
||||||
|
this._inOverview = false;
|
||||||
|
|
||||||
|
this._trackedActors = [];
|
||||||
|
|
||||||
|
global.screen.connect('monitors-changed',
|
||||||
|
Lang.bind(this, this._monitorsChanged));
|
||||||
|
global.screen.connect('restacked',
|
||||||
|
Lang.bind(this, this._windowsRestacked));
|
||||||
|
|
||||||
|
// Need to update struts on new workspaces when they are added
|
||||||
|
global.screen.connect('notify::n-workspaces',
|
||||||
|
Lang.bind(this, this._queueUpdateRegions));
|
||||||
|
|
||||||
|
Main.overview.connect('showing',
|
||||||
|
Lang.bind(this, this._overviewShowing));
|
||||||
|
Main.overview.connect('hidden',
|
||||||
|
Lang.bind(this, this._overviewHidden));
|
||||||
|
|
||||||
|
this._updateMonitors();
|
||||||
|
this._updateFullscreen();
|
||||||
|
this._queueUpdateRegions();
|
||||||
|
},
|
||||||
|
|
||||||
|
_allocated: function(actor, box, flags) {
|
||||||
|
let children = this.actor.get_children();
|
||||||
|
for (let i = 0; i < children.length; i++)
|
||||||
|
children[i].allocate_preferred_size(flags);
|
||||||
|
},
|
||||||
|
|
||||||
|
// addActor:
|
||||||
|
// @actor: an actor to add to the chrome layer
|
||||||
|
// @params: (optional) additional params
|
||||||
|
//
|
||||||
|
// Adds @actor to the chrome layer and extends the input region
|
||||||
|
// and window manager struts to include it. (Window manager struts
|
||||||
|
// will only be affected if @actor is touching a screen edge.)
|
||||||
|
// Changes in @actor's size and position will automatically result
|
||||||
|
// in appropriate changes to the input region and struts. Changes
|
||||||
|
// in its visibility will affect the input region, but NOT the
|
||||||
|
// struts.
|
||||||
|
//
|
||||||
|
// If %visibleInOverview is %true in @params, @actor will remain
|
||||||
|
// visible when the overview is brought up. Otherwise it will
|
||||||
|
// automatically be hidden. Likewise, if %visibleInFullscreen is
|
||||||
|
// %true, the actor will be visible even when a fullscreen window
|
||||||
|
// should be covering it.
|
||||||
|
//
|
||||||
|
// If %affectsStruts or %affectsInputRegion is %false, the actor
|
||||||
|
// will not have the indicated effect.
|
||||||
|
addActor: function(actor, params) {
|
||||||
|
this.actor.add_actor(actor);
|
||||||
|
this._trackActor(actor, params);
|
||||||
|
},
|
||||||
|
|
||||||
|
// trackActor:
|
||||||
|
// @actor: a descendant of the chrome to begin tracking
|
||||||
|
// @params: parameters describing how to track @actor
|
||||||
|
//
|
||||||
|
// Tells the chrome to track @actor, which must be a descendant
|
||||||
|
// of an actor added via addActor(). This can be used to extend the
|
||||||
|
// struts or input region to cover specific children.
|
||||||
|
//
|
||||||
|
// @params can have any of the same values as in addActor(), though
|
||||||
|
// some possibilities don't make sense (eg, trying to have a
|
||||||
|
// %visibleInOverview child of a non-%visibleInOverview parent).
|
||||||
|
// By default, @actor has the same params as its chrome ancestor.
|
||||||
|
trackActor: function(actor, params) {
|
||||||
|
let ancestor = actor.get_parent();
|
||||||
|
let index = this._findActor(ancestor);
|
||||||
|
while (ancestor && index == -1) {
|
||||||
|
ancestor = ancestor.get_parent();
|
||||||
|
index = this._findActor(ancestor);
|
||||||
|
}
|
||||||
|
if (!ancestor)
|
||||||
|
throw new Error('actor is not a descendent of the chrome layer');
|
||||||
|
|
||||||
|
let ancestorData = this._trackedActors[index];
|
||||||
|
if (!params)
|
||||||
|
params = {};
|
||||||
|
// We can't use Params.parse here because we want to drop
|
||||||
|
// the extra values like ancestorData.actor
|
||||||
|
for (let prop in defaultParams) {
|
||||||
|
if (!params[prop])
|
||||||
|
params[prop] = ancestorData[prop];
|
||||||
|
}
|
||||||
|
|
||||||
|
this._trackActor(actor, params);
|
||||||
|
},
|
||||||
|
|
||||||
|
// untrackActor:
|
||||||
|
// @actor: an actor previously tracked via trackActor()
|
||||||
|
//
|
||||||
|
// Undoes the effect of trackActor()
|
||||||
|
untrackActor: function(actor) {
|
||||||
|
this._untrackActor(actor);
|
||||||
|
},
|
||||||
|
|
||||||
|
// removeActor:
|
||||||
|
// @actor: a child of the chrome layer
|
||||||
|
//
|
||||||
|
// Removes @actor from the chrome layer
|
||||||
|
removeActor: function(actor) {
|
||||||
|
this.actor.remove_actor(actor);
|
||||||
|
this._untrackActor(actor);
|
||||||
|
},
|
||||||
|
|
||||||
|
_findActor: function(actor) {
|
||||||
|
for (let i = 0; i < this._trackedActors.length; i++) {
|
||||||
|
let actorData = this._trackedActors[i];
|
||||||
|
if (actorData.actor == actor)
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
return -1;
|
||||||
|
},
|
||||||
|
|
||||||
|
_trackActor: function(actor, params) {
|
||||||
|
if (this._findActor(actor) != -1)
|
||||||
|
throw new Error('trying to re-track existing chrome actor');
|
||||||
|
|
||||||
|
let actorData = Params.parse(params, defaultParams);
|
||||||
|
actorData.actor = actor;
|
||||||
|
actorData.visibleId = actor.connect('notify::visible',
|
||||||
|
Lang.bind(this, this._queueUpdateRegions));
|
||||||
|
actorData.allocationId = actor.connect('notify::allocation',
|
||||||
|
Lang.bind(this, this._queueUpdateRegions));
|
||||||
|
actorData.parentSetId = actor.connect('parent-set',
|
||||||
|
Lang.bind(this, this._actorReparented));
|
||||||
|
// Note that destroying actor will unset its parent, so we don't
|
||||||
|
// need to connect to 'destroy' too.
|
||||||
|
|
||||||
|
this._trackedActors.push(actorData);
|
||||||
|
this._queueUpdateRegions();
|
||||||
|
},
|
||||||
|
|
||||||
|
_untrackActor: function(actor) {
|
||||||
|
let i = this._findActor(actor);
|
||||||
|
|
||||||
|
if (i == -1)
|
||||||
|
return;
|
||||||
|
let actorData = this._trackedActors[i];
|
||||||
|
|
||||||
|
this._trackedActors.splice(i, 1);
|
||||||
|
actor.disconnect(actorData.visibleId);
|
||||||
|
actor.disconnect(actorData.allocationId);
|
||||||
|
actor.disconnect(actorData.parentSetId);
|
||||||
|
|
||||||
|
this._queueUpdateRegions();
|
||||||
|
},
|
||||||
|
|
||||||
|
_actorReparented: function(actor, oldParent) {
|
||||||
|
if (!this.actor.contains(actor))
|
||||||
|
this._untrackActor(actor);
|
||||||
|
},
|
||||||
|
|
||||||
|
_updateVisibility: function() {
|
||||||
|
for (let i = 0; i < this._trackedActors.length; i++) {
|
||||||
|
let actorData = this._trackedActors[i];
|
||||||
|
if (this._inOverview && !actorData.visibleInOverview)
|
||||||
|
this.actor.set_skip_paint(actorData.actor, true);
|
||||||
|
else if (!this._inOverview && !actorData.visibleInFullscreen &&
|
||||||
|
this._findMonitorForActor(actorData.actor).inFullscreen)
|
||||||
|
this.actor.set_skip_paint(actorData.actor, true);
|
||||||
|
else
|
||||||
|
this.actor.set_skip_paint(actorData.actor, false);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
_overviewShowing: function() {
|
||||||
|
this._inOverview = true;
|
||||||
|
this._updateVisibility();
|
||||||
|
this._queueUpdateRegions();
|
||||||
|
},
|
||||||
|
|
||||||
|
_overviewHidden: function() {
|
||||||
|
this._inOverview = false;
|
||||||
|
this._updateVisibility();
|
||||||
|
this._queueUpdateRegions();
|
||||||
|
},
|
||||||
|
|
||||||
|
_updateMonitors: function() {
|
||||||
|
let monitors = global.get_monitors();
|
||||||
|
let primary = global.get_primary_monitor();
|
||||||
|
this._monitors = monitors;
|
||||||
|
for (let i = 0; i < monitors.length; i++) {
|
||||||
|
let monitor = monitors[i];
|
||||||
|
if (monitor.x == primary.x &&
|
||||||
|
monitor.y == primary.y &&
|
||||||
|
monitor.width == primary.width &&
|
||||||
|
monitor.height == primary.height)
|
||||||
|
this._primaryMonitor = monitor;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
_findMonitorForRect: function(x, y, w, h) {
|
||||||
|
// First look at what monitor the center of the rectangle is at
|
||||||
|
let cx = x + w/2;
|
||||||
|
let cy = y + h/2;
|
||||||
|
for (let i = 0; i < this._monitors.length; i++) {
|
||||||
|
let monitor = this._monitors[i];
|
||||||
|
if (cx >= monitor.x && cx < monitor.x + monitor.width &&
|
||||||
|
cy >= monitor.y && cy < monitor.y + monitor.height)
|
||||||
|
return monitor;
|
||||||
|
}
|
||||||
|
// If the center is not on a monitor, return the first overlapping monitor
|
||||||
|
for (let i = 0; i < this._monitors.length; i++) {
|
||||||
|
let monitor = this._monitors[i];
|
||||||
|
if (x + w > monitor.x && x < monitor.x + monitor.width &&
|
||||||
|
y + h > monitor.y && y < monitor.y + monitor.height)
|
||||||
|
return monitor;
|
||||||
|
}
|
||||||
|
// otherwise on no monitor
|
||||||
|
return null;
|
||||||
|
},
|
||||||
|
|
||||||
|
_findMonitorForWindow: function(window) {
|
||||||
|
return this._findMonitorForRect(window.x, window.y, window.width, window.height);
|
||||||
|
},
|
||||||
|
|
||||||
|
// This call guarantees that we return some monitor to simplify usage of it
|
||||||
|
// In practice all tracked actors should be visible on some monitor anyway
|
||||||
|
_findMonitorForActor: function(actor) {
|
||||||
|
let [x, y] = actor.get_transformed_position();
|
||||||
|
let [w, h] = actor.get_transformed_size();
|
||||||
|
let monitor = this._findMonitorForRect(x, y, w, h);
|
||||||
|
if (monitor)
|
||||||
|
return monitor;
|
||||||
|
return this._primaryMonitor; // Not on any monitor, pretend its on the primary
|
||||||
|
},
|
||||||
|
|
||||||
|
_monitorsChanged: function() {
|
||||||
|
this._updateMonitors();
|
||||||
|
|
||||||
|
// Update everything that depends on monitor positions
|
||||||
|
this._updateFullscreen();
|
||||||
|
this._updateVisibility();
|
||||||
|
this._queueUpdateRegions();
|
||||||
|
},
|
||||||
|
|
||||||
|
_queueUpdateRegions: function() {
|
||||||
|
if (!this._updateRegionIdle)
|
||||||
|
this._updateRegionIdle = Mainloop.idle_add(Lang.bind(this, this._updateRegions),
|
||||||
|
Meta.PRIORITY_BEFORE_REDRAW);
|
||||||
|
},
|
||||||
|
|
||||||
|
_updateFullscreen: function() {
|
||||||
|
let windows = Main.getWindowActorsForWorkspace(global.screen.get_active_workspace_index());
|
||||||
|
|
||||||
|
// Reset all monitors to not fullscreen
|
||||||
|
for (let i = 0; i < this._monitors.length; i++)
|
||||||
|
this._monitors[i].inFullscreen = false;
|
||||||
|
|
||||||
|
// The chrome layer should be visible unless there is a window
|
||||||
|
// with layer FULLSCREEN, or a window with layer
|
||||||
|
// OVERRIDE_REDIRECT that covers the whole screen.
|
||||||
|
// ('override_redirect' is not actually a layer above all
|
||||||
|
// other windows, but this seems to be how mutter treats it
|
||||||
|
// currently...) If we wanted to be extra clever, we could
|
||||||
|
// figure out when an OVERRIDE_REDIRECT window was trying to
|
||||||
|
// partially overlap us, and then adjust the input region and
|
||||||
|
// our clip region accordingly...
|
||||||
|
|
||||||
|
// @windows is sorted bottom to top.
|
||||||
|
|
||||||
|
for (let i = windows.length - 1; i > -1; i--) {
|
||||||
|
let window = windows[i];
|
||||||
|
let layer = window.get_meta_window().get_layer();
|
||||||
|
|
||||||
|
if (layer == Meta.StackLayer.FULLSCREEN) {
|
||||||
|
let monitor = this._findMonitorForWindow(window);
|
||||||
|
if (monitor)
|
||||||
|
monitor.inFullscreen = true;
|
||||||
|
}
|
||||||
|
if (layer == Meta.StackLayer.OVERRIDE_REDIRECT) {
|
||||||
|
let monitor = this._findMonitorForWindow(window);
|
||||||
|
if (monitor &&
|
||||||
|
window.x <= monitor.x &&
|
||||||
|
window.x + window.width >= monitor.x + monitor.width &&
|
||||||
|
window.y <= monitor.y &&
|
||||||
|
window.y + window.height >= monitor.y + monitor.height)
|
||||||
|
monitor.inFullscreen = true;
|
||||||
|
} else
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
_windowsRestacked: function() {
|
||||||
|
let wasInFullscreen = [];
|
||||||
|
for (let i = 0; i < this._monitors.length; i++)
|
||||||
|
wasInFullscreen[i] = this._monitors[i].inFullscreen;
|
||||||
|
|
||||||
|
this._updateFullscreen();
|
||||||
|
|
||||||
|
let changed = false;
|
||||||
|
for (let i = 0; i < wasInFullscreen.length; i++) {
|
||||||
|
if (wasInFullscreen[i] != this._monitors[i].inFullscreen) {
|
||||||
|
changed = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (changed) {
|
||||||
|
this._updateVisibility();
|
||||||
|
this._queueUpdateRegions();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Figure out where the pointer is in case we lost track of
|
||||||
|
// it during a grab. (In particular, if a trayicon popup menu
|
||||||
|
// is dismissed, see if we need to close the message tray.)
|
||||||
|
global.sync_pointer();
|
||||||
|
},
|
||||||
|
|
||||||
|
_updateRegions: function() {
|
||||||
|
let rects = [], struts = [], i;
|
||||||
|
|
||||||
|
delete this._updateRegionIdle;
|
||||||
|
|
||||||
|
for (i = 0; i < this._trackedActors.length; i++) {
|
||||||
|
let actorData = this._trackedActors[i];
|
||||||
|
if (!actorData.affectsInputRegion && !actorData.affectsStruts)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
let [x, y] = actorData.actor.get_transformed_position();
|
||||||
|
let [w, h] = actorData.actor.get_transformed_size();
|
||||||
|
x = Math.round(x);
|
||||||
|
y = Math.round(y);
|
||||||
|
w = Math.round(w);
|
||||||
|
h = Math.round(h);
|
||||||
|
let rect = new Meta.Rectangle({ x: x, y: y, width: w, height: h});
|
||||||
|
|
||||||
|
if (actorData.affectsInputRegion &&
|
||||||
|
actorData.actor.get_paint_visibility() &&
|
||||||
|
!this.actor.get_skip_paint(actorData.actor))
|
||||||
|
rects.push(rect);
|
||||||
|
|
||||||
|
if (!actorData.affectsStruts)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
// Limit struts to the size of the screen
|
||||||
|
let x1 = Math.max(x, 0);
|
||||||
|
let x2 = Math.min(x + w, global.screen_width);
|
||||||
|
let y1 = Math.max(y, 0);
|
||||||
|
let y2 = Math.min(y + h, global.screen_height);
|
||||||
|
|
||||||
|
// NetWM struts are not really powerful enought to handle
|
||||||
|
// a multi-monitor scenario, they only describe what happens
|
||||||
|
// around the outer sides of the full display region. However
|
||||||
|
// it can describe a partial region along each side, so
|
||||||
|
// we can support having the struts only affect the
|
||||||
|
// primary monitor. This should be enough as we only have
|
||||||
|
// chrome affecting the struts on the primary monitor so
|
||||||
|
// far.
|
||||||
|
//
|
||||||
|
// Metacity wants to know what side of the screen the
|
||||||
|
// strut is considered to be attached to. If the actor is
|
||||||
|
// only touching one edge, or is touching the entire
|
||||||
|
// border of the primary monitor, then it's obvious which
|
||||||
|
// side to call it. If it's in a corner, we pick a side
|
||||||
|
// arbitrarily. If it doesn't touch any edges, or it spans
|
||||||
|
// the width/height across the middle of the screen, then
|
||||||
|
// we don't create a strut for it at all.
|
||||||
|
let side;
|
||||||
|
let primary = this._primaryMonitor;
|
||||||
|
if (x1 <= primary.x && x2 >= primary.x + primary.width) {
|
||||||
|
if (y1 <= primary.y)
|
||||||
|
side = Meta.Side.TOP;
|
||||||
|
else if (y2 >= primary.y + primary.height)
|
||||||
|
side = Meta.Side.BOTTOM;
|
||||||
|
else
|
||||||
|
continue;
|
||||||
|
} else if (y1 <= primary.y && y2 >= primary.y + primary.height) {
|
||||||
|
if (x1 <= 0)
|
||||||
|
side = Meta.Side.LEFT;
|
||||||
|
else if (x2 >= global.screen_width)
|
||||||
|
side = Meta.Side.RIGHT;
|
||||||
|
else
|
||||||
|
continue;
|
||||||
|
} else if (x1 <= 0)
|
||||||
|
side = Meta.Side.LEFT;
|
||||||
|
else if (y1 <= 0)
|
||||||
|
side = Meta.Side.TOP;
|
||||||
|
else if (x2 >= global.screen_width)
|
||||||
|
side = Meta.Side.RIGHT;
|
||||||
|
else if (y2 >= global.screen_height)
|
||||||
|
side = Meta.Side.BOTTOM;
|
||||||
|
else
|
||||||
|
continue;
|
||||||
|
|
||||||
|
// Ensure that the strut rects goes all the way to the screen edge,
|
||||||
|
// as this really what mutter expects.
|
||||||
|
switch (side) {
|
||||||
|
case Meta.Side.TOP:
|
||||||
|
y1 = 0;
|
||||||
|
break;
|
||||||
|
case Meta.Side.BOTTOM:
|
||||||
|
y2 = global.screen_height;
|
||||||
|
break;
|
||||||
|
case Meta.Side.LEFT:
|
||||||
|
x1 = 0;
|
||||||
|
break;
|
||||||
|
case Meta.Side.RIGHT:
|
||||||
|
x2 = global.screen_width;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
let strutRect = new Meta.Rectangle({ x: x1, y: y1, width: x2 - x1, height: y2 - y1});
|
||||||
|
let strut = new Meta.Strut({ rect: strutRect, side: side });
|
||||||
|
struts.push(strut);
|
||||||
|
}
|
||||||
|
|
||||||
|
global.set_stage_input_region(rects);
|
||||||
|
|
||||||
|
let screen = global.screen;
|
||||||
|
for (let w = 0; w < screen.n_workspaces; w++) {
|
||||||
|
let workspace = screen.get_workspace_by_index(w);
|
||||||
|
workspace.set_builtin_struts(struts);
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Signals.addSignalMethods(Chrome.prototype);
|
@ -1,65 +0,0 @@
|
|||||||
|
|
||||||
const Lang = imports.lang;
|
|
||||||
const Main = imports.ui.main;
|
|
||||||
|
|
||||||
const ComponentManager = new Lang.Class({
|
|
||||||
Name: 'ComponentManager',
|
|
||||||
|
|
||||||
_init: function() {
|
|
||||||
this._allComponents = {};
|
|
||||||
this._enabledComponents = [];
|
|
||||||
|
|
||||||
Main.sessionMode.connect('updated', Lang.bind(this, this._sessionUpdated));
|
|
||||||
this._sessionUpdated();
|
|
||||||
},
|
|
||||||
|
|
||||||
_sessionUpdated: function() {
|
|
||||||
let newEnabledComponents = Main.sessionMode.components;
|
|
||||||
|
|
||||||
newEnabledComponents.filter(Lang.bind(this, function(name) {
|
|
||||||
return this._enabledComponents.indexOf(name) == -1;
|
|
||||||
})).forEach(Lang.bind(this, function(name) {
|
|
||||||
this._enableComponent(name);
|
|
||||||
}));
|
|
||||||
|
|
||||||
this._enabledComponents.filter(Lang.bind(this, function(name) {
|
|
||||||
return newEnabledComponents.indexOf(name) == -1;
|
|
||||||
})).forEach(Lang.bind(this, function(name) {
|
|
||||||
this._disableComponent(name);
|
|
||||||
}));
|
|
||||||
|
|
||||||
this._enabledComponents = newEnabledComponents;
|
|
||||||
},
|
|
||||||
|
|
||||||
_importComponent: function(name) {
|
|
||||||
let module = imports.ui.components[name];
|
|
||||||
return module.Component;
|
|
||||||
},
|
|
||||||
|
|
||||||
_ensureComponent: function(name) {
|
|
||||||
let component = this._allComponents[name];
|
|
||||||
if (component)
|
|
||||||
return component;
|
|
||||||
|
|
||||||
if (Main.sessionMode.isLocked)
|
|
||||||
return null;
|
|
||||||
|
|
||||||
let constructor = this._importComponent(name);
|
|
||||||
component = new constructor();
|
|
||||||
this._allComponents[name] = component;
|
|
||||||
return component;
|
|
||||||
},
|
|
||||||
|
|
||||||
_enableComponent: function(name) {
|
|
||||||
let component = this._ensureComponent(name);
|
|
||||||
if (component)
|
|
||||||
component.enable();
|
|
||||||
},
|
|
||||||
|
|
||||||
_disableComponent: function(name) {
|
|
||||||
let component = this._allComponents[name];
|
|
||||||
if (component == null)
|
|
||||||
return;
|
|
||||||
component.disable();
|
|
||||||
}
|
|
||||||
});
|
|
@ -1,241 +0,0 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
|
||||||
|
|
||||||
const Lang = imports.lang;
|
|
||||||
const Mainloop = imports.mainloop;
|
|
||||||
const GLib = imports.gi.GLib;
|
|
||||||
const Gio = imports.gi.Gio;
|
|
||||||
const Params = imports.misc.params;
|
|
||||||
const Shell = imports.gi.Shell;
|
|
||||||
|
|
||||||
const GnomeSession = imports.misc.gnomeSession;
|
|
||||||
const LoginManager = imports.misc.loginManager;
|
|
||||||
const Main = imports.ui.main;
|
|
||||||
const ShellMountOperation = imports.ui.shellMountOperation;
|
|
||||||
|
|
||||||
const GNOME_SESSION_AUTOMOUNT_INHIBIT = 16;
|
|
||||||
|
|
||||||
// GSettings keys
|
|
||||||
const SETTINGS_SCHEMA = 'org.gnome.desktop.media-handling';
|
|
||||||
const SETTING_ENABLE_AUTOMOUNT = 'automount';
|
|
||||||
|
|
||||||
const AUTORUN_EXPIRE_TIMEOUT_SECS = 10;
|
|
||||||
|
|
||||||
const AutomountManager = new Lang.Class({
|
|
||||||
Name: 'AutomountManager',
|
|
||||||
|
|
||||||
_init: function() {
|
|
||||||
this._settings = new Gio.Settings({ schema: SETTINGS_SCHEMA });
|
|
||||||
this._volumeQueue = [];
|
|
||||||
this._session = new GnomeSession.SessionManager();
|
|
||||||
this._session.connectSignal('InhibitorAdded',
|
|
||||||
Lang.bind(this, this._InhibitorsChanged));
|
|
||||||
this._session.connectSignal('InhibitorRemoved',
|
|
||||||
Lang.bind(this, this._InhibitorsChanged));
|
|
||||||
this._inhibited = false;
|
|
||||||
|
|
||||||
this._loginManager = LoginManager.getLoginManager();
|
|
||||||
this._volumeMonitor = Gio.VolumeMonitor.get();
|
|
||||||
},
|
|
||||||
|
|
||||||
enable: function() {
|
|
||||||
this._volumeAddedId = this._volumeMonitor.connect('volume-added', Lang.bind(this, this._onVolumeAdded));
|
|
||||||
this._volumeRemovedId = this._volumeMonitor.connect('volume-removed', Lang.bind(this, this._onVolumeRemoved));
|
|
||||||
this._driveConnectedId = this._volumeMonitor.connect('drive-connected', Lang.bind(this, this._onDriveConnected));
|
|
||||||
this._driveDisconnectedId = this._volumeMonitor.connect('drive-disconnected', Lang.bind(this, this._onDriveDisconnected));
|
|
||||||
this._driveEjectButtonId = this._volumeMonitor.connect('drive-eject-button', Lang.bind(this, this._onDriveEjectButton));
|
|
||||||
|
|
||||||
this._mountAllId = Mainloop.idle_add(Lang.bind(this, this._startupMountAll));
|
|
||||||
},
|
|
||||||
|
|
||||||
disable: function() {
|
|
||||||
this._volumeMonitor.disconnect(this._volumeAddedId);
|
|
||||||
this._volumeMonitor.disconnect(this._volumeRemovedId);
|
|
||||||
this._volumeMonitor.disconnect(this._driveConnectedId);
|
|
||||||
this._volumeMonitor.disconnect(this._driveDisconnectedId);
|
|
||||||
this._volumeMonitor.disconnect(this._driveEjectButtonId);
|
|
||||||
|
|
||||||
if (this._mountAllId > 0) {
|
|
||||||
Mainloop.source_remove(this._mountAllId);
|
|
||||||
this._mountAllId = 0;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_InhibitorsChanged: function(object, senderName, [inhibtor]) {
|
|
||||||
this._session.IsInhibitedRemote(GNOME_SESSION_AUTOMOUNT_INHIBIT,
|
|
||||||
Lang.bind(this,
|
|
||||||
function(result, error) {
|
|
||||||
if (!error) {
|
|
||||||
this._inhibited = result[0];
|
|
||||||
}
|
|
||||||
}));
|
|
||||||
},
|
|
||||||
|
|
||||||
_startupMountAll: function() {
|
|
||||||
let volumes = this._volumeMonitor.get_volumes();
|
|
||||||
volumes.forEach(Lang.bind(this, function(volume) {
|
|
||||||
this._checkAndMountVolume(volume, { checkSession: false,
|
|
||||||
useMountOp: false,
|
|
||||||
allowAutorun: false });
|
|
||||||
}));
|
|
||||||
|
|
||||||
this._mountAllId = 0;
|
|
||||||
return false;
|
|
||||||
},
|
|
||||||
|
|
||||||
_onDriveConnected: function() {
|
|
||||||
// if we're not in the current ConsoleKit session,
|
|
||||||
// or screensaver is active, don't play sounds
|
|
||||||
if (!this._loginManager.sessionActive)
|
|
||||||
return;
|
|
||||||
|
|
||||||
global.play_theme_sound(0, 'device-added-media');
|
|
||||||
},
|
|
||||||
|
|
||||||
_onDriveDisconnected: function() {
|
|
||||||
// if we're not in the current ConsoleKit session,
|
|
||||||
// or screensaver is active, don't play sounds
|
|
||||||
if (!this._loginManager.sessionActive)
|
|
||||||
return;
|
|
||||||
|
|
||||||
global.play_theme_sound(0, 'device-removed-media');
|
|
||||||
},
|
|
||||||
|
|
||||||
_onDriveEjectButton: function(monitor, drive) {
|
|
||||||
// TODO: this code path is not tested, as the GVfs volume monitor
|
|
||||||
// doesn't emit this signal just yet.
|
|
||||||
if (!this._loginManager.sessionActive)
|
|
||||||
return;
|
|
||||||
|
|
||||||
// we force stop/eject in this case, so we don't have to pass a
|
|
||||||
// mount operation object
|
|
||||||
if (drive.can_stop()) {
|
|
||||||
drive.stop
|
|
||||||
(Gio.MountUnmountFlags.FORCE, null, null,
|
|
||||||
Lang.bind(this, function(drive, res) {
|
|
||||||
try {
|
|
||||||
drive.stop_finish(res);
|
|
||||||
} catch (e) {
|
|
||||||
log("Unable to stop the drive after drive-eject-button " + e.toString());
|
|
||||||
}
|
|
||||||
}));
|
|
||||||
} else if (drive.can_eject()) {
|
|
||||||
drive.eject_with_operation
|
|
||||||
(Gio.MountUnmountFlags.FORCE, null, null,
|
|
||||||
Lang.bind(this, function(drive, res) {
|
|
||||||
try {
|
|
||||||
drive.eject_with_operation_finish(res);
|
|
||||||
} catch (e) {
|
|
||||||
log("Unable to eject the drive after drive-eject-button " + e.toString());
|
|
||||||
}
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_onVolumeAdded: function(monitor, volume) {
|
|
||||||
this._checkAndMountVolume(volume);
|
|
||||||
},
|
|
||||||
|
|
||||||
_checkAndMountVolume: function(volume, params) {
|
|
||||||
params = Params.parse(params, { checkSession: true,
|
|
||||||
useMountOp: true,
|
|
||||||
allowAutorun: true });
|
|
||||||
|
|
||||||
if (params.checkSession) {
|
|
||||||
// if we're not in the current ConsoleKit session,
|
|
||||||
// don't attempt automount
|
|
||||||
if (!this._loginManager.sessionActive)
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._inhibited)
|
|
||||||
return;
|
|
||||||
|
|
||||||
// Volume is already mounted, don't bother.
|
|
||||||
if (volume.get_mount())
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (!this._settings.get_boolean(SETTING_ENABLE_AUTOMOUNT) ||
|
|
||||||
!volume.should_automount() ||
|
|
||||||
!volume.can_mount()) {
|
|
||||||
// allow the autorun to run anyway; this can happen if the
|
|
||||||
// mount gets added programmatically later, even if
|
|
||||||
// should_automount() or can_mount() are false, like for
|
|
||||||
// blank optical media.
|
|
||||||
this._allowAutorun(volume);
|
|
||||||
this._allowAutorunExpire(volume);
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (params.useMountOp) {
|
|
||||||
let operation = new ShellMountOperation.ShellMountOperation(volume);
|
|
||||||
this._mountVolume(volume, operation, params.allowAutorun);
|
|
||||||
} else {
|
|
||||||
this._mountVolume(volume, null, params.allowAutorun);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_mountVolume: function(volume, operation, allowAutorun) {
|
|
||||||
if (allowAutorun)
|
|
||||||
this._allowAutorun(volume);
|
|
||||||
|
|
||||||
let mountOp = operation ? operation.mountOp : null;
|
|
||||||
volume._operation = operation;
|
|
||||||
|
|
||||||
volume.mount(0, mountOp, null,
|
|
||||||
Lang.bind(this, this._onVolumeMounted));
|
|
||||||
},
|
|
||||||
|
|
||||||
_onVolumeMounted: function(volume, res) {
|
|
||||||
this._allowAutorunExpire(volume);
|
|
||||||
|
|
||||||
try {
|
|
||||||
volume.mount_finish(res);
|
|
||||||
this._closeOperation(volume);
|
|
||||||
} catch (e) {
|
|
||||||
// FIXME: we will always get G_IO_ERROR_FAILED from the gvfs udisks
|
|
||||||
// backend in this case, see
|
|
||||||
// https://bugs.freedesktop.org/show_bug.cgi?id=51271
|
|
||||||
if (e.message.indexOf('No key available with this passphrase') != -1) {
|
|
||||||
this._reaskPassword(volume);
|
|
||||||
} else {
|
|
||||||
if (!e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.FAILED_HANDLED))
|
|
||||||
log('Unable to mount volume ' + volume.get_name() + ': ' + e.toString());
|
|
||||||
|
|
||||||
this._closeOperation(volume);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_onVolumeRemoved: function(monitor, volume) {
|
|
||||||
this._volumeQueue =
|
|
||||||
this._volumeQueue.filter(function(element) {
|
|
||||||
return (element != volume);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
|
|
||||||
_reaskPassword: function(volume) {
|
|
||||||
let existingDialog = volume._operation ? volume._operation.borrowDialog() : null;
|
|
||||||
let operation =
|
|
||||||
new ShellMountOperation.ShellMountOperation(volume,
|
|
||||||
{ existingDialog: existingDialog });
|
|
||||||
this._mountVolume(volume, operation);
|
|
||||||
},
|
|
||||||
|
|
||||||
_closeOperation: function(volume) {
|
|
||||||
if (volume._operation)
|
|
||||||
volume._operation.close();
|
|
||||||
},
|
|
||||||
|
|
||||||
_allowAutorun: function(volume) {
|
|
||||||
volume.allowAutorun = true;
|
|
||||||
},
|
|
||||||
|
|
||||||
_allowAutorunExpire: function(volume) {
|
|
||||||
Mainloop.timeout_add_seconds(AUTORUN_EXPIRE_TIMEOUT_SECS, function() {
|
|
||||||
volume.allowAutorun = false;
|
|
||||||
return false;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
const Component = AutomountManager;
|
|
@ -1,638 +0,0 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
|
||||||
|
|
||||||
const Lang = imports.lang;
|
|
||||||
const Gio = imports.gi.Gio;
|
|
||||||
const St = imports.gi.St;
|
|
||||||
|
|
||||||
const LoginManager = imports.misc.loginManager;
|
|
||||||
const Main = imports.ui.main;
|
|
||||||
const MessageTray = imports.ui.messageTray;
|
|
||||||
const ShellMountOperation = imports.ui.shellMountOperation;
|
|
||||||
|
|
||||||
// GSettings keys
|
|
||||||
const SETTINGS_SCHEMA = 'org.gnome.desktop.media-handling';
|
|
||||||
const SETTING_DISABLE_AUTORUN = 'autorun-never';
|
|
||||||
const SETTING_START_APP = 'autorun-x-content-start-app';
|
|
||||||
const SETTING_IGNORE = 'autorun-x-content-ignore';
|
|
||||||
const SETTING_OPEN_FOLDER = 'autorun-x-content-open-folder';
|
|
||||||
|
|
||||||
const AutorunSetting = {
|
|
||||||
RUN: 0,
|
|
||||||
IGNORE: 1,
|
|
||||||
FILES: 2,
|
|
||||||
ASK: 3
|
|
||||||
};
|
|
||||||
|
|
||||||
// misc utils
|
|
||||||
function shouldAutorunMount(mount, forTransient) {
|
|
||||||
let root = mount.get_root();
|
|
||||||
let volume = mount.get_volume();
|
|
||||||
|
|
||||||
if (!volume || (!volume.allowAutorun && forTransient))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if (!root.is_native() || isMountRootHidden(root))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
function isMountRootHidden(root) {
|
|
||||||
let path = root.get_path();
|
|
||||||
|
|
||||||
// skip any mounts in hidden directory hierarchies
|
|
||||||
return (path.indexOf('/.') != -1);
|
|
||||||
}
|
|
||||||
|
|
||||||
function isMountNonLocal(mount) {
|
|
||||||
// If the mount doesn't have an associated volume, that means it could
|
|
||||||
// be a remote filesystem. For certain kinds of local filesystems,
|
|
||||||
// like digital cameras and music players, there's no associated
|
|
||||||
// gvfs volume, so err on the side of caution and assume it's a local
|
|
||||||
// filesystem to allow the prompt.
|
|
||||||
let volume = mount.get_volume();
|
|
||||||
if (volume == null)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
return (volume.get_identifier("class") == "network");
|
|
||||||
}
|
|
||||||
|
|
||||||
function startAppForMount(app, mount) {
|
|
||||||
let files = [];
|
|
||||||
let root = mount.get_root();
|
|
||||||
let retval = false;
|
|
||||||
|
|
||||||
files.push(root);
|
|
||||||
|
|
||||||
try {
|
|
||||||
retval = app.launch(files,
|
|
||||||
global.create_app_launch_context())
|
|
||||||
} catch (e) {
|
|
||||||
log('Unable to launch the application ' + app.get_name()
|
|
||||||
+ ': ' + e.toString());
|
|
||||||
}
|
|
||||||
|
|
||||||
return retval;
|
|
||||||
}
|
|
||||||
|
|
||||||
/******************************************/
|
|
||||||
|
|
||||||
const HotplugSnifferIface = <interface name="org.gnome.Shell.HotplugSniffer">
|
|
||||||
<method name="SniffURI">
|
|
||||||
<arg type="s" direction="in" />
|
|
||||||
<arg type="as" direction="out" />
|
|
||||||
</method>
|
|
||||||
</interface>;
|
|
||||||
|
|
||||||
const HotplugSnifferProxy = Gio.DBusProxy.makeProxyWrapper(HotplugSnifferIface);
|
|
||||||
function HotplugSniffer() {
|
|
||||||
return new HotplugSnifferProxy(Gio.DBus.session,
|
|
||||||
'org.gnome.Shell.HotplugSniffer',
|
|
||||||
'/org/gnome/Shell/HotplugSniffer');
|
|
||||||
}
|
|
||||||
|
|
||||||
const ContentTypeDiscoverer = new Lang.Class({
|
|
||||||
Name: 'ContentTypeDiscoverer',
|
|
||||||
|
|
||||||
_init: function(callback) {
|
|
||||||
this._callback = callback;
|
|
||||||
this._settings = new Gio.Settings({ schema: SETTINGS_SCHEMA });
|
|
||||||
},
|
|
||||||
|
|
||||||
guessContentTypes: function(mount) {
|
|
||||||
let autorunEnabled = !this._settings.get_boolean(SETTING_DISABLE_AUTORUN);
|
|
||||||
let shouldScan = autorunEnabled && !isMountNonLocal(mount);
|
|
||||||
|
|
||||||
if (shouldScan) {
|
|
||||||
// guess mount's content types using GIO
|
|
||||||
mount.guess_content_type(false, null,
|
|
||||||
Lang.bind(this,
|
|
||||||
this._onContentTypeGuessed));
|
|
||||||
} else {
|
|
||||||
this._emitCallback(mount, []);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_onContentTypeGuessed: function(mount, res) {
|
|
||||||
let contentTypes = [];
|
|
||||||
|
|
||||||
try {
|
|
||||||
contentTypes = mount.guess_content_type_finish(res);
|
|
||||||
} catch (e) {
|
|
||||||
log('Unable to guess content types on added mount ' + mount.get_name()
|
|
||||||
+ ': ' + e.toString());
|
|
||||||
}
|
|
||||||
|
|
||||||
if (contentTypes.length) {
|
|
||||||
this._emitCallback(mount, contentTypes);
|
|
||||||
} else {
|
|
||||||
let root = mount.get_root();
|
|
||||||
|
|
||||||
let hotplugSniffer = new HotplugSniffer();
|
|
||||||
hotplugSniffer.SniffURIRemote(root.get_uri(),
|
|
||||||
Lang.bind(this, function([contentTypes]) {
|
|
||||||
this._emitCallback(mount, contentTypes);
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_emitCallback: function(mount, contentTypes) {
|
|
||||||
if (!contentTypes)
|
|
||||||
contentTypes = [];
|
|
||||||
|
|
||||||
// we're not interested in win32 software content types here
|
|
||||||
contentTypes = contentTypes.filter(function(type) {
|
|
||||||
return (type != 'x-content/win32-software');
|
|
||||||
});
|
|
||||||
|
|
||||||
let apps = [];
|
|
||||||
contentTypes.forEach(function(type) {
|
|
||||||
let app = Gio.app_info_get_default_for_type(type, false);
|
|
||||||
|
|
||||||
if (app)
|
|
||||||
apps.push(app);
|
|
||||||
});
|
|
||||||
|
|
||||||
if (apps.length == 0)
|
|
||||||
apps.push(Gio.app_info_get_default_for_type('inode/directory', false));
|
|
||||||
|
|
||||||
this._callback(mount, apps, contentTypes);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
const AutorunManager = new Lang.Class({
|
|
||||||
Name: 'AutorunManager',
|
|
||||||
|
|
||||||
_init: function() {
|
|
||||||
this._loginManager = LoginManager.getLoginManager();
|
|
||||||
|
|
||||||
this._volumeMonitor = Gio.VolumeMonitor.get();
|
|
||||||
|
|
||||||
this._transDispatcher = new AutorunTransientDispatcher(this);
|
|
||||||
},
|
|
||||||
|
|
||||||
_ensureResidentSource: function() {
|
|
||||||
if (this._residentSource)
|
|
||||||
return;
|
|
||||||
|
|
||||||
this._residentSource = new AutorunResidentSource(this);
|
|
||||||
let destroyId = this._residentSource.connect('destroy', Lang.bind(this, function() {
|
|
||||||
this._residentSource.disconnect(destroyId);
|
|
||||||
this._residentSource = null;
|
|
||||||
}));
|
|
||||||
},
|
|
||||||
|
|
||||||
enable: function() {
|
|
||||||
this._scanMounts();
|
|
||||||
|
|
||||||
this._mountAddedId = this._volumeMonitor.connect('mount-added', Lang.bind(this, this._onMountAdded));
|
|
||||||
this._mountRemovedId = this._volumeMonitor.connect('mount-removed', Lang.bind(this, this._onMountRemoved));
|
|
||||||
},
|
|
||||||
|
|
||||||
disable: function() {
|
|
||||||
if (this._residentSource)
|
|
||||||
this._residentSource.destroy();
|
|
||||||
this._volumeMonitor.disconnect(this._mountAddedId);
|
|
||||||
this._volumeMonitor.disconnect(this._mountRemovedId);
|
|
||||||
},
|
|
||||||
|
|
||||||
_processMount: function(mount, hotplug) {
|
|
||||||
let discoverer = new ContentTypeDiscoverer(Lang.bind(this, function(mount, apps, contentTypes) {
|
|
||||||
this._ensureResidentSource();
|
|
||||||
this._residentSource.addMount(mount, apps);
|
|
||||||
|
|
||||||
if (hotplug)
|
|
||||||
this._transDispatcher.addMount(mount, apps, contentTypes);
|
|
||||||
}));
|
|
||||||
discoverer.guessContentTypes(mount);
|
|
||||||
},
|
|
||||||
|
|
||||||
_scanMounts: function() {
|
|
||||||
let mounts = this._volumeMonitor.get_mounts();
|
|
||||||
mounts.forEach(Lang.bind(this, function(mount) {
|
|
||||||
this._processMount(mount, false);
|
|
||||||
}));
|
|
||||||
},
|
|
||||||
|
|
||||||
_onMountAdded: function(monitor, mount) {
|
|
||||||
// don't do anything if our session is not the currently
|
|
||||||
// active one
|
|
||||||
if (!this._loginManager.sessionActive)
|
|
||||||
return;
|
|
||||||
|
|
||||||
this._processMount(mount, true);
|
|
||||||
},
|
|
||||||
|
|
||||||
_onMountRemoved: function(monitor, mount) {
|
|
||||||
this._transDispatcher.removeMount(mount);
|
|
||||||
if (this._residentSource)
|
|
||||||
this._residentSource.removeMount(mount);
|
|
||||||
},
|
|
||||||
|
|
||||||
ejectMount: function(mount) {
|
|
||||||
let mountOp = new ShellMountOperation.ShellMountOperation(mount);
|
|
||||||
|
|
||||||
// first, see if we have a drive
|
|
||||||
let drive = mount.get_drive();
|
|
||||||
let volume = mount.get_volume();
|
|
||||||
|
|
||||||
if (drive &&
|
|
||||||
drive.get_start_stop_type() == Gio.DriveStartStopType.SHUTDOWN &&
|
|
||||||
drive.can_stop()) {
|
|
||||||
drive.stop(0, mountOp.mountOp, null,
|
|
||||||
Lang.bind(this, this._onStop));
|
|
||||||
} else {
|
|
||||||
if (mount.can_eject()) {
|
|
||||||
mount.eject_with_operation(0, mountOp.mountOp, null,
|
|
||||||
Lang.bind(this, this._onEject));
|
|
||||||
} else if (volume && volume.can_eject()) {
|
|
||||||
volume.eject_with_operation(0, mountOp.mountOp, null,
|
|
||||||
Lang.bind(this, this._onEject));
|
|
||||||
} else if (drive && drive.can_eject()) {
|
|
||||||
drive.eject_with_operation(0, mountOp.mountOp, null,
|
|
||||||
Lang.bind(this, this._onEject));
|
|
||||||
} else if (mount.can_unmount()) {
|
|
||||||
mount.unmount_with_operation(0, mountOp.mountOp, null,
|
|
||||||
Lang.bind(this, this._onUnmount));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_onUnmount: function(mount, res) {
|
|
||||||
try {
|
|
||||||
mount.unmount_with_operation_finish(res);
|
|
||||||
} catch (e) {
|
|
||||||
if (!e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.FAILED_HANDLED))
|
|
||||||
log('Unable to eject the mount ' + mount.get_name()
|
|
||||||
+ ': ' + e.toString());
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_onEject: function(source, res) {
|
|
||||||
try {
|
|
||||||
source.eject_with_operation_finish(res);
|
|
||||||
} catch (e) {
|
|
||||||
if (!e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.FAILED_HANDLED))
|
|
||||||
log('Unable to eject the drive ' + source.get_name()
|
|
||||||
+ ': ' + e.toString());
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_onStop: function(drive, res) {
|
|
||||||
try {
|
|
||||||
drive.stop_finish(res);
|
|
||||||
} catch (e) {
|
|
||||||
if (!e.matches(Gio.IOErrorEnum, Gio.IOErrorEnum.FAILED_HANDLED))
|
|
||||||
log('Unable to stop the drive ' + drive.get_name()
|
|
||||||
+ ': ' + e.toString());
|
|
||||||
}
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
const AutorunResidentSource = new Lang.Class({
|
|
||||||
Name: 'AutorunResidentSource',
|
|
||||||
Extends: MessageTray.Source,
|
|
||||||
|
|
||||||
_init: function(manager) {
|
|
||||||
this.parent(_("Removable Devices"), 'media-removable');
|
|
||||||
this.showInLockScreen = false;
|
|
||||||
|
|
||||||
this._mounts = [];
|
|
||||||
|
|
||||||
this._manager = manager;
|
|
||||||
this._notification = new AutorunResidentNotification(this._manager, this);
|
|
||||||
},
|
|
||||||
|
|
||||||
buildRightClickMenu: function() {
|
|
||||||
return null;
|
|
||||||
},
|
|
||||||
|
|
||||||
addMount: function(mount, apps) {
|
|
||||||
if (!shouldAutorunMount(mount, false))
|
|
||||||
return;
|
|
||||||
|
|
||||||
let filtered = this._mounts.filter(function (element) {
|
|
||||||
return (element.mount == mount);
|
|
||||||
});
|
|
||||||
|
|
||||||
if (filtered.length != 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
let element = { mount: mount, apps: apps };
|
|
||||||
this._mounts.push(element);
|
|
||||||
this._redisplay();
|
|
||||||
},
|
|
||||||
|
|
||||||
removeMount: function(mount) {
|
|
||||||
this._mounts =
|
|
||||||
this._mounts.filter(function (element) {
|
|
||||||
return (element.mount != mount);
|
|
||||||
});
|
|
||||||
|
|
||||||
this._redisplay();
|
|
||||||
},
|
|
||||||
|
|
||||||
_redisplay: function() {
|
|
||||||
if (this._mounts.length == 0) {
|
|
||||||
this._notification.destroy();
|
|
||||||
this.destroy();
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._notification.updateForMounts(this._mounts);
|
|
||||||
|
|
||||||
// add ourselves as a source, and push the notification
|
|
||||||
if (!Main.messageTray.contains(this)) {
|
|
||||||
Main.messageTray.add(this);
|
|
||||||
this.pushNotification(this._notification);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
const AutorunResidentNotification = new Lang.Class({
|
|
||||||
Name: 'AutorunResidentNotification',
|
|
||||||
Extends: MessageTray.Notification,
|
|
||||||
|
|
||||||
_init: function(manager, source) {
|
|
||||||
this.parent(source, source.title, null, { customContent: true });
|
|
||||||
|
|
||||||
// set the notification as resident
|
|
||||||
this.setResident(true);
|
|
||||||
|
|
||||||
this._layout = new St.BoxLayout ({ style_class: 'hotplug-resident-box',
|
|
||||||
vertical: true });
|
|
||||||
this._manager = manager;
|
|
||||||
|
|
||||||
this.addActor(this._layout,
|
|
||||||
{ x_expand: true,
|
|
||||||
x_fill: true });
|
|
||||||
},
|
|
||||||
|
|
||||||
updateForMounts: function(mounts) {
|
|
||||||
// remove all the layout content
|
|
||||||
this._layout.destroy_all_children();
|
|
||||||
|
|
||||||
for (let idx = 0; idx < mounts.length; idx++) {
|
|
||||||
let element = mounts[idx];
|
|
||||||
|
|
||||||
let actor = this._itemForMount(element.mount, element.apps);
|
|
||||||
this._layout.add(actor, { x_fill: true,
|
|
||||||
expand: true });
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_itemForMount: function(mount, apps) {
|
|
||||||
let item = new St.BoxLayout();
|
|
||||||
|
|
||||||
// prepare the mount button content
|
|
||||||
let mountLayout = new St.BoxLayout();
|
|
||||||
|
|
||||||
let mountIcon = new St.Icon({ gicon: mount.get_icon(),
|
|
||||||
style_class: 'hotplug-resident-mount-icon' });
|
|
||||||
mountLayout.add_actor(mountIcon);
|
|
||||||
|
|
||||||
let labelBin = new St.Bin({ y_align: St.Align.MIDDLE });
|
|
||||||
let mountLabel =
|
|
||||||
new St.Label({ text: mount.get_name(),
|
|
||||||
style_class: 'hotplug-resident-mount-label',
|
|
||||||
track_hover: true,
|
|
||||||
reactive: true });
|
|
||||||
labelBin.add_actor(mountLabel);
|
|
||||||
mountLayout.add_actor(labelBin);
|
|
||||||
|
|
||||||
let mountButton = new St.Button({ child: mountLayout,
|
|
||||||
x_align: St.Align.START,
|
|
||||||
x_fill: true,
|
|
||||||
style_class: 'hotplug-resident-mount',
|
|
||||||
button_mask: St.ButtonMask.ONE });
|
|
||||||
item.add(mountButton, { x_align: St.Align.START,
|
|
||||||
expand: true });
|
|
||||||
|
|
||||||
let ejectIcon =
|
|
||||||
new St.Icon({ icon_name: 'media-eject-symbolic',
|
|
||||||
style_class: 'hotplug-resident-eject-icon' });
|
|
||||||
|
|
||||||
let ejectButton =
|
|
||||||
new St.Button({ style_class: 'hotplug-resident-eject-button',
|
|
||||||
button_mask: St.ButtonMask.ONE,
|
|
||||||
child: ejectIcon });
|
|
||||||
item.add(ejectButton, { x_align: St.Align.END });
|
|
||||||
|
|
||||||
// now connect signals
|
|
||||||
mountButton.connect('clicked', Lang.bind(this, function(actor, event) {
|
|
||||||
startAppForMount(apps[0], mount);
|
|
||||||
}));
|
|
||||||
|
|
||||||
ejectButton.connect('clicked', Lang.bind(this, function() {
|
|
||||||
this._manager.ejectMount(mount);
|
|
||||||
}));
|
|
||||||
|
|
||||||
return item;
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
const AutorunTransientDispatcher = new Lang.Class({
|
|
||||||
Name: 'AutorunTransientDispatcher',
|
|
||||||
|
|
||||||
_init: function(manager) {
|
|
||||||
this._manager = manager;
|
|
||||||
this._sources = [];
|
|
||||||
this._settings = new Gio.Settings({ schema: SETTINGS_SCHEMA });
|
|
||||||
},
|
|
||||||
|
|
||||||
_getAutorunSettingForType: function(contentType) {
|
|
||||||
let runApp = this._settings.get_strv(SETTING_START_APP);
|
|
||||||
if (runApp.indexOf(contentType) != -1)
|
|
||||||
return AutorunSetting.RUN;
|
|
||||||
|
|
||||||
let ignore = this._settings.get_strv(SETTING_IGNORE);
|
|
||||||
if (ignore.indexOf(contentType) != -1)
|
|
||||||
return AutorunSetting.IGNORE;
|
|
||||||
|
|
||||||
let openFiles = this._settings.get_strv(SETTING_OPEN_FOLDER);
|
|
||||||
if (openFiles.indexOf(contentType) != -1)
|
|
||||||
return AutorunSetting.FILES;
|
|
||||||
|
|
||||||
return AutorunSetting.ASK;
|
|
||||||
},
|
|
||||||
|
|
||||||
_getSourceForMount: function(mount) {
|
|
||||||
let filtered =
|
|
||||||
this._sources.filter(function (source) {
|
|
||||||
return (source.mount == mount);
|
|
||||||
});
|
|
||||||
|
|
||||||
// we always make sure not to add two sources for the same
|
|
||||||
// mount in addMount(), so it's safe to assume filtered.length
|
|
||||||
// is always either 1 or 0.
|
|
||||||
if (filtered.length == 1)
|
|
||||||
return filtered[0];
|
|
||||||
|
|
||||||
return null;
|
|
||||||
},
|
|
||||||
|
|
||||||
_addSource: function(mount, apps) {
|
|
||||||
// if we already have a source showing for this
|
|
||||||
// mount, return
|
|
||||||
if (this._getSourceForMount(mount))
|
|
||||||
return;
|
|
||||||
|
|
||||||
// add a new source
|
|
||||||
this._sources.push(new AutorunTransientSource(this._manager, mount, apps));
|
|
||||||
},
|
|
||||||
|
|
||||||
addMount: function(mount, apps, contentTypes) {
|
|
||||||
// if autorun is disabled globally, return
|
|
||||||
if (this._settings.get_boolean(SETTING_DISABLE_AUTORUN))
|
|
||||||
return;
|
|
||||||
|
|
||||||
// if the mount doesn't want to be autorun, return
|
|
||||||
if (!shouldAutorunMount(mount, true))
|
|
||||||
return;
|
|
||||||
|
|
||||||
let setting = this._getAutorunSettingForType(contentTypes[0]);
|
|
||||||
|
|
||||||
// check at the settings for the first content type
|
|
||||||
// to see whether we should ask
|
|
||||||
if (setting == AutorunSetting.IGNORE)
|
|
||||||
return; // return right away
|
|
||||||
|
|
||||||
let success = false;
|
|
||||||
let app = null;
|
|
||||||
|
|
||||||
if (setting == AutorunSetting.RUN) {
|
|
||||||
app = Gio.app_info_get_default_for_type(contentTypes[0], false);
|
|
||||||
} else if (setting == AutorunSetting.FILES) {
|
|
||||||
app = Gio.app_info_get_default_for_type('inode/directory', false);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (app)
|
|
||||||
success = startAppForMount(app, mount);
|
|
||||||
|
|
||||||
// we fallback here also in case the settings did not specify 'ask',
|
|
||||||
// but we failed launching the default app or the default file manager
|
|
||||||
if (!success)
|
|
||||||
this._addSource(mount, apps);
|
|
||||||
},
|
|
||||||
|
|
||||||
removeMount: function(mount) {
|
|
||||||
let source = this._getSourceForMount(mount);
|
|
||||||
|
|
||||||
// if we aren't tracking this mount, don't do anything
|
|
||||||
if (!source)
|
|
||||||
return;
|
|
||||||
|
|
||||||
// destroy the notification source
|
|
||||||
source.destroy();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
const AutorunTransientSource = new Lang.Class({
|
|
||||||
Name: 'AutorunTransientSource',
|
|
||||||
Extends: MessageTray.Source,
|
|
||||||
|
|
||||||
_init: function(manager, mount, apps) {
|
|
||||||
this._manager = manager;
|
|
||||||
this.mount = mount;
|
|
||||||
this.apps = apps;
|
|
||||||
|
|
||||||
this.parent(mount.get_name());
|
|
||||||
|
|
||||||
this._notification = new AutorunTransientNotification(this._manager, this);
|
|
||||||
|
|
||||||
// add ourselves as a source, and popup the notification
|
|
||||||
Main.messageTray.add(this);
|
|
||||||
this.notify(this._notification);
|
|
||||||
},
|
|
||||||
|
|
||||||
createIcon: function(size) {
|
|
||||||
return new St.Icon({ gicon: this.mount.get_icon(),
|
|
||||||
icon_size: size });
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
const AutorunTransientNotification = new Lang.Class({
|
|
||||||
Name: 'AutorunTransientNotification',
|
|
||||||
Extends: MessageTray.Notification,
|
|
||||||
|
|
||||||
_init: function(manager, source) {
|
|
||||||
this.parent(source, source.title, null, { customContent: true });
|
|
||||||
|
|
||||||
this._manager = manager;
|
|
||||||
this._box = new St.BoxLayout({ style_class: 'hotplug-transient-box',
|
|
||||||
vertical: true });
|
|
||||||
this.addActor(this._box);
|
|
||||||
|
|
||||||
this._mount = source.mount;
|
|
||||||
|
|
||||||
source.apps.forEach(Lang.bind(this, function (app) {
|
|
||||||
let actor = this._buttonForApp(app);
|
|
||||||
|
|
||||||
if (actor)
|
|
||||||
this._box.add(actor, { x_fill: true,
|
|
||||||
x_align: St.Align.START });
|
|
||||||
}));
|
|
||||||
|
|
||||||
this._box.add(this._buttonForEject(), { x_fill: true,
|
|
||||||
x_align: St.Align.START });
|
|
||||||
|
|
||||||
// set the notification to transient and urgent, so that it
|
|
||||||
// expands out
|
|
||||||
this.setTransient(true);
|
|
||||||
this.setUrgency(MessageTray.Urgency.CRITICAL);
|
|
||||||
},
|
|
||||||
|
|
||||||
_buttonForApp: function(app) {
|
|
||||||
let box = new St.BoxLayout();
|
|
||||||
let icon = new St.Icon({ gicon: app.get_icon(),
|
|
||||||
style_class: 'hotplug-notification-item-icon' });
|
|
||||||
box.add(icon);
|
|
||||||
|
|
||||||
let label = new St.Bin({ y_align: St.Align.MIDDLE,
|
|
||||||
child: new St.Label
|
|
||||||
({ text: _("Open with %s").format(app.get_name()) })
|
|
||||||
});
|
|
||||||
box.add(label);
|
|
||||||
|
|
||||||
let button = new St.Button({ child: box,
|
|
||||||
x_fill: true,
|
|
||||||
x_align: St.Align.START,
|
|
||||||
button_mask: St.ButtonMask.ONE,
|
|
||||||
style_class: 'hotplug-notification-item' });
|
|
||||||
|
|
||||||
button.connect('clicked', Lang.bind(this, function() {
|
|
||||||
startAppForMount(app, this._mount);
|
|
||||||
this.destroy();
|
|
||||||
}));
|
|
||||||
|
|
||||||
return button;
|
|
||||||
},
|
|
||||||
|
|
||||||
_buttonForEject: function() {
|
|
||||||
let box = new St.BoxLayout();
|
|
||||||
let icon = new St.Icon({ icon_name: 'media-eject-symbolic',
|
|
||||||
style_class: 'hotplug-notification-item-icon' });
|
|
||||||
box.add(icon);
|
|
||||||
|
|
||||||
let label = new St.Bin({ y_align: St.Align.MIDDLE,
|
|
||||||
child: new St.Label
|
|
||||||
({ text: _("Eject") })
|
|
||||||
});
|
|
||||||
box.add(label);
|
|
||||||
|
|
||||||
let button = new St.Button({ child: box,
|
|
||||||
x_fill: true,
|
|
||||||
x_align: St.Align.START,
|
|
||||||
button_mask: St.ButtonMask.ONE,
|
|
||||||
style_class: 'hotplug-notification-item' });
|
|
||||||
|
|
||||||
button.connect('clicked', Lang.bind(this, function() {
|
|
||||||
this._manager.ejectMount(this._mount);
|
|
||||||
}));
|
|
||||||
|
|
||||||
return button;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
const Component = AutorunManager;
|
|
@ -1,227 +0,0 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
|
||||||
|
|
||||||
const Lang = imports.lang;
|
|
||||||
const Shell = imports.gi.Shell;
|
|
||||||
const Clutter = imports.gi.Clutter;
|
|
||||||
const St = imports.gi.St;
|
|
||||||
const Pango = imports.gi.Pango;
|
|
||||||
const Gio = imports.gi.Gio;
|
|
||||||
const GObject = imports.gi.GObject;
|
|
||||||
const Gcr = imports.gi.Gcr;
|
|
||||||
|
|
||||||
const ModalDialog = imports.ui.modalDialog;
|
|
||||||
const ShellEntry = imports.ui.shellEntry;
|
|
||||||
const CheckBox = imports.ui.checkBox;
|
|
||||||
|
|
||||||
let prompter = null;
|
|
||||||
|
|
||||||
const KeyringDialog = new Lang.Class({
|
|
||||||
Name: 'KeyringDialog',
|
|
||||||
Extends: ModalDialog.ModalDialog,
|
|
||||||
|
|
||||||
_init: function() {
|
|
||||||
this.parent({ styleClass: 'prompt-dialog' });
|
|
||||||
|
|
||||||
this.prompt = new Shell.KeyringPrompt();
|
|
||||||
this.prompt.connect('show-password', Lang.bind(this, this._onShowPassword));
|
|
||||||
this.prompt.connect('show-confirm', Lang.bind(this, this._onShowConfirm));
|
|
||||||
this.prompt.connect('hide-prompt', Lang.bind(this, this._onHidePrompt));
|
|
||||||
|
|
||||||
let mainContentBox = new St.BoxLayout({ style_class: 'prompt-dialog-main-layout',
|
|
||||||
vertical: false });
|
|
||||||
this.contentLayout.add(mainContentBox);
|
|
||||||
|
|
||||||
let icon = new St.Icon({ icon_name: 'dialog-password-symbolic' });
|
|
||||||
mainContentBox.add(icon,
|
|
||||||
{ x_fill: true,
|
|
||||||
y_fill: false,
|
|
||||||
x_align: St.Align.END,
|
|
||||||
y_align: St.Align.START });
|
|
||||||
|
|
||||||
this._messageBox = new St.BoxLayout({ style_class: 'prompt-dialog-message-layout',
|
|
||||||
vertical: true });
|
|
||||||
mainContentBox.add(this._messageBox,
|
|
||||||
{ y_align: St.Align.START, expand: true, x_fill: true, y_fill: true });
|
|
||||||
|
|
||||||
let subject = new St.Label({ style_class: 'prompt-dialog-headline' });
|
|
||||||
this.prompt.bind_property('message', subject, 'text', GObject.BindingFlags.SYNC_CREATE);
|
|
||||||
|
|
||||||
this._messageBox.add(subject,
|
|
||||||
{ y_fill: false,
|
|
||||||
y_align: St.Align.START });
|
|
||||||
|
|
||||||
let description = new St.Label({ style_class: 'prompt-dialog-description' });
|
|
||||||
description.clutter_text.ellipsize = Pango.EllipsizeMode.NONE;
|
|
||||||
description.clutter_text.line_wrap = true;
|
|
||||||
this.prompt.bind_property('description', description, 'text', GObject.BindingFlags.SYNC_CREATE);
|
|
||||||
this._messageBox.add(description,
|
|
||||||
{ y_fill: true,
|
|
||||||
y_align: St.Align.START });
|
|
||||||
|
|
||||||
this._controlTable = null;
|
|
||||||
|
|
||||||
let buttons = [{ label: '',
|
|
||||||
action: Lang.bind(this, this._onCancelButton),
|
|
||||||
key: Clutter.Escape
|
|
||||||
},
|
|
||||||
{ label: '',
|
|
||||||
action: Lang.bind(this, this._onContinueButton),
|
|
||||||
default: true
|
|
||||||
}]
|
|
||||||
|
|
||||||
this.setButtons(buttons);
|
|
||||||
this._cancelButton = buttons[0].button;
|
|
||||||
this._continueButton = buttons[1].button;
|
|
||||||
|
|
||||||
this.prompt.bind_property('cancel-label', this._cancelButton, 'label', GObject.BindingFlags.SYNC_CREATE);
|
|
||||||
this.prompt.bind_property('continue-label', this._continueButton, 'label', GObject.BindingFlags.SYNC_CREATE);
|
|
||||||
},
|
|
||||||
|
|
||||||
_buildControlTable: function() {
|
|
||||||
let table = new St.Table({ style_class: 'keyring-dialog-control-table' });
|
|
||||||
let row = 0;
|
|
||||||
|
|
||||||
if (this.prompt.password_visible) {
|
|
||||||
let label = new St.Label(({ style_class: 'prompt-dialog-password-label' }));
|
|
||||||
label.set_text(_("Password:"));
|
|
||||||
table.add(label, { row: row, col: 0,
|
|
||||||
x_expand: false, x_fill: true,
|
|
||||||
x_align: St.Align.START,
|
|
||||||
y_fill: false, y_align: St.Align.MIDDLE });
|
|
||||||
this._passwordEntry = new St.Entry({ style_class: 'prompt-dialog-password-entry',
|
|
||||||
text: '',
|
|
||||||
can_focus: true});
|
|
||||||
this._passwordEntry.clutter_text.set_password_char('\u25cf'); // ● U+25CF BLACK CIRCLE
|
|
||||||
ShellEntry.addContextMenu(this._passwordEntry, { isPassword: true });
|
|
||||||
this._passwordEntry.clutter_text.connect('activate', Lang.bind(this, this._onPasswordActivate));
|
|
||||||
table.add(this._passwordEntry, { row: row, col: 1, x_expand: true, x_fill: true, x_align: St.Align.START });
|
|
||||||
row++;
|
|
||||||
} else {
|
|
||||||
this._passwordEntry = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this.prompt.confirm_visible) {
|
|
||||||
var label = new St.Label(({ style_class: 'prompt-dialog-password-label' }));
|
|
||||||
label.set_text(_("Type again:"));
|
|
||||||
table.add(label, { row: row, col: 0,
|
|
||||||
x_expand: false, x_fill: true,
|
|
||||||
x_align: St.Align.START,
|
|
||||||
y_fill: false, y_align: St.Align.MIDDLE });
|
|
||||||
this._confirmEntry = new St.Entry({ style_class: 'prompt-dialog-password-entry',
|
|
||||||
text: '',
|
|
||||||
can_focus: true});
|
|
||||||
this._confirmEntry.clutter_text.set_password_char('\u25cf'); // ● U+25CF BLACK CIRCLE
|
|
||||||
ShellEntry.addContextMenu(this._confirmEntry, { isPassword: true });
|
|
||||||
this._confirmEntry.clutter_text.connect('activate', Lang.bind(this, this._onConfirmActivate));
|
|
||||||
table.add(this._confirmEntry, { row: row, col: 1, x_expand: true, x_fill: true, x_align: St.Align.START });
|
|
||||||
row++;
|
|
||||||
} else {
|
|
||||||
this._confirmEntry = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
this.prompt.set_password_actor(this._passwordEntry ? this._passwordEntry.clutter_text : null);
|
|
||||||
this.prompt.set_confirm_actor(this._confirmEntry ? this._confirmEntry.clutter_text : null);
|
|
||||||
|
|
||||||
if (this.prompt.choice_visible) {
|
|
||||||
let choice = new CheckBox.CheckBox();
|
|
||||||
this.prompt.bind_property('choice-label', choice.getLabelActor(), 'text', GObject.BindingFlags.SYNC_CREATE);
|
|
||||||
this.prompt.bind_property('choice-chosen', choice.actor, 'checked', GObject.BindingFlags.SYNC_CREATE | GObject.BindingFlags.BIDIRECTIONAL);
|
|
||||||
table.add(choice.actor, { row: row, col: 1, x_expand: false, x_fill: true, x_align: St.Align.START });
|
|
||||||
row++;
|
|
||||||
}
|
|
||||||
|
|
||||||
let warning = new St.Label({ style_class: 'prompt-dialog-error-label' });
|
|
||||||
warning.clutter_text.ellipsize = Pango.EllipsizeMode.NONE;
|
|
||||||
warning.clutter_text.line_wrap = true;
|
|
||||||
table.add(warning, { row: row, col: 1, x_expand: false, x_fill: false, x_align: St.Align.START });
|
|
||||||
this.prompt.bind_property('warning-visible', warning, 'visible', GObject.BindingFlags.SYNC_CREATE);
|
|
||||||
this.prompt.bind_property('warning', warning, 'text', GObject.BindingFlags.SYNC_CREATE);
|
|
||||||
|
|
||||||
if (this._controlTable) {
|
|
||||||
this._controlTable.destroy_all_children();
|
|
||||||
this._controlTable.destroy();
|
|
||||||
}
|
|
||||||
|
|
||||||
this._controlTable = table;
|
|
||||||
this._messageBox.add(table, { x_fill: true, y_fill: true });
|
|
||||||
},
|
|
||||||
|
|
||||||
_ensureOpen: function() {
|
|
||||||
// NOTE: ModalDialog.open() is safe to call if the dialog is
|
|
||||||
// already open - it just returns true without side-effects
|
|
||||||
if (this.open())
|
|
||||||
return true;
|
|
||||||
|
|
||||||
// The above fail if e.g. unable to get input grab
|
|
||||||
//
|
|
||||||
// In an ideal world this wouldn't happen (because the
|
|
||||||
// Shell is in complete control of the session) but that's
|
|
||||||
// just not how things work right now.
|
|
||||||
|
|
||||||
log('keyringPrompt: Failed to show modal dialog.' +
|
|
||||||
' Dismissing prompt request');
|
|
||||||
this.prompt.cancel()
|
|
||||||
return false;
|
|
||||||
},
|
|
||||||
|
|
||||||
_onShowPassword: function(prompt) {
|
|
||||||
this._buildControlTable();
|
|
||||||
this._ensureOpen();
|
|
||||||
this._passwordEntry.grab_key_focus();
|
|
||||||
},
|
|
||||||
|
|
||||||
_onShowConfirm: function(prompt) {
|
|
||||||
this._buildControlTable();
|
|
||||||
this._ensureOpen();
|
|
||||||
this._continueButton.grab_key_focus();
|
|
||||||
},
|
|
||||||
|
|
||||||
_onHidePrompt: function(prompt) {
|
|
||||||
this.close();
|
|
||||||
},
|
|
||||||
|
|
||||||
_onPasswordActivate: function() {
|
|
||||||
if (this.prompt.confirm_visible)
|
|
||||||
this._confirmEntry.grab_key_focus();
|
|
||||||
else
|
|
||||||
this._onContinueButton();
|
|
||||||
},
|
|
||||||
|
|
||||||
_onConfirmActivate: function() {
|
|
||||||
this._onContinueButton();
|
|
||||||
},
|
|
||||||
|
|
||||||
_onContinueButton: function() {
|
|
||||||
this.prompt.complete();
|
|
||||||
},
|
|
||||||
|
|
||||||
_onCancelButton: function() {
|
|
||||||
this.prompt.cancel();
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
const KeyringPrompter = new Lang.Class({
|
|
||||||
Name: 'KeyringPrompter',
|
|
||||||
|
|
||||||
_init: function() {
|
|
||||||
this._prompter = new Gcr.SystemPrompter();
|
|
||||||
this._prompter.connect('new-prompt', function(prompter) {
|
|
||||||
let dialog = new KeyringDialog();
|
|
||||||
return dialog.prompt;
|
|
||||||
});
|
|
||||||
this._dbusId = null;
|
|
||||||
},
|
|
||||||
|
|
||||||
enable: function() {
|
|
||||||
this._prompter.register(Gio.DBus.session);
|
|
||||||
this._dbusId = Gio.DBus.session.own_name('org.gnome.keyring.SystemPrompter',
|
|
||||||
Gio.BusNameOwnerFlags.REPLACE, null, null);
|
|
||||||
},
|
|
||||||
|
|
||||||
disable: function() {
|
|
||||||
this._prompter.unregister(false);
|
|
||||||
Gio.DBus.session.unown_name(this._dbusId);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
const Component = KeyringPrompter;
|
|