Added set height for iFrame in order to have only internal scroll

Disabled Window scroll

git-svn-id: http://svn.d4science-ii.research-infrastructures.eu/gcube/trunk/portlets/user/gcube-ckan-datacatalog@130449 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
Francesco Mangiacrapa 2016-07-15 16:19:05 +00:00
parent 60f784cd04
commit 420ee338f4
4 changed files with 93 additions and 86 deletions

View File

@ -21,6 +21,8 @@
<inherits <inherits
name='org.gcube.portlets.widgets.ckandatapublisherwidget.CKanMetadataPublisher' /> name='org.gcube.portlets.widgets.ckandatapublisherwidget.CKanMetadataPublisher' />
<inherits name='org.gcube.portlets.widgets.sessionchecker.SessionChecker' />
<inherits name='org.gcube.portlets.user.gcubewidgets.WidgetFactory' /> <inherits name='org.gcube.portlets.user.gcubewidgets.WidgetFactory' />
<!-- Specify the paths for translatable code --> <!-- Specify the paths for translatable code -->

View File

@ -3,7 +3,6 @@ package org.gcube.portlets.gcubeckan.gcubeckandatacatalog.client;
import org.gcube.portlets.gcubeckan.gcubeckandatacatalog.client.view.CKanLeaveFrame; import org.gcube.portlets.gcubeckan.gcubeckandatacatalog.client.view.CKanLeaveFrame;
import org.gcube.portlets.gcubeckan.gcubeckandatacatalog.client.view.GCubeCkanDataCatalogPanel; import org.gcube.portlets.gcubeckan.gcubeckandatacatalog.client.view.GCubeCkanDataCatalogPanel;
import org.gcube.portlets.widgets.sessionchecker.client.CheckSession;
import com.google.gwt.core.client.EntryPoint; import com.google.gwt.core.client.EntryPoint;
import com.google.gwt.core.client.GWT; import com.google.gwt.core.client.GWT;
@ -30,6 +29,7 @@ public class GCubeCkanDataCatalog implements EntryPoint {
private CKanLeaveFrame frame; private CKanLeaveFrame frame;
public static final String GET_PATH_PARAMETER = "path"; public static final String GET_PATH_PARAMETER = "path";
public static final String GET_QUERY_PARAMETER = "query"; public static final String GET_QUERY_PARAMETER = "query";
public static final String GCUBE_CKAN_IFRAME = "gcube-ckan-iframe";
/** /**
* This is the entry point method. * This is the entry point method.

View File

@ -3,6 +3,7 @@
*/ */
package org.gcube.portlets.gcubeckan.gcubeckandatacatalog.client.view; package org.gcube.portlets.gcubeckan.gcubeckandatacatalog.client.view;
import org.gcube.portlets.gcubeckan.gcubeckandatacatalog.client.GCubeCkanDataCatalog;
import org.gcube.portlets.gcubeckan.gcubeckandatacatalog.client.event.IFrameInstanciedEvent; import org.gcube.portlets.gcubeckan.gcubeckandatacatalog.client.event.IFrameInstanciedEvent;
import com.google.gwt.core.shared.GWT; import com.google.gwt.core.shared.GWT;
@ -61,24 +62,15 @@ public class CkanFramePanel extends FlowPanel{
} }
frame = new Frame(ckanUrlConnector); frame = new Frame(ckanUrlConnector);
frame.getElement().setId(GCubeCkanDataCatalog.GCUBE_CKAN_IFRAME);
frame.setWidth("100%");
// frame.getElement().getStyle().setOverflow(Overflow.HIDDEN);
// frame.getElement().setAttribute("scrolling", "no");
frame.getElement().getStyle().setBorderWidth(0, Unit.PX); frame.getElement().getStyle().setBorderWidth(0, Unit.PX);
// frame.getElement().setPropertyString("frameBorder", "0");
frame.addLoadHandler(new LoadHandler() { frame.addLoadHandler(new LoadHandler() {
@Override @Override
public void onLoad(LoadEvent arg0) { public void onLoad(LoadEvent arg0) {
/*NodeList<Element> listHeaders = Document.get().getElementsByTagName("header");
if(listHeaders!=null){
GWT.log("List Header by tag name is/are: "+listHeaders.getLength() +", hidden..");
for (int i = 0; i < listHeaders.getLength(); i++) {
Element header = listHeaders.getItem(i);
header.getStyle().setVisibility(Visibility.HIDDEN);
}
}else
GWT.log("List Header by tag name is null");*/
} }
}); });
add(frame); add(frame);

View File

@ -1,6 +1,7 @@
/** /**
* *
*/ */
package org.gcube.portlets.gcubeckan.gcubeckandatacatalog.client.view; package org.gcube.portlets.gcubeckan.gcubeckandatacatalog.client.view;
import java.util.Map; import java.util.Map;
@ -23,12 +24,10 @@ import com.google.gwt.user.client.ui.RootPanel;
import com.google.gwt.user.client.ui.ScrollPanel; import com.google.gwt.user.client.ui.ScrollPanel;
import com.google.gwt.user.client.ui.VerticalPanel; import com.google.gwt.user.client.ui.VerticalPanel;
/** /**
* The Class GCubeCkanDataCatalogPanel. * The Class GCubeCkanDataCatalogPanel.
* *
* @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it * @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it Jun 9, 2016
* Jun 9, 2016
*/ */
public class GCubeCkanDataCatalogPanel extends BaseViewTemplate { public class GCubeCkanDataCatalogPanel extends BaseViewTemplate {
@ -40,14 +39,19 @@ public class GCubeCkanDataCatalogPanel extends BaseViewTemplate{
private RootPanel rootPanel; private RootPanel rootPanel;
private HandlerManager eventBus; private HandlerManager eventBus;
private CkanConnectorAccessPoint ckanAccessPoint; private CkanConnectorAccessPoint ckanAccessPoint;
public static final int IFRAME_FIX_HEIGHT = 1800;
/** /**
* Instantiates a new g cube ckan data catalog panel. * Instantiates a new g cube ckan data catalog panel.
* *
* @param rootPanel the root panel * @param rootPanel
* @param eventManager the event manager * the root panel
* @param eventManager
* the event manager
*/ */
public GCubeCkanDataCatalogPanel(RootPanel rootPanel, HandlerManager eventManager){ public GCubeCkanDataCatalogPanel(
RootPanel rootPanel, HandlerManager eventManager) {
this.rootPanel = rootPanel; this.rootPanel = rootPanel;
this.eventBus = eventManager; this.eventBus = eventManager;
ckanFramePanel = new CkanFramePanel(eventBus); ckanFramePanel = new CkanFramePanel(eventBus);
@ -55,13 +59,17 @@ public class GCubeCkanDataCatalogPanel extends BaseViewTemplate{
ckanOrganizationsPanel = new CkanOrganizationsPanel(this); ckanOrganizationsPanel = new CkanOrganizationsPanel(this);
initPanel(); initPanel();
setTopPanelVisible(true); setTopPanelVisible(true);
String pathParameter = Window.Location.getParameter(GCubeCkanDataCatalog.GET_PATH_PARAMETER); String pathParameter =
String queryParameter = Window.Location.getParameter(GCubeCkanDataCatalog.GET_QUERY_PARAMETER); Window.Location.getParameter(GCubeCkanDataCatalog.GET_PATH_PARAMETER);
String queryParameter =
GCubeCkanDataCatalog.service.getCKanConnector(pathParameter, queryParameter, new AsyncCallback<CkanConnectorAccessPoint>() { Window.Location.getParameter(GCubeCkanDataCatalog.GET_QUERY_PARAMETER);
GCubeCkanDataCatalog.service.getCKanConnector(
pathParameter, queryParameter,
new AsyncCallback<CkanConnectorAccessPoint>() {
@Override @Override
public void onSuccess(CkanConnectorAccessPoint ckan) { public void onSuccess(CkanConnectorAccessPoint ckan) {
ckanAccessPoint = ckan; ckanAccessPoint = ckan;
instanceCkanFrame(ckan.buildURI()); instanceCkanFrame(ckan.buildURI());
GCubeCkanDataCatalogPanel.this.rootPanel.remove(loading); GCubeCkanDataCatalogPanel.this.rootPanel.remove(loading);
@ -69,26 +77,25 @@ public class GCubeCkanDataCatalogPanel extends BaseViewTemplate{
@Override @Override
public void onFailure(Throwable caught) { public void onFailure(Throwable caught) {
GCubeCkanDataCatalogPanel.this.rootPanel.remove(loading); GCubeCkanDataCatalogPanel.this.rootPanel.remove(loading);
Window.alert("Sorry, An error occurred during contacting Gcube Ckan Data Catalogue!"); Window.alert("Sorry, An error occurred during contacting Gcube Ckan Data Catalogue!");
} }
}); });
GCubeCkanDataCatalog.service.outsidePortal(new AsyncCallback<Boolean>() { GCubeCkanDataCatalog.service.outsidePortal(new AsyncCallback<Boolean>() {
@Override @Override
public void onSuccess(Boolean result) { public void onSuccess(Boolean result) {
if (result) { if (result) {
// the portlet is outside the portal and no user is logged in // the portlet is outside the portal and no user is logged
// in
// show only home and statistics // show only home and statistics
managementPanel.doNotShowUserRelatedInfo(); managementPanel.doNotShowUserRelatedInfo();
}
}else{ else {
// polling for session expired check // polling for session expired check
CheckSession.getInstance().startPolling(); CheckSession.getInstance().startPolling();
// RETRIEVE USER'S ORGANIZATIONS // RETRIEVE USER'S ORGANIZATIONS
GCubeCkanDataCatalog.service.getCkanOrganizationsNamesAndUrlsForUser(new AsyncCallback<Map<String, String>>() { GCubeCkanDataCatalog.service.getCkanOrganizationsNamesAndUrlsForUser(new AsyncCallback<Map<String, String>>() {
@ -101,15 +108,15 @@ public class GCubeCkanDataCatalogPanel extends BaseViewTemplate{
@Override @Override
public void onFailure(Throwable caught) { public void onFailure(Throwable caught) {
} }
}); });
// MANAGE CKAN MANAGEMENT PANEL ACCORDING TO MY ROLE // MANAGE CKAN MANAGEMENT PANEL ACCORDING TO MY ROLE
GCubeCkanDataCatalog.service.getMyRole(new AsyncCallback<CkanRole>() { GCubeCkanDataCatalog.service.getMyRole(new AsyncCallback<CkanRole>() {
@Override @Override
public void onFailure(Throwable caught) { public void onFailure(Throwable caught) {
} }
@Override @Override
@ -133,9 +140,7 @@ public class GCubeCkanDataCatalogPanel extends BaseViewTemplate{
} }
} }
}); });
} }
} }
@Override @Override
@ -144,23 +149,25 @@ public class GCubeCkanDataCatalogPanel extends BaseViewTemplate{
// the portlet is outside the portal and no user is logged in // the portlet is outside the portal and no user is logged in
// show only home and statistics // show only home and statistics
managementPanel.doNotShowUserRelatedInfo(); managementPanel.doNotShowUserRelatedInfo();
} }
}); });
Window.addResizeHandler(new ResizeHandler() { Window.addResizeHandler(new ResizeHandler() {
@Override @Override
public void onResize(ResizeEvent event) { public void onResize(ResizeEvent event) {
GWT.log("onWindowResized width: " + event.getWidth() + " height: " + event.getHeight()); GWT.log("onWindowResized width: " + event.getWidth() +
" height: " + event.getHeight());
updateSize(); updateSize();
} }
}); });
Window.enableScrolling(false);
rootPanel.add(loading); rootPanel.add(loading);
rootPanel.add(this); rootPanel.add(this);
updateSize(); updateSize();
// listenForPostMessage();
// postMessage("Un messaggio");
} }
/** /**
@ -172,16 +179,17 @@ public class GCubeCkanDataCatalogPanel extends BaseViewTemplate{
if (managementPanel.isVisible()) if (managementPanel.isVisible())
return managementPanel.getCurrentHeight(); return managementPanel.getCurrentHeight();
return 0; return 0;
} }
/** /**
* Sets the top panel visible. * Sets the top panel visible.
* *
* @param bool the new top panel visible * @param bool
* the new top panel visible
*/ */
public void setTopPanelVisible(boolean bool) { public void setTopPanelVisible(boolean bool) {
managementPanel.setVisible(bool); managementPanel.setVisible(bool);
updateSize(); updateSize();
} }
@ -189,16 +197,19 @@ public class GCubeCkanDataCatalogPanel extends BaseViewTemplate{
/** /**
* show or hide edit/insert buttons according to the role. * show or hide edit/insert buttons according to the role.
* *
* @param show the show * @param show
* the show
*/ */
public void showEditInsertButtons(boolean show) { public void showEditInsertButtons(boolean show) {
managementPanel.showInsertAndEditProductButtons(show); managementPanel.showInsertAndEditProductButtons(show);
} }
/** /**
* Instance ckan frame. * Instance ckan frame.
* *
* @param ckanUrlConnector the ckan url connector * @param ckanUrlConnector
* the ckan url connector
* @return the frame * @return the frame
*/ */
public Frame instanceCkanFrame(String ckanUrlConnector) { public Frame instanceCkanFrame(String ckanUrlConnector) {
@ -206,13 +217,13 @@ public class GCubeCkanDataCatalogPanel extends BaseViewTemplate{
ckanFramePanel.setVisible(true); ckanFramePanel.setVisible(true);
ckanOrganizationsPanel.setVisible(false); ckanOrganizationsPanel.setVisible(false);
return ckanFramePanel.instanceFrame(ckanUrlConnector); return ckanFramePanel.instanceFrame(ckanUrlConnector);
} }
/** /**
* Inits the panel. * Inits the panel.
*/ */
private void initPanel() { private void initPanel() {
setTopPanelVisible(false); setTopPanelVisible(false);
addToTop(managementPanel); addToTop(managementPanel);
VerticalPanel containerIntoScrollPanel = new VerticalPanel(); VerticalPanel containerIntoScrollPanel = new VerticalPanel();
@ -228,27 +239,28 @@ public class GCubeCkanDataCatalogPanel extends BaseViewTemplate{
* Update window size. * Update window size.
*/ */
public void updateSize() { public void updateSize() {
/*RootPanel workspace = rootPanel;
RootPanel workspace = rootPanel;
int topBorder = workspace.getAbsoluteTop(); int topBorder = workspace.getAbsoluteTop();
int leftBorder = workspace.getAbsoluteLeft(); GWT.log("top: "+topBorder);
int footer = 0; //85 footer is bottombar + sponsor int footer = 30; // 85 footer is bottombar + sponsor
int rightScrollBar = 0; int rootHeight = Window.getClientHeight() - topBorder - 5 - footer;
int rootHeight = Window.getClientHeight() - topBorder - 5 - footer;// - ((footer == null)?0:(footer.getOffsetHeight()-15));
int rootWidth = Window.getClientWidth() - 2* leftBorder - rightScrollBar;
GWT.log("New iFrame size w: "+rootWidth + " h: "+rootHeight);
this.setSize(rootWidth+"px",rootHeight+"px");
int height = rootHeight - getTopPanelHeight(); int height = rootHeight - getTopPanelHeight();
// if(height<2000)
// height = 2000;
if (ckanFramePanel.getFrame() != null) { if (ckanFramePanel.getFrame() != null) {
ckanFramePanel.getFrame().setSize(rootWidth+"px", height+"px");
int newH =managementPanel != null && managementPanel.getCurrentHeight() > 0 ? managementPanel.getOffsetHeight() + height : height; int newH =managementPanel != null && managementPanel.getCurrentHeight() > 0 ? managementPanel.getOffsetHeight() + height : height;
// managementPanel.setHeight(height+50+"px"); ckanFramePanel.getFrame().setHeight(2000+"px");
this.setHeight(newH+"px"); }*/
}
}
RootPanel workspace = this.rootPanel;
int topBorder = workspace.getAbsoluteTop();
int footer = 55;
int rootHeight = Window.getClientHeight() - topBorder - 5 - footer;
int height = rootHeight - getTopPanelHeight();
if (this.ckanFramePanel.getFrame() != null) {
int newH = this.managementPanel != null &&this.managementPanel.getCurrentHeight() > 0? this.managementPanel.getOffsetHeight() + height : height;
this.ckanFramePanel.getFrame().setHeight(newH + "px");
}
// workspace.setHeight(height+"px");
}
/** /**
* Gets the base urlckan connector. * Gets the base urlckan connector.
@ -256,16 +268,17 @@ public class GCubeCkanDataCatalogPanel extends BaseViewTemplate{
* @return the base urlckan connector * @return the base urlckan connector
*/ */
public String getBaseURLCKANConnector() { public String getBaseURLCKANConnector() {
return ckanAccessPoint.getBaseUrlWithContext(); return ckanAccessPoint.getBaseUrlWithContext();
} }
/** /**
* Gets the gcube token value to ckan connector. * Gets the gcube token value to ckan connector.
* *
* @return the gcube token value to ckan connector * @return the gcube token value to ckan connector
*/ */
public String getGcubeTokenValueToCKANConnector() { public String getGcubeTokenValueToCKANConnector() {
return ckanAccessPoint.getGcubeTokenValue(); return ckanAccessPoint.getGcubeTokenValue();
} }
@ -275,16 +288,16 @@ public class GCubeCkanDataCatalogPanel extends BaseViewTemplate{
* @return the path info * @return the path info
*/ */
public String getPathInfo() { public String getPathInfo() {
return ckanAccessPoint.getPathInfoParameter(); return ckanAccessPoint.getPathInfoParameter();
} }
/** /**
* Show the organizations panel * Show the organizations panel.
*/ */
public void showOrganizations() { public void showOrganizations() {
ckanOrganizationsPanel.setVisible(true); ckanOrganizationsPanel.setVisible(true);
ckanFramePanel.setVisible(false); ckanFramePanel.setVisible(false);
} }
} }