📄 find.java
字号:
/******************************************************************************
* The contents of this file are subject to the Compiere License Version 1.1
* ("License"); You may not use this file except in compliance with the License
* You may obtain a copy of the License at http://www.compiere.org/license.html
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for
* the specific language governing rights and limitations under the License.
* The Original Code is Compiere ERP & CRM Business Solution
* The Initial Developer of the Original Code is Jorg Janke and ComPiere, Inc.
* Portions created by Jorg Janke are Copyright (C) 1999-2001 Jorg Janke, parts
* created by ComPiere are Copyright (C) ComPiere, Inc.; All Rights Reserved.
* Contributor(s): ______________________________________.
*****************************************************************************/
package org.compiere.apps.search;
import java.awt.*;
import java.awt.event.*;
import java.util.*;
import javax.swing.*;
import javax.swing.table.*;
import javax.swing.event.*;
import java.sql.*;
import java.math.*;
import org.compiere.apps.*;
import org.compiere.grid.ed.*;
import org.compiere.model.*;
import org.compiere.util.*;
import org.compiere.plaf.*;
import org.compiere.swing.*;
/**
* Find Records.
* Based on AD_Find for persistency, query is build to restrict info
*
* @author Jorg Janke
* @version $Id: Find.java,v 1.11 2003/03/05 06:23:59 jjanke Exp $
*/
public final class Find extends JDialog
implements ActionListener, ChangeListener, DataStatusListener
{
/**
* Constructor
* @param owner Frame Dialog Onwer
* @param targetWindowNo WindowNo of target window
* @param targetTab Tab Model
*/
public Find (Frame owner, int targetWindowNo, MTab targetTab)
{
super(owner, Msg.getMsg(Env.getCtx(), "Find") + ": " + targetTab.getName(), true);
Log.trace(Log.l3_Util, "Find", targetTab.getName());
//
m_targetWindowNo = targetWindowNo;
m_query = targetTab.getQuery();
m_targetTab = targetTab;
setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE);
// Required for Column Validation
Env.setContext(Env.getCtx(), m_targetWindowNo, "Find_Table_ID", targetTab.getAD_Table_ID());
// Context for Advanced Search Grid is WINDOW_FIND
Env.setContext(Env.getCtx(), Env.WINDOW_FIND, "Find_Table_ID", targetTab.getAD_Table_ID());
//
try
{
CompiereColor.setBackground(this);
jbInit();
initFind();
}
catch(Exception e)
{
Log.error("Find", e);
}
//
this.getRootPane().setDefaultButton(confirmPanelS.getOKButton());
AEnv.showCenterWindow(owner, this);
} // Find
/** Target Window No */
private int m_targetWindowNo;
/** Target Window MTab */
private MTab m_targetTab;
/** Resulting query */
private MQuery m_query = null;
private int m_total;
private PreparedStatement m_pstmt;
//
private boolean hasValue = false;
private boolean hasDocNo = false;
private boolean hasName = false;
private boolean hasDescription = false;
/** Line in Simple Content */
private int m_sLine = 6;
/** List of VEditors */
private ArrayList m_sEditors = new ArrayList();
/** Target Fields with AD_Column_ID as key */
private Hashtable m_targetFields = new Hashtable();
//
public static final int TABNO = 99; // for GridController
//
private CPanel southPanel = new CPanel();
private BorderLayout southLayout = new BorderLayout();
private StatusBar statusBar = new StatusBar();
private CTabbedPane tabbedPane = new CTabbedPane();
private CPanel advancedPanel = new CPanel();
private BorderLayout advancedLayout = new BorderLayout();
private ConfirmPanel confirmPanelA = new ConfirmPanel(true, true, false, false, false, true);
private JButton bIgnore = new JButton();
private JToolBar toolBar = new JToolBar();
private JButton bSave = new JButton();
private JButton bNew = new JButton();
private JButton bDelete = new JButton();
private GridLayout gridLayout1 = new GridLayout();
private ConfirmPanel confirmPanelS = new ConfirmPanel(true);
private BorderLayout simpleLayout = new BorderLayout();
private CPanel scontentPanel = new CPanel();
private GridBagLayout scontentLayout = new GridBagLayout();
private CPanel simplePanel = new CPanel();
private JLabel valueLabel = new JLabel();
private JLabel nameLabel = new JLabel();
private JLabel descriptionLabel = new JLabel();
private JTextField valueField = new JTextField();
private JTextField nameField = new JTextField();
private JTextField descriptionField = new JTextField();
private JLabel docNoLabel = new JLabel();
private JTextField docNoField = new JTextField();
private Component spaceE;
private Component spaceN;
private Component spaceW;
private Component spaceS;
private JScrollPane advancedScrollPane = new JScrollPane();
private CTable advancedTable = new CTable();
public static final int INDEX_COLUMNNAME = 0;
public static final int INDEX_OPERATOR = 1;
public static final int INDEX_VALUE = 2;
public static final int INDEX_VALUE2 = 3;
/**
* Static Init.
* <pre>
* tabbedPane
* simplePanel
* scontentPanel
* confirmPanelS
* advancedPanel
* toolBar
* GC
* confirmPanelA
* southPanel
* statusBar
* </pre>
* @throws Exception
*/
private void jbInit() throws Exception
{
spaceE = Box.createHorizontalStrut(8);
spaceN = Box.createVerticalStrut(8);
spaceW = Box.createHorizontalStrut(8);
spaceS = Box.createVerticalStrut(8);
bIgnore.setIcon(new ImageIcon(org.compiere.Compiere.class.getResource("images/Ignore24.gif")));
bIgnore.setMargin(new Insets(2, 2, 2, 2));
bIgnore.setToolTipText(Msg.getMsg(Env.getCtx(),"New"));
bIgnore.addActionListener(this);
bSave.setIcon(new ImageIcon(org.compiere.Compiere.class.getResource("images/Save24.gif")));
bSave.setMargin(new Insets(2, 2, 2, 2));
bSave.setToolTipText(Msg.getMsg(Env.getCtx(),"Save"));
bSave.addActionListener(this);
bNew.setIcon(new ImageIcon(org.compiere.Compiere.class.getResource("images/New24.gif")));
bNew.setMargin(new Insets(2, 2, 2, 2));
bNew.setToolTipText(Msg.getMsg(Env.getCtx(),"New"));
bNew.addActionListener(this);
bDelete.setIcon(new ImageIcon(org.compiere.Compiere.class.getResource("images/Delete24.gif")));
bDelete.setMargin(new Insets(2, 2, 2, 2));
bDelete.setToolTipText(Msg.getMsg(Env.getCtx(),"Delete"));
bDelete.addActionListener(this);
//
southPanel.setLayout(southLayout);
valueLabel.setLabelFor(valueField);
valueLabel.setText(Msg.translate(Env.getCtx(),"Value"));
nameLabel.setLabelFor(nameField);
nameLabel.setText(Msg.translate(Env.getCtx(),"Name"));
descriptionLabel.setLabelFor(descriptionField);
descriptionLabel.setText(Msg.translate(Env.getCtx(),"Description"));
valueField.setText("%");
valueField.setColumns(20);
nameField.setText("%");
nameField.setColumns(20);
descriptionField.setText("%");
descriptionField.setColumns(20);
scontentPanel.setToolTipText(Msg.getMsg(Env.getCtx(),"FindTip"));
docNoLabel.setLabelFor(docNoField);
docNoLabel.setText(Msg.translate(Env.getCtx(),"DocumentNo"));
docNoField.setText("%");
docNoField.setColumns(20);
advancedScrollPane.setPreferredSize(new Dimension(450, 150));
southPanel.add(statusBar, BorderLayout.SOUTH);
this.getContentPane().add(southPanel, BorderLayout.SOUTH);
//
scontentPanel.setLayout(scontentLayout);
simplePanel.setLayout(simpleLayout);
simplePanel.add(confirmPanelS, BorderLayout.SOUTH);
simplePanel.add(scontentPanel, BorderLayout.CENTER);
scontentPanel.add(valueLabel, new GridBagConstraints(1, 1, 1, 1, 0.0, 0.0
,GridBagConstraints.EAST, GridBagConstraints.NONE, new Insets(5, 5, 0, 5), 0, 0));
scontentPanel.add(nameLabel, new GridBagConstraints(1, 3, 1, 1, 0.0, 0.0
,GridBagConstraints.EAST, GridBagConstraints.NONE, new Insets(5, 5, 0, 5), 0, 0));
scontentPanel.add(descriptionLabel, new GridBagConstraints(1, 4, 1, 1, 0.0, 0.0
,GridBagConstraints.EAST, GridBagConstraints.NONE, new Insets(5, 5, 5, 5), 0, 0));
scontentPanel.add(valueField, new GridBagConstraints(2, 1, 1, 1, 0.0, 0.0
,GridBagConstraints.WEST, GridBagConstraints.NONE, new Insets(5, 0, 0, 5), 0, 0));
scontentPanel.add(descriptionField, new GridBagConstraints(2, 4, 1, 1, 0.0, 0.0
,GridBagConstraints.WEST, GridBagConstraints.NONE, new Insets(5, 0, 5, 5), 0, 0));
scontentPanel.add(docNoLabel, new GridBagConstraints(1, 2, 1, 1, 0.0, 0.0
,GridBagConstraints.EAST, GridBagConstraints.NONE, new Insets(5, 5, 0, 5), 0, 0));
scontentPanel.add(nameField, new GridBagConstraints(2, 3, 1, 1, 0.0, 0.0
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(5, 0, 0, 5), 0, 0));
scontentPanel.add(docNoField, new GridBagConstraints(2, 2, 1, 1, 0.0, 0.0
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(5, 0, 0, 5), 0, 0));
//
scontentPanel.add(spaceE, new GridBagConstraints(3, 3, 1, 1, 0.0, 0.0
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(10, 10, 10, 10), 0, 0));
scontentPanel.add(spaceN, new GridBagConstraints(2, 0, 1, 1, 0.0, 0.0
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(10, 10, 10, 10), 0, 0));
scontentPanel.add(spaceW, new GridBagConstraints(0, 3, 1, 1, 0.0, 0.0
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(10, 10, 10, 10), 0, 0));
scontentPanel.add(spaceS, new GridBagConstraints(2, 15, 1, 1, 0.0, 0.0
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(10, 10, 10, 10), 0, 0));
//
// tabbedPane.add(simplePanel, Msg.getMsg(Env.getCtx(),"Find"));
tabbedPane.add(simplePanel, Msg.getMsg(Env.getCtx(),"Find"));
//
toolBar.add(bIgnore, null);
toolBar.addSeparator();
toolBar.add(bNew, null);
toolBar.add(bSave, null);
toolBar.add(bDelete, null);
advancedPanel.setLayout(advancedLayout);
advancedPanel.add(toolBar, BorderLayout.NORTH);
advancedPanel.add(confirmPanelA, BorderLayout.SOUTH);
advancedPanel.add(advancedScrollPane, BorderLayout.CENTER);
advancedScrollPane.getViewport().add(advancedTable, null);
// tabbedPane.add(advancedPanel, Msg.getMsg(Env.getCtx(),"Advanced"));
tabbedPane.add(advancedPanel, Msg.getMsg(Env.getCtx(),"Advanced"));
//
this.getContentPane().add(tabbedPane, BorderLayout.CENTER);
//
confirmPanelA.addActionListener(this);
confirmPanelS.addActionListener(this);
} // jbInit
/**
* Dynamic Init.
* set up GridController
*/
private void initFind()
{
Log.trace(Log.l3_Util, "Find.initFind");
// Get Info from target Tab
int size = m_targetTab.getFieldCount();
for (int i = 0; i < size; i++)
{
MField mField = m_targetTab.getField(i);
String columnName = mField.getColumnName();
if (columnName.equals("Value"))
hasValue = true;
else if (columnName.equals("Name"))
hasName = true;
else if (columnName.equals("DocumentNo"))
hasDocNo = true;
else if (columnName.equals("Description"))
hasDescription = true;
else if (mField.isSelectionColumn())
addSelectionColumn (mField);
// TargetFields
m_targetFields.put (new Integer(mField.getAD_Column_ID()), mField);
} // for all target tab fields
// Disable simple query fields
valueLabel.setVisible(hasValue);
valueField.setVisible(hasValue);
if (hasValue)
valueField.addActionListener(this);
docNoLabel.setVisible(hasDocNo);
docNoField.setVisible(hasDocNo);
if (hasDocNo)
docNoField.addActionListener(this);
nameLabel.setVisible(hasName);
nameField.setVisible(hasName);
if (hasName)
nameField.addActionListener(this);
descriptionLabel.setVisible(hasDescription);
descriptionField.setVisible(hasDescription);
if (hasDescription)
descriptionField.addActionListener(this);
// Get Total
m_total = getNoOfRecords(null);
setStatusDB (m_total);
statusBar.setStatusLine("");
tabbedPane.addChangeListener(this);
// Better Labels for OK/Cancel
confirmPanelA.getOKButton().setToolTipText(Msg.getMsg(Env.getCtx(),"QueryEnter"));
confirmPanelA.getCancelButton().setToolTipText(Msg.getMsg(Env.getCtx(),"QueryCancel"));
confirmPanelS.getOKButton().setToolTipText(Msg.getMsg(Env.getCtx(),"QueryEnter"));
confirmPanelS.getCancelButton().setToolTipText(Msg.getMsg(Env.getCtx(),"QueryCancel"));
} // initFind
/**
* Add Selection Column to first Tab
* @param mField field
*/
private void addSelectionColumn (MField mField)
{
Log.trace(Log.l4_Data, "Find.addSelectionColumn", mField.getHeader());
VEditor editor = VEditorFactory.getEditor(mField, false);
editor.setMandatory(false);
editor.setReadWrite(true);
CLabel label = VEditorFactory.getLabel(mField);
//
m_sLine++;
scontentPanel.add(label, new GridBagConstraints(1, m_sLine, 1, 1, 0.0, 0.0
,GridBagConstraints.EAST, GridBagConstraints.NONE, new Insets(5, 5, 5, 5), 0, 0));
scontentPanel.add((Component)editor, new GridBagConstraints(2, m_sLine, 1, 1, 0.0, 0.0
,GridBagConstraints.WEST, GridBagConstraints.NONE, new Insets(5, 0, 5, 5), 0, 0));
m_sEditors.add(editor);
} // addSelectionColumn
/**
* Init Find GridController
*/
private void initFindAdvanced()
{
Log.trace(Log.l3_Util, "Find.initFindAdvanced");
advancedTable.setModel(new DefaultTableModel(0, 4));
advancedTable.setAutoResizeMode(JTable.AUTO_RESIZE_SUBSEQUENT_COLUMNS);
// 0 = Columns
Vector items = new Vector();
for (int c = 0; c < m_targetTab.getFieldCount(); c++)
{
MField field = m_targetTab.getField(c);
if (field.isKey())
;
else
items.add(new ValueNamePair(field.getColumnName(), field.getHeader()));
}
CComboBox columns = new CComboBox(items);
TableColumn tc = advancedTable.getColumnModel().getColumn(INDEX_COLUMNNAME);
tc.setPreferredWidth(150);
tc.setCellEditor(new DefaultCellEditor(columns));
tc.setHeaderValue(Msg.translate(Env.getCtx(), "AD_Column_ID"));
// 1 = Operators
CComboBox compare = new CComboBox(MQuery.OPERATORS);
tc = advancedTable.getColumnModel().getColumn(INDEX_OPERATOR);
tc.setPreferredWidth(40);
tc.setCellEditor(new DefaultCellEditor(compare));
tc.setHeaderValue(Msg.getMsg(Env.getCtx(), "Operator"));
// 2 = QueryValue
tc = advancedTable.getColumnModel().getColumn(INDEX_VALUE);
tc.setCellEditor(new FindValueEditor(this, false));
tc.setCellRenderer(new FindValueRenderer(this, false));
tc.setHeaderValue(Msg.getMsg(Env.getCtx(), "QueryValue"));
// 3 = QueryValue2
tc = advancedTable.getColumnModel().getColumn(INDEX_VALUE2);
tc.setPreferredWidth(50);
tc.setCellEditor(new FindValueEditor(this, true));
tc.setCellRenderer(new FindValueRenderer(this, true));
tc.setHeaderValue(Msg.getMsg(Env.getCtx(), "QueryValue2"));
// No Row - Create one
cmd_new();
} // initFindAdvanced
/**
* Dispose window
*/
public void dispose()
{
Log.trace(Log.l3_Util, "Find.dispose");
// Find SQL
if (m_pstmt != null)
{
try {
m_pstmt.close();
} catch (SQLException e) {}
}
m_pstmt = null;
// TargetFields
if (m_targetFields != null)
m_targetFields.clear();
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -