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

gwt.material.design.addins.client.bubble.MaterialBubble 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.addins.client.bubble;

import com.google.gwt.dom.client.Document;
import gwt.material.design.addins.client.MaterialAddins;
import gwt.material.design.addins.client.base.constants.AddinsCssName;
import gwt.material.design.addins.client.bubble.js.JsBubbleOptions;
import gwt.material.design.client.MaterialDesignBase;
import gwt.material.design.client.base.HasPosition;
import gwt.material.design.client.base.MaterialWidget;
import gwt.material.design.client.base.helper.ColorHelper;
import gwt.material.design.client.base.mixin.CssNameMixin;
import gwt.material.design.client.constants.Color;
import gwt.material.design.client.constants.Position;

import static gwt.material.design.addins.client.bubble.js.JsBubble.$;

//@formatter:off

/**
 * Bubble component used on chat module
 * 

*

XML Namespace Declaration

*
 * {@code
 * xmlns:ma='urn:import:gwt.material.design.addins.client'
 * }
 * 
*

*

UiBinder Usage:

*
 * {@code
 * 
 *   
 *   
 * 
 * }
 * 
* * @author kevzlou7979 * @see Material Bubble */ //@formatter:on public class MaterialBubble extends MaterialWidget implements HasPosition { private MaterialWidget triangle = new MaterialWidget(Document.get().createDivElement()); private CssNameMixin positionMixin; static { if (MaterialAddins.isDebug()) { MaterialDesignBase.injectDebugJs(MaterialBubbleDebugClientBundle.INSTANCE.bubbleJsDebug()); MaterialDesignBase.injectCss(MaterialBubbleDebugClientBundle.INSTANCE.bubbleCssDebug()); } else { MaterialDesignBase.injectJs(MaterialBubbleClientBundle.INSTANCE.bubbleJs()); MaterialDesignBase.injectCss(MaterialBubbleClientBundle.INSTANCE.bubbleCss()); } } public MaterialBubble() { super(Document.get().createSpanElement(), AddinsCssName.BUBBLE); triangle.setStyleName(AddinsCssName.TRIANGLE); positionMixin = new CssNameMixin<>(triangle); positionMixin.setCssName(Position.LEFT); add(triangle); setShadow(1); } public MaterialBubble(Color textColor, Color backgroundColor) { this(); setTextColor(textColor); setBackgroundColor(backgroundColor); } public MaterialBubble(Color textColor, Color backgroundColor, Position position) { this(textColor, backgroundColor); setPosition(position); } /** * Initialize the bubble component. */ protected void initialize() { JsBubbleOptions options = new JsBubbleOptions(); options.position = getPosition().getCssName(); options.color = ColorHelper.setupComputedBackgroundColor(getBackgroundColor()); $(getElement()).bubble(options); } @Override public Position getPosition() { return positionMixin.getCssName(); } @Override public void setPosition(Position position) { positionMixin.setCssName(position); initialize(); } public MaterialWidget getTriangle() { return triangle; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy