com.github.gwtbootstrap.client.ui.Column Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gwt-bootstrap Show documentation
Show all versions of gwt-bootstrap Show documentation
A GWT Library that provides the widgets of Twitter Bootstrap.
/*
* Copyright 2012 GWT-Bootstrap
*
* 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.github.gwtbootstrap.client.ui;
import com.github.gwtbootstrap.client.ui.base.DivWidget;
import com.github.gwtbootstrap.client.ui.base.HasSize;
import com.github.gwtbootstrap.client.ui.base.SizeHelper;
import com.github.gwtbootstrap.client.ui.config.ColumnSizeConfigurator;
import com.github.gwtbootstrap.client.ui.config.Configurator;
import com.github.gwtbootstrap.client.ui.constants.Constants;
import com.google.gwt.core.client.GWT;
import com.google.gwt.uibinder.client.UiConstructor;
import com.google.gwt.user.client.ui.Widget;
//@formatter:off
/**
* Column of the Bootstrap grid system.
*
* It has to be added to a {@link Row} or a {@link FluidRow}.
*
*
*
*
UiBinder Usage:
*
*
* {@code
*
*
* }
*
* Setting the size
is mandatory.
*
*
* @since 2.0.4.0
*
* @author Carlos Alexandro Becker
* @author Dominik Mayer
*
* @see Bootstrap documentation
* @see Configurator#hasResponsiveDesign()
*/
//@formatter:on
public class Column extends DivWidget implements HasSize {
private static final ColumnSizeConfigurator CONFIGURATOR = GWT.create(ColumnSizeConfigurator.class);
private static final String OFFSET_ERROR_MESSAGE =
"The offset of the Column has to be between "
+ CONFIGURATOR.getMinimumOffsetSize()+ " and "
+ CONFIGURATOR.getMaximumOffsetSize() + "!";
/**
* Creates a new Column of given size.
*
* @param size
* the size of the Column in the Bootstrap grid system
*/
@UiConstructor
public Column(int size) {
super();
setSize(size);
}
/**
* Creates a new Column of given size and with given offset.
*
* @param size
* the size of the Column in the Bootstrap grid system
* @param offset
* the offset from the left side
*/
public Column(int size, int offset) {
this(size);
setOffset(offset);
}
/**
* Creates a new Column of given size, with given offset and widgets
*
* @param size
* the size of the Column in the Bootstrap grid system
* @param offset
* the offset from the left side
* @param widgets
* the widgets to be added to the Column
*/
public Column(int size, int offset, Widget... widgets) {
this(size, offset);
add(widgets);
}
/**
* Creates a new Column of given size and with given widgets.
*
* @param size
* the size of the Column in the Bootstrap grid system
* @param widgets
* the widgets to be added to the Column
*/
public Column(int size, Widget... widgets) {
this(size);
add(widgets);
}
/**
* Sets the size of the Column in the Bootstrap grid system.
*
* @param size
* the size of the Column
*/
public void setSize(int size) {
SizeHelper.setSize(this, size);
}
/**
* Sets the offset of the Column from the left side.
*
* @param offset
* the offset in the Bootstrap grid system
*/
public void setOffset(int offset) {
if (offset < CONFIGURATOR.getMinimumOffsetSize())
throw new IllegalArgumentException(OFFSET_ERROR_MESSAGE);
if (offset > CONFIGURATOR.getMaximumOffsetSize())
throw new IllegalArgumentException(OFFSET_ERROR_MESSAGE);
addStyleName(Constants.OFFSET + offset);
}
/**
* Adds the provided widgets to the Column.
*
* @param widgets
* the widgets to be added
*/
public void add(Widget... widgets) {
for (Widget widget : widgets) {
add(widget);
}
}
}