/* * To change this template, choose Tools | Templates * and open the template in the editor. */ package com.wcs.netbeans.liquiface.ui.wizards.addfk; /* * #%L * Liquiface - GUI for Liquibase * %% * Copyright (C) 2013 Webstar Csoport Kft. * %% * 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/gpl-3.0.html>. * #L% */ import com.wcs.netbeans.liquiface.model.Column; import com.wcs.netbeans.liquiface.ui.wizards.AbstractWizardPanel; import java.util.HashMap; import java.util.Map; import javax.swing.JTable; import javax.swing.event.ChangeListener; import org.openide.WizardDescriptor; import org.openide.WizardValidationException; public class AddForeignKeyWizardPanel1 extends AbstractWizardPanel { /** * The visual component that displays this panel. If you need to access the component from this class, just use * getComponent(). */ private AddForeignKeyVisualPanel1 component; private String tableName; public AddForeignKeyWizardPanel1(String tableName) { this.tableName = tableName; } // Get the visual component for the panel. In this template, the component // is kept separate. This can be more efficient: if the wizard is created // but never displayed, or not all panels are displayed, it is better to // create only those which really need to be visible. @Override public AddForeignKeyVisualPanel1 getComponent() { if (component == null) { component = new AddForeignKeyVisualPanel1(tableName); } return component; } @Override public void storeSettings(WizardDescriptor wiz) { wiz.putProperty(AddForeignKeyWizardConstants.FOREIGN_KEY_NAME, getComponent().getFkNameField().getText()); wiz.putProperty(AddForeignKeyWizardConstants.REFERENCED_TABLE_NAME, (String) getComponent().getReferencedTableField().getSelectedItem()); wiz.putProperty(AddForeignKeyWizardConstants.REFERENCES_UNIQUE_CONSTRAINT, getComponent().isReferencesUniqueColumn()); Map<String, String> columnsMap = new HashMap<String, String>(); JTable columnTable = getComponent().getColumnsTable(); for (int i = 0; i < columnTable.getRowCount(); i++) { String referencedColumn = (String) columnTable.getValueAt(i, 0); String localColumn = (String) columnTable.getValueAt(i, 1); columnsMap.put(referencedColumn, localColumn); } wiz.putProperty(AddForeignKeyWizardConstants.COLUMN_MAP, columnsMap); } @Override public void validate() throws WizardValidationException { String fkName = getComponent().getFkNameField().getText(); if (fkName.equals("")){ throw new WizardValidationException(null, "The name is required!", null); } String referencedTableName = (String) getComponent().getReferencedTableField().getSelectedItem(); if (referencedTableName.equals("")) { throw new WizardValidationException(null, "Referenced table is required!", null); } String referencedConstraintName = (String) getComponent().getReferencedConstraintField().getSelectedItem(); if (referencedConstraintName.equals("")) { throw new WizardValidationException(null, "Referenced constraint is required!", null); } JTable columnTable = getComponent().getColumnsTable(); for (int i = 0; i < columnTable.getRowCount(); i++) { Object localColumn = columnTable.getValueAt(i, 1); if (localColumn == null) { throw new WizardValidationException(null, "All local columns are required!", null); } } } }