public void setUpFile() { removeAll(); boolean currentFileIsDir = false; File tmp = ((FileSourcedConverter) m_dsLoader.getLoader()).retrieveFile(); String tmpString = tmp.toString(); if (Environment.containsEnvVariables(tmpString)) { try { tmpString = m_env.substitute(tmpString); } catch (Exception ex) { // ignore } } File tmp2 = new File((new File(tmpString)).getAbsolutePath()); if (tmp2.isDirectory()) { m_fileChooser.setCurrentDirectory(tmp2); currentFileIsDir = true; } else { m_fileChooser.setSelectedFile(tmp2); } FileSourcedConverter loader = (FileSourcedConverter) m_dsLoader.getLoader(); String[] ext = loader.getFileExtensions(); ExtensionFileFilter firstFilter = null; for (int i = 0; i < ext.length; i++) { ExtensionFileFilter ff = new ExtensionFileFilter(ext[i], loader.getFileDescription() + " (*" + ext[i] + ")"); if (i == 0) firstFilter = ff; m_fileChooser.addChoosableFileFilter(ff); } if (firstFilter != null) m_fileChooser.setFileFilter(firstFilter); JPanel about = m_LoaderEditor.getAboutPanel(); JPanel northPanel = new JPanel(); northPanel.setLayout(new BorderLayout()); if (about != null) { northPanel.add(about, BorderLayout.NORTH); } add(northPanel, BorderLayout.NORTH); final EnvironmentField ef = new EnvironmentField(); JPanel efHolder = new JPanel(); efHolder.setLayout(new BorderLayout()); ef.setEnvironment(m_env); /*int width = ef.getPreferredSize().width; int height = ef.getPreferredSize().height; // ef.setMinimumSize(new Dimension(width * 2, height)); ef.setPreferredSize(new Dimension(width * 2, height)); */ m_fileText = ef; // only set the text on the EnvironmentField if the current file is not a directory if (!currentFileIsDir) { ef.setText(tmp.toString()); } efHolder.add(ef, BorderLayout.CENTER); JButton browseBut = new JButton("Browse..."); browseBut.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent e) { try { // final JFrame jf = new JFrame("Choose file"); final JDialog jf = new JDialog( (JDialog) LoaderCustomizer.this.getTopLevelAncestor(), "Choose file", true); jf.setLayout(new BorderLayout()); // jf.getContentPane().setLayout(new BorderLayout()); jf.getContentPane().add(m_fileChooser, BorderLayout.CENTER); m_fileChooserFrame = jf; jf.pack(); jf.setVisible(true); } catch (Exception ex) { ex.printStackTrace(); } } }); JPanel bP = new JPanel(); bP.setLayout(new BorderLayout()); bP.setBorder(BorderFactory.createEmptyBorder(5, 0, 5, 5)); bP.add(browseBut, BorderLayout.CENTER); efHolder.add(bP, BorderLayout.EAST); JPanel alignedP = new JPanel(); alignedP.setBorder(BorderFactory.createTitledBorder("File")); alignedP.setLayout(new BorderLayout()); JLabel efLab = new JLabel("Filename", SwingConstants.RIGHT); efLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); alignedP.add(efLab, BorderLayout.WEST); alignedP.add(efHolder, BorderLayout.CENTER); northPanel.add(alignedP, BorderLayout.SOUTH); JPanel butHolder = new JPanel(); // butHolder.setLayout(new GridLayout(1,2)); butHolder.setLayout(new FlowLayout()); JButton OKBut = new JButton("OK"); OKBut.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent e) { try { ((FileSourcedConverter) m_dsLoader.getLoader()).setFile(new File(ef.getText())); // tell the loader that a new file has been selected so // that it can attempt to load the header // m_dsLoader.setLoader(m_dsLoader.getLoader()); m_dsLoader.newFileSelected(); } catch (Exception ex) { ex.printStackTrace(); } if (m_modifyListener != null) { m_modifyListener.setModifiedStatus(LoaderCustomizer.this, true); } m_parentWindow.dispose(); } }); JButton CancelBut = new JButton("Cancel"); CancelBut.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent e) { if (m_modifyListener != null) { m_modifyListener.setModifiedStatus(LoaderCustomizer.this, false); } if (m_backup != null) { m_dsLoader.setLoader(m_backup); } m_parentWindow.dispose(); } }); butHolder.add(OKBut); butHolder.add(CancelBut); JPanel optionsHolder = new JPanel(); optionsHolder.setLayout(new BorderLayout()); optionsHolder.setBorder(BorderFactory.createTitledBorder("Other options")); optionsHolder.add(m_LoaderEditor, BorderLayout.SOUTH); JScrollPane scroller = new JScrollPane(optionsHolder); add(scroller, BorderLayout.CENTER); add(butHolder, BorderLayout.SOUTH); }
/** Sets up a customizer window for a Database Connection */ private void setUpDatabase() { removeAll(); JPanel db = new JPanel(); GridBagLayout gbLayout = new GridBagLayout(); // db.setLayout(new GridLayout(6, 1)); db.setLayout(gbLayout); JLabel urlLab = new JLabel("Database URL", SwingConstants.RIGHT); urlLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); GridBagConstraints gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 0; gbConstraints.gridx = 0; gbLayout.setConstraints(urlLab, gbConstraints); db.add(urlLab); m_dbaseURLText = new EnvironmentField(); m_dbaseURLText.setEnvironment(m_env); /* int width = m_dbaseURLText.getPreferredSize().width; int height = m_dbaseURLText.getPreferredSize().height; m_dbaseURLText.setMinimumSize(new Dimension(width * 2, height)); m_dbaseURLText.setPreferredSize(new Dimension(width * 2, height)); */ m_dbaseURLText.setText(((DatabaseConverter) m_dsLoader.getLoader()).getUrl()); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 0; gbConstraints.gridx = 1; gbConstraints.weightx = 5; gbLayout.setConstraints(m_dbaseURLText, gbConstraints); db.add(m_dbaseURLText); JLabel userLab = new JLabel("Username", SwingConstants.RIGHT); userLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 1; gbConstraints.gridx = 0; gbLayout.setConstraints(userLab, gbConstraints); db.add(userLab); m_userNameText = new EnvironmentField(); m_userNameText.setEnvironment(m_env); /* m_userNameText.setMinimumSize(new Dimension(width * 2, height)); m_userNameText.setPreferredSize(new Dimension(width * 2, height)); */ m_userNameText.setText(((DatabaseConverter) m_dsLoader.getLoader()).getUser()); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 1; gbConstraints.gridx = 1; gbLayout.setConstraints(m_userNameText, gbConstraints); db.add(m_userNameText); JLabel passwordLab = new JLabel("Password ", SwingConstants.RIGHT); passwordLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 2; gbConstraints.gridx = 0; gbLayout.setConstraints(passwordLab, gbConstraints); db.add(passwordLab); m_passwordText = new JPasswordField(); JPanel passwordHolder = new JPanel(); passwordHolder.setLayout(new BorderLayout()); passwordHolder.setBorder(BorderFactory.createEmptyBorder(5, 5, 5, 5)); // passwordHolder.add(passwordLab, BorderLayout.WEST); passwordHolder.add(m_passwordText, BorderLayout.CENTER); /* passwordHolder.setMinimumSize(new Dimension(width * 2, height)); passwordHolder.setPreferredSize(new Dimension(width * 2, height)); */ gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 2; gbConstraints.gridx = 1; gbLayout.setConstraints(passwordHolder, gbConstraints); db.add(passwordHolder); JLabel queryLab = new JLabel("Query", SwingConstants.RIGHT); queryLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 3; gbConstraints.gridx = 0; gbLayout.setConstraints(queryLab, gbConstraints); db.add(queryLab); m_queryText = new EnvironmentField(); m_queryText.setEnvironment(m_env); /* m_queryText.setMinimumSize(new Dimension(width * 2, height)); m_queryText.setPreferredSize(new Dimension(width * 2, height)); */ m_queryText.setText(((DatabaseLoader) m_dsLoader.getLoader()).getQuery()); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 3; gbConstraints.gridx = 1; gbLayout.setConstraints(m_queryText, gbConstraints); db.add(m_queryText); JLabel keyLab = new JLabel("Key columns", SwingConstants.RIGHT); keyLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 4; gbConstraints.gridx = 0; gbLayout.setConstraints(keyLab, gbConstraints); db.add(keyLab); m_keyText = new EnvironmentField(); m_keyText.setEnvironment(m_env); /*m_keyText.setMinimumSize(new Dimension(width * 2, height)); m_keyText.setPreferredSize(new Dimension(width * 2, height)); */ m_keyText.setText(((DatabaseLoader) m_dsLoader.getLoader()).getKeys()); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 4; gbConstraints.gridx = 1; gbLayout.setConstraints(m_keyText, gbConstraints); db.add(m_keyText); JLabel propsLab = new JLabel("DB config props", SwingConstants.RIGHT); propsLab.setToolTipText( "The custom properties that the user can use to override the default ones."); propsLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 5; gbConstraints.gridx = 0; gbLayout.setConstraints(propsLab, gbConstraints); db.add(propsLab); m_dbProps = new FileEnvironmentField(); m_dbProps.setEnvironment(m_env); m_dbProps.resetFileFilters(); m_dbProps.addFileFilter( new ExtensionFileFilter(".props", "DatabaseUtils property file (*.props)")); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 5; gbConstraints.gridx = 1; gbLayout.setConstraints(m_dbProps, gbConstraints); db.add(m_dbProps); File toSet = ((DatabaseLoader) m_dsLoader.getLoader()).getCustomPropsFile(); if (toSet != null) { m_dbProps.setText(toSet.getPath()); } JButton loadPropsBut = new JButton("Load"); loadPropsBut.setToolTipText("Load config"); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 5; gbConstraints.gridx = 2; gbLayout.setConstraints(loadPropsBut, gbConstraints); db.add(loadPropsBut); loadPropsBut.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent e) { if (m_dbProps.getText() != null && m_dbProps.getText().length() > 0) { String propsS = m_dbProps.getText(); try { propsS = m_env.substitute(propsS); } catch (Exception ex) { } File propsFile = new File(propsS); if (propsFile.exists()) { ((DatabaseLoader) m_dsLoader.getLoader()).setCustomPropsFile(propsFile); ((DatabaseLoader) m_dsLoader.getLoader()).resetOptions(); m_dbaseURLText.setText(((DatabaseLoader) m_dsLoader.getLoader()).getUrl()); } } } }); JPanel buttonsP = new JPanel(); buttonsP.setLayout(new FlowLayout()); JButton ok, cancel; buttonsP.add(ok = new JButton("OK")); buttonsP.add(cancel = new JButton("Cancel")); ok.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent evt) { /*((DatabaseLoader)m_dsLoader.getLoader()).resetStructure(); ((DatabaseConverter)m_dsLoader.getLoader()).setUrl(m_dbaseURLText.getText()); ((DatabaseConverter)m_dsLoader.getLoader()).setUser(m_userNameText.getText()); ((DatabaseConverter)m_dsLoader.getLoader()).setPassword(new String(m_passwordText.getPassword())); ((DatabaseLoader)m_dsLoader.getLoader()).setQuery(m_queryText.getText()); ((DatabaseLoader)m_dsLoader.getLoader()).setKeys(m_keyText.getText()); */ if (resetAndUpdateDatabaseLoaderIfChanged()) { try { // m_dsLoader.notifyStructureAvailable(((DatabaseLoader)m_dsLoader.getLoader()).getStructure()); // database connection has been configured m_dsLoader.setDB(true); } catch (Exception ex) { } } if (m_parentWindow != null) { m_parentWindow.dispose(); } } }); cancel.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent evt) { if (m_backup != null) { m_dsLoader.setLoader(m_backup); } if (m_parentWindow != null) { m_parentWindow.dispose(); } } }); JPanel holderP = new JPanel(); holderP.setLayout(new BorderLayout()); holderP.add(db, BorderLayout.NORTH); holderP.add(buttonsP, BorderLayout.SOUTH); // db.add(buttonsP); JPanel about = m_LoaderEditor.getAboutPanel(); if (about != null) { add(about, BorderLayout.NORTH); } add(holderP, BorderLayout.SOUTH); }
/** Sets up dialog for saving instances in a file */ public void setUpFile() { removeAll(); m_fileChooser.setFileFilter( new FileFilter() { public boolean accept(File f) { return f.isDirectory(); } public String getDescription() { return "Directory"; } }); m_fileChooser.setAcceptAllFileFilterUsed(false); try { if (!(((m_dsSaver.getSaver()).retrieveDir()).equals(""))) { String dirStr = m_dsSaver.getSaver().retrieveDir(); if (Environment.containsEnvVariables(dirStr)) { try { dirStr = m_env.substitute(dirStr); } catch (Exception ex) { // ignore } } File tmp = new File(dirStr); tmp = new File(tmp.getAbsolutePath()); m_fileChooser.setCurrentDirectory(tmp); } } catch (Exception ex) { System.out.println(ex); } JPanel innerPanel = new JPanel(); innerPanel.setLayout(new BorderLayout()); JPanel alignedP = new JPanel(); GridBagLayout gbLayout = new GridBagLayout(); alignedP.setLayout(gbLayout); JLabel prefixLab = new JLabel("Prefix for file name", SwingConstants.RIGHT); prefixLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); GridBagConstraints gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 0; gbConstraints.gridx = 0; gbLayout.setConstraints(prefixLab, gbConstraints); alignedP.add(prefixLab); m_prefixText = new EnvironmentField(); m_prefixText.setEnvironment(m_env); m_prefixText.setToolTipText( "Prefix for file name " + "(or filename itself if relation name is not used)"); /* int width = m_prefixText.getPreferredSize().width; int height = m_prefixText.getPreferredSize().height; m_prefixText.setMinimumSize(new Dimension(width * 2, height)); m_prefixText.setPreferredSize(new Dimension(width * 2, height)); */ gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 0; gbConstraints.gridx = 1; gbLayout.setConstraints(m_prefixText, gbConstraints); alignedP.add(m_prefixText); try { // m_prefixText = new JTextField(m_dsSaver.getSaver().filePrefix(),25); m_prefixText.setText(m_dsSaver.getSaver().filePrefix()); /* final JLabel prefixLab = new JLabel(" Prefix for file name:", SwingConstants.LEFT); */ JLabel relationLab = new JLabel("Relation name for filename", SwingConstants.RIGHT); relationLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 1; gbConstraints.gridx = 0; gbLayout.setConstraints(relationLab, gbConstraints); alignedP.add(relationLab); m_relationNameForFilename = new JCheckBox(); m_relationNameForFilename.setSelected(m_dsSaver.getRelationNameForFilename()); m_relationNameForFilename.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent e) { if (m_relationNameForFilename.isSelected()) { m_prefixText.setLabel("Prefix for file name"); m_fileChooser.setApproveButtonText("Select directory and prefix"); } else { m_prefixText.setLabel("File name"); m_fileChooser.setApproveButtonText("Select directory and filename"); } } }); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 1; gbConstraints.gridx = 1; gbConstraints.weightx = 5; gbLayout.setConstraints(m_relationNameForFilename, gbConstraints); alignedP.add(m_relationNameForFilename); } catch (Exception ex) { } // innerPanel.add(m_SaverEditor, BorderLayout.SOUTH); JPanel about = m_SaverEditor.getAboutPanel(); if (about != null) { innerPanel.add(about, BorderLayout.NORTH); } add(innerPanel, BorderLayout.NORTH); // add(m_fileChooser, BorderLayout.CENTER); JLabel directoryLab = new JLabel("Directory", SwingConstants.RIGHT); directoryLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 2; gbConstraints.gridx = 0; gbLayout.setConstraints(directoryLab, gbConstraints); alignedP.add(directoryLab); m_directoryText = new EnvironmentField(); // m_directoryText.setBorder(BorderFactory.createEmptyBorder(5, 5, 5, 5)); m_directoryText.setEnvironment(m_env); /* width = m_directoryText.getPreferredSize().width; height = m_directoryText.getPreferredSize().height; m_directoryText.setMinimumSize(new Dimension(width * 2, height)); m_directoryText.setPreferredSize(new Dimension(width * 2, height)); */ try { m_directoryText.setText(m_dsSaver.getSaver().retrieveDir()); } catch (IOException ex) { // ignore } JButton browseBut = new JButton("Browse..."); browseBut.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent e) { try { final JFrame jf = new JFrame("Choose directory"); jf.getContentPane().setLayout(new BorderLayout()); jf.getContentPane().add(m_fileChooser, BorderLayout.CENTER); jf.pack(); jf.setVisible(true); m_fileChooserFrame = jf; } catch (Exception ex) { ex.printStackTrace(); } } }); JPanel efHolder = new JPanel(); efHolder.setLayout(new BorderLayout()); JPanel bP = new JPanel(); bP.setLayout(new BorderLayout()); bP.setBorder(BorderFactory.createEmptyBorder(5, 0, 5, 5)); bP.add(browseBut, BorderLayout.CENTER); efHolder.add(m_directoryText, BorderLayout.CENTER); efHolder.add(bP, BorderLayout.EAST); // efHolder.setBorder(BorderFactory.createEmptyBorder(5, 5, 5, 5)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 2; gbConstraints.gridx = 1; gbLayout.setConstraints(efHolder, gbConstraints); alignedP.add(efHolder); JLabel relativeLab = new JLabel("Use relative file paths", SwingConstants.RIGHT); relativeLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 3; gbConstraints.gridx = 0; gbLayout.setConstraints(relativeLab, gbConstraints); alignedP.add(relativeLab); m_relativeFilePath = new JCheckBox(); m_relativeFilePath.setSelected( ((FileSourcedConverter) m_dsSaver.getSaver()).getUseRelativePath()); m_relativeFilePath.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent e) { ((FileSourcedConverter) m_dsSaver.getSaver()) .setUseRelativePath(m_relativeFilePath.isSelected()); } }); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 3; gbConstraints.gridx = 1; gbLayout.setConstraints(m_relativeFilePath, gbConstraints); alignedP.add(m_relativeFilePath); JButton OKBut = new JButton("OK"); OKBut.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent e) { try { (m_dsSaver.getSaver()).setFilePrefix(m_prefixText.getText()); (m_dsSaver.getSaver()).setDir(m_directoryText.getText()); m_dsSaver.setRelationNameForFilename(m_relationNameForFilename.isSelected()); } catch (Exception ex) { ex.printStackTrace(); } m_parentFrame.dispose(); } }); JButton CancelBut = new JButton("Cancel"); CancelBut.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent e) { m_parentFrame.dispose(); } }); JPanel butHolder = new JPanel(); butHolder.setLayout(new FlowLayout()); butHolder.add(OKBut); butHolder.add(CancelBut); JPanel holder2 = new JPanel(); holder2.setLayout(new BorderLayout()); holder2.add(alignedP, BorderLayout.NORTH); holder2.add(butHolder, BorderLayout.SOUTH); add(holder2, BorderLayout.SOUTH); }
/** Sets up the dialog for saving to a database */ private void setUpDatabase() { removeAll(); JPanel db = new JPanel(); GridBagLayout gbLayout = new GridBagLayout(); db.setLayout(gbLayout); JLabel dbaseURLLab = new JLabel(" Database URL", SwingConstants.RIGHT); dbaseURLLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); GridBagConstraints gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 0; gbConstraints.gridx = 0; gbLayout.setConstraints(dbaseURLLab, gbConstraints); db.add(dbaseURLLab); m_dbaseURLText = new EnvironmentField(); m_dbaseURLText.setEnvironment(m_env); /* int width = m_dbaseURLText.getPreferredSize().width; int height = m_dbaseURLText.getPreferredSize().height; m_dbaseURLText.setMinimumSize(new Dimension(width * 2, height)); m_dbaseURLText.setPreferredSize(new Dimension(width * 2, height)); */ m_dbaseURLText.setText(((DatabaseConverter) m_dsSaver.getSaver()).getUrl()); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 0; gbConstraints.gridx = 1; gbConstraints.weightx = 5; gbLayout.setConstraints(m_dbaseURLText, gbConstraints); db.add(m_dbaseURLText); JLabel userLab = new JLabel("Username", SwingConstants.RIGHT); userLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 1; gbConstraints.gridx = 0; gbLayout.setConstraints(userLab, gbConstraints); db.add(userLab); m_userNameText = new EnvironmentField(); m_userNameText.setEnvironment(m_env); /* m_userNameText.setMinimumSize(new Dimension(width * 2, height)); m_userNameText.setPreferredSize(new Dimension(width * 2, height)); */ m_userNameText.setText(((DatabaseConverter) m_dsSaver.getSaver()).getUser()); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 1; gbConstraints.gridx = 1; gbLayout.setConstraints(m_userNameText, gbConstraints); db.add(m_userNameText); JLabel passwordLab = new JLabel("Password ", SwingConstants.RIGHT); passwordLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 2; gbConstraints.gridx = 0; gbLayout.setConstraints(passwordLab, gbConstraints); db.add(passwordLab); m_passwordText = new JPasswordField(); JPanel passwordHolder = new JPanel(); passwordHolder.setLayout(new BorderLayout()); passwordHolder.setBorder(BorderFactory.createEmptyBorder(5, 5, 5, 5)); passwordHolder.add(m_passwordText, BorderLayout.CENTER); /*passwordHolder.setMinimumSize(new Dimension(width * 2, height)); passwordHolder.setPreferredSize(new Dimension(width * 2, height)); */ gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 2; gbConstraints.gridx = 1; gbLayout.setConstraints(passwordHolder, gbConstraints); db.add(passwordHolder); JLabel tableLab = new JLabel("Table Name", SwingConstants.RIGHT); tableLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 3; gbConstraints.gridx = 0; gbLayout.setConstraints(tableLab, gbConstraints); db.add(tableLab); m_tableText = new EnvironmentField(); m_tableText.setEnvironment(m_env); /* m_tableText.setMinimumSize(new Dimension(width * 2, height)); m_tableText.setPreferredSize(new Dimension(width * 2, height)); */ m_tableText.setEnabled(!((DatabaseSaver) m_dsSaver.getSaver()).getRelationForTableName()); m_tableText.setText(((DatabaseSaver) m_dsSaver.getSaver()).getTableName()); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 3; gbConstraints.gridx = 1; gbLayout.setConstraints(m_tableText, gbConstraints); db.add(m_tableText); JLabel tabLab = new JLabel("Use relation name", SwingConstants.RIGHT); tabLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 4; gbConstraints.gridx = 0; gbLayout.setConstraints(tabLab, gbConstraints); db.add(tabLab); m_tabBox = new JCheckBox(); m_tabBox.setSelected(((DatabaseSaver) m_dsSaver.getSaver()).getRelationForTableName()); m_tabBox.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent e) { m_tableText.setEnabled(!m_tabBox.isSelected()); } }); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 4; gbConstraints.gridx = 1; gbLayout.setConstraints(m_tabBox, gbConstraints); db.add(m_tabBox); JLabel idLab = new JLabel("Automatic primary key", SwingConstants.RIGHT); idLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 5; gbConstraints.gridx = 0; gbLayout.setConstraints(idLab, gbConstraints); db.add(idLab); m_idBox = new JCheckBox(); m_idBox.setSelected(((DatabaseSaver) m_dsSaver.getSaver()).getAutoKeyGeneration()); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 5; gbConstraints.gridx = 1; gbLayout.setConstraints(m_idBox, gbConstraints); db.add(m_idBox); JPanel buttonsP = new JPanel(); buttonsP.setLayout(new FlowLayout()); JButton ok, cancel; buttonsP.add(ok = new JButton("OK")); buttonsP.add(cancel = new JButton("Cancel")); ok.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent evt) { ((DatabaseSaver) m_dsSaver.getSaver()).resetStructure(); ((DatabaseConverter) m_dsSaver.getSaver()).setUrl(m_dbaseURLText.getText()); ((DatabaseConverter) m_dsSaver.getSaver()).setUser(m_userNameText.getText()); ((DatabaseConverter) m_dsSaver.getSaver()) .setPassword(new String(m_passwordText.getPassword())); if (!m_tabBox.isSelected()) { ((DatabaseSaver) m_dsSaver.getSaver()).setTableName(m_tableText.getText()); } ((DatabaseSaver) m_dsSaver.getSaver()).setAutoKeyGeneration(m_idBox.isSelected()); ((DatabaseSaver) m_dsSaver.getSaver()).setRelationForTableName(m_tabBox.isSelected()); if (m_parentFrame != null) { m_parentFrame.dispose(); } } }); cancel.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent evt) { if (m_parentFrame != null) { m_parentFrame.dispose(); } } }); JPanel holderP = new JPanel(); holderP.setLayout(new BorderLayout()); holderP.add(db, BorderLayout.NORTH); holderP.add(buttonsP, BorderLayout.SOUTH); // db.add(buttonsP); JPanel about = m_SaverEditor.getAboutPanel(); if (about != null) { add(about, BorderLayout.NORTH); } add(holderP, BorderLayout.SOUTH); }
public void setUpFile() { removeAll(); boolean currentFileIsDir = false; File tmp = ((FileSourcedConverter) m_dsLoader.getLoader()).retrieveFile(); String tmpString = tmp.toString(); if (Environment.containsEnvVariables(tmpString)) { try { tmpString = m_env.substitute(tmpString); } catch (Exception ex) { // ignore } } File tmp2 = new File((new File(tmpString)).getAbsolutePath()); if (tmp2.isDirectory()) { m_fileChooser.setCurrentDirectory(tmp2); currentFileIsDir = true; } else { m_fileChooser.setSelectedFile(tmp2); } FileSourcedConverter loader = (FileSourcedConverter) m_dsLoader.getLoader(); String[] ext = loader.getFileExtensions(); ExtensionFileFilter firstFilter = null; for (int i = 0; i < ext.length; i++) { ExtensionFileFilter ff = new ExtensionFileFilter(ext[i], loader.getFileDescription() + " (*" + ext[i] + ")"); if (i == 0) firstFilter = ff; m_fileChooser.addChoosableFileFilter(ff); } if (firstFilter != null) m_fileChooser.setFileFilter(firstFilter); JPanel about = m_LoaderEditor.getAboutPanel(); JPanel northPanel = new JPanel(); northPanel.setLayout(new BorderLayout()); if (about != null) { northPanel.add(about, BorderLayout.NORTH); } add(northPanel, BorderLayout.NORTH); final EnvironmentField ef = new EnvironmentField(); JPanel efHolder = new JPanel(); efHolder.setLayout(new BorderLayout()); ef.setEnvironment(m_env); /*int width = ef.getPreferredSize().width; int height = ef.getPreferredSize().height; // ef.setMinimumSize(new Dimension(width * 2, height)); ef.setPreferredSize(new Dimension(width * 2, height)); */ m_fileText = ef; // only set the text on the EnvironmentField if the current file is not a directory if (!currentFileIsDir) { ef.setText(tmp.toString()); } efHolder.add(ef, BorderLayout.CENTER); JButton browseBut = new JButton("Browse..."); browseBut.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent e) { try { final JFrame jf = new JFrame("Choose file"); jf.getContentPane().setLayout(new BorderLayout()); jf.getContentPane().add(m_fileChooser, BorderLayout.CENTER); jf.pack(); jf.setVisible(true); m_fileChooserFrame = jf; } catch (Exception ex) { ex.printStackTrace(); } } }); JPanel bP = new JPanel(); bP.setLayout(new BorderLayout()); bP.setBorder(BorderFactory.createEmptyBorder(5, 0, 5, 5)); bP.add(browseBut, BorderLayout.CENTER); efHolder.add(bP, BorderLayout.EAST); JPanel alignedP = new JPanel(); GridBagLayout gbLayout = new GridBagLayout(); alignedP.setLayout(gbLayout); JLabel efLab = new JLabel("Filename", SwingConstants.RIGHT); efLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); GridBagConstraints gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 0; gbConstraints.gridx = 0; gbLayout.setConstraints(efLab, gbConstraints); alignedP.add(efLab); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 0; gbConstraints.gridx = 1; gbConstraints.weightx = 5; gbLayout.setConstraints(efHolder, gbConstraints); alignedP.add(efHolder); northPanel.add(alignedP, BorderLayout.SOUTH); // add(m_fileChooser, BorderLayout.CENTER); // m_relativeFilePath = new JCheckBox("Use relative file paths"); m_relativeFilePath = new JCheckBox(); m_relativeFilePath.setSelected( ((FileSourcedConverter) m_dsLoader.getLoader()).getUseRelativePath()); m_relativeFilePath.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent e) { ((FileSourcedConverter) m_dsLoader.getLoader()) .setUseRelativePath(m_relativeFilePath.isSelected()); } }); JLabel relativeLab = new JLabel("Use relative file paths", SwingConstants.RIGHT); relativeLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 1; gbConstraints.gridx = 0; gbLayout.setConstraints(relativeLab, gbConstraints); alignedP.add(relativeLab); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 1; gbConstraints.gridx = 1; gbLayout.setConstraints(m_relativeFilePath, gbConstraints); alignedP.add(m_relativeFilePath); JPanel butHolder = new JPanel(); // butHolder.setLayout(new GridLayout(1,2)); butHolder.setLayout(new FlowLayout()); JButton OKBut = new JButton("OK"); OKBut.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent e) { try { ((FileSourcedConverter) m_dsLoader.getLoader()).setFile(new File(ef.getText())); // tell the loader that a new file has been selected so // that it can attempt to load the header m_dsLoader.setLoader(m_dsLoader.getLoader()); m_dsLoader.newFileSelected(); } catch (Exception ex) { ex.printStackTrace(); } m_parentFrame.dispose(); } }); JButton CancelBut = new JButton("Cancel"); CancelBut.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent e) { m_parentFrame.dispose(); } }); butHolder.add(OKBut); butHolder.add(CancelBut); add(butHolder, BorderLayout.SOUTH); }
/** Sets up a customizer window for a Database Connection */ private void setUpDatabase() { removeAll(); JPanel db = new JPanel(); GridBagLayout gbLayout = new GridBagLayout(); // db.setLayout(new GridLayout(6, 1)); db.setLayout(gbLayout); JLabel urlLab = new JLabel("Database URL", SwingConstants.RIGHT); urlLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); GridBagConstraints gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 0; gbConstraints.gridx = 0; gbLayout.setConstraints(urlLab, gbConstraints); db.add(urlLab); m_dbaseURLText = new EnvironmentField(); m_dbaseURLText.setEnvironment(m_env); /* int width = m_dbaseURLText.getPreferredSize().width; int height = m_dbaseURLText.getPreferredSize().height; m_dbaseURLText.setMinimumSize(new Dimension(width * 2, height)); m_dbaseURLText.setPreferredSize(new Dimension(width * 2, height)); */ m_dbaseURLText.setText(((DatabaseConverter) m_dsLoader.getLoader()).getUrl()); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 0; gbConstraints.gridx = 1; gbConstraints.weightx = 5; gbLayout.setConstraints(m_dbaseURLText, gbConstraints); db.add(m_dbaseURLText); JLabel userLab = new JLabel("Username", SwingConstants.RIGHT); userLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 1; gbConstraints.gridx = 0; gbLayout.setConstraints(userLab, gbConstraints); db.add(userLab); m_userNameText = new EnvironmentField(); m_userNameText.setEnvironment(m_env); /* m_userNameText.setMinimumSize(new Dimension(width * 2, height)); m_userNameText.setPreferredSize(new Dimension(width * 2, height)); */ m_userNameText.setText(((DatabaseConverter) m_dsLoader.getLoader()).getUser()); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 1; gbConstraints.gridx = 1; gbLayout.setConstraints(m_userNameText, gbConstraints); db.add(m_userNameText); JLabel passwordLab = new JLabel("Password ", SwingConstants.RIGHT); passwordLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 2; gbConstraints.gridx = 0; gbLayout.setConstraints(passwordLab, gbConstraints); db.add(passwordLab); m_passwordText = new JPasswordField(); JPanel passwordHolder = new JPanel(); passwordHolder.setLayout(new BorderLayout()); passwordHolder.setBorder(BorderFactory.createEmptyBorder(5, 5, 5, 5)); // passwordHolder.add(passwordLab, BorderLayout.WEST); passwordHolder.add(m_passwordText, BorderLayout.CENTER); /* passwordHolder.setMinimumSize(new Dimension(width * 2, height)); passwordHolder.setPreferredSize(new Dimension(width * 2, height)); */ gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 2; gbConstraints.gridx = 1; gbLayout.setConstraints(passwordHolder, gbConstraints); db.add(passwordHolder); JLabel queryLab = new JLabel("Query", SwingConstants.RIGHT); queryLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 3; gbConstraints.gridx = 0; gbLayout.setConstraints(queryLab, gbConstraints); db.add(queryLab); m_queryText = new EnvironmentField(); m_queryText.setEnvironment(m_env); /* m_queryText.setMinimumSize(new Dimension(width * 2, height)); m_queryText.setPreferredSize(new Dimension(width * 2, height)); */ m_queryText.setText(((DatabaseLoader) m_dsLoader.getLoader()).getQuery()); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 3; gbConstraints.gridx = 1; gbLayout.setConstraints(m_queryText, gbConstraints); db.add(m_queryText); JLabel keyLab = new JLabel("Key columns", SwingConstants.RIGHT); keyLab.setBorder(BorderFactory.createEmptyBorder(0, 5, 0, 0)); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 4; gbConstraints.gridx = 0; gbLayout.setConstraints(keyLab, gbConstraints); db.add(keyLab); m_keyText = new EnvironmentField(); m_keyText.setEnvironment(m_env); /*m_keyText.setMinimumSize(new Dimension(width * 2, height)); m_keyText.setPreferredSize(new Dimension(width * 2, height)); */ m_keyText.setText(((DatabaseLoader) m_dsLoader.getLoader()).getKeys()); gbConstraints = new GridBagConstraints(); gbConstraints.anchor = GridBagConstraints.EAST; gbConstraints.fill = GridBagConstraints.HORIZONTAL; gbConstraints.gridy = 4; gbConstraints.gridx = 1; gbLayout.setConstraints(m_keyText, gbConstraints); db.add(m_keyText); JPanel buttonsP = new JPanel(); buttonsP.setLayout(new FlowLayout()); JButton ok, cancel; buttonsP.add(ok = new JButton("OK")); buttonsP.add(cancel = new JButton("Cancel")); ok.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent evt) { ((DatabaseLoader) m_dsLoader.getLoader()).resetStructure(); ((DatabaseConverter) m_dsLoader.getLoader()).setUrl(m_dbaseURLText.getText()); ((DatabaseConverter) m_dsLoader.getLoader()).setUser(m_userNameText.getText()); ((DatabaseConverter) m_dsLoader.getLoader()) .setPassword(new String(m_passwordText.getPassword())); ((DatabaseLoader) m_dsLoader.getLoader()).setQuery(m_queryText.getText()); ((DatabaseLoader) m_dsLoader.getLoader()).setKeys(m_keyText.getText()); try { m_dsLoader.notifyStructureAvailable( ((DatabaseLoader) m_dsLoader.getLoader()).getStructure()); // database connection has been configured m_dsLoader.setDB(true); } catch (Exception ex) { } if (m_parentFrame != null) { m_parentFrame.dispose(); } } }); cancel.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent evt) { if (m_parentFrame != null) { m_parentFrame.dispose(); } } }); JPanel holderP = new JPanel(); holderP.setLayout(new BorderLayout()); holderP.add(db, BorderLayout.NORTH); holderP.add(buttonsP, BorderLayout.SOUTH); // db.add(buttonsP); JPanel about = m_LoaderEditor.getAboutPanel(); if (about != null) { add(about, BorderLayout.NORTH); } add(holderP, BorderLayout.SOUTH); }