/** * Copyright (c) 2005-2011 by Appcelerator, Inc. All Rights Reserved. * Licensed under the terms of the Eclipse Public License (EPL). * Please see the license.txt included with this distribution for details. * Any modifications to this file must keep this entire header intact. */ /* * Created on Apr 8, 2006 */ package com.python.pydev.refactoring.wizards; import org.eclipse.jface.util.Assert; import org.eclipse.ltk.core.refactoring.RefactoringStatus; import org.eclipse.ltk.ui.refactoring.UserInputWizardPage; import org.eclipse.swt.SWT; import org.eclipse.swt.events.ModifyEvent; import org.eclipse.swt.events.ModifyListener; import org.eclipse.swt.widgets.Composite; import org.eclipse.swt.widgets.Text; public abstract class TextInputWizardPage extends UserInputWizardPage { private String fInitialValue; private Text fTextField; public static final String PAGE_NAME = "TextInputPage";//$NON-NLS-1$ /** * Creates a new text input page. * @param isLastUserPage <code>true</code> if this page is the wizard's last * user input page. Otherwise <code>false</code>. */ public TextInputWizardPage(String description, boolean isLastUserPage) { this(description, isLastUserPage, ""); //$NON-NLS-1$ } /** * Creates a new text input page. * @param isLastUserPage <code>true</code> if this page is the wizard's last * user input page. Otherwise <code>false</code> * @param initialValue the initial value */ public TextInputWizardPage(String description, boolean isLastUserPage, String initialValue) { super(PAGE_NAME); Assert.isNotNull(initialValue); setDescription(description); fInitialValue = initialValue; } /** * Returns whether the initial input is valid. Typically it is not, because the * user is required to provide some information e.g. a new type name etc. * * @return <code>true</code> iff the input provided at initialization is valid */ protected boolean isInitialInputValid() { return false; } /** * Returns whether an empty string is a valid input. Typically it is not, because * the user is required to provide some information e.g. a new type name etc. * * @return <code>true</code> iff an empty string is valid */ protected boolean isEmptyInputValid() { return false; } /** * Returns the content of the text input field. * * @return the content of the text input field. Returns <code>null</code> if * not text input field has been created */ protected String getText() { if (fTextField == null) return null; return fTextField.getText(); } /** * Sets the new text for the text field. Does nothing if the text field has not been created. * @param text the new value */ protected void setText(String text) { if (fTextField == null) return; fTextField.setText(text); } /** * Performs input validation. Returns a <code>RefactoringStatus</code> which * describes the result of input validation. <code>Null<code> is interpreted * as no error. */ protected RefactoringStatus validateTextField(String text) { return null; } protected Text createTextInputField(Composite parent) { return createTextInputField(parent, SWT.BORDER); } protected Text createTextInputField(Composite parent, int style) { fTextField = new Text(parent, style); fTextField.addModifyListener(new ModifyListener() { public void modifyText(ModifyEvent e) { textModified(getText()); } }); fTextField.setText(fInitialValue); return fTextField; } /** * Checks the page's state and issues a corresponding error message. The page validation * is computed by calling <code>validatePage</code>. */ protected void textModified(String text) { if (!isEmptyInputValid() && text.equals("")) { //$NON-NLS-1$ setPageComplete(false); setErrorMessage(null); restoreMessage(); return; } if ((!isInitialInputValid()) && text.equals(fInitialValue)) { setPageComplete(false); setErrorMessage(null); restoreMessage(); return; } setPageComplete(validateTextField(text)); } /** * Subclasses can override if they want to restore the message differently. * This implementation calls <code>setMessage(null)</code>, which clears the message * thus exposing the description. */ protected void restoreMessage() { setMessage(null); } /* (non-Javadoc) * Method declared in IDialogPage */ public void dispose() { fTextField = null; } /* (non-Javadoc) * Method declared in WizardPage */ public void setVisible(boolean visible) { if (visible) { textModified(getText()); } super.setVisible(visible); if (visible && fTextField != null) { fTextField.setFocus(); } } }