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

com.googlecode.wicket.jquery.ui.form.slider.Slider Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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.
 */
package com.googlecode.wicket.jquery.ui.form.slider;

import org.apache.wicket.markup.html.basic.Label;
import org.apache.wicket.markup.html.form.AbstractTextComponent;
import org.apache.wicket.markup.html.form.FormComponentPanel;
import org.apache.wicket.markup.html.form.HiddenField;
import org.apache.wicket.markup.html.form.TextField;
import org.apache.wicket.markup.html.panel.Fragment;
import org.apache.wicket.model.IModel;
import org.apache.wicket.validation.IValidator;
import org.apache.wicket.validation.validator.RangeValidator;

import com.googlecode.wicket.jquery.core.JQueryAbstractBehavior;
import com.googlecode.wicket.jquery.core.JQueryBehavior;

/**
 * Provides a jQuery slider based on a {@link FormComponentPanel}
 *
 * @author Sebastien Briquet - sebfz1
 */
public class Slider extends AbstractSlider
{
	public enum Range {
		MIN("'min'"),
		MAX("'max'");

		private String range;

		private Range(String range)
		{
			this.range = range;
		}

		@Override
		public String toString()
		{
			return this.range;
		}
	}

	private static final long serialVersionUID = 1L;

	private IValidator rangeValidator = null;
	protected AbstractTextComponent input = null; // protected, will be accessed in AjaxSlider

	/**
	 * Constructor
	 * @param id the markup id
	 */
	public Slider(String id)
	{
		super(id);
		this.initialize();
	}

	/**
	 * Constructor
	 * @param id the markup id
	 * @param model the {@link IModel}
	 */
	public Slider(String id, IModel model)
	{
		super(id, model);
		this.initialize();
	}

	/**
	 * Constructor
	 * @param id the markup id
	 * @param model the {@link IModel}
	 * @param label {@link Label} on which the current slide value will be displayed
	 */
	public Slider(String id, IModel model, Label label)
	{
		super(id, model, label);
		this.initialize();
	}

	/**
	 * Constructor
	 * @param id the markup id
	 * @param model the {@link IModel}
	 * @param input the {@link TextField} that will host the slider value when being updated.
	 */
	public Slider(String id, IModel model, TextField input)
	{
		super(id, model);

		this.input = input;
		this.input.setRequired(true); //prevent null model object in case of no value is supplied.
		this.input.setOutputMarkupId(true);
		this.input.add(this.newInputBehavior());

		this.initialize();
	}

	@Override
	public void convertInput()
 	{
 		this.setConvertedInput(this.input.getConvertedInput());
 	}

	@Override
	public Slider setRangeValidator(RangeValidator validator)
	{
		this.rangeValidator = validator;

		return this;
	}

	/**
	 * Get the label pattern to be used to display the value. Should be overridden with care!
* Note: the pattern is a javascript string, where the value is represented by "ui.value".
* * @return default to ui.value */ protected String getLabelPattern() { return "ui.value"; } // Events // @Override protected void onInitialize() { super.onInitialize(); if (this.rangeValidator != null) { this.input.add(this.rangeValidator); //let throw a NPE if no input is defined. } } @Override public void onConfigure(JQueryBehavior behavior) { super.onConfigure(behavior); StringBuilder statements = new StringBuilder(); statements.append("jQuery('#").append(this.input.getMarkupId()).append("').val(ui.value); "); if (super.labelId != null) { statements.append("jQuery('#").append(super.labelId).append("').text(").append(this.getLabelPattern()).append("); "); } behavior.setOption("slide", String.format("function(event, ui) { %s }", statements)); behavior.setOption("value", this.getModelObject()); } // Options // /** * Sets the {@link Range} * @param range the {@code Range} * @return this, for chaining */ public Slider setRange(Range range) { super.options.set("range", range); return this; } // Factory // @Override protected Fragment newInputFragment(String id) { Fragment fragment; // no input TextField has been supplied in ctor // if (this.input == null) { this.input = new HiddenField("input", this.getModel(), Integer.class); fragment = new Fragment(id, "input-fragment", this); fragment.add(this.input.setOutputMarkupPlaceholderTag(true)); } else { fragment = super.newInputFragment(id); //return empty fragment } return fragment; } /** * Gets a new behavior that will handle the change event triggered on provided input.
* The behavior is added to the input that has been supplied in the constructor (means it is visible and the user can interact with) * @return a {@link JQueryAbstractBehavior} */ private JQueryAbstractBehavior newInputBehavior() { return new JQueryAbstractBehavior() { private static final long serialVersionUID = 1L; @Override protected String $() { StringBuilder statements = new StringBuilder(); statements.append("jQuery('#").append(Slider.this.input.getMarkupId()).append("').on('change', function() { "); statements.append(" jQuery('#").append(Slider.this.label.getMarkupId()).append("').slider('value', jQuery(this).val()); "); //change the slider value (+slide) statements.append("});"); return statements.toString(); } }; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy