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

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

There is a newer version: 2.8.3
Show newest version
/*
 * #%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.user.client.ui.Widget;
import gwt.material.design.client.base.AbstractSideNav;
import gwt.material.design.client.base.MaterialWidget;
import gwt.material.design.client.constants.SideNavType;

import static gwt.material.design.client.js.JsMaterialElement.$;

//@formatter:off

/**
 * SideNav (Mini) is an extension to {@link MaterialSideNav} that provides
 * mini variant / icon only sidenav. Also with this type, you can enable
 * expansion feature by setExpandable(true).
 * 

*

UiBinder Usage:

*
 * {@code
 * 
 *     
 *     
 * 
 * }
 * 
* * @author kevzlou7979 * @author Ben Dol * @see Material SideNav * @see Material Design Specification * @see Pattern * @see Pattern Expandable */ //@formatter:on public class MaterialSideNavMini extends AbstractSideNav { private boolean overlay; private boolean expandable; private boolean expandOnClick; public MaterialSideNavMini() { super(SideNavType.MINI); setShowOnAttach(false); } @Override protected void setup() { applyBodyScroll(); if (isExpandable()) { setType(SideNavType.MINI_WITH_EXPAND); applyTransition(getElement()); int originalWidth = getWidth(); int miniWidth = 64; pushElement(getMain(), miniWidth); pushElementMargin(getFooter(), miniWidth); setWidth(miniWidth); registerHandler(addOpeningHandler(event -> expand(originalWidth))); registerHandler(addClosingHandler(event -> collapse(miniWidth))); // Add Opening when sidenav link is clicked by default for (Widget w : getChildren()) { if (w instanceof MaterialWidget && isExpandOnClick()) { $(w.getElement()).off("click").on("click", (e, param1) -> { if (!getElement().hasClassName("expanded")) { open(); } return true; }); } } } else { setType(SideNavType.MINI); setWidth(64); } } protected void expand(int width) { addStyleName("expanded"); setWidth(width); if (!isOverlay()) { pushElement(getMain(), width); pushElementMargin(getFooter(), width); } } protected void collapse(int width) { removeStyleName("expanded"); setWidth(width); if (!isOverlay()) { pushElement(getMain(), width); pushElementMargin(getFooter(), width); } } public void setExpandable(boolean expandable) { this.expandable = expandable; } public boolean isExpandable() { return expandable; } public boolean isExpandOnClick() { return expandOnClick; } public void setExpandOnClick(boolean expandOnClick) { this.expandOnClick = expandOnClick; } public boolean isOverlay() { return overlay; } public void setOverlay(boolean overlay) { this.overlay = overlay; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy