X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.spreadsheet.common%2Fsrc%2Forg%2Fsimantics%2Fspreadsheet%2Fcommon%2FTreeTableCell.java;h=1f5b8a2215702248f71f7595db8d8435ffe409d9;hb=refs%2Fchanges%2F31%2F1231%2F2;hp=baf3b83de6873a371a5dddc669c9199f7a0f1194;hpb=fad36d463b75c3a9944d875fc627c3533f6da74d;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.spreadsheet.common/src/org/simantics/spreadsheet/common/TreeTableCell.java b/bundles/org.simantics.spreadsheet.common/src/org/simantics/spreadsheet/common/TreeTableCell.java index baf3b83de..1f5b8a221 100644 --- a/bundles/org.simantics.spreadsheet.common/src/org/simantics/spreadsheet/common/TreeTableCell.java +++ b/bundles/org.simantics.spreadsheet.common/src/org/simantics/spreadsheet/common/TreeTableCell.java @@ -22,6 +22,7 @@ import org.simantics.document.server.io.SimpleFont; public class TreeTableCell extends TableCell implements ITreeTableCell { private int parent = -1; + private Object parentData; private boolean editable = true; private Object data; @@ -29,17 +30,32 @@ public class TreeTableCell extends TableCell implements ITreeTableCell { public TreeTableCell() { } - public TreeTableCell(String text, Object data, Object font, int parent, int row, int column, boolean editable) { + public TreeTableCell(String text, Object data, Object font, Object parentData, int parent, int row, int column, boolean editable) { super(column, row, 0, 0, text, (IFont)font, null, null, false, 1, 1); this.editable = editable; this.parent = parent; + this.parentData = parentData; this.data = data; } + @Override + public int getRowSpan() { + throw new IllegalStateException("Row span is not supported in TreeTableCell"); + } + + @Override + public int getColumnSpan() { + throw new IllegalStateException("Column span is not supported in TreeTableCell"); + } + public static TreeTableCell createTreeTableCell(String text, Object data, Object font, int parent, int row, int column, boolean editable) { - return new TreeTableCell(text, data, extractIFont(font), parent, row, column, editable); + return new TreeTableCell(text, data, extractIFont(font), null, parent, row, column, editable); } + public static TreeTableCell createTreeTableCell2(String text, Object data, Object font, Object parentData, int row, int column, boolean editable) { + return new TreeTableCell(text, data, extractIFont(font), parentData, -1, row, column, editable); + } + private static IFont extractIFont(Object font) { if(font instanceof FontDescriptor) { FontDescriptor descriptor = (FontDescriptor)font; @@ -61,6 +77,11 @@ public class TreeTableCell extends TableCell implements ITreeTableCell { this.parent = parent; } + @Override + public Object getParentData() { + return parentData; + } + @Override public int getParent() { return parent; @@ -76,4 +97,45 @@ public class TreeTableCell extends TableCell implements ITreeTableCell { return editable; } + @Override + public int hashCode() { + + final int prime = 31; + + int result = super.hashCode(); + + result = data != null ? prime * result + data.hashCode() : parent; + result = parentData != null ? prime * result + parentData.hashCode() : result; + result = prime * result + Integer.hashCode(parent); + result = prime * result + Boolean.hashCode(editable); + + return result; + + } + @Override + public boolean equals(Object obj) { + if (this == obj) + return true; + if (obj == null) + return false; + if (getClass() != obj.getClass()) + return false; + TreeTableCell other = (TreeTableCell) obj; + if (data == null) { + if (other.data != null) + return false; + } else if (!data.equals(other.data)) + return false; + if (parentData == null) { + if (other.parentData != null) + return false; + } else if (!parentData.equals(other.parentData)) + return false; + if (parent != other.parent) + return false; + if (editable != other.editable) + return false; + return super.equals(obj); + } + }