Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(3021)

Unified Diff: editor/tools/plugins/com.xored.glance.ui/src/com/xored/glance/ui/controls/text/styled/TextSelector.java

Issue 17431004: New UI for Find command: find-as-you-type. (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: Created 7 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: editor/tools/plugins/com.xored.glance.ui/src/com/xored/glance/ui/controls/text/styled/TextSelector.java
===================================================================
--- editor/tools/plugins/com.xored.glance.ui/src/com/xored/glance/ui/controls/text/styled/TextSelector.java (revision 0)
+++ editor/tools/plugins/com.xored.glance.ui/src/com/xored/glance/ui/controls/text/styled/TextSelector.java (revision 0)
@@ -0,0 +1,71 @@
+/*******************************************************************************
+ * Copyright (c) 2012 xored software, Inc. All rights reserved. This program and the accompanying
+ * materials are made available under the terms of the Eclipse Public License v1.0 which accompanies
+ * this distribution, and is available at http://www.eclipse.org/legal/epl-v10.html Contributors:
+ * xored software, Inc. - initial API and implementation (Yuri Strot)
+ ******************************************************************************/
+package com.xored.glance.ui.controls.text.styled;
+
+import org.eclipse.jface.text.Region;
+import org.eclipse.swt.events.FocusEvent;
+import org.eclipse.swt.events.FocusListener;
+import org.eclipse.swt.widgets.Control;
+
+import com.xored.glance.ui.sources.Match;
+
+/**
+ * For all rich text components we remove native selection (make it empty) to draw our own colorful
+ * current match. However if focus was moved back to text component, selection should be drawn as
+ * usually. TextSelector manages this behavior.
+ *
+ * @author Yuri Strot
+ */
+public abstract class TextSelector implements FocusListener {
+
+ public void setMatch(Match match) {
+ this.match = match;
+ if (match != null) {
+ reveal(match.getOffset(), match.getLength());
+ }
+ }
+
+ public void dispose() {
+ getControl().removeFocusListener(this);
+ showSelection();
+ }
+
+ public void focusLost(FocusEvent e) {
+ hideSelection();
+ }
+
+ public void focusGained(FocusEvent e) {
+ showSelection();
+ }
+
+ protected void init() {
+ getControl().addFocusListener(this);
+ hideSelection();
+ }
+
+ private void hideSelection() {
+ Region region = getSelection();
+ setSelection(region.getOffset() + region.getLength(), 0);
+ }
+
+ private void showSelection() {
+ if (match != null) {
+ setSelection(match.getOffset(), match.getLength());
+ }
+ }
+
+ protected abstract Control getControl();
+
+ protected abstract Region getSelection();
+
+ protected abstract void setSelection(int offset, int length);
+
+ protected abstract void reveal(int offset, int length);
+
+ private Match match;
+
+}

Powered by Google App Engine
This is Rietveld 408576698