package org.activityinfo.ui.client.component.report.editor.map.layerOptions; /* * #%L * ActivityInfo Server * %% * Copyright (C) 2009 - 2013 UNICEF * %% * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public * License along with this program. If not, see * <http://www.gnu.org/licenses/gpl-3.0.html>. * #L% */ import com.extjs.gxt.ui.client.event.ColorPaletteEvent; import com.extjs.gxt.ui.client.event.Events; import com.extjs.gxt.ui.client.event.Listener; import com.extjs.gxt.ui.client.event.SliderEvent; import com.extjs.gxt.ui.client.widget.ColorPalette; import com.extjs.gxt.ui.client.widget.LayoutContainer; import com.extjs.gxt.ui.client.widget.Slider; import com.extjs.gxt.ui.client.widget.form.LabelField; 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.Timer; import org.activityinfo.i18n.shared.I18N; import org.activityinfo.legacy.shared.reports.model.layers.BubbleMapLayer; /* * Displays a list of options the user can choose to configure a BubbleMapLayer * TODO: replace the two min/max sliders with a RangeSlider (Slider with 2 knobs) */ public class BubbleLayerOptions extends LayoutContainer implements LayerOptionsWidget<BubbleMapLayer> { private BubbleMapLayer bubbleMapLayer; private ColorPalette colorPicker = new ColorPalette(); private Slider sliderMinSize = new Slider(); private Slider sliderMaxSize = new Slider(); private Timer timerMinSlider; private Timer timerMaxSlider; public BubbleLayerOptions() { super(); setStyleAttribute("padding", "5px"); createColorPicker(); createMinMaxSliders(); } private void createColorPicker() { colorPicker.setValue("000000"); // Set the selected color to the maplayer colorPicker.addListener(Events.Select, new Listener<ColorPaletteEvent>() { @Override public void handleEvent(ColorPaletteEvent be) { bubbleMapLayer.setBubbleColor(colorPicker.getValue()); ValueChangeEvent.fire(BubbleLayerOptions.this, bubbleMapLayer); } }); LabelField labelColor = new LabelField(I18N.CONSTANTS.color()); add(labelColor); add(colorPicker); } private void setSliderDefaults(Slider slider) { slider.setMinValue(1); slider.setMaxValue(60); slider.setIncrement(1); slider.setDraggable(true); slider.setAutoWidth(true); } private void createMinMaxSliders() { setSliderDefaults(sliderMinSize); setSliderDefaults(sliderMaxSize); sliderMinSize.setValue(16); sliderMaxSize.setValue(48); LabelField labelMin = new LabelField(I18N.CONSTANTS.radiusMinimum()); LabelField labelMax = new LabelField(I18N.CONSTANTS.radiusMaximum()); add(labelMin); add(sliderMinSize); add(labelMax); add(sliderMaxSize); // Ensure min can't be more then max, and max can't be less then min sliderMinSize.addListener(Events.Change, new Listener<SliderEvent>() { @Override public void handleEvent(SliderEvent be) { timerMinSlider.cancel(); timerMinSlider.schedule(250); } }); sliderMaxSize.addListener(Events.Change, new Listener<SliderEvent>() { @Override public void handleEvent(SliderEvent be) { timerMaxSlider.cancel(); timerMaxSlider.schedule(250); } }); timerMinSlider = new Timer() { @Override public void run() { if (sliderMinSize.getValue() > sliderMaxSize.getValue()) { sliderMinSize.setValue(sliderMaxSize.getValue()); } bubbleMapLayer.setMinRadius(sliderMinSize.getValue()); ValueChangeEvent.fire(BubbleLayerOptions.this, bubbleMapLayer); } }; timerMaxSlider = new Timer() { @Override public void run() { if (sliderMaxSize.getValue() < sliderMinSize.getValue()) { sliderMaxSize.setValue(sliderMinSize.getValue()); } bubbleMapLayer.setMaxRadius(sliderMaxSize.getValue()); ValueChangeEvent.fire(BubbleLayerOptions.this, bubbleMapLayer); } }; } @Override public BubbleMapLayer getValue() { return bubbleMapLayer; } private void updateUI() { sliderMinSize.setValue(bubbleMapLayer.getMinRadius(), true); sliderMaxSize.setValue(bubbleMapLayer.getMaxRadius(), true); colorPicker.setValue(bubbleMapLayer.getBubbleColor()); } // TODO: fireevent @Override public void setValue(BubbleMapLayer value, boolean fireEvents) { setValue(value); } @Override public void setValue(BubbleMapLayer value) { this.bubbleMapLayer = value; updateUI(); } @Override public HandlerRegistration addValueChangeHandler(ValueChangeHandler<BubbleMapLayer> handler) { return this.addHandler(handler, ValueChangeEvent.getType()); } }