/[schmitzm]/trunk/src/skrueger/swing/CancellableDialogAdapter.java
ViewVC logotype

Diff of /trunk/src/skrueger/swing/CancellableDialogAdapter.java

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

branches/1.0-gt2-2.6/src/skrueger/swing/CancellableDialogAdapter.java revision 420 by alfonx, Thu Oct 1 20:22:48 2009 UTC trunk/src/skrueger/swing/CancellableDialogAdapter.java revision 707 by alfonx, Mon Feb 15 11:07:30 2010 UTC
# Line 1  Line 1 
1  package skrueger.swing;  package skrueger.swing;
2    
3  import java.awt.Window;  import java.awt.Component;
4  import java.awt.event.WindowAdapter;  import java.awt.Dialog;
5  import java.awt.event.WindowEvent;  import java.awt.event.ActionEvent;
6    import java.util.Locale;
7    
8    import javax.swing.AbstractAction;
9  import javax.swing.JDialog;  import javax.swing.JDialog;
10  import javax.swing.JOptionPane;  import javax.swing.JOptionPane;
11    
12  public abstract class CancellableDialogAdapter extends JDialog implements  import schmitzm.lang.LangUtil;
13    import schmitzm.lang.ResourceProvider;
14    import schmitzm.swing.SwingUtil;
15    
16    /**
17     * An abstract {@link JDialog} that implements a basic structure of how
18     * cancellable {@link JDialog}s work. The {@link JDialog} is designed to work on
19     * the real object and restore it's state when the user cancels the
20     * {@link JDialog}.
21     *
22     * Pressing ESC or clicking the "Close X" results in asking the user whether to Save/Cancel/Abort .  
23     */
24    public abstract class CancellableDialogAdapter extends AtlasDialog implements
25                  CancellableDialog {                  CancellableDialog {
26            
27            protected static ResourceProvider RESOURCE = new ResourceProvider(LangUtil
28                            .extendPackagePath(SwingUtil.class,
29                                            "resource.locales.SwingResourceBundle"), Locale.ENGLISH);
30    
31    
32            /** Has this dialog been canceled ?**/
33          protected boolean cancelled = false;          protected boolean cancelled = false;
34    
35            private OkButton okButton;
36            
37            private CancelButton cancelButton;
38            
39            public CancellableDialogAdapter(Component parentWindow) {
40                    super(parentWindow);
41            }
42    
43            public CancellableDialogAdapter(Component parentWindow, String title) {
44                    super(parentWindow, title);
45            }
46    
47          @Override          @Override
48          public boolean isCancelled() {          public boolean isCancelled() {
49                  return cancelled;                  return cancelled;
50          }          }
51    
52          public CancellableDialogAdapter(final Window parentWindow) {          /**
53                  super(parentWindow);           * Allows to close the {@link JDialog} from "outside". The user will be
54                  initDialog();           * asked and she may cancel the close process.
55             */
56            public boolean close() {
57                    int showConfirmDialog = JOptionPane.showConfirmDialog(
58                                    CancellableDialogAdapter.this,
59                                    RESOURCE.getString("CancellableDialogAdapter.close.save.msg",getTitle()), RESOURCE.getString("CancellableDialogAdapter.close.save.title"), JOptionPane.YES_NO_CANCEL_OPTION);
60    
61                    if (showConfirmDialog == JOptionPane.YES_OPTION) {
62                            return okClose();
63                    }
64                    else if (showConfirmDialog == JOptionPane.NO_OPTION) {
65                            cancelClose();
66                            return true;
67                    }
68                    
69                    return false;
70          }          }
71            
72    
73          private void initDialog() {          /**
74             * This method can be called from "outside" to force a close of this
75                  setDefaultCloseOperation(JDialog.DO_NOTHING_ON_CLOSE);           * {@link Dialog}. The user can't cancel the process. He may only decide to
76             * save possible changes.
77                  addWindowListener(new WindowAdapter() {           */
78            public void forceClose() {
                         @Override  
                         public void windowClosing(WindowEvent e) {  
                                 setDefaultCloseOperation(JDialog.DO_NOTHING_ON_CLOSE);  
                                   
                                 int showConfirmDialog = JOptionPane.showConfirmDialog(  
                                                 CancellableDialogAdapter.this, "Speichern?",  
                                                 "Ă„nderungen speichern?", JOptionPane.YES_NO_CANCEL_OPTION); // i8n  
   
                                 if (showConfirmDialog == JOptionPane.YES_OPTION)  
                                         okClose();  
                                 else if (showConfirmDialog == JOptionPane.NO_OPTION)  
                                         cancelClose();  
                         }  
   
                 });  
         }  
79    
80          public CancellableDialogAdapter(final Window parentWindow, String title) {                  int res = JOptionPane.showConfirmDialog(
81                  super(parentWindow, title);                                  CancellableDialogAdapter.this,
82                  initDialog();                                  RESOURCE.getString("CancellableDialogAdapter.forceClose.save.msg",getTitle()), RESOURCE.getString("CancellableDialogAdapter.close.save.title"), JOptionPane.YES_NO_OPTION);
83                    
84                    if (res == JOptionPane.YES_OPTION) {
85                            okClose();
86                    } else {
87                            cancelClose();
88                    }
89          }          }
90            
91    
92            /**
93             * Default implementation that calls {@link #cancel()} and
94             * {@link #dispose()}.
95             */
96          @Override          @Override
97          public void cancelClose() {          public void cancelClose() {
98                  cancel();                  cancel();
# Line 62  public abstract class CancellableDialogA Line 105  public abstract class CancellableDialogA
105          /**          /**
106           * This method is called when the dialog is closed and not canceled. Can be           * This method is called when the dialog is closed and not canceled. Can be
107           * overwritten to do anything when the dialog has been accepted. For example           * overwritten to do anything when the dialog has been accepted. For example
108           * cheking for any {@link Checkable} components. Returns false, if the ok           * checking for any {@link Checkable} components. <br/>
109           * has been vetoed.           *
110             * @Return <code>false</code>, if the ok has been vetoed.
111             */
112            public boolean okClose() {
113                    dispose();
114                    return true;
115            }
116    
117            /**
118             * @return a default OkButton that will call {@link #okClose()}
119           */           */
120          public abstract boolean okClose();          protected OkButton getOkButton() {
121                    if (okButton == null) {
122                            okButton = new OkButton(new AbstractAction() {
123                                    
124                                    @Override
125                                    public void actionPerformed(ActionEvent e) {
126                                            okClose();
127                                    }
128                            });
129                    }
130                    return okButton;
131            }
132            
133    
134            /**
135             * @return a default CancelButton that will call {@link #cancelClose()}
136             */
137            protected CancelButton getCancelButton() {
138                    if (cancelButton == null) {
139                            cancelButton = new CancelButton(new AbstractAction() {
140                                    
141                                    @Override
142                                    public void actionPerformed(ActionEvent e) {
143                                            cancelClose();
144                                    }
145                            });
146                    }
147                    return cancelButton;
148            }
149    
150  }  }

Legend:
Removed from v.420  
changed lines
  Added in v.707

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26