aboutsummaryrefslogtreecommitdiffstats
path: root/documentation/articles
diff options
context:
space:
mode:
authorErik Lumme <erik@vaadin.com>2017-09-13 12:54:25 +0300
committerErik Lumme <erik@vaadin.com>2017-09-13 12:54:25 +0300
commitdf686512ff51ac70ec5f7d0017173820f17c0965 (patch)
tree4112b0aa1c70e405a8615272ce8697c890350287 /documentation/articles
parent08af96539385f69d808bd64c91772a8987f54b61 (diff)
downloadvaadin-framework-df686512ff51ac70ec5f7d0017173820f17c0965.tar.gz
vaadin-framework-df686512ff51ac70ec5f7d0017173820f17c0965.zip
Migrate CreatingAComponentExtension
Diffstat (limited to 'documentation/articles')
-rw-r--r--documentation/articles/CreatingAComponentExtension.asciidoc92
-rw-r--r--documentation/articles/contents.asciidoc1
2 files changed, 93 insertions, 0 deletions
diff --git a/documentation/articles/CreatingAComponentExtension.asciidoc b/documentation/articles/CreatingAComponentExtension.asciidoc
new file mode 100644
index 0000000000..92a673f013
--- /dev/null
+++ b/documentation/articles/CreatingAComponentExtension.asciidoc
@@ -0,0 +1,92 @@
+[[creating-a-component-extension]]
+Creating a component extension
+------------------------------
+
+In this tutorial we create a simple extension that can be attached to a
+`PasswordField`, displaying a floating notification if the user's Caps
+Lock seems to be enabled. We assume the reader is already familiar with
+the link:CreatingAUIExtension.asciidoc[Creating a UI extension]
+tutorial.
+
+This extension has almost no server-side functionality; the whole Extension
+class is as follows:
+
+[source,java]
+....
+public class CapsLockWarning extends AbstractExtension {
+ protected CapsLockWarning(PasswordField field) {
+ // Non-public constructor to discourage direct instantiation
+ extend(field);
+ }
+
+ public static CapsLockWarning warnFor(PasswordField field) {
+ return new CapsLockWarning(field);
+ }
+}
+....
+
+When there's nothing to configure for the extension, users just want to
+enable it for some component and be done with it. By defining a static
+factory method, the user only needs to do something like
+`CapsLockWarning.warnFor(myPasswordField);` to make `myPasswordField`
+get the new functionality.
+
+The client side is not overly complicated, either. We override the
+`extend` method, called by the framework when the client-side extension
+connector is attached to its target the client-side counterpart of the
+connector to which the server-side extension instance is attached in
+this case, `PasswordFieldConnector`.
+
+We add a key press handler to the password widget, checking if the input
+looks like Caps Lock might be enabled. The Caps Lock state cannot be
+directly queried in GWT/JavaScript, so we use a trick: check if either
+
+* the shift key was not held but the entered character was uppercase, or
+* the shift key _was_ held but the entered character was lowercase.
+
+If this is the case, we show a warning in the form of a floating widget
+(`VOverlay`). This demonstrates how an extension may make use of UI
+elements even though it is not a part of the layout hierarchy. A
+frequent use case for extensions is showing different types of floating
+overlay elements that are temporary in character.
+
+[source,java]
+....
+
+@Connect(CapsLockWarning.class)
+public class CapsLockWarningConnector extends AbstractExtensionConnector {
+ @Override
+ protected void extend(ServerConnector target) {
+ final Widget passwordWidget = ((ComponentConnector) target).getWidget();
+
+ final VOverlay warning = new VOverlay();
+ warning.setOwner(passwordWidget);
+ warning.add(new HTML("Caps Lock is enabled!"));
+
+ passwordWidget.addDomHandler(new KeyPressHandler() {
+ @Override
+ public void onKeyPress(KeyPressEvent event) {
+ if (isEnabled() && isCapsLockOn(event)) {
+ warning.showRelativeTo(passwordWidget);
+ } else {
+ warning.hide();
+ }
+ }
+ }, KeyPressEvent.getType());
+ }
+
+ private boolean isCapsLockOn(KeyPressEvent e) {
+ return e.isShiftKeyDown() ^ Character.isUpperCase(e.getCharCode());
+ }
+}
+....
+
+To use the Caps Lock warning, compile your widgetset and extend a
+PasswordField with something like this
+
+[source,java]
+....
+PasswordField field = new PasswordField("Enter your password");
+CapsLockWarning.warnFor(field);
+addComponent(field);
+....
diff --git a/documentation/articles/contents.asciidoc b/documentation/articles/contents.asciidoc
index 417f8af458..22ad7cbf81 100644
--- a/documentation/articles/contents.asciidoc
+++ b/documentation/articles/contents.asciidoc
@@ -78,5 +78,6 @@ are great, too.
- link:CreatingAnEclipseProject.asciidoc[Creating an Eclipse project]
- link:CreatingASimpleComponentContainer.asciidoc[Creating a simple component container]
- link:UsingRPCToSendEventsToTheClient.asciidoc[Using RPC to send events to the client]
+- link:CreatingAComponentExtension.asciidoc[Creating a component extension]
- link:CreatingAUIExtension.asciidoc[Creating a UI extension]
- link:CreatingAThemeUsingSass.asciidoc[Creating a theme using Sass]