001    /* ========================================================================
002     * JCommon : a free general purpose class library for the Java(tm) platform
003     * ========================================================================
004     *
005     * (C) Copyright 2000-2005, by Object Refinery Limited and Contributors.
006     *
007     * Project Info:  http://www.jfree.org/jcommon/index.html
008     *
009     * This library is free software; you can redistribute it and/or modify it
010     * under the terms of the GNU Lesser General Public License as published by
011     * the Free Software Foundation; either version 2.1 of the License, or
012     * (at your option) any later version.
013     *
014     * This library is distributed in the hope that it will be useful, but
015     * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
016     * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
017     * License for more details.
018     *
019     * You should have received a copy of the GNU Lesser General Public
020     * License along with this library; if not, write to the Free Software
021     * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301,
022     * USA.
023     *
024     * [Java is a trademark or registered trademark of Sun Microsystems, Inc.
025     * in the United States and other countries.]
026     *
027     * ----------------------
028     * AbstractTabbedGUI.java
029     * ----------------------
030     * (C)opyright 2004, by Thomas Morgner and Contributors.
031     *
032     * Original Author:  Thomas Morgner;
033     * Contributor(s):   David Gilbert (for Object Refinery Limited);
034     *
035     * $Id: TabbedFrame.java,v 1.8 2008/09/10 09:19:04 mungady Exp $
036     *
037     * Changes
038     * -------------------------
039     * 16-Feb-2004 : Initial version
040     * 07-Jun-2004 : Added standard header (DG);
041     */
042    
043    package org.jfree.ui.tabbedui;
044    
045    import java.awt.BorderLayout;
046    import java.awt.event.ActionEvent;
047    import java.awt.event.WindowAdapter;
048    import java.awt.event.WindowEvent;
049    import java.beans.PropertyChangeEvent;
050    import java.beans.PropertyChangeListener;
051    import javax.swing.JFrame;
052    import javax.swing.JPanel;
053    
054    /**
055     * A JFrame implementation that uses a tabbed UI as backend.
056     *
057     * @author Thomas Morgner
058     */
059    public class TabbedFrame extends JFrame {
060    
061        /** The backend. */
062        private AbstractTabbedUI tabbedUI;
063    
064        /**
065         * A property change listener that waits for the menubar to change.
066         */
067        private class MenuBarChangeListener implements PropertyChangeListener {
068    
069            /**
070             * Creates a new change listener.
071             */
072            public MenuBarChangeListener() {
073            }
074    
075            /**
076             * This method gets called when a bound property is changed.
077             *
078             * @param evt A PropertyChangeEvent object describing the event source
079             *            and the property that has changed.
080             */
081            public void propertyChange(final PropertyChangeEvent evt) {
082                if (evt.getPropertyName().equals(AbstractTabbedUI.JMENUBAR_PROPERTY)) {
083                    setJMenuBar(getTabbedUI().getJMenuBar());
084                }
085            }
086        }
087    
088        /**
089         * Default constructor.
090         */
091        public TabbedFrame() {
092        }
093    
094        /**
095         * Creates a new tabbed frame with the specified title.
096         *
097         * @param title  the frame title.
098         */
099        public TabbedFrame(final String title) {
100            super(title);
101        }
102    
103        /**
104         * Returns the UI implementation for the frame.
105         *
106         * @return Returns the tabbedUI.
107         */
108        protected final AbstractTabbedUI getTabbedUI()
109        {
110          return this.tabbedUI;
111        }
112    
113        /**
114         * Initialises the dialog.
115         *
116         * @param tabbedUI  the UI that controls the dialog.
117         */
118        public void init(final AbstractTabbedUI tabbedUI) {
119    
120            this.tabbedUI = tabbedUI;
121            this.tabbedUI.addPropertyChangeListener(
122                AbstractTabbedUI.JMENUBAR_PROPERTY, new MenuBarChangeListener()
123            );
124    
125            addWindowListener(new WindowAdapter() {
126                public void windowClosing(final WindowEvent e) {
127                    getTabbedUI().getCloseAction().actionPerformed
128                        (new ActionEvent(this, ActionEvent.ACTION_PERFORMED, null, 0));
129                }
130            });
131    
132            final JPanel panel = new JPanel();
133            panel.setLayout(new BorderLayout());
134            panel.add(tabbedUI, BorderLayout.CENTER);
135            setContentPane(panel);
136            setJMenuBar(tabbedUI.getJMenuBar());
137        }
138    
139    }