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

com.github.gwtbootstrap.client.ui.base.IconAnchor 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.base;

import com.github.gwtbootstrap.client.ui.Icon;
import com.github.gwtbootstrap.client.ui.constants.*;
import com.google.gwt.dom.client.AnchorElement;
import com.google.gwt.dom.client.Node;
import com.google.gwt.dom.client.Text;
import com.google.gwt.event.dom.client.ClickEvent;
import com.google.gwt.event.dom.client.ClickHandler;
import com.google.gwt.event.dom.client.HasClickHandlers;
import com.google.gwt.event.dom.client.HasMouseDownHandlers;
import com.google.gwt.event.dom.client.MouseDownEvent;
import com.google.gwt.event.dom.client.MouseDownHandler;
import com.google.gwt.event.shared.HandlerRegistration;
import com.google.gwt.user.client.DOM;
import com.google.gwt.user.client.Event;
import com.google.gwt.user.client.ui.Focusable;
import com.google.gwt.user.client.ui.HasEnabled;
import com.google.gwt.user.client.ui.HasName;
import com.google.gwt.user.client.ui.HasText;
import com.google.gwt.user.client.ui.impl.FocusImpl;

/**
 * An Anchor with optional image and caret.
 *
 * 

* It uses a HTML {@code } tag and can contain text and child widgets. But * not both at the same time. *

* *

*

UiBinder Usage:

* {@code Some Text} *

* *

* Here we add a second Icon: * *

 * {@code 
 *     
 * }
 * 
* * All parameter are optional. All setters can be used as parameters. *

* * @since 2.0.4.0 * * @author Dominik Mayer * @author ohashi keisuke */ public class IconAnchor extends ComplexWidget implements HasText, HasIcon, HasHref, HasClickHandlers, HasEnabled, Focusable, HasName, HasMouseDownHandlers { private static final FocusImpl impl = FocusImpl.getFocusImplForWidget(); protected Icon icon = new Icon(); private TextNode text = new TextNode(""); private Caret caret = new Caret(); private IconPosition iconPosition; /** * Creates the widget and sets the {@code href} property to * {@code javascript:;} in order to avoid problems when clicking on it. */ public IconAnchor() { super("a"); setIconPosition(IconPosition.LEFT); setEmptyHref(); } /** * {@inheritDoc} */ @Override public void setIconPosition(IconPosition position) { this.iconPosition = position; icon.removeFromParent(); text.removeFromParent(); if(IconPosition.RIGHT == position) { this.insert(text , 0); this.insert(icon , 1); return; } else if(IconPosition.LEFT == position){ this.insert(icon, 0); this.insert(text, 1); return; } } /** * {@inheritDoc} */ @Override public void setIcon(IconType type) { setBaseIcon(type); } /** * {@inheritDoc} */ @Override public void setBaseIcon(BaseIconType type) { this.icon.setBaseType(type); } /** * {@inheritDoc} */ @Override public void setIconSize(IconSize size) { icon.setIconSize(size); } /** * {@inheritDoc} */ public void setText(String text) { if ( !this.getElement().isOrHasChild( this.text.getElement() ) ) { Node toRemove = null; for ( int i = 0; i < this.getElement().getChildCount(); i++) { Node n = this.getElement().getChildNodes().getItem( i ); if ( n.getNodeType() == 3 /*TEXT_NODE*/ ) { Text t = n.cast(); if ( t.getNodeValue().equals( this.text.getText() ) || t.getNodeValue().equals( text ) ) { toRemove = t; } } } if ( toRemove != null ) { this.getElement().removeChild(toRemove); } this.getElement().appendChild( this.text.getElement() ); } this.text.removeFromParent(); this.text = new TextNode(" " + text + " "); setIconPosition(iconPosition); } /** * {@inheritDoc} */ public String getText() { return text.getText(); } /** * {@inheritDoc} */ public void setHref(String href) { getElement().setAttribute("href", href); } /** * {@inheritDoc} */ public String getHref() { return getElement().getAttribute("href"); } /** * Shows or hides the caret. * * @param visible * true if the caret should be shown. */ public void setCaret(boolean visible) { if (visible) super.add(caret); else super.remove(caret); } /** * {@inheritDoc} */ public void setTargetHistoryToken(String targetHistoryToken) { setHref("#" + targetHistoryToken); } /** * {@inheritDoc} */ public String getTargetHistoryToken() { String[] hrefs = getHref().split("#"); return hrefs[1]; } /** * Sets the hrefproperty of this element to "javascript:;" in * order to get another cursor (hand). */ public void setEmptyHref() { setHref(Constants.EMPTY_HREF); } /** * {@inheritDoc} */ @Override public HandlerRegistration addClickHandler(ClickHandler handler) { return addDomHandler(handler, ClickEvent.getType()); } /** * {@inheritDoc} */ @Override public HandlerRegistration addMouseDownHandler(MouseDownHandler handler) { return addDomHandler(handler, MouseDownEvent.getType()); } /** * {@inheritDoc} */ @Override public boolean isEnabled() { return !DOM.getElementPropertyBoolean(getElement(), "disabled"); } /** * {@inheritDoc} */ @Override public void setEnabled(boolean enabled) { DOM.setElementPropertyBoolean(getElement(), "disabled", !enabled); } /** * {@inheritDoc} */ @Override public void onBrowserEvent(Event event) { switch (DOM.eventGetType(event)) { case Event.ONCLICK: if (isEnabled()) { super.onBrowserEvent(event); } break; default: super.onBrowserEvent(event); break; } } @Override public int getTabIndex() { return impl.getTabIndex(getElement()); } @Override public void setAccessKey(char key) { DOM.setElementProperty(getElement(), "accessKey", "" + key); } @Override public void setFocus(boolean focused) { if (focused) { impl.focus(getElement()); } else { impl.blur(getElement()); } } @Override public void setTabIndex(int index) { impl.setTabIndex(getElement(), index); } @Override protected void onAttach() { super.onAttach(); // Accessibility: setting tab index to be 0 by default, ensuring element // appears in tab sequence. We must ensure that the element doesn't already // have a tabIndex set. This is not a problem for normal widgets, but when // a widget is used to wrap an existing static element, it can already have // a tabIndex. int tabIndex = getTabIndex(); if (-1 == tabIndex) { setTabIndex(0); } } /** * Set active style name. * @param active true : set active false : unset active */ public void setActive(boolean active) { setStyleName(Constants.ACTIVE, active); } /** * Has the active css style name? * @return true: has false : none. */ public boolean isActive() { return getStyleName().contains(Constants.ACTIVE); } /** * {@inheritDoc} */ @Override public void setName(String name) { getAnchorElement().setName(name); } /** * {@inheritDoc} */ @Override public String getName() { return getAnchorElement().getName(); } /** * Set target attribute * @param target target name */ public void setTarget(String target) { getAnchorElement().setTarget(target); } /** * Get target attribute value * @return target attribute value */ public String getTarget() { return getAnchorElement().getTarget(); } protected AnchorElement getAnchorElement() { return AnchorElement.as(getElement()); } /** * {@inheritDoc} */ @Override public void setCustomIconStyle(String customIconStyle) { icon.addStyleName(customIconStyle); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy