001    /*
002     *  Copyright 2012 GWT-Bootstrap
003     *
004     *  Licensed under the Apache License, Version 2.0 (the "License");
005     *  you may not use this file except in compliance with the License.
006     *  You may obtain a copy of the License at
007     *
008     *      http://www.apache.org/licenses/LICENSE-2.0
009     *
010     *  Unless required by applicable law or agreed to in writing, software
011     *  distributed under the License is distributed on an "AS IS" BASIS,
012     *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013     *  See the License for the specific language governing permissions and
014     *  limitations under the License.
015     */
016    package com.github.gwtbootstrap.client.ui;
017    
018    import com.github.gwtbootstrap.client.ui.base.DropdownBase;
019    import com.github.gwtbootstrap.client.ui.base.IconAnchor;
020    import com.github.gwtbootstrap.client.ui.constants.ButtonType;
021    import com.github.gwtbootstrap.client.ui.constants.IconType;
022    import com.github.gwtbootstrap.client.ui.resources.ButtonSize;
023    import com.google.gwt.event.dom.client.ClickHandler;
024    import com.google.gwt.event.shared.HandlerRegistration;
025    
026    //@formatter:off
027    /**
028     * Button with a dropdown menu.
029     * 
030     * <p>
031     * <h3>UiBinder Usage:</h3>
032     * 
033     * <pre>
034     * {@code
035     * <b:DropdownButton text="I am the Caption">
036     *     <b:NavHeader>Header</b:NavHeader>
037     *     <b:NavLink>Link 1</b:NavLink>
038     *     <b:NavLink>Link 2</b:NavLink>
039     * </b:DropdownButton>
040     * }
041     * </pre>
042     * </p>
043     * 
044     * @since 2.0.4.0
045     * 
046     * @author Dominik Mayer
047     * 
048     * @see <a href="http://twitter.github.com/bootstrap/components.html#buttonDropdowns">Bootstrap documentation</a>
049     * @see Dropdown
050     * @see SplitDropdownButton
051     */
052    //@formatter:on
053    public class DropdownButton extends DropdownBase {
054    
055            private Button trigger;
056    
057            /**
058             * Creates a DropdownButton without a caption.
059             */
060            public DropdownButton() {
061                    super("div");
062                    addStyleName("btn-group");
063            }
064    
065            /**
066             * Creates a DropdownButton with the given caption.
067             * 
068             * @param caption
069             *            the button's caption
070             */
071            public DropdownButton(String caption) {
072                    this();
073                    setText(caption);
074            }
075    
076            /**
077             * {@inheritDoc}
078             */
079            @Override
080            protected IconAnchor createTrigger() {
081                    trigger = new Button();
082                    trigger.setCaret(true);
083                    return trigger;
084            }
085    
086            /**
087             * Sets the button's size.
088             * 
089             * @param size
090             *            the button's size
091             */
092            public void setSize(ButtonSize size) {
093                    trigger.setSize(size);
094            }
095    
096            /**
097             * Sets the button's type.
098             * 
099             * @param type
100             *            the button's type
101             */
102            public void setType(ButtonType type) {
103                    trigger.setType(type);
104            }
105    
106            /**
107             * Sets the button's icon.
108             * 
109             * @param type
110             *            the icon's type
111             */
112            public void setIcon(IconType type) {
113                    trigger.setIcon(type);
114            }
115    
116        @Override
117        public HandlerRegistration addClickHandler(ClickHandler handler) {
118            return trigger.addClickHandler(handler);
119        }
120    }