// Copyright (C) 2009 The Android Open Source Project // // 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.google.gwtexpui.user.client; import com.google.gwt.user.client.ui.Composite; import com.google.gwt.user.client.ui.Widget; /** * Widget to display within a {@link ViewSite}. *<p> * Implementations must override {@code protected void onLoad()} and * arrange for {@link #display()} to be invoked once the DOM within the view is * consistent for presentation to the user. Typically this means that the * subclass can start RPCs within {@code onLoad()} and then invoke * {@code display()} from within the AsyncCallback's * {@code onSuccess(Object)} method. */ public abstract class View extends Composite { ViewSite<? extends View> site; @Override protected void onUnload() { site = null; super.onUnload(); } /** true if this is the current view of its parent view site */ public final boolean isCurrentView() { Widget p = getParent(); while (p != null) { if (p instanceof ViewSite<?>) { return ((ViewSite<?>) p).getView() == this; } p = p.getParent(); } return false; } /** Replace the current view in the parent ViewSite with this view. */ public final void display() { if (site != null) { site.swap(this); } } }