Package com.commander4j.sys

Source Code of com.commander4j.sys.JInternalFrameLanguageAdmin

package com.commander4j.sys;

import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Component;
import java.awt.Dimension;
import java.awt.Rectangle;
import java.awt.Toolkit;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.sql.PreparedStatement;

import javax.swing.JDesktopPane;
import javax.swing.JOptionPane;
import javax.swing.JPopupMenu;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.ListSelectionModel;
import javax.swing.SwingConstants;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.TableColumn;
import javax.swing.table.TableModel;
import javax.swing.table.TableRowSorter;

import com.commander4j.db.JDBLanguage;
import com.commander4j.db.JDBQuery;
import com.commander4j.gui.JButton4j;
import com.commander4j.gui.JComboBox4j;
import com.commander4j.gui.JLabel4j_std;
import com.commander4j.gui.JMenuItem4j;
import com.commander4j.gui.JTextField4j;
import com.commander4j.tablemodel.JDBLanguageTableModel;
import com.commander4j.util.JExcel;
import com.commander4j.util.JHelp;
import com.commander4j.util.JUtility;
import javax.swing.DefaultComboBoxModel;

public class JInternalFrameLanguageAdmin extends javax.swing.JInternalFrame
{
  private JButton4j jButtonExcel;
  private static final long serialVersionUID = 1;
  private JScrollPane jScrollPane1;
  private JButton4j jButtonEdit;
  private JButton4j jButtonClose;
  private JButton4j jButtonHelp;
  private JButton4j jButtonPrint;
  private JButton4j jButtonDelete;
  private JButton4j jButtonAdd;
  private String resourceKey;
  private JDesktopPane jDesktopPane1;
  private String languageID;
  private JDBLanguage lang = new JDBLanguage(Common.selectedHostID, Common.sessionID);
  private JTextField4j textFieldText;
  private JTextField4j textFieldResourceKey;
  private JTextField4j textFieldMnemonic;
  private JComboBox4j comboBoxLanguageID;
  private String schemaName = Common.hostList.getHost(Common.selectedHostID).getDatabaseParameters().getjdbcDatabaseSchema();
  private JTable jTable1;
  private PreparedStatement listStatement;

  public JInternalFrameLanguageAdmin()
  {
    super();
    setIconifiable(true);
    getContentPane().setBackground(Color.WHITE);
    initGUI();

    JDBQuery query = new JDBQuery(Common.selectedHostID, Common.sessionID);
    query.clear();
    query.addText(JUtility.substSchemaName(schemaName, "select * from {schema}SYS_LANGUAGE where 1=2"));
    query.bindParams();
    listStatement = query.getPreparedStatement();
    populateList();

    final JHelp help = new JHelp();
    help.enableHelpOnButton(jButtonHelp, JUtility.getHelpSetIDforModule("FRM_LANGUAGE_ADMIN"));

    Dimension screen = Toolkit.getDefaultToolkit().getScreenSize();
    Rectangle window = getBounds();
    setLocation((screen.width - window.width) / 2, (screen.height - window.height) / 2);

  }

  private void buildSQL() {

    JDBQuery.closeStatement(listStatement);
   
    String temp = "";

    JDBQuery query = new JDBQuery(Common.selectedHostID, Common.sessionID);
    query.clear();

    temp = "select * from {schema}SYS_LANGUAGE";
    query.addText(JUtility.substSchemaName(schemaName, temp));

    if (textFieldText.getText().equals("") == false)
    {
      query.addParamtoSQL("text like ", "%" + textFieldText.getText() + "%");
    }

    if (textFieldResourceKey.getText().equals("") == false)
    {
      query.addParamtoSQL("resource_key like ", "%" + textFieldResourceKey.getText() + "%");
    }

    if (textFieldMnemonic.getText().equals("") == false)
    {
      query.addParamtoSQL("mnemonic = ", textFieldMnemonic.getText());
    }

    query.addParamtoSQL("language_id = ", ((String) comboBoxLanguageID.getSelectedItem()).toString());

    query.appendSort("resource_key,language_id", "asc");

    query.bindParams();
    listStatement = query.getPreparedStatement();
  }

