//{HEADER
/**
* This class is part of jnex 'Nexirius Application Framework for Java'
*
* Copyright (C) Nexirius GmbH, CH-4450 Sissach, Switzerland (www.nexirius.ch)
*
* <p>This library is free software; you can redistribute it and/or<br>
* modify it under the terms of the GNU Lesser General Public<br>
* License as published by the Free Software Foundation; either<br>
* version 2.1 of the License, or (at your option) any later version.</p>
*
* <p>This library is distributed in the hope that it will be useful,<br>
* but WITHOUT ANY WARRANTY; without even the implied warranty of<br>
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU<br>
* Lesser General Public License for more details.</p>
*
* <p>You should have received a copy of the GNU Lesser General Public<br>
* License along with this library; if not, write to the Free Software<br>
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA</p>
* </blockquote>
*
* <p>
* Nexirius GmbH, hereby disclaims all copyright interest in<br>
* the library jnex' 'Nexirius Application Framework for Java' written<br>
* by Marcel Baumann.</p>
*/
//}HEADER
package com.nexirius.framework.htmlview;
import com.nexirius.framework.datamodel.DataModel;
import com.nexirius.util.statemachine.State;
import com.nexirius.util.CopyPairs;
/**
* this class represents one state in the state machine which is used to handle requests from a AssisantServlet
*/
public class HTMLState extends State {
private DataModel orig;
private DataModel model;
private String template;
private boolean isEditor;
protected CopyPairs copyPairs;
/**
* Creates a new HTMLState for an AssistantServlet
*
* @param name the name of the state
* @param model the model instance which is used as the actual parent of this state
* @param isEditor the general type of dialog for this state (view or edit)
* @param template the template which represents this state
*/
public HTMLState(String name, DataModel model, boolean isEditor, String template) {
super(name, false);
this.model = model;
this.template = template;
this.isEditor = isEditor;
}
public DataModel getModel() {
return model;
}
public String getTemplate() {
return template;
}
public boolean isEditor() {
return isEditor;
}
public void setModel(DataModel model) {
this.model = model;
}
/**
* duplicate the actual model and remember the original
*/
public void startDuplicatePopup() {
orig = model;
if (orig != null) {
copyPairs = new CopyPairs();
model = orig.duplicate(null, copyPairs);
}
}
/**
* assign the duplicated model to the original model (call this method when the OK button was pressed in a
* popup dialog which uses duplicate
* @return original DataModel instance
*/
public DataModel finishDuplicatePopup() {
if (model != null) {
orig.assignDuplicate(model, copyPairs);
model = orig;
orig = null;
}
return model;
}
public void setTemplate(String template) {
this.template = template;
}
public void setIsEditor(boolean isEditor) {
this.isEditor = isEditor;
}
}