gwt.material.design.client.ui.MaterialTab Maven / Gradle / Ivy
/*
* #%L
* GwtMaterial
* %%
* Copyright (C) 2015 - 2017 GwtMaterialDesign
* %%
* 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.
* #L%
*/
package gwt.material.design.client.ui;
import com.google.gwt.core.client.Scheduler;
import com.google.gwt.dom.client.Element;
import com.google.gwt.event.logical.shared.HasSelectionHandlers;
import com.google.gwt.event.logical.shared.SelectionEvent;
import com.google.gwt.event.logical.shared.SelectionHandler;
import com.google.gwt.event.shared.HandlerRegistration;
import com.google.gwt.user.client.ui.Widget;
import gwt.material.design.client.base.HasType;
import gwt.material.design.client.base.JsLoader;
import gwt.material.design.client.base.MaterialWidget;
import gwt.material.design.client.base.mixin.ColorsMixin;
import gwt.material.design.client.base.mixin.CssTypeMixin;
import gwt.material.design.client.constants.Color;
import gwt.material.design.client.constants.CssName;
import gwt.material.design.client.constants.TabType;
import gwt.material.design.client.ui.html.UnorderedList;
import static gwt.material.design.client.js.JsMaterialElement.$;
//@formatter:off
/**
* The tabs structure consists of an unordered list of tabs that have hashes corresponding to tab ids.
* Then when you click on each tab, only the container with the corresponding tab id will become visible.
*
*
UiBinder Usage:
*
* {@code
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
* }
*
*
* @author kevzlou7979
* @author Ben Dol
* @see Material Tabs
* @see Material Design Specification
*/
//@formatter:on
public class MaterialTab extends UnorderedList implements JsLoader, HasType, HasSelectionHandlers {
private Color indicatorColor;
private MaterialWidget indicator;
private ColorsMixin indicatorColorMixin;
private CssTypeMixin typeMixin;
public MaterialTab() {
super(CssName.TABS);
}
@Override
protected void onLoad() {
super.onLoad();
load();
}
@Override
public void load() {
if (getWidgetCount() > 0) {
getChildren().forEach(child -> registerChildHandler(child));
$(getElement()).tabs();
applyIndicator();
}
}
@Override
protected void onUnload() {
super.onUnload();
unload();
}
@Override
public void unload() {
clearAllIndicators();
}
@Override
public void reload() {
if (isAttached()) {
unload();
load();
}
}
/**
* Select a given tab by id.
*
* @param tabId Tab to selects id.
*/
public void selectTab(String tabId) {
$(getElement()).tabs("select_tab", tabId);
}
@Override
public void add(Widget child) {
super.add(child);
reload();
}
protected void registerChildHandler(Widget child) {
if (child instanceof MaterialTabItem) {
MaterialTabItem item = (MaterialTabItem) child;
item.getHandlerRegistry().clearHandlers();
item.registerHandler(item.addMouseDownHandler(e -> SelectionEvent.fire(MaterialTab.this, getChildren().indexOf(child))));
}
}
@Override
public void clear() {
super.clear();
reload();
}
@Override
public boolean remove(Widget w) {
boolean value = super.remove(w);
reload();
return value;
}
@Override
public void insert(Widget child, int beforeIndex) {
super.insert(child, beforeIndex);
reload();
}
protected void applyIndicator() {
indicator = new MaterialWidget(getIndicatorElement());
indicatorColorMixin = new ColorsMixin<>(indicator);
setIndicatorColor(indicatorColor);
clearAllIndicators();
}
protected void clearAllIndicators() {
Scheduler.get().scheduleDeferred(() -> {
for (int i = 1; i < $(getElement()).find(".indicator").length(); i++) {
$(getElement()).find(".indicator").eq(i).remove();
}
});
}
public int getTabIndex() {
return $(getElement()).find("li:has(a.active)").index();
}
public void setTabIndex(int tabIndex) {
int i = 0;
for (Widget w : this) {
if (i == tabIndex) {
if (w instanceof MaterialTabItem) {
((MaterialTabItem) w).selectTab();
break;
}
}
i++;
}
}
public void setIndicatorColor(Color indicatorColor) {
this.indicatorColor = indicatorColor;
if (indicatorColorMixin != null && indicatorColor != null) {
indicatorColorMixin.setBackgroundColor(indicatorColor);
}
}
protected Element getIndicatorElement() {
return $(getElement()).find(".indicator").last().asElement();
}
@Override
public void setType(TabType type) {
getTypeMixin().setType(type);
}
@Override
public TabType getType() {
return getTypeMixin().getType();
}
@Override
public HandlerRegistration addSelectionHandler(SelectionHandler handler) {
return addHandler(handler, SelectionEvent.getType());
}
protected CssTypeMixin getTypeMixin() {
if (typeMixin == null) {
typeMixin = new CssTypeMixin<>(this);
}
return typeMixin;
}
}