--- /dev/null
+package org.simantics.views.swt.client.impl;\r
+\r
+import org.eclipse.jface.viewers.StructuredSelection;\r
+import org.eclipse.swt.custom.StyledText;\r
+import org.eclipse.swt.events.SelectionEvent;\r
+import org.eclipse.swt.events.SelectionListener;\r
+import org.eclipse.swt.graphics.Point;\r
+import org.eclipse.swt.widgets.Composite;\r
+import org.simantics.views.ViewUtils;\r
+import org.simantics.views.swt.client.base.SingleSWTViewNode;\r
+\r
+public class SWTStyledText extends SingleSWTViewNode<StyledText> {\r
+ \r
+ private static final long serialVersionUID = 7932335224632082902L;\r
+ \r
+ @Override\r
+ public void createControls(Composite parent) {\r
+ \r
+ control = new StyledText(parent, style);\r
+ control.setEnabled(false);\r
+ setProperties();\r
+ \r
+ control.addSelectionListener(new SelectionListener() {\r
+ @Override\r
+ public void widgetSelected(SelectionEvent e) {\r
+ String selectionText = control.getSelectionText();\r
+ ViewUtils.setWorkbenchSelection(new StructuredSelection(selectionText));\r
+ }\r
+ @Override\r
+ public void widgetDefaultSelected(SelectionEvent e) {\r
+ widgetSelected(e);\r
+ }\r
+ });\r
+ \r
+ }\r
+ \r
+ @Override\r
+ public void synchronizeText(String text) {\r
+ if(text != null) {\r
+ // Try to keep the vertical scroll position of the text widget\r
+ int caretOffset = control.getCaretOffset();\r
+ int charCount = control.getCharCount();\r
+ int topIndex = control.getTopIndex();\r
+ int diff = text.length() - charCount;\r
+ control.setText(text);\r
+ caretOffset = Math.max(0, Math.min(caretOffset + diff, text.length()));\r
+ control.setTopIndex(topIndex);\r
+ control.setCaretOffset(caretOffset);\r
+ control.setEnabled(true);\r
+ } else {\r
+ control.setText("");\r
+ control.setEnabled(false);\r
+ }\r
+ }\r
+ \r
+ public String readText() {\r
+ return control.getText();\r
+ }\r
+ \r
+ public Point readSelection() {\r
+ return control.getSelection();\r
+ }\r
+\r
+}\r