/*
* Copyright 2011 Vaadin Ltd.
*
* 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.
*/
package com.vaadin.ui;
import com.vaadin.data.Property;
import com.vaadin.shared.ui.progressindicator.ProgressIndicatorServerRpc;
import com.vaadin.shared.ui.progressindicator.ProgressIndicatorState;
/**
* ProgressIndicator
is component that shows user state of a
* process (like long computing or file upload)
*
* ProgressIndicator
has two main modes. One for indeterminate
* processes and other (default) for processes which progress can be measured
*
* May view an other property that indicates progress 0...1
*
* @author Vaadin Ltd.
* @since 4
*/
@SuppressWarnings("serial")
public class ProgressIndicator extends AbstractField implements
Property.Viewer, Property.ValueChangeListener {
private ProgressIndicatorServerRpc rpc = new ProgressIndicatorServerRpc() {
@Override
public void poll() {
// Nothing to do.
}
};
/**
* Creates an a new ProgressIndicator.
*/
public ProgressIndicator() {
this(0.0f);
}
/**
* Creates a new instance of ProgressIndicator with given state.
*
* @param value
*/
public ProgressIndicator(float value) {
setValue(value);
registerRpc(rpc);
}
/**
* Creates a new instance of ProgressIndicator with state read from the
* given datasource.
*
* @param contentSource
*/
public ProgressIndicator(Property contentSource) {
setPropertyDataSource(contentSource);
registerRpc(rpc);
}
@Override
public void beforeClientResponse(boolean initial) {
super.beforeClientResponse(initial);
getState().state = getValue();
}
/**
* Gets the value of the ProgressIndicator. Value of the ProgressIndicator
* is Float between 0 and 1.
*
* @return the Value of the ProgressIndicator.
* @see com.vaadin.ui.AbstractField#getValue()
*/
@Override
public Float getValue() {
return super.getValue();
}
/**
* Sets the value of the ProgressIndicator. Value of the ProgressIndicator
* is the Float between 0 and 1.
*
* @param newValue
* the New value of the ProgressIndicator.
* @see com.vaadin.ui.AbstractField#setValue()
*/
@Override
public void setValue(Float newValue) {
super.setValue(newValue);
}
/*
* (non-Javadoc)
*
* @see com.vaadin.ui.AbstractField#getType()
*/
@Override
public Class getType() {
return Float.class;
}
@Override
protected ProgressIndicatorState getState() {
return (ProgressIndicatorState) super.getState();
}
/**
* Sets whether or not the ProgressIndicator is indeterminate.
*
* @param indeterminate
* true to set to indeterminate mode.
*/
public void setIndeterminate(boolean indeterminate) {
getState().indeterminate = indeterminate;
}
/**
* Gets whether or not the ProgressIndicator is indeterminate.
*
* @return true to set to indeterminate mode.
*/
public boolean isIndeterminate() {
return getState().indeterminate;
}
/**
* Sets the interval that component checks for progress.
*
* @param pollingInterval
* the interval in milliseconds.
*/
public void setPollingInterval(int pollingInterval) {
getState().pollingInterval = pollingInterval;
}
/**
* Gets the interval that component checks for progress.
*
* @return the interval in milliseconds.
*/
public int getPollingInterval() {
return getState().pollingInterval;
}
}