Java tutorial
package gwt.material.design.client.ui; /* * #%L * GwtMaterial * %% * Copyright (C) 2015 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% */ import com.google.gwt.dom.client.Document; import com.google.gwt.dom.client.Style.Unit; 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.logical.shared.ValueChangeEvent; import com.google.gwt.event.logical.shared.ValueChangeHandler; import com.google.gwt.event.shared.HandlerRegistration; import com.google.gwt.user.client.ui.HasValue; import gwt.material.design.client.base.MaterialWidget; import gwt.material.design.client.base.HasError; import gwt.material.design.client.base.mixin.ErrorMixin; import gwt.material.design.client.constants.InputType; import gwt.material.design.client.ui.html.Label; import gwt.material.design.client.ui.html.Span; //@formatter:off /** * Material Switch or other call it toggle - used for an alternative for checkbox * * <h3>UiBinder Usage:</h3> * <pre> *{@code<m:MaterialSwitch value="true"/> *<m:MaterialSwitch value="true" disabled="true"/> * } * </pre> * * @author kevzlou7979 * @see <a href="http://gwt-material-demo.herokuapp.com/#forms">Material Switch</a> */ //@formatter:on public class MaterialSwitch extends MaterialWidget implements HasValue<Boolean>, HasClickHandlers, HasError { private MaterialInput input = new MaterialInput(); private Span span = new Span(); private Label label = new Label(); private MaterialLabel lblError = new MaterialLabel(); private final ErrorMixin<MaterialSwitch, MaterialLabel> errorMixin = new ErrorMixin<>(this, lblError, null); /** * Creates a switch element */ public MaterialSwitch() { super(Document.get().createDivElement()); setStyleName("switch"); span.setStyleName("lever"); input.setType(InputType.CHECKBOX); label.add(input); label.add(span); add(label); add(lblError); lblError.getElement().getStyle().setMarginTop(16, Unit.PX); //register click handler here in order to have it at first position // and therefore it will deal with clicks as first and setup the value // right before others get notified. addClickHandler(new ClickHandler() { @Override public void onClick(ClickEvent event) { setValue(!getValue()); event.preventDefault(); } }); } /** * Creates a material switch with default value. */ public MaterialSwitch(boolean value) { this(); setValue(value); } @Override protected void onLoad() { super.onLoad(); } @Override public void setEnabled(boolean enabled) { super.setEnabled(enabled); getElement().setAttribute("style", "background-color:transparent !important"); label.getElement().setAttribute("style", "background-color:transparent !important"); span.setEnabled(enabled); input.setEnabled(enabled); } /** * Set the value of switch component. */ @Override public void setValue(Boolean value, boolean fireEvents) { boolean oldValue = getValue(); if (value) { input.getElement().setAttribute("checked", "true"); } else { input.getElement().removeAttribute("checked"); } if (fireEvents && oldValue != value) { ValueChangeEvent.fire(this, getValue()); } } @Override public void setValue(Boolean value) { setValue(value, true); } /** * Gets the value of switch component. */ @Override public Boolean getValue() { return input.getElement().hasAttribute("checked"); } @Override public HandlerRegistration addValueChangeHandler(ValueChangeHandler<Boolean> handler) { return addHandler(handler, ValueChangeEvent.getType()); } /** * @return the input */ public MaterialInput getInput() { return input; } /** * @param input the input to set */ public void setInput(MaterialInput input) { this.input = input; } /** * @return the span */ public Span getSpan() { return span; } /** * @param span the span to set */ public void setSpan(Span span) { this.span = span; } /** * @return the label */ public Label getLabel() { return label; } /** * @param label the label to set */ public void setLabel(Label label) { this.label = label; } @Override public HandlerRegistration addClickHandler(final ClickHandler handler) { return addDomHandler(new ClickHandler() { @Override public void onClick(ClickEvent event) { if (isEnabled()) { handler.onClick(event); } } }, ClickEvent.getType()); } @Override public void setError(String error) { errorMixin.setError(error); } @Override public void setSuccess(String success) { errorMixin.setSuccess(success); } @Override public void clearErrorOrSuccess() { errorMixin.clearErrorOrSuccess(); } }