View Javadoc
1   /**
2    * This file Copyright (c) 2013-2018 Magnolia International
3    * Ltd.  (http://www.magnolia-cms.com). All rights reserved.
4    *
5    *
6    * This file is dual-licensed under both the Magnolia
7    * Network Agreement and the GNU General Public License.
8    * You may elect to use one or the other of these licenses.
9    *
10   * This file is distributed in the hope that it will be
11   * useful, but AS-IS and WITHOUT ANY WARRANTY; without even the
12   * implied warranty of MERCHANTABILITY or FITNESS FOR A
13   * PARTICULAR PURPOSE, TITLE, or NONINFRINGEMENT.
14   * Redistribution, except as permitted by whichever of the GPL
15   * or MNA you select, is prohibited.
16   *
17   * 1. For the GPL license (GPL), you can redistribute and/or
18   * modify this file under the terms of the GNU General
19   * Public License, Version 3, as published by the Free Software
20   * Foundation.  You should have received a copy of the GNU
21   * General Public License, Version 3 along with this program;
22   * if not, write to the Free Software Foundation, Inc., 51
23   * Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
24   *
25   * 2. For the Magnolia Network Agreement (MNA), this file
26   * and the accompanying materials are made available under the
27   * terms of the MNA which accompanies this distribution, and
28   * is available at http://www.magnolia-cms.com/mna.html
29   *
30   * Any modifications to this file must keep this entire header
31   * intact.
32   *
33   */
34  package info.magnolia.ui.vaadin.editor;
35  
36  import info.magnolia.ui.api.ioc.SubAppScoped;
37  import info.magnolia.ui.vaadin.editor.gwt.shared.PlatformType;
38  import info.magnolia.ui.vaadin.gwt.client.shared.ComponentElement;
39  import info.magnolia.ui.vaadin.gwt.client.shared.PageEditorParameters;
40  
41  import com.vaadin.ui.Component;
42  import com.vaadin.ui.CssLayout;
43  
44  /**
45   * Implements {@link PageEditorView}. Depending on current status defined in {@link info.magnolia.ui.vaadin.gwt.client.shared.PageEditorParameters#isPreview()}
46   * the view will be styled for page preview or editing.
47   */
48  @SubAppScoped
49  public class PageEditorViewImpl extends CssLayout implements PageEditorView {
50  
51      private PageEditorgeEditor.html#PageEditor">PageEditor pageEditor = new PageEditor();
52  
53      public PageEditorViewImpl() {
54          super();
55          addStyleName("pageEditorView");
56          setSizeFull();
57          addComponent(pageEditor);
58      }
59  
60      @Override
61      public void setListener(PageEditorListener listener) {
62          pageEditor.setListener(listener);
63      }
64  
65      @Override
66      public void refresh() {
67          pageEditor.refresh();
68      }
69  
70      @Override
71      public void load(PageEditorParameters parameters) {
72          if (parameters.isPreview()) {
73              addStyleName("preview");
74              PlatformType currentPlatform = parameters.getPlatformType();
75  
76              if (currentPlatform == PlatformType.DESKTOP) {
77                  // width and height for desktop must be 100% to take up all the available space but it won't be
78                  // displayed in the status bar
79                  setSizeFull();
80              } else {
81                  setWidth(currentPlatform.getWidth(), Unit.PIXELS);
82                  setHeight(currentPlatform.getHeight(), Unit.PIXELS);
83              }
84          } else {
85              removeStyleName("preview");
86              setSizeFull(); // reset
87          }
88          pageEditor.load(parameters);
89      }
90      @Override
91      public void update(PageEditorParameters parameters) {
92          pageEditor.update(parameters);
93      }
94  
95      @Override
96      public void startMoveComponent(ComponentElement moveComponent) {
97          pageEditor.startMoveComponent(moveComponent);
98      }
99  
100     @Override
101     public void cancelMoveComponent() {
102         pageEditor.cancelMoveComponent();
103     }
104 
105     @Override
106     public Component asVaadinComponent() {
107         return this;
108     }
109 }