/*******************************************************************************
* Copyright 2012 University of Southern California
*
* 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.
*
* This code was developed by the Information Integration Group as part
* of the Karma project at the Information Sciences Institute of the
* University of Southern California. For more information, publications,
* and related projects, please see: http://www.isi.edu/integration
******************************************************************************/
package edu.isi.karma.controller.command.worksheet;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.List;
import edu.isi.karma.controller.command.CommandException;
import edu.isi.karma.controller.command.WorksheetCommand;
import edu.isi.karma.controller.update.ErrorUpdate;
import edu.isi.karma.controller.update.SVGAlignmentUpdate_ForceKarmaLayout;
import edu.isi.karma.controller.update.SemanticTypesUpdate;
import edu.isi.karma.controller.update.UpdateContainer;
import edu.isi.karma.modeling.alignment.Alignment;
import edu.isi.karma.modeling.alignment.AlignmentManager;
import edu.isi.karma.modeling.semantictypes.SemanticTypeUtil;
import edu.isi.karma.rep.CellValue;
import edu.isi.karma.rep.HNode;
import edu.isi.karma.rep.HNodePath;
import edu.isi.karma.rep.Node;
import edu.isi.karma.rep.Node.NodeStatus;
import edu.isi.karma.rep.Worksheet;
import edu.isi.karma.view.VWorksheet;
import edu.isi.karma.view.VWorkspace;
public class SplitByCommaCommand extends WorksheetCommand {
private final String hNodeId;
private final String vWorksheetId;
private final String delimiter;
private String columnName;
private HNode hNode;
private String splitValueHNodeID;
private HashMap<Node, CellValue> oldNodeValueMap = new HashMap<Node, CellValue>();
private HashMap<Node, NodeStatus> oldNodeStatusMap = new HashMap<Node, NodeStatus>();
// private final Logger logger = LoggerFactory.getLogger(this.getClass());
protected SplitByCommaCommand(String id, String worksheetId,
String hNodeId, String vWorksheetId, String delimiter) {
super(id, worksheetId);
this.hNodeId = hNodeId;
this.vWorksheetId = vWorksheetId;
this.delimiter = delimiter;
addTag(CommandTag.Transformation);
}
@Override
public String getCommandName() {
return this.getClass().getSimpleName();
}
@Override
public String getTitle() {
return "Split By Comma";
}
@Override
public String getDescription() {
return columnName;
}
@Override
public CommandType getCommandType() {
return CommandType.undoable;
}
@Override
public UpdateContainer doIt(VWorkspace vWorkspace) throws CommandException {
UpdateContainer c = new UpdateContainer();
Worksheet wk = vWorkspace.getRepFactory().getWorksheet(worksheetId);
VWorksheet vw = vWorkspace.getViewFactory().getVWorksheet(vWorksheetId);
// Get the HNode
hNode = vWorkspace.getRepFactory().getHNode(hNodeId);
// The column should not have a nested table but check to make sure!
if (hNode.hasNestedTable()) {
c.add(new ErrorUpdate("Cannot split column with nested table!"));
return c;
}
columnName = hNode.getColumnName();
SplitColumnByDelimiter split = new SplitColumnByDelimiter(hNodeId, wk, delimiter, vWorkspace.getWorkspace());
split.split(oldNodeValueMap, oldNodeStatusMap);
splitValueHNodeID = split.getSplitValueHNodeID();
List<HNodePath> columnPaths = wk.getHeaders().getAllPaths();
vWorkspace.getViewFactory().updateWorksheet(vWorksheetId, wk,
columnPaths, vWorkspace);
vw = vWorkspace.getViewFactory().getVWorksheet(vWorksheetId);
vw.update(c);
// Add updates related to the alignment
addAlignmentUpdate(c, vWorkspace, wk);
return c;
}
@Override
public UpdateContainer undoIt(VWorkspace vWorkspace) {
UpdateContainer c = new UpdateContainer();
Worksheet wk = vWorkspace.getRepFactory().getWorksheet(worksheetId);
VWorksheet vw = vWorkspace.getViewFactory().getVWorksheet(vWorksheetId);
List<HNodePath> columnPaths = wk.getHeaders().getAllPaths();
// Get the path which has the split value hNodeId
HNodePath selectedPath = null;
for (HNodePath path : columnPaths) {
if (path.getLeaf().getId().equals(splitValueHNodeID)) {
selectedPath = path;
}
}
// Clear the nested table for the HNode
hNode.removeNestedTable();
// Replace the path
int oldPathIndex = columnPaths.indexOf(selectedPath);
for (HNodePath path : wk.getHeaders().getAllPaths()) {
if (path.getLeaf().getId().equals(hNodeId)) {
hNode = path.getLeaf();
selectedPath = path;
}
}
columnPaths.set(oldPathIndex, selectedPath);
// Populate the column with old values
Collection<Node> nodes = new ArrayList<Node>();
wk.getDataTable().collectNodes(selectedPath, nodes);
for (Node node : nodes) {
//pedro 2012-09-15 this does not look correct.
node.setNestedTable(null, vWorkspace.getRepFactory());
node.setValue(oldNodeValueMap.get(node), oldNodeStatusMap.get(node), vWorkspace.getRepFactory());
}
vWorkspace.getViewFactory().updateWorksheet(vWorksheetId, wk,
columnPaths, vWorkspace);
vw = vWorkspace.getViewFactory().getVWorksheet(vWorksheetId);
vw.update(c);
return c;
}
private void addAlignmentUpdate(UpdateContainer c, VWorkspace vWorkspace, Worksheet worksheet) {
String alignmentId = AlignmentManager.Instance().constructAlignmentId(
vWorkspace.getWorkspace().getId(), vWorksheetId);
Alignment alignment = AlignmentManager.Instance().getAlignment(alignmentId);
if (alignment == null) {
alignment = new Alignment(vWorkspace.getWorkspace().getOntologyManager());
AlignmentManager.Instance().addAlignmentToMap(alignmentId, alignment);
}
// Compute the semantic type suggestions
SemanticTypeUtil.computeSemanticTypesSuggestion(worksheet, vWorkspace.getWorkspace()
.getCrfModelHandler(), vWorkspace.getWorkspace().getOntologyManager(), alignment);
c.add(new SemanticTypesUpdate(worksheet, vWorksheetId, alignment));
c.add(new SVGAlignmentUpdate_ForceKarmaLayout(vWorkspace.getViewFactory().
getVWorksheet(vWorksheetId), alignment));
}
}