blob: 587b87cbe6d84ac6a20337bc8fe3c4635cc4f51b [file] [log] [blame]
/*
* Copyright 2008 Google Inc.
*
* 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.gwt.i18n.client;
/**
* A widget that implements this interface has the ability to override
* the document directionality for its root element.
*
* Widgets that implement this interface should be leaf widgets. More
* specifically, they should not implement the
* {@link com.google.gwt.user.client.ui.HasWidgets} interface.
*/
public interface HasDirection {
/**
* Possible return values for {@link HasDirection#getDirection()} and parameter values for
* {@link HasDirection#setDirection(Direction)}.Widgets that implement this interface can
* either have a direction that is right-to-left (RTL), left-to-right (LTR), or default
* (which means that their directionality is inherited from their parent widget).
*/
enum Direction { RTL, LTR, DEFAULT }
/**
* Sets the directionality for a widget.
*
* @param direction <code>RTL</code> if the directionality should be set to right-to-left,
* <code>LTR</code> if the directionality should be set to left-to-right
* <code>DEFAULT</code> if the directionality should not be explicitly set
*/
void setDirection(Direction direction);
/**
* Gets the directionality of the widget.
*
* @return <code>RTL</code> if the directionality is right-to-left,
* <code>LTR</code> if the directionality is left-to-right, or
* <code>DEFAULT</code> if the directionality is not explicitly specified
*/
Direction getDirection();
}