view flys-client/src/main/java/de/intevation/flys/client/client/ui/AutoIntegerPanel.java @ 3719:e82acd5c86f7

Merged revisions 5495-5496,5509,5514-5515,5521-5526 via svnmerge from file:///home/clients/bsh/bsh-generischer-viewer/Material/SVN/flys-client/trunk ........ r5495 | ingo | 2012-09-17 14:55:09 +0200 (Mo, 17 Sep 2012) | 1 line Added missing i18n strings for minfo state description. ........ r5496 | ingo | 2012-09-17 15:47:43 +0200 (Mo, 17 Sep 2012) | 1 line Tagged 'flys-client' as 2.9.1 ........ r5509 | teichmann | 2012-09-18 17:54:37 +0200 (Di, 18 Sep 2012) | 1 line Removed trailing whitespace. ........ r5514 | bricks | 2012-09-19 09:56:42 +0200 (Mi, 19 Sep 2012) | 2 lines Add missing Changelog entry for r5472 ........ r5515 | bricks | 2012-09-19 09:59:35 +0200 (Mi, 19 Sep 2012) | 2 lines Implement a scrolling gauge info tree ........ r5521 | bricks | 2012-09-19 14:41:48 +0200 (Mi, 19 Sep 2012) | 2 lines Add station info to the gauges ........ r5522 | bricks | 2012-09-19 14:43:43 +0200 (Mi, 19 Sep 2012) | 2 lines Improve the handling of the GaugePanel in the ParameterList ........ r5523 | bricks | 2012-09-19 14:51:02 +0200 (Mi, 19 Sep 2012) | 4 lines Improve the GaugePanel Be locale aware and only load the gauge info if the river name changes. ........ r5524 | bricks | 2012-09-19 15:14:46 +0200 (Mi, 19 Sep 2012) | 5 lines Fix a NullPointerException When iterating over a list it must be checked if the reference to the list is valid. ........ r5525 | bricks | 2012-09-19 15:16:24 +0200 (Mi, 19 Sep 2012) | 2 lines Don't display the GaugePanel if no river is selected ........ r5526 | bricks | 2012-09-19 15:18:36 +0200 (Mi, 19 Sep 2012) | 2 lines Use the wstunit from the river as unit for the Pegelnullpunkt ........ flys-client/tags/2.9.1@5528 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author Ingo Weinzierl <ingo.weinzierl@intevation.de>
date Wed, 19 Sep 2012 14:42:48 +0000
parents d900ab031dfe
children 360e22afb98b
line wrap: on
line source
package de.intevation.flys.client.client.ui;

import com.google.gwt.core.client.GWT;

import com.smartgwt.client.widgets.Canvas;
import com.smartgwt.client.widgets.Label;
import com.smartgwt.client.widgets.form.validator.Validator;
import com.smartgwt.client.widgets.form.validator.CustomValidator;
import com.smartgwt.client.widgets.layout.VLayout;

import de.intevation.flys.client.shared.model.Data;
import de.intevation.flys.client.shared.model.DataList;

import de.intevation.flys.client.client.FLYSConstants;


/**
 * @author <a href="mailto:ingo.weinzierl@intevation.de">Ingo Weinzierl</a>
 */
public class AutoIntegerPanel extends TextProvider {

    public static final String FIELD_NAME = "integer_field";

    public static final String FIELD_DEFAULT_VALUE = "auto";


    protected static FLYSConstants MSG = GWT.create(FLYSConstants.class);

    protected String dataName;


    @Override
    public Canvas create(DataList dataList) {
        Data   data   = dataList.get(0);
        this.dataName = data.getLabel();

        Canvas label  = new Label(data.getDescription());
        Canvas form   = createForm(getTitle());
        Canvas submit = getNextButton();

        VLayout layout = new VLayout();
        layout.setHeight(35);
        label.setHeight(35);

        layout.addMember(label);
        layout.addMember(form);
        layout.addMember(submit);
        layout.setMembersMargin(10);

        initDefaultValues(dataList);

        return layout;
    }


    @Override
    protected void initDefaultValues(DataList dataList) {
        super.initDefaultValues(dataList);

        String def = getValueAsString();

        if (def == null || def.length() == 0) {
            form.setValue(getFieldName(), FIELD_DEFAULT_VALUE);
        }
    }


    protected String getTitle() {
        return MSG.uesk_profile_distance();
    }


    @Override
    protected String getDataName() {
        return dataName;
    }


    @Override
    protected String getValueAsString() {
        String v = (String) form.getValue(getFieldName());
        return v.toLowerCase();
    }


    @Override
    protected Validator getValidator() {
        Validator v = new AutoIntegerValidator();
        v.setValidateOnChange(false);

        return v;
    }


    public class AutoIntegerValidator extends CustomValidator {
        @Override
        protected boolean condition(Object value) {
            String v = (String) value;

            if (v == null || v.length() == 0) {
                return false;
            }

            if (v.trim().equalsIgnoreCase("auto")) {
                return true;
            }

            try {
                Integer anInt = Integer.parseInt(v);

                return true;
            }
            catch (NumberFormatException nfe) {
                return false;
            }
        }
    }
}
// vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :

http://dive4elements.wald.intevation.org