/*******************************************************************************
* 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.update;
import java.io.PrintWriter;
import edu.isi.karma.rep.hierarchicalheadings.HHTable;
import edu.isi.karma.rep.hierarchicalheadings.HHTree;
import edu.isi.karma.view.VWorksheet;
import edu.isi.karma.view.VWorkspace;
import edu.isi.karma.view.alignmentHeadings.AlignmentColorKeyTranslator;
import edu.isi.karma.view.alignmentHeadings.AlignmentForest;
public class AlignmentHeadersUpdate extends AbstractUpdate {
private String vWorksheetId;
private String alignmentId;
AlignmentForest forest;
public enum JsonKeys {
worksheetId, rows, alignmentId
}
public AlignmentHeadersUpdate(AlignmentForest forest, String worksheetId, String alignmentId) {
this.forest = forest;
this.vWorksheetId = worksheetId;
this.alignmentId = alignmentId;
}
@Override
public void generateJson(String prefix, PrintWriter pw,
VWorkspace vWorkspace) {
HHTree hHtree = new HHTree();
hHtree.constructHHTree(forest);
VWorksheet vw = vWorkspace.getViewFactory().getVWorksheet(vWorksheetId);
hHtree.computeHTMLColSpanUsingLeafColumnIndices(vw.getColumnCoordinatesSet(), vw.getLeafColIndexMap());
HHTable table = new HHTable();
table.constructCells(hHtree);
AlignmentColorKeyTranslator trans = new AlignmentColorKeyTranslator();
pw.println(prefix + "{");
pw.println("\"" + GenericJsonKeys.updateType.name()
+ "\": \""+AlignmentHeadersUpdate.class.getSimpleName()+"\",");
pw.println("\"" + JsonKeys.worksheetId.name() + "\": \"" + vWorksheetId
+ "\",");
pw.println("\"" + JsonKeys.alignmentId.name() + "\": \"" + alignmentId
+ "\",");
pw.println("\""+JsonKeys.rows.name()+ "\":");
table.generateJson(pw, trans, true);
pw.println(prefix + "}");
}
}