  private void populateList() {

    JDBLanguage lang1 = new JDBLanguage(Common.selectedHostID, Common.sessionID);

    JDBLanguageTableModel languagetable = new JDBLanguageTableModel(lang1.getLanguageDataResultSet(listStatement));
    TableRowSorter<JDBLanguageTableModel> sorter = new TableRowSorter<JDBLanguageTableModel>(languagetable);

    jTable1.setRowSorter(sorter);
    jTable1.setModel(languagetable);

    jScrollPane1.setViewportView(jTable1);
    jTable1.getTableHeader().setReorderingAllowed(false);
    jTable1.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);

    jTable1.setFont(Common.font_list);

    TableColumn col = jTable1.getColumnModel().getColumn(0);
    col.setPreferredWidth(270);
    col = jTable1.getColumnModel().getColumn(1);
    col.setPreferredWidth(80);
    col = jTable1.getColumnModel().getColumn(2);
    col.setPreferredWidth(520);
    col = jTable1.getColumnModel().getColumn(3);
    col.setPreferredWidth(80);
    jScrollPane1.repaint();
  }

  private void initGUI() {
    try
    {
      this.setPreferredSize(new java.awt.Dimension(979, 535));
      this.setBounds(0, 0, 1005+Common.LFAdjustWidth, 618+Common.LFAdjustHeight);
      setVisible(true);
      this.setClosable(true);
      {
        jDesktopPane1 = new JDesktopPane();
        jDesktopPane1.setBackground(Color.WHITE);
        this.getContentPane().add(jDesktopPane1, BorderLayout.CENTER);
        jDesktopPane1.setPreferredSize(new java.awt.Dimension(917, 504));
        jDesktopPane1.setLayout(null);
        {
          jScrollPane1 = new JScrollPane();
          jScrollPane1.getViewport().setBackground(Common.color_tablebackground);
          jDesktopPane1.add(jScrollPane1);
          jScrollPane1.setBounds(3, 113, 973, 435);
          {
            TableModel jTable1Model = new DefaultTableModel(new String[][] { { "One", "Two" }, { "Three", "Four" } }, new String[] { "Column 1", "Column 2" });
            jTable1 = new JTable();
            jTable1.setDefaultRenderer(Object.class, Common.renderer_table);

            JPopupMenu popupMenu = new JPopupMenu();
            addPopup(jTable1, popupMenu);

            {
              final JMenuItem4j newItemMenuItem = new JMenuItem4j(Common.icon_report);
              newItemMenuItem.addActionListener(new ActionListener() {
                public void actionPerformed(final ActionEvent e) {
                  JLaunchReport.runReport("RPT_LANGUAGE",null,"",null,"");
                }
              });
              newItemMenuItem.setText(lang.get("btn_Print"));
              popupMenu.add(newItemMenuItem);
            }

            {
              final JMenuItem4j newItemMenuItem = new JMenuItem4j(Common.icon_XLS);
              newItemMenuItem.addActionListener(new ActionListener() {
                public void actionPerformed(final ActionEvent e) {
                  export();
                }
              });
              newItemMenuItem.setText(lang.get("btn_Excel"));
              popupMenu.add(newItemMenuItem);
            }

            {
              final JMenuItem4j newItemMenuItem = new JMenuItem4j(Common.icon_add);
              newItemMenuItem.addActionListener(new ActionListener() {
                public void actionPerformed(final ActionEvent e) {
                add();
                }
              });
              newItemMenuItem.setText(lang.get("btn_Add"));
              newItemMenuItem.setEnabled(Common.userList.getUser(Common.sessionID).isModuleAllowed("FRM_ADMIN_LANGUAGE_ADD"));
              popupMenu.add(newItemMenuItem);
            }

            {
              final JMenuItem4j newItemMenuItem = new JMenuItem4j(Common.icon_edit);
              newItemMenuItem.addActionListener(new ActionListener() {
                public void actionPerformed(final ActionEvent e) {
                  editRecord();
                }
              });
              newItemMenuItem.setText(lang.get("btn_Edit"));
              newItemMenuItem.setEnabled(Common.userList.getUser(Common.sessionID).isModuleAllowed("FRM_ADMIN_LANGUAGE_EDIT"));
              popupMenu.add(newItemMenuItem);
            }

            {
              final JMenuItem4j newItemMenuItem = new JMenuItem4j(Common.icon_delete);
              newItemMenuItem.addActionListener(new ActionListener() {
                public void actionPerformed(final ActionEvent e) {
                  delete();
                }
              });
              newItemMenuItem.setText(lang.get("btn_Delete"));
              newItemMenuItem.setEnabled(Common.userList.getUser(Common.sessionID).isModuleAllowed("FRM_ADMIN_LANGUAGE_DELETE"));
              popupMenu.add(newItemMenuItem);
            }

            jScrollPane1.setViewportView(jTable1);
            jTable1.setModel(jTable1Model);
            jTable1.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
            jTable1.getTableHeader().setFont(Common.font_table_header);
            jTable1.getTableHeader().setForeground(Common.color_tableHeaderFont);
            jTable1.addMouseListener(new MouseAdapter() {
              public void mouseClicked(MouseEvent evt) {
                if (evt.getClickCount() == 2)
                {
                  if (Common.userList.getUser(Common.sessionID).isModuleAllowed("FRM_ADMIN_MATERIAL_EDIT") == true)
                  {
                    editRecord();
                  }
                }
              }
            });

          }
          {
            jButtonEdit = new JButton4j(Common.icon_edit);
            jDesktopPane1.add(jButtonEdit);
            jButtonEdit.setText(lang.get("btn_Edit"));
            jButtonEdit.setBounds(246, 78, 120, 30);
            jButtonEdit.setEnabled(Common.userList.getUser(Common.sessionID).isModuleAllowed("FRM_ADMIN_LANGUAGE_EDIT"));
            jButtonEdit.addActionListener(new ActionListener() {
              public void actionPerformed(ActionEvent evt) {
                editRecord();
              }
            });
          }
          {
            jButtonClose = new JButton4j(Common.icon_close);
            jDesktopPane1.add(jButtonClose);
            jButtonClose.setText(lang.get("btn_Close"));
            jButtonClose.setBounds(856, 78, 120, 30);
            jButtonClose.setMnemonic(lang.getMnemonicChar());
            jButtonClose.addActionListener(new ActionListener() {
              public void actionPerformed(ActionEvent evt) {
                jButtonCloseActionPerformed(evt);
              }
            });
          }
          {

            jButtonAdd = new JButton4j(Common.icon_add);
            jDesktopPane1.add(jButtonAdd);
            jButtonAdd.setText(lang.get("btn_Add"));
            jButtonAdd.setBounds(124, 78, 120, 30);
            jButtonAdd.setMnemonic(lang.getMnemonicChar());
            jButtonAdd.setEnabled(Common.userList.getUser(Common.sessionID).isModuleAllowed("FRM_ADMIN_LANGUAGE_ADD"));
            jButtonAdd.addActionListener(new ActionListener() {
              public void actionPerformed(ActionEvent evt) {
                add();
              }
            });
          }
          {
            jButtonDelete = new JButton4j(Common.icon_delete);
            jDesktopPane1.add(jButtonDelete);
            jButtonDelete.setText(lang.get("btn_Delete"));
            jButtonDelete.setBounds(368, 78, 120, 30);
            jButtonDelete.setMnemonic(lang.getMnemonicChar());
            jButtonDelete.setEnabled(Common.userList.getUser(Common.sessionID).isModuleAllowed("FRM_ADMIN_LANGUAGE_DELETE"));
            jButtonDelete.addActionListener(new ActionListener() {
              public void actionPerformed(ActionEvent evt) {
                delete();
              }
            });
          }
          {
            jButtonPrint = new JButton4j(Common.icon_report);
            jDesktopPane1.add(jButtonPrint);
            jButtonPrint.setText(lang.get("btn_Print"));
            jButtonPrint.setBounds(612, 78, 120, 30);
            jButtonPrint.setMnemonic(lang.getMnemonicChar());
            jButtonPrint.addActionListener(new ActionListener() {
              public void actionPerformed(ActionEvent evt) {
                JLaunchReport.runReport("RPT_LANGUAGE",null,"",null,"");
              }
            });
          }
          {
            jButtonHelp = new JButton4j(Common.icon_help);
            jDesktopPane1.add(jButtonHelp);
            jButtonHelp.setText(lang.get("btn_Help"));
            jButtonHelp.setBounds(734, 78, 120, 30);
            jButtonHelp.setMnemonic(lang.getMnemonicChar());
          }
          {
            textFieldText = new JTextField4j();
            textFieldText.setBounds(141, 45, 414, 20);
            jDesktopPane1.add(textFieldText);
            textFieldText.setColumns(10);

            textFieldResourceKey = new JTextField4j();
            textFieldResourceKey.setBounds(685, 12, 280, 20);
            jDesktopPane1.add(textFieldResourceKey);
            textFieldResourceKey.setColumns(10);

            textFieldMnemonic = new JTextField4j();
            textFieldMnemonic.setBounds(685, 45, 35, 20);
            jDesktopPane1.add(textFieldMnemonic);
            textFieldMnemonic.setColumns(10);
          }
          {
            jButtonExcel = new JButton4j(Common.icon_XLS);
            jButtonExcel.addActionListener(new ActionListener() {
              public void actionPerformed(final ActionEvent e) {
                export();
              }
            });

            jButtonExcel.setText(lang.get("btn_Excel"));
            jButtonExcel.setMnemonic(lang.getMnemonicChar());
            jButtonExcel.setBounds(490, 78, 120, 30);
            jDesktopPane1.add(jButtonExcel);
          }

          JButton4j button = new JButton4j(Common.icon_search);
          button.addActionListener(new ActionListener() {
            public void actionPerformed(ActionEvent arg0) {
              buildSQL();
              populateList();
            }
          });
          button.setText(lang.get("btn_Search"));
          button.setMnemonic(lang.getMnemonicChar());
          button.setBounds(3, 78, 120, 30);
          jDesktopPane1.add(button);

          JLabel4j_std label = new JLabel4j_std();
          label.setForeground(Color.RED);
          label.setBackground(Color.GRAY);
          label.setBounds(0, 550, 976, 21);
          jDesktopPane1.add(label);

          JLabel4j_std label_1 = new JLabel4j_std();
          label_1.setHorizontalTextPosition(SwingConstants.RIGHT);
          label_1.setHorizontalAlignment(SwingConstants.RIGHT);
          label_1.setText(lang.get("lbl_Text"));
          label_1.setBounds(8, 45, 115, 21);
          jDesktopPane1.add(label_1);

          JLabel4j_std label_2 = new JLabel4j_std();
          label_2.setHorizontalTextPosition(SwingConstants.RIGHT);
          label_2.setHorizontalAlignment(SwingConstants.RIGHT);
          label_2.setBounds(557, 12, 115, 21);
          label_2.setText(lang.get("lbl_Resource_Key"));
          jDesktopPane1.add(label_2);

          JLabel4j_std label_3 = new JLabel4j_std();
          label_3.setHorizontalTextPosition(SwingConstants.RIGHT);
          label_3.setHorizontalAlignment(SwingConstants.RIGHT);
          label_3.setText(lang.get("lbl_Language_ID"));
          label_3.setBounds(8, 12, 115, 21);
          jDesktopPane1.add(label_3);

          JLabel4j_std label_4 = new JLabel4j_std();
          label_4.setText(lang.get("lbl_Mnemonic"));
          label_4.setHorizontalTextPosition(SwingConstants.RIGHT);
          label_4.setHorizontalAlignment(SwingConstants.RIGHT);
          label_4.setBounds(557, 45, 115, 21);
          jDesktopPane1.add(label_4);

          comboBoxLanguageID = new JComboBox4j();
          comboBoxLanguageID.setModel(new DefaultComboBoxModel(Common.languages));
          comboBoxLanguageID.setPreferredSize(new Dimension(45, 21));
          comboBoxLanguageID.setLightWeightPopupEnabled(true);
          comboBoxLanguageID.setIgnoreRepaint(false);
          comboBoxLanguageID.setEnabled(true);
          comboBoxLanguageID.setEditable(false);
          comboBoxLanguageID.setBounds(141, 12, 72, 23);
          comboBoxLanguageID.addItem("");
          comboBoxLanguageID.addItem("EN");
          comboBoxLanguageID.addItem("DE");
          comboBoxLanguageID.addItem("FR");
          comboBoxLanguageID.addItem("HU");
          comboBoxLanguageID.addItem("IT");
          comboBoxLanguageID.addItem("NL");
          jDesktopPane1.add(comboBoxLanguageID);
        }
      }
    }
    catch (Exception e)
    {
      e.printStackTrace();
    }
  }

  private void delete() {
    int row = jTable1.getSelectedRow();
    if (row >= 0)
    {

      resourceKey = jTable1.getValueAt(row, 0).toString();
      languageID = jTable1.getValueAt(row, 1).toString();

      int n = JOptionPane.showConfirmDialog(Common.mainForm, "Delete Resource Key " + resourceKey + " ?", "Confirm", JOptionPane.YES_NO_OPTION);
      if (n == 0)
      {
        JDBLanguage c = new JDBLanguage(Common.selectedHostID, Common.sessionID);

        c.setKey(resourceKey);
        c.setLanguage(languageID);
        c.delete();
        buildSQL();
        populateList();
      }
    }
  }

  private void export() {
    JDBLanguage language = new JDBLanguage(Common.selectedHostID, Common.sessionID);

    JExcel export = new JExcel();
    buildSQL();
    export.saveAs("language.xls", language.getLanguageDataResultSet(listStatement), Common.mainForm);
  }

  private void add() {
    JDBLanguage ctl = new JDBLanguage(Common.selectedHostID, Common.sessionID);

    resourceKey = JUtility.replaceNullStringwithBlank(JOptionPane.showInputDialog(Common.mainForm, "Enter new Resource Key"));

    if (resourceKey.equals("") == false)
    {
      languageID = JUtility.replaceNullStringwithBlank(JOptionPane.showInputDialog(Common.mainForm, "Enter new Language ID"));
      if (languageID.equals("") == false)
      {
        languageID = languageID.toUpperCase();
        if (ctl.create(resourceKey, languageID, "", "") == false)
        {
          JUtility.errorBeep();
          JOptionPane.showMessageDialog(Common.mainForm, ctl.getErrorMessage(), "Error", JOptionPane.ERROR_MESSAGE);
        }
        else
        {
          buildSQL();
          populateList();
          JLaunchMenu.runForm("FRM_ADMIN_LANGUAGE_EDIT", resourceKey, languageID);
          buildSQL();
          populateList();
        }
      }
    }

  }

  private void editRecord() {
    int row = jTable1.getSelectedRow();
    if (row >= 0)
    {

      resourceKey = jTable1.getValueAt(row, 0).toString();
      languageID = jTable1.getValueAt(row, 1).toString();

      JLaunchMenu.runForm("FRM_ADMIN_LANGUAGE_EDIT", resourceKey, languageID);

      buildSQL();
      populateList();
    }
  }

  private void jButtonCloseActionPerformed(ActionEvent evt) {
    JDBQuery.closeStatement(listStatement);
    dispose();
  }

  private static void addPopup(Component component, final JPopupMenu popup) {
    component.addMouseListener(new MouseAdapter() {
      public void mousePressed(MouseEvent e) {
        if (e.isPopupTrigger())
        {
          showMenu(e);
        }
      }

      public void mouseReleased(MouseEvent e) {
        if (e.isPopupTrigger())
        {
          showMenu(e);
        }
      }

      private void showMenu(MouseEvent e) {
        popup.show(e.getComponent(), e.getX(), e.getY());
      }
    });
  }
}
TOP

Related Classes of com.commander4j.sys.JInternalFrameLanguageAdmin

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.