summaryrefslogtreecommitdiffstats
path: root/kjsembed/design.h
diff options
context:
space:
mode:
Diffstat (limited to 'kjsembed/design.h')
-rw-r--r--kjsembed/design.h183
1 files changed, 183 insertions, 0 deletions
diff --git a/kjsembed/design.h b/kjsembed/design.h
new file mode 100644
index 00000000..d255aeef
--- /dev/null
+++ b/kjsembed/design.h
@@ -0,0 +1,183 @@
+/*
+ * Copyright (C) 2002-2004, Richard J. Moore <rich@kde.org>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Library General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library 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
+ * Library General Public License for more details.
+ *
+ * You should have received a copy of the GNU Library General Public License
+ * along with this library; see the file COPYING.LIB. If not, write to
+ * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ * Boston, MA 02110-1301, USA.
+ */
+
+/**
+ * @mainpage Framework for embedding the KJS Javascript Interpreter
+ *
+ * @section intro Introduction
+ *
+ * The KJSEmbed library provides a framework that makes it easy for
+ * applications to embed KJS, the KDE JavaScript interpreter. The
+ * facilities available include a JS console widget, a dialog loader
+ * and a binding between JS and the properties and slots of QObjects.
+ *
+ * @section classes Important Classes
+ *
+ * The most important classes to consider are:
+ *
+ * @ref KJSEmbed::KJSEmbedPart :
+ * Main API for KJSEmbed.
+ *
+ * @ref KJSEmbed::JSConsoleWidget :
+ * A widget that provides an interactive JS console.
+ *
+ * @ref KJSEmbed::JSObjectProxy :
+ * A Javascript object that can access the properties of a QObject,
+ *
+ * @ref KJSEmbed::SecurityPolicy :
+ * Defines a security policy for @ref JSObjectProxy.
+ *
+ * @section basic Basic Usage
+ *
+ * The simplest way to use KJSEmbed is by simply creating a Javascript
+ * console widget. The console allows the user to enter and run arbitrary
+ * Javascript expressions.
+ * <pre>
+ * KJSEmbed::JSConsoleWidget *win = new KJSEmbed::JSConsoleWidget();
+ * win->show();
+ * </pre>
+ * The embedding application can run scripts in the console using the
+ * execute() method.
+ *
+ * The best way to use KJSEmbed is keep control of the interpreter
+ * yourself using the KJSEmbedPart, this way you can make parts of your
+ * application available to scripts. The following example creates its
+ * own interpreter then binds it to the console:
+ * <pre>
+ * KJSEmbed::KJSEmbedPart *js = new KJSEmbed::KJSEmbedPart();
+ * KJSEmbed::JSConsoleWidget *console = js->view();
+ * </pre>
+ *
+ * @section proxy Publishing QObjects
+ *
+ * KJSEmbed allows applications to make arbitrary QObjects visible to a
+ * Javascript interpreter. The binding itself is provided by the @ref JSProxyObject
+ * class, but is more easily used via the addObject(...) methods of @ref KJSEmbedPart.
+ *
+ * The following code shows how easy it is to make an object available for
+ * scripting. It creates a QVBox containing two QLabels then makes them visible
+ * to KJSEmbed:
+ * <pre>
+ * QVBox *toplevel = new QVBox( 0, "box" );
+ * QLabel *title = new QLabel( "Some Title", toplevel, "title");
+ * QLabel *main = new QLabel( "Some text, more text.", toplevel, "main" );
+ *
+ * js->addObject( title );
+ * js->addObject( main, "text" );
+ * </pre>
+ *
+ * Publishing an object makes it possibile for scripts to access both the
+ * properties and slots as if it was a normal Javascript object. The code
+ * above allows scripts read-write access to the label properties as this
+ * script illustrates:
+ * <pre>
+ * title.text = "World"
+ * title.text = "Hello " + title.text
+ * </pre>
+ * The script above would set the text of the label to 'Hello World'.
+ *
+ * The slots of a QObject bound to the interpreter are made available to
+ * scripts as if they normal methods. In the example above, we could conceal
+ * the label 'main' entirely by calling its hide() slot:
+ * <pre>
+ * main.hide()
+ * </pre>
+ *
+ * @section tree Access To the QObject Tree
+ *
+ * As well as providing script access to an individual widget, KJSEmbed
+ * allows scripts to walk the object tree and access others. If we
+ * modified the previous example to publish the QBox widget 'toplevel' as
+ * follows:
+ * <pre>
+ * js->addObject( toplevel, "window" );
+ * </pre>
+ * Then, despite the fact we've only explicitly published a single widget,
+ * we've also provided access to both 'main' and 'title'. The ability
+ * to navigate the object tree is limited by the SecurityPolicy, the default
+ * policy only allows scripts access to children of the published object.
+ *
+ * To achieve the same result as before, we could use script like this:
+ * <pre>
+ * window.child("main").text = "World"
+ * window.child("main").text = "Hello " + window.child("main").text
+ * </pre>
+ * The result of this script is identical to the previous example.
+ *
+ * @section examples Some KJSEmbed examples
+ * @subsection embedjs Example of embedding KJSEmbed into an application.
+ * @image html embedjs.png
+ * This is an example of how to embed and interface with KJSEmbed. This
+ * example covers:
+ * @li embedding the kpart.
+ * @li publishing the interface.
+ * @li calling javascript members.
+ * @li handling javascript objects returned by these members.
+ * @li embedding the KJSEmbed console.
+ * @dontinclude embedviewimp.cpp
+ * To embed the interpreter we can just create a new KJSEmbed part.
+ * @skipline m_part
+ * To publish the objects we can then call @ref KJSEmbed::KJSEmbedPart::addObject on our part.
+ * This will then add any QObject based class the the global scope of the
+ * javascript interperter.
+ * @skipline addObject
+ * Once you have your objects published you can then execute javascript code from a file.
+ * @skipline runFile
+ * @dontinclude embedviewimp.cpp
+ * When the script is running javascript methods can be accessed by calling the
+ * @ref KJSEmbed::KJSEmbedPart::callMethod method.
+ * @skipline args
+ * @until callMethod
+ * Any arguments that you wish to pass into the javascript method are contained in the
+ * @ref KJS::List. This is just a list of @ref KJS::Value objects and can be created from
+ * QVariants or from custom @ref KJS::Object based classes.
+ * Once you have the data back from the method you can convert it easily from the @ref KJS::Value
+ * type to a QVariant with the @ref KJSEmbed::convertToVariant method.
+ * @line personalData
+ * @until notes:
+ * Complex arrays or @ref KJS::Objects are transparently converted to QVariant::Map types so
+ * they can easily be manipulated from C++.
+ * The KJSEmbed::console is also easy to add to applications. An example of a method that
+ * will toggle the console is below.
+ * @skipline consoleClicked
+ * @until }
+ *
+ * @subsection embedjs Example of Using Qt Designer files in KJSEmbed.
+ * @image html jscalc.png
+ * This is a very simple example that shows off how to use Qt widget files
+ * and connect the objects to javascript functions.
+ * @dontinclude calc.js
+ * To load the Qt Designer user interface file and publish the objects in the XML file
+ * the KJSEmbed Factory class has a UI loader.
+ * @skipline Factory.loadui
+ * Once the file is loaded the user interface object can then be manipulated by javascript.
+ * @line new Calculator
+ * @until application.exec
+ * It is important to note that before the javascript will support connecting signals and slots
+ * the application.exec() method must be called.
+ *
+ * Connecting the user interface to javascript methods is similar C++ in that you create
+ * a method and then use the connect(...) method to connect the signal to the method.
+ * @dontinclude calc.js
+ * @skipline function
+ * @until display
+ * @skipline this.clear
+ * @skipline clear
+ * @skipline }
+ */