+/*
+ * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$)
+ * Copyright (C) $$Year-Rel$$ The Jalview Authors
+ *
+ * This file is part of Jalview.
+ *
+ * Jalview is free software: you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation, either version 3
+ * of the License, or (at your option) any later version.
+ *
+ * Jalview is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty
+ * of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+ * PURPOSE. See the GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with Jalview. If not, see <http://www.gnu.org/licenses/>.
+ * The Jalview Authors are detailed in the 'AUTHORS' file.
+ */
+
package jalview.io;
-import jalview.gui.AlignFrame;
-import jalview.schemes.ColourSchemeI;
+import jalview.api.ComplexAlignFile;
+import jalview.api.FeatureSettingsModelI;
+import jalview.api.FeaturesDisplayedI;
+import jalview.datamodel.HiddenColumns;
+import jalview.datamodel.SequenceI;
import java.io.IOException;
+import java.io.StringReader;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
-public class HtmlFile extends AlignFile
+public class HtmlFile extends AlignFile implements ComplexAlignFile
{
- // public static final String FILE_EXT = "html";
- //
- // public static final String FILE_DESC = "HTML";
+ public static final String FILE_EXT = "html";
+
+ public static final String FILE_DESC = "HTML";
+
+ private String globalColourScheme;
+
+ private boolean showSeqFeatures;
+
+ private HiddenColumns hiddenColumns;
+
+ private SequenceI[] hiddenSequences;
- private ColourSchemeI cs;
+ private FeaturesDisplayedI displayedFeatures;
public HtmlFile()
{
super(source);
}
- public HtmlFile(String inFile, String type) throws IOException
+ public HtmlFile(String inFile, DataSourceType sourceType)
+ throws IOException
{
- super(inFile, type);
+ super(inFile, sourceType);
}
- @SuppressWarnings("unchecked")
@Override
public void parse() throws IOException
{
+ Element content = null;
+ Document doc = null;
try
{
StringBuilder htmlData = new StringBuilder();
{
htmlData.append(currentLine);
}
+ doc = Jsoup.parse(htmlData.toString());
+ } catch (OutOfMemoryError oom)
+ {
+ errormessage = "Not enough memory to process HTML document";
+ throw new IOException(errormessage);
+ }
+
+ try
+ {
+ boolean contentFromDiv = true;
+ // search for BioJSON data in div element with id seqData
+ content = doc.select("div[id=seqData]").first();
+ if (content == null)
+ {
+ contentFromDiv = false;
+ // search for BioJSON data in input element with id seqData
+ content = doc.getElementById("seqData");
+ }
- Document doc = Jsoup.parse(htmlData.toString());
- Element content = doc.getElementById("seqData");
-
- String alignmentJsonString = content.val();
-
- new JSONFile().parse(alignmentJsonString);
-
- // JSONParser jsonParser = new JSONParser();
- // JSONObject alignmentJsonObj = (JSONObject) jsonParser
- // .parse(alignmentJsonString);
- // JSONArray seqJsonArray = (JSONArray) alignmentJsonObj.get("seqs");
- // String bioJsColourScheme = (String) alignmentJsonObj
- // .get("globalColorScheme");
- // cs = getJalviewColorScheme(bioJsColourScheme);
- //
- // for (Iterator<JSONObject> sequenceIter = seqJsonArray.iterator();
- // sequenceIter
- // .hasNext();)
- // {
- // JSONObject sequence = sequenceIter.next();
- // String sequcenceString = sequence.get("seq").toString();
- // Sequence seq = new Sequence(sequence.get("name").toString(),
- // sequcenceString, Integer.valueOf(sequence.get("start")
- // .toString()), Integer.valueOf(sequence.get("end")
- // .toString()));
- //
- // JSONArray jsonSeqArray = (JSONArray) sequence.get("features");
- // SequenceFeature[] retrievedSeqFeatures = getJalviewSequenceFeatures(
- // jsonSeqArray, seq);
- // if (retrievedSeqFeatures != null)
- // {
- // seq.setSequenceFeatures(retrievedSeqFeatures);
- // }
- // seqs.add(seq);
- //
- // }
+ if (content == null)
+ {
+ errormessage = "The html document is not embedded with BioJSON data";
+ throw new IOException(errormessage);
+ }
+ JSONFile jsonFile = new JSONFile().parse(new StringReader(
+ contentFromDiv ? content.text() : content.val()));
+ this.seqs = jsonFile.getSeqs();
+ this.seqGroups = jsonFile.getSeqGroups();
+ this.annotations = jsonFile.getAnnotations();
+ this.showSeqFeatures = jsonFile.isShowSeqFeatures();
+ this.globalColourScheme = jsonFile.getGlobalColourScheme();
+ this.hiddenSequences = jsonFile.getHiddenSequences();
+ this.hiddenColumns = jsonFile.getHiddenColumns();
+ this.displayedFeatures = jsonFile.getDisplayedFeatures();
} catch (Exception e)
{
- e.printStackTrace();
+ throw e;
}
}
- // public SequenceFeature[] getJalviewSequenceFeatures(
- // JSONArray jsonSeqFeatures, Sequence seq)
- // {
- // SequenceFeature[] seqFeatures = null;
- // int count = 0;
- // if (jsonSeqFeatures != null)
- // {
- // seqFeatures = new SequenceFeature[jsonSeqFeatures.size()];
- // for (@SuppressWarnings("unchecked")
- // Iterator<JSONObject> seqFeatureItr = jsonSeqFeatures.iterator();
- // seqFeatureItr
- // .hasNext();)
- // {
- //
- // SequenceFeature sequenceFeature = new SequenceFeature();
- // JSONObject jsonFeature = seqFeatureItr.next();
- // Long begin = (Long) jsonFeature.get("xStart");
- // Long end = (Long) jsonFeature.get("xEnd");
- // String type = (String) jsonFeature.get("text");
- // // String color = (String) jsonFeature.get("fillColor");
- //
- // sequenceFeature.setBegin(seq.findPosition(begin.intValue()));
- // sequenceFeature.setEnd(seq.findPosition(end.intValue()) - 1);
- // sequenceFeature.setType(type);
- // seqFeatures[count++] = sequenceFeature;
- // }
- // }
- // return seqFeatures;
- // }
-
- public void LoadAlignmentFeatures(AlignFrame af)
+ @Override
+ public String print(SequenceI[] sqs, boolean jvsuffix)
{
+ throw new UnsupportedOperationException(
+ "Print method of HtmlFile is not supported!");
+ }
- af.setShowSeqFeatures(true);
- af.changeColour(cs);
- af.setMenusForViewport();
+ @Override
+ public boolean isShowSeqFeatures()
+ {
+ return showSeqFeatures;
}
- // private ColourSchemeI getJalviewColorScheme(String bioJsColourSchemeName)
- // {
- // ColourSchemeI jalviewColor = null;
- // for (JalviewBioJsColorSchemeMapper cs : JalviewBioJsColorSchemeMapper
- // .values())
- // {
- // if (cs.getBioJsName().equals(bioJsColourSchemeName))
- // {
- // jalviewColor = cs.getJvColourScheme();
- // break;
- // }
- // }
- // return jalviewColor;
- // }
+ public void setShowSeqFeatures(boolean showSeqFeatures)
+ {
+ this.showSeqFeatures = showSeqFeatures;
+ }
@Override
- public String print()
+ public String getGlobalColourScheme()
{
- throw new UnsupportedOperationException(
- "Print method of HtmlFile not yet supported!");
+ return globalColourScheme;
+ }
+
+ public void setColourScheme(String globalColourScheme)
+ {
+ this.globalColourScheme = globalColourScheme;
+ }
+
+ @Override
+ public HiddenColumns getHiddenColumns()
+ {
+ return hiddenColumns;
+ }
+
+ public void setHiddenColumns(HiddenColumns hidden)
+ {
+ this.hiddenColumns = hidden;
+ }
+
+ @Override
+ public SequenceI[] getHiddenSequences()
+ {
+ return hiddenSequences;
+ }
+
+ public void setHiddenSequences(SequenceI[] hiddenSequences)
+ {
+ this.hiddenSequences = hiddenSequences;
+ }
+
+ @Override
+ public FeaturesDisplayedI getDisplayedFeatures()
+ {
+ return displayedFeatures;
+ }
+
+ /**
+ * Returns a descriptor for suitable feature display settings with
+ * <ul>
+ * <li>ResNums or insertions features visible</li>
+ * <li>insertions features coloured red</li>
+ * <li>ResNum features coloured by label</li>
+ * <li>Insertions displayed above (on top of) ResNums</li>
+ * </ul>
+ */
+ @Override
+ public FeatureSettingsModelI getFeatureColourScheme()
+ {
+ return new PDBFeatureSettings();
}
}