|
|||||||||||||||||||
Source file | Conditionals | Statements | Methods | TOTAL | |||||||||||||||
ConfirmCheckBoxDialog.java | 0% | 0% | 0% | 0% |
|
1 | /*BEGIN_COPYRIGHT_BLOCK | |
2 | * | |
3 | * Copyright (c) 2001-2010, JavaPLT group at Rice University (drjava@rice.edu) | |
4 | * All rights reserved. | |
5 | * | |
6 | * Redistribution and use in source and binary forms, with or without | |
7 | * modification, are permitted provided that the following conditions are met: | |
8 | * * Redistributions of source code must retain the above copyright | |
9 | * notice, this list of conditions and the following disclaimer. | |
10 | * * Redistributions in binary form must reproduce the above copyright | |
11 | * notice, this list of conditions and the following disclaimer in the | |
12 | * documentation and/or other materials provided with the distribution. | |
13 | * * Neither the names of DrJava, the JavaPLT group, Rice University, nor the | |
14 | * names of its contributors may be used to endorse or promote products | |
15 | * derived from this software without specific prior written permission. | |
16 | * | |
17 | * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | |
18 | * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | |
19 | * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | |
20 | * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR | |
21 | * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | |
22 | * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | |
23 | * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR | |
24 | * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF | |
25 | * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | |
26 | * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | |
27 | * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |
28 | * | |
29 | * This software is Open Source Initiative approved Open Source Software. | |
30 | * Open Source Initative Approved is a trademark of the Open Source Initiative. | |
31 | * | |
32 | * This file is part of DrJava. Download the current version of this project | |
33 | * from http://www.drjava.org/ or http://sourceforge.net/projects/drjava/ | |
34 | * | |
35 | * END_COPYRIGHT_BLOCK*/ | |
36 | ||
37 | package edu.rice.cs.util.swing; | |
38 | ||
39 | import edu.rice.cs.util.swing.Utilities; | |
40 | import javax.swing.*; | |
41 | ||
42 | /** | |
43 | * Simple class wrapping JOptionPane to have a checkbox underneath the message. | |
44 | * @version $Id: ConfirmCheckBoxDialog.java 5175 2010-01-20 08:46:32Z mgricken $ | |
45 | */ | |
46 | public class ConfirmCheckBoxDialog { | |
47 | private JDialog _dialog; | |
48 | private JOptionPane _optionPane; | |
49 | private JCheckBox _checkBox; | |
50 | ||
51 | /** Instantiates a new confirm dialog with default checkbox text. | |
52 | * @param parent the parent frame | |
53 | * @param title the title of the dialog | |
54 | * @param message the stuff to display in the body of the dialog. For a simple message, it should be a String; it can | |
55 | * also be an Object[] including Strings and Components to display in the body of the dialog. | |
56 | */ | |
57 | 0 | public ConfirmCheckBoxDialog(JFrame parent, String title, Object message) { |
58 | 0 | this(parent, title, message, "Do not show this message again"); |
59 | } | |
60 | ||
61 | /** Instantiates a new confirm dialog with Yes/No as the options. | |
62 | * @param parent the parent frame | |
63 | * @param title the title of the dialog | |
64 | * @param message the stuff to display in the body of the dialog. For a simple message, it should be a String; it can | |
65 | * also be an Object[] including Strings and Components to display in the body of the dialog. | |
66 | * @param checkBoxText the text to display with the checkbox | |
67 | */ | |
68 | 0 | public ConfirmCheckBoxDialog(JFrame parent, String title, Object message, String checkBoxText) { |
69 | 0 | this(parent, title, message, checkBoxText, JOptionPane.QUESTION_MESSAGE, JOptionPane.YES_NO_OPTION); } |
70 | ||
71 | /** Instantiates a new confirm dialog with Yes/No as the options. | |
72 | * @param parent The parent frame | |
73 | * @param title The title of the dialog | |
74 | * @param message The stuff to display in the body of the dialog. For a simple message, it should be a String; it can | |
75 | * also be an Object[] including Strings and Components to display in the body of the dialog. | |
76 | * @param checkBoxText The text to display with the checkbox | |
77 | * @param messageType The JOptionPane message type | |
78 | * @param optionType The JOptionPane option type | |
79 | */ | |
80 | 0 | public ConfirmCheckBoxDialog(JFrame parent, String title, Object message, String checkBoxText, int messageType, |
81 | int optionType) { | |
82 | 0 | _optionPane = new JOptionPane(message, messageType, optionType); |
83 | 0 | JPanel checkBoxPane = new JPanel(); |
84 | 0 | checkBoxPane.add(_initCheckBox(checkBoxText)); |
85 | 0 | _optionPane.add(checkBoxPane, 1); |
86 | 0 | _dialog = _optionPane.createDialog(parent, title); |
87 | } | |
88 | ||
89 | /** Initializes the JCheckBox to have the given text. */ | |
90 | 0 | private JCheckBox _initCheckBox(String text) { |
91 | 0 | _checkBox = new JCheckBox(text); |
92 | 0 | return _checkBox; |
93 | } | |
94 | ||
95 | /** Shows the dialog. | |
96 | * @return the JOptionPane result of showing the dialog. | |
97 | */ | |
98 | 0 | public int show() { |
99 | 0 | Utilities.setPopupLoc(_dialog, _dialog.getOwner()); |
100 | 0 | _dialog.setVisible(true); |
101 | ||
102 | 0 | Object val = _optionPane.getValue(); |
103 | 0 | if (val == null || !(val instanceof Integer)) { |
104 | 0 | return JOptionPane.CLOSED_OPTION; |
105 | } | |
106 | 0 | return ((Integer)val).intValue(); |
107 | } | |
108 | ||
109 | /** Gets the selected value of the check box. Should not be called until the dialog is shown. | |
110 | * @return the value of the checkbox | |
111 | */ | |
112 | 0 | public boolean getCheckBoxValue() { return _checkBox.isSelected(); } |
113 | } |
|