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

com.github.gwtbootstrap.client.ui.Navbar Maven / Gradle / Ivy

/*
 *  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.constants.Constants;
import com.github.gwtbootstrap.client.ui.constants.NavbarConstants;
import com.github.gwtbootstrap.client.ui.constants.NavbarPosition;
import com.google.gwt.dom.client.Document;
import com.google.gwt.dom.client.Element;
import com.google.gwt.user.client.ui.RootPanel;
import com.google.gwt.user.client.ui.Widget;

//@formatter:off

/**
 * Navbar with optional text, links and forms.
 * 

* The Navbar can be fixed on the top or bottom of the site where it will stay * when the user scrolls the page. For proper rendering, a fixed Navbar cannot * be part of any container! It has to be attached directly to the * {@link RootPanel}. *

*

*

UiBinder Usage:

*

*

 * {@code
 * 
 *     
 *         Bootstrap
 *         
 *             Link 1
 *             Link 2
 *         
 *         
 *         
 *             Link 3
 *         
 *     
 *     
 *         [...]
 *     
 * 
 *
 * }
 * 
*

* * NOTE: We assume that most people will use the {@linkplain ResponsiveNavbar}, so, we automatically * add a padding-top: 50px in body.If you don't want this, you have to put * a padding-top: 0px; manually in your document body tag. * * @author Dominik Mayer * @author Carlos Alexandro Becker * @see Bootstrap documentation * @see ResponsiveNavbar * @since 2.0.4.0 */ //@formatter:on public class Navbar extends DivWidget { private class NavbarInner extends DivWidget { public NavbarInner() { setStyleName(NavbarConstants.NAVBAR_INNER); } } private final Container container = getContainer(); private final NavbarInner navbarInner = new NavbarInner(); private Scrollspy spy; private boolean scrollspy; /** * Creates an empty Navbar. */ public Navbar() { setStyleName(NavbarConstants.NAVBAR); navbarInner.add(container); super.add(navbarInner); setId(Document.get().createUniqueId()); } public void setId(String id) { getElement().setId(id); } public String getId() { return getElement().getId(); } /** * Defines the default container implementation. You can override this in a * extended class if you want another implementation, like a * {@link FluidContainer}. */ protected Container getContainer() { return new Container(); } /** * Defines whether the Navbar should contain a {@link Scrollspy}. * * @param scrollspy * true to include a Scrollspy. Default: * false */ public void setScrollspy(boolean scrollspy) { this.scrollspy = scrollspy; if(scrollspy) { spy = new Scrollspy(this); } } /** * Defines scrollspy target element. * * @param spyElement * target element */ public void setSpyElement(Element spyElement) { assert spyElement != null; if (spy == null) spy = new Scrollspy(this); spy.setSpyElement(spyElement); this.scrollspy = true; } @Override protected void onAttach() { super.onAttach(); if (spy == null) spy = new Scrollspy(this); if (scrollspy) { spy.configure(); } // TODO make a unconfigure feature. } /** * Fix the Navbar at the top or bottom of the screen. *

* For this to work properly, the Navbar must not be a child of a * {@link Container}. * * @param position * the position of the Navbar */ public void setPosition(NavbarPosition position) { for (NavbarPosition p : NavbarPosition.values()) { if (!p.get().isEmpty()) { removeStyleName(p.get()); } } addStyle(position); } /** * {@inheritDoc} */ @Override public void add(Widget child) { container.add(child); } /** * Adds a widget to the Navbar element, not the container. * * @param widget * widget to add */ protected void addWidget(Widget widget) { super.add(widget); } public Scrollspy getSpy() { return spy; } /** * Set inverse style. * @param inverse true:set false:unset */ public void setInverse(boolean inverse) { setStyleName(Constants.NAVBAR_INVERSE , inverse); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy