summaryrefslogtreecommitdiffstats
path: root/server
diff options
context:
space:
mode:
Diffstat (limited to 'server')
-rw-r--r--server/src/com/vaadin/server/Responsive.java161
1 files changed, 161 insertions, 0 deletions
diff --git a/server/src/com/vaadin/server/Responsive.java b/server/src/com/vaadin/server/Responsive.java
new file mode 100644
index 0000000000..d69c204c94
--- /dev/null
+++ b/server/src/com/vaadin/server/Responsive.java
@@ -0,0 +1,161 @@
+/*
+ * Copyright 2000-2013 Vaadin Ltd.
+ *
+ * Licensed under the Apache License, Version 2.0 (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.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations under
+ * the License.
+ */
+
+package com.vaadin.server;
+
+import com.vaadin.ui.Component;
+
+/**
+ * An extension providing responsive layout capabilities to any Vaadin
+ * component. The Responsive extension allows specifying different CSS rules for
+ * different dimensions of extended components. This allows creating
+ * applications that provide an optimal viewing experience – easy reading and
+ * navigation with a minimum of resizing, panning, and scrolling – across a wide
+ * range of devices (from mobile phones to desktop computer monitors).
+ * <p>
+ * NOTE! You should always specify a relative (%) size for the extended
+ * component, doing otherwise will prevent the Responsive extension from
+ * working, as the component will not dynamically resize.
+ * </p>
+ * <p>
+ * All configuration of the visual breakpoints (ranges) for the component are
+ * done with CSS. Pixels (px) are the only supported unit. Fractional pixels are
+ * not supported.
+ * </p>
+ * <p>
+ * <i>Dynamic style injections (e.g. through
+ * <code>Page.getCurrent().getStyles().add(...)</code>) or any other style
+ * updates after the initial page load are not supported at the moment.</i>
+ * </p>
+ *
+ *
+ * <p>
+ * Example:
+ *
+ * <b>Java</b>
+ *
+ * <pre>
+ * CssLayout layout = new CssLayout();
+ * layout.setStyleName("responsive");
+ * layout.setSizeFull();
+ * Responsive.makeResponsive(layout);
+ * </pre>
+ *
+ * <b>SCSS</b>
+ *
+ * <pre>
+ * .v-csslayout.responsive {
+ * &[width-range~="0-300px"] {
+ * // Styles for the layout when its width is between 0 and 300 pixels
+ * }
+ * &[width-range~="301-500px"] {
+ * // Styles for the layout when its width is between 301 and 500 pixels
+ * }
+ * &[width-range~="501px-"] {
+ * // Styles for the layout when its width is over 500 pixels
+ * }
+ * &[height-range~="0-300px"] {
+ * // Styles for the layout when its height is between 0 and 300 pixels
+ * }
+ * &[height-range~="301-500px"] {
+ * // Styles for the layout when its height is between 301 and 500 pixels
+ * }
+ * &[height-range~="501-"] {
+ * // Styles for the layout when its height is over 500 pixels
+ * }
+ * }
+ * </pre>
+ *
+ * <b>CSS</b>
+ *
+ * <pre>
+ * .v-csslayout.responsive[width-range~="0-300px"] {
+ * // Styles for the layout when its width is between 0 and 300 pixels
+ * }
+ * .v-csslayout.responsive[width-range~="301-500px"] {
+ * // Styles for the layout when its width is between 301 and 500 pixels
+ * }
+ * .v-csslayout.responsive[width-range~="501-"] {
+ * // Styles for the layout when its width is over 500 pixels
+ * }
+ *
+ * .v-csslayout.responsive[height-range~="0-300px"] {
+ * // Styles for the layout when its height is between 0 and 300 pixels
+ * }
+ * .v-csslayout.responsive[height-range~="301-500px"] {
+ * // Styles for the layout when its height is between 301 and 500 pixels
+ * }
+ * .v-csslayout.responsive[height-range~="501px-"] {
+ * // Styles for the layout when its height is over 500 pixels
+ * }
+ * </pre>
+ *
+ * </p>
+ * <p>
+ * <b>Note:</b> <i>The defined ranges are applied on a global context, so even
+ * if you would write your CSS to target only a given context, the ranges would
+ * be applied to all other instances with the same style name.</i>
+ * </p>
+ * <p>
+ * E.g. this would affect all CssLayout instances in the application, even
+ * though the CSS implies it would only affect CssLayout instances inside a
+ * parent with a style name "foobar":
+ * </p>
+ *
+ * <pre>
+ * .foobar .v-csslayout[width-range~="0px-100px"] {
+ * // These properties will affect all responsive CssLayout instances
+ * }
+ * </pre>
+ *
+ * <p>
+ * To scope the ranges, use an additional style name for the target component,
+ * and add that to your CSS selector:
+ * </p>
+ *
+ * <pre>
+ * .v-csslayout.mystyle[width-range="0px-100px"] {
+ * // These properties will only affect responsive CssLayout instances with an additional style name of 'mystyle'
+ * }
+ * </pre>
+ *
+ * @author Vaadin Ltd
+ * @since 7.2
+ */
+public class Responsive extends AbstractExtension {
+
+ /**
+ * Creates a new instance, which can be used to extend a component.
+ */
+ protected Responsive() {
+ }
+
+ /**
+ * Enable responsive width and height range styling for the target component
+ * or UI instance.
+ *
+ * @param target
+ * The component which should be able to respond to width and/or
+ * height changes.
+ */
+ public static void makeResponsive(Component... components) {
+ for (Component c : components) {
+ if (c instanceof AbstractClientConnector) {
+ new Responsive().extend((AbstractClientConnector) c);
+ }
+ }
+ }
+}