blob: c4c1cdef9b7df2fec6f8f81bd4f2303b0fd81e35 [file] [log] [blame]
/*
* Copyright 2010 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.user.client.ui;
/**
* A widget that implements this interface can be configured to be aligned
* according to its contents' direction, in addition to the static alignment
* options offered by {@link HasHorizontalAlignment}.
*/
public interface HasAutoHorizontalAlignment extends HasHorizontalAlignment {
/**
* Specifies that the widget's contents should be aligned left for LTR
* content, right for RTL content, and if the content's direction is DEFAULT,
* like {@link #ALIGN_LOCALE_START}.
*/
AutoHorizontalAlignmentConstant ALIGN_CONTENT_START =
new AutoHorizontalAlignmentConstant();
/**
* Specifies that the widget's contents should be aligned right for LTR
* content, left for RTL content, and if the content's direction is DEFAULT,
* like {@link #ALIGN_LOCALE_END}.
*/
AutoHorizontalAlignmentConstant ALIGN_CONTENT_END =
new AutoHorizontalAlignmentConstant();
/**
* Gets the horizontal auto-alignment setting. This may be one of the
* auto-alignment values above that depend on content direction (e.g.
* {@link HasAutoHorizontalAlignment#ALIGN_CONTENT_START}), or one of the
* "static" {@link HasHorizontalAlignment.HorizontalAlignmentConstant}
* alignment values (e.g. {@link HasHorizontalAlignment#ALIGN_LOCALE_START}).
* It may be set by either {@code setAutoHorizontalAlignment} or {@code
* HasHorizontalAlignment#setHorizontalAlignment}. The default is null,
* indicating that no specific horizontal alignment has been set, allowing it
* to be determined by the usual HTML and CSS mechanisms.
*
* @return the current automatic horizontal alignment policy.
*/
AutoHorizontalAlignmentConstant getAutoHorizontalAlignment();
/**
* Sets the horizontal alignment, allowing in addition to the "static"
* {@link HasHorizontalAlignment.HorizontalAlignmentConstant} values, the
* "automatic" {@link HasHorizontalAlignment.AutoHorizontalAlignmentConstant}
* values that depend on the content direction. Determines the values returned
* by both {@link #getAutoHorizontalAlignment} and
* {@link HasHorizontalAlignment#getHorizontalAlignment()}.
* <p> For the {@code ALIGN_CONTENT_START} and {@code ALIGN_CONTENT_END}
* values, sets the horizontal alignment (including the value of {@code
* HasHorizontalAlignment#getHorizontalAlignment()}) to the start or end edge
* of the current content's direction, respectively, and continues to
* automatically update it whenever the content direction changes.
* <p> For other values, operates like {@link #setHorizontalAlignment}.
* <p> For {@code null}, the horizontal alignment is cleared, allowing it to
* be determined by the standard HTML mechanisms such as inheritance and CSS
* rules.
* @see HasHorizontalAlignment
*
* @param autoHorizontalAlignment the new automatic horizontal alignment
* policy
*/
void setAutoHorizontalAlignment(AutoHorizontalAlignmentConstant
autoHorizontalAlignment);
}