X-Git-Url: https://gerrit.simantics.org/r/gitweb?p=simantics%2Fplatform.git;a=blobdiff_plain;f=bundles%2Forg.simantics.spreadsheet.common%2Fsrc%2Forg%2Fsimantics%2Fspreadsheet%2Fcommon%2FTreeTableCell.java;h=1f5b8a2215702248f71f7595db8d8435ffe409d9;hp=299c7c7964955e4c47b2aa1beab214342ae35c39;hb=2993f438f049233534c33dd51a3d2bb381657954;hpb=b93b08597911347520cbd9e900be026645f7b743 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 299c7c796..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,10 +30,11 @@ 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; } @@ -47,9 +49,13 @@ public class TreeTableCell extends TableCell implements ITreeTableCell { } 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; @@ -71,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; @@ -86,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); + } + }