All Downloads are FREE. Search and download functionalities are using the official Maven repository.

gwt.material.design.client.ui.MaterialNavBar Maven / Gradle / Ivy

There is a newer version: 2.8.3
Show newest version
package gwt.material.design.client.ui;

/*
 * #%L
 * GwtMaterial
 * %%
 * Copyright (C) 2015 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%
 */

import com.google.gwt.dom.client.Element;
import com.google.gwt.dom.client.Style;
import com.google.gwt.user.client.ui.Widget;
import gwt.material.design.client.base.HasActivates;
import gwt.material.design.client.base.HasProgress;
import gwt.material.design.client.base.HasType;
import gwt.material.design.client.base.mixin.ActivatesMixin;
import gwt.material.design.client.base.mixin.CssTypeMixin;
import gwt.material.design.client.base.mixin.ProgressMixin;
import gwt.material.design.client.constants.*;
import gwt.material.design.client.ui.html.Div;
import gwt.material.design.client.ui.html.Nav;

//@formatter:off

/**
 * Material NavBar represents as a app tool bar, that contains NavBrand,
 * NavSection and initialize Material Sidenav.
 *
 * 

UiBinder Usage:

*
 * {@code
 * 
 *     Title
 *     
 *         
 *         
 *         
 *          
 *     
 * 
 * }
 *
 * @author kevzlou7979
 * @author Ben Dol
 * @see Material Nav Bar
 */
//@formatter:on
public class MaterialNavBar extends Nav implements HasActivates, HasProgress, HasType {

    private Div div = new Div();

    private MaterialLink navMenu = new MaterialLink(IconType.MENU);
    private MaterialProgress progress = new MaterialProgress();

    private final CssTypeMixin typeMixin = new CssTypeMixin<>(this);
    private final ActivatesMixin activatesMixin = new ActivatesMixin<>(navMenu);
    private final ProgressMixin progressMixin = new ProgressMixin<>(this);

    public MaterialNavBar() {
        div.setStyleName("nav-wrapper");
        div.add(navMenu);
        super.add(div);
        navMenu.setFontSize(2.7, Style.Unit.EM);
        navMenu.addStyleName("button-collapse");
        navMenu.setHideOn(HideOn.HIDE_ON_LARGE);
        navMenu.getElement().getStyle().clearDisplay();
        navMenu.setCircle(true);
        navMenu.setWaves(WavesType.LIGHT);
        navMenu.setWidth("64px");
        navMenu.setTextAlign(TextAlign.CENTER);
        navMenu.setIconPosition(IconPosition.NONE);
    }

    @Override
    protected void onLoad() {
        super.onLoad();
        if (typeMixin.getType() != null) {
            applyType(typeMixin.getType().getCssName(), getElement());
        }
    }

    @Override
    public void add(Widget child) {
        div.add(child);
    }

    @Override
    public void clear() {
        div.clear();
    }

    @Override
    public void setType(NavBarType type) {
        typeMixin.setType(type);
    }

    private native void applyType(String type, Element element) /*-{
        if(type === "navbar-shrink"){
            $wnd.initShrink(element, 300)
        }else{
            console.log('Default type of navbar was applied');
        }
    }-*/;

    @Override
    public NavBarType getType() {
        return typeMixin.getType();
    }

    @Override
    public void showProgress(ProgressType type) {
        progressMixin.showProgress(type);
    }

    @Override
    public void setPercent(double percent) {
        progressMixin.setPercent(percent);
    }

    @Override
    public void hideProgress() {
        progressMixin.hideProgress();
    }

    @Override
    public void setActivates(String activates) {
        activatesMixin.setActivates(activates);
    }

    @Override
    public String getActivates() {
        return activatesMixin.getActivates();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy