001 // This file is part of AceWiki.
002 // Copyright 2008-2012, AceWiki developers.
003 //
004 // AceWiki is free software: you can redistribute it and/or modify it under the terms of the GNU
005 // Lesser General Public License as published by the Free Software Foundation, either version 3 of
006 // the License, or (at your option) any later version.
007 //
008 // AceWiki is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without
009 // even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
010 // Lesser General Public License for more details.
011 //
012 // You should have received a copy of the GNU Lesser General Public License along with AceWiki. If
013 // not, see http://www.gnu.org/licenses/.
014
015 package ch.uzh.ifi.attempto.echocomp;
016
017 import nextapp.echo.app.Border;
018 import nextapp.echo.app.Color;
019 import nextapp.echo.app.Extent;
020 import nextapp.echo.app.event.ActionListener;
021
022 /**
023 * This is a convenience class for easy creation of password fields.
024 *
025 * @author Tobias Kuhn
026 */
027 public class PasswordField extends nextapp.echo.app.PasswordField {
028
029 private static final long serialVersionUID = 7918679972682431845L;
030
031 /**
032 * Creates a new password field.
033 *
034 * @param width The width of the password field.
035 * @param actionListener The action-listener.
036 */
037 public PasswordField(int width, ActionListener actionListener) {
038 setWidth(new Extent(width));
039 setHeight(new Extent(17));
040 setBackground(Style.lightBackground);
041 setBorder(new Border(1, Color.BLACK, Border.STYLE_INSET));
042 setDisabledBackground(Style.lightDisabled);
043 if (actionListener != null) {
044 addActionListener(actionListener);
045 }
046 }
047
048 /**
049 * Creates a new password field.
050 *
051 * @param actionListener The action-listener.
052 */
053 public PasswordField(ActionListener actionListener) {
054 this(500, actionListener);
055 }
056
057 /**
058 * Creates a new password field.
059 *
060 * @param width The width of the password field.
061 */
062 public PasswordField(int width) {
063 this(width, null);
064 }
065
066 /**
067 * Creates a new password field.
068 */
069 public PasswordField() {
070 this(500, null);
071 }
072
073 }