/**********************************************************************************
* $URL: https://source.sakaiproject.org/svn/sam/trunk/samigo-app/src/java/org/sakaiproject/tool/assessment/ui/listener/delivery/ShowFeedbackActionListener.java $
* $Id: ShowFeedbackActionListener.java 106463 2012-04-02 12:20:09Z david.horwitz@uct.ac.za $
***********************************************************************************
*
* Copyright (c) 2004, 2005, 2006, 2008 The Sakai Foundation
*
* Licensed under the Educational Community 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.opensource.org/licenses/ECL-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.sakaiproject.tool.assessment.ui.listener.delivery;
import java.util.Iterator;
import java.util.Set;
import java.util.Date;
import javax.faces.application.FacesMessage;
import javax.faces.context.FacesContext;
import javax.faces.event.AbortProcessingException;
import javax.faces.event.ActionEvent;
import javax.faces.event.ActionListener;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.sakaiproject.tool.assessment.services.FinFormatException;
import org.sakaiproject.tool.assessment.services.SaLengthException;
import org.sakaiproject.tool.assessment.ui.bean.delivery.DeliveryBean;
import org.sakaiproject.tool.assessment.ui.listener.delivery.SubmitToGradingActionListener;
import org.sakaiproject.tool.assessment.ui.listener.delivery.UpdateTimerListener;
import org.sakaiproject.tool.assessment.ui.listener.delivery.DeliveryActionListener;
import org.sakaiproject.tool.assessment.ui.listener.util.ContextUtil;
/**
* <p>Title: Samigo</p>
* <p>Purpose: this module handles the beginning of the assessment
* <p>Description: Sakai Assessment Manager</p>
* @author Ed Smiley
* @version $Id: ShowFeedbackActionListener.java 106463 2012-04-02 12:20:09Z david.horwitz@uct.ac.za $
*/
public class ShowFeedbackActionListener implements ActionListener
{
private static Log log = LogFactory.getLog(ShowFeedbackActionListener.class);
private static ContextUtil cu;
/**
* ACTION.
* @param ae
* @throws AbortProcessingException
*/
public void processAction(ActionEvent ae) throws
AbortProcessingException
{
log.debug("ShowFeedbackActionListener.processAction() ");
// get managed bean and set its action accordingly
DeliveryBean delivery = (DeliveryBean) cu.lookupBean("delivery");
String nextAction = delivery.checkBeforeProceed();
if (!("safeToProceed").equals(nextAction)) {
delivery.setOutcome(nextAction);
}
else{
UpdateTimerListener u = new UpdateTimerListener();
u.processAction(ae);
SubmitToGradingActionListener s = new SubmitToGradingActionListener();
try {
s.processAction(ae);
}
catch (FinFormatException e) {
log.debug(e.getMessage());
delivery.setOutcome("takeAssessment");
return;
}
catch (SaLengthException sae) {
log.debug(sae.getMessage());
delivery.setOutcome("takeAssessment");
return;
}
DeliveryActionListener d = new DeliveryActionListener();
d.processAction(ae);
delivery.setOutcome("takeAssessment");
}
}
}