/*
* Copyright 2014 JBoss Inc
*
* 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 org.overlord.dtgov.ui.client.local.events;
import com.google.gwt.event.shared.EventHandler;
import com.google.gwt.event.shared.GwtEvent;
import com.google.gwt.event.shared.HandlerRegistration;
import com.google.gwt.event.shared.HasHandlers;
/**
* Custom GWT Event created to pass a signal from the modal box to the main page
* that the process(workflow) has been stopped and the list of processes need to
* be refreshed.
*
* @author David Virgil Naranjo
*
*/
public class StopProcessEvent extends GwtEvent<StopProcessEvent.Handler> {
/** The Constant TYPE. */
public static Type<Handler> TYPE;
private Object item;
public StopProcessEvent(Object item) {
this.setItem(item);
}
/**
* Handler for {@link StopProcessEvent}.
*/
public static interface Handler extends EventHandler {
/**
* Called when {@link StopProcessEvent} is fired.
*
* @param event
* the {@link StopProcessEvent} that was fired
*/
public void onProcessStopped(StopProcessEvent event);
}
/**
* Indicates if a widget supports ok/cancel.
*/
public static interface HasStopProcessHandlers extends HasHandlers {
/**
* Adds a handler to the widget.
*
* @param handler
*/
public HandlerRegistration addStopProcessHandler(Handler handler);
}
/**
* Fires the event.
*
* @param source
* @param item
*/
public static StopProcessEvent fire(HasHandlers source, Object item) {
StopProcessEvent event = new StopProcessEvent(item);
if (TYPE != null)
source.fireEvent(event);
return event;
}
/**
* Gets the type associated with this event.
*
* @return returns the handler type
*/
public static Type<Handler> getType() {
if (TYPE == null) {
TYPE = new Type<Handler>();
}
return TYPE;
}
/*
* (non-Javadoc)
*
* @see com.google.gwt.event.shared.GwtEvent#getAssociatedType()
*/
@Override
public Type<Handler> getAssociatedType() {
return TYPE;
}
/*
* (non-Javadoc)
*
* @see
* com.google.gwt.event.shared.GwtEvent#dispatch(com.google.gwt.event.shared
* .EventHandler)
*/
@Override
protected void dispatch(Handler handler) {
handler.onProcessStopped(this);
}
/**
* @return the item
*/
public Object getItem() {
return item;
}
/**
* @param item
* the item to set
*/
public void setItem(Object item) {
this.item = item;
}
}