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

gwt.material.design.client.ui.MaterialImage 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.dom.client.Document;
import com.google.gwt.dom.client.ImageElement;
import com.google.gwt.event.dom.client.*;
import com.google.gwt.event.logical.shared.ValueChangeEvent;
import com.google.gwt.event.logical.shared.ValueChangeHandler;
import com.google.gwt.event.shared.HandlerRegistration;
import com.google.gwt.resources.client.ImageResource;
import com.google.gwt.user.client.ui.HasValue;
import gwt.material.design.client.base.*;
import gwt.material.design.client.base.mixin.ActivatesMixin;
import gwt.material.design.client.base.mixin.CssTypeMixin;
import gwt.material.design.client.base.mixin.ImageMixin;
import gwt.material.design.client.constants.CssName;
import gwt.material.design.client.constants.ImageType;

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

//@formatter:off

/**
 * Images can be styled in different ways using Material Design
 * 

UiBinder Usage:

*

*

 * {@code //Simple Image
 * 
 *
 * // Circle Image
 * 
 *
 * // MaterialBoxed Image
 * 
 * }
 * 
* * @author kevzlou7979 * @author Ben Dol * @see Material Media * @see Material Design Specification */ //@formatter:on public class MaterialImage extends MaterialWidget implements HasCaption, HasType, HasImage, HasLoadHandlers, HasErrorHandlers, HasActivates, HasValue, HasSourceSet { private CssTypeMixin typeMixin; private ImageMixin imageMixin; private ActivatesMixin activatesMixin; /** * Creates an empty image. */ public MaterialImage() { super(Document.get().createImageElement(), CssName.RESPONSIVE_IMG); } /** * Creates a simple image. */ public MaterialImage(String url) { this(); setUrl(url); } /** * Creates an image with Specific type. */ public MaterialImage(String url, ImageType type) { this(url); setType(type); } /** * Creates an image from an ImageResource. */ public MaterialImage(ImageResource resource) { this(); setResource(resource); } /** * Creates an image from an ImageResource with Specific type. */ public MaterialImage(ImageResource resource, ImageType type) { this(resource); setType(type); } @Override protected void onLoad() { super.onLoad(); $(".materialboxed").materialbox(); } @Override public void setType(ImageType type) { getTypeMixin().setType(type); } @Override public ImageType getType() { return getTypeMixin().getType(); } @Override public String getCaption() { return getElement().getAttribute("data-caption"); } @Override public void setCaption(String caption) { getElement().setAttribute("data-caption", caption); } @Override public void setUrl(String url) { setValue(url, true); } @Override public String getUrl() { return getValue(); } @Override public void setResource(ImageResource resource) { getImageMixin().setResource(resource); } @Override public ImageResource getResource() { return getImageMixin().getResource(); } @Override public void setAlt(String alt) { getImageMixin().setAlt(alt); } @Override public String getAlt() { return getImageMixin().getAlt(); } public int getWidth() { return ((ImageElement)getElement().cast()).getWidth(); } public int getHeight() { return ((ImageElement)getElement().cast()).getHeight(); } @Override public void setActivates(String activates) { getActivatesMixin().setActivates(activates); } @Override public String getActivates() { return getActivatesMixin().getActivates(); } @Override public String getValue() { return getImageMixin().getUrl(); } @Override public void setValue(String value) { setValue(value, false); } @Override public void setValue(String value, boolean fireEvents) { String oldValue = getUrl(); getImageMixin().setUrl(value); if(fireEvents) { ValueChangeEvent.fireIfNotEqual(this, oldValue, value); } } @Override public void setSourceSet(String value) { getElement().setAttribute("srcset", value); } @Override public String getSourceSet() { return getElement().getAttribute("srcset"); } @Override public HandlerRegistration addLoadHandler(final LoadHandler handler) { return addDomHandler(handler, LoadEvent.getType()); } @Override public HandlerRegistration addErrorHandler(final ErrorHandler handler) { return addDomHandler(handler, ErrorEvent.getType()); } @Override public HandlerRegistration addValueChangeHandler(ValueChangeHandler handler) { return addHandler(handler, ValueChangeEvent.getType()); } protected CssTypeMixin getTypeMixin() { if (typeMixin == null) { typeMixin = new CssTypeMixin<>(this); } return typeMixin; } protected ImageMixin getImageMixin() { if (imageMixin == null) { imageMixin = new ImageMixin<>(this); } return imageMixin; } protected ActivatesMixin getActivatesMixin() { if (activatesMixin == null) { activatesMixin = new ActivatesMixin<>(this); } return activatesMixin; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy