/* * This file is a part of EpnTAPClient. * This program aims to provide EPN-TAP support for software clients, like CASSIS spectrum analyzer. * See draft specifications: https://voparis-confluence.obspm.fr/pages/viewpage.action?pageId=559861 * Copyright (C) 2016 Institut de Recherche en Astrophysique et Planétologie. * * This program is free software: you can * redistribute it and/or modify it under the terms of the GNU General Public License as published * by the Free Software Foundation, either version 3 of the License, or (at your option) any later * version. This program is distributed in the hope that it will be useful, but WITHOUT ANY * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR * PURPOSE. See the GNU General Public License for more details. You should have received a copy of * the GNU General Public License along with this program. If not, see * <http://www.gnu.org/licenses/>. */ package eu.omp.irap.vespa.epntapclient.gui; import java.awt.BorderLayout; import java.awt.Dimension; import javax.swing.JOptionPane; import javax.swing.JPanel; import javax.swing.JSplitPane; import eu.omp.irap.vespa.epntapclient.gui.panels.BottomBarPanel; import eu.omp.irap.vespa.epntapclient.gui.panels.RequestPanel; import eu.omp.irap.vespa.epntapclient.gui.panels.ResultsPanel; import eu.omp.irap.vespa.epntapclient.gui.panels.ServicesPanel; /** * The main view of the application, which manage all the other views. * * @author N. Jourdane */ public class EpnTapMainView extends JPanel { /** The serial version UID. */ private static final long serialVersionUID = 1L; /** The JPanel where the VOTable results is displayed. */ private ResultsPanel resultsPanel; /** The JPanel where the list of services is displayed. */ private ServicesPanel servicesPanel; /** The JPanel where the user build the query. */ private RequestPanel requestPanel; /** The status bar. */ private BottomBarPanel bottomBarPanel; /** * The main view constructor, which create all the panels. * * @param voTableServicesView The view to put in the services panel, built by ServicesController * @param voTableResultsView The view to put in the results panel, built by ResultsController. */ public EpnTapMainView(ViewListener viewListener) { servicesPanel = new ServicesPanel(viewListener); resultsPanel = new ResultsPanel(viewListener); requestPanel = new RequestPanel(viewListener); bottomBarPanel = new BottomBarPanel(viewListener); buildMainView(); } /** * Build and fill the GUI. */ private void buildMainView() { setLayout(new BorderLayout()); JSplitPane northPanel = new JSplitPane(JSplitPane.HORIZONTAL_SPLIT, servicesPanel, requestPanel); JSplitPane mainPanel = new JSplitPane(JSplitPane.VERTICAL_SPLIT, northPanel, resultsPanel); add(mainPanel, BorderLayout.CENTER); add(bottomBarPanel, BorderLayout.SOUTH); setSizes(); } private void setSizes() { servicesPanel.setPreferredSize( new Dimension(GUIDim.LEFT_PANEL_WIDTH, GUIDim.TOP_PANEL_HEIGHT)); servicesPanel.setMinimumSize( new Dimension(GUIDim.LEFT_PANEL_MIN_WIDTH, GUIDim.TOP_PANEL_MIN_HEIGHT)); requestPanel.setPreferredSize( new Dimension(GUIDim.RIGHT_PANEL_WIDTH, GUIDim.TOP_PANEL_HEIGHT)); requestPanel.setMinimumSize( new Dimension(GUIDim.RIGHT_PANEL_MIN_WIDTH, GUIDim.TOP_PANEL_MIN_HEIGHT)); resultsPanel.setPreferredSize( new Dimension(GUIDim.LEFT_PANEL_MIN_WIDTH + GUIDim.RIGHT_PANEL_MIN_WIDTH, GUIDim.BOTTOM_PANEL_HEIGHT)); resultsPanel.setMinimumSize( new Dimension(GUIDim.LEFT_PANEL_MIN_WIDTH + GUIDim.RIGHT_PANEL_MIN_WIDTH, GUIDim.BOTTOM_PANEL_MIN_HEIGHT)); } /** * @return The JPanel where the VOTable result is displayed. */ public ResultsPanel getResultsPanel() { return resultsPanel; } /** * @return The JPanel containing the GUI elements to build the query. */ public RequestPanel getRequestPanel() { return requestPanel; } /** * @return The JPanel where the list of services is displayed. */ public ServicesPanel getServicesPanel() { return servicesPanel; } /** * @return The status bar. */ public BottomBarPanel getBottomBarPanel() { return bottomBarPanel; } /** * Display an error message. Usually used each time an error happens. * * @param title The title of the error. * @param message The message of the error. */ public void displayError(String title, String message) { JOptionPane.showMessageDialog(this, message, title, JOptionPane.ERROR_MESSAGE); } }