ca.sqlpower.architect.swingui.olap.DimensionUsageEditPanel.java Source code

Java tutorial

Introduction

Here is the source code for ca.sqlpower.architect.swingui.olap.DimensionUsageEditPanel.java

Source

/*
 * Copyright (c) 2008, SQL Power Group Inc.
 *
 * This file is part of Power*Architect.
 *
 * Power*Architect 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.
 *
 * Power*Architect 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 ca.sqlpower.architect.swingui.olap;

import javax.swing.JComboBox;
import javax.swing.JComponent;
import javax.swing.JPanel;
import javax.swing.JTextField;

import ca.sqlpower.architect.olap.OLAPUtil;
import ca.sqlpower.architect.olap.MondrianModel.Cube;
import ca.sqlpower.architect.olap.MondrianModel.DimensionUsage;
import ca.sqlpower.architect.swingui.SQLObjectComboBoxModel;
import ca.sqlpower.sqlobject.SQLObjectException;
import ca.sqlpower.sqlobject.SQLColumn;
import ca.sqlpower.sqlobject.SQLTable;
import ca.sqlpower.swingui.DataEntryPanel;
import ca.sqlpower.validation.swingui.FormValidationHandler;
import ca.sqlpower.validation.swingui.NotNullValidator;
import ca.sqlpower.validation.swingui.StatusComponent;

import com.jgoodies.forms.builder.DefaultFormBuilder;
import com.jgoodies.forms.layout.FormLayout;

public class DimensionUsageEditPanel implements DataEntryPanel {

    private final DimensionUsage dimensionUsage;

    private final JPanel panel;

    private JTextField captionField;

    private JComboBox foreignKeyChooser;

    /**
     * Validation handler for errors in the dialog
     */
    private FormValidationHandler handler;
    private StatusComponent status = new StatusComponent();

    /**
     * Creates a new property editor for the given dimension usage.
     * 
     * @param dimensionUsage
     *            usage The data model of the dimension usage to edit
     * @throws SQLObjectException
     *             if digging up the source table results in a database error
     */
    public DimensionUsageEditPanel(DimensionUsage dimensionUsage) throws SQLObjectException {
        this.dimensionUsage = dimensionUsage;

        FormLayout layout = new FormLayout("left:max(40dlu;pref), 3dlu, 80dlu:grow", "");
        DefaultFormBuilder builder = new DefaultFormBuilder(layout);
        builder.setDefaultDialogBorder();
        builder.append(status, 3);
        builder.append("Caption", captionField = new JTextField(dimensionUsage.getCaption()));
        builder.append("Foreign Key", foreignKeyChooser = new JComboBox());

        Cube cube = (Cube) dimensionUsage.getParent();
        SQLTable factTable = OLAPUtil.tableForCube(cube);
        if (factTable == null) {
            foreignKeyChooser.addItem("Parent Cube has no fact table");
            foreignKeyChooser.setEnabled(false);
        } else if (factTable.getColumns().isEmpty()) {
            foreignKeyChooser.addItem("Parent Cube Fact table has no columns");
            foreignKeyChooser.setEnabled(false);
        } else {
            foreignKeyChooser.setModel(new SQLObjectComboBoxModel(factTable, SQLColumn.class));
            for (SQLColumn col : factTable.getColumns()) {
                if (col.getName().equals(dimensionUsage.getForeignKey())) {
                    foreignKeyChooser.setSelectedItem(col);
                }
            }
        }

        handler = new FormValidationHandler(status, true);
        handler.addValidateObject(foreignKeyChooser, new NotNullValidator("Foreign key"));

        panel = builder.getPanel();
    }

    public boolean applyChanges() {
        dimensionUsage.begin("Modify Dimension Usage Properties");
        if (!(captionField.getText().equals(""))) {
            dimensionUsage.setCaption(captionField.getText());
        } else {
            dimensionUsage.setCaption(null);
        }

        if (foreignKeyChooser.isEnabled()) {
            SQLColumn selectedCol = (SQLColumn) foreignKeyChooser.getSelectedItem();
            String pk = selectedCol.getName();
            dimensionUsage.setForeignKey(pk);
        }
        dimensionUsage.commit();
        return true;
    }

    public void discardChanges() {
        // nothing to do
    }

    public JComponent getPanel() {
        return panel;
    }

    public boolean hasUnsavedChanges() {
        return true;
    }
}