BF [ 1705166 ] Sort tabs working wrongly
https://sourceforge.net/tracker/?func=detail&atid=879332&aid=1705166&group_id=176962 BF [ 1705429 ] Sort tab doesn't have ignore support https://sourceforge.net/tracker/?func=detail&atid=879332&aid=1705429&group_id=176962 BF [ 1705431 ] Sort tab is modifing readonly records https://sourceforge.net/tracker/?func=detail&atid=879332&aid=1705431&group_id=176962 FR [ 1705437 ] Sort Tab - add drag and drop support https://sourceforge.net/tracker/?func=detail&atid=879335&aid=1705437&group_id=176962 BF [ 1705444 ] Sort Tab is navigable ??? https://sourceforge.net/tracker/?func=detail&atid=879332&aid=1705444&group_id=176962 + save optimization - save only what have changed
This commit is contained in:
parent
50ecd95167
commit
2f6d0c9058
|
@ -159,9 +159,11 @@ public final class APanel extends CPanel
|
||||||
} // jbInit
|
} // jbInit
|
||||||
|
|
||||||
private AppsAction aPrevious, aNext, aParent, aDetail, aFirst, aLast,
|
private AppsAction aPrevious, aNext, aParent, aDetail, aFirst, aLast,
|
||||||
aNew, aCopy, aDelete, aIgnore, aPrint,
|
aNew, aCopy, aDelete, aPrint,
|
||||||
aRefresh, aHistory, aAttachment, aChat, aMulti, aFind,
|
aRefresh, aHistory, aAttachment, aChat, aMulti, aFind,
|
||||||
aWorkflow, aZoomAcross, aRequest, aWinSize, aArchive;
|
aWorkflow, aZoomAcross, aRequest, aWinSize, aArchive;
|
||||||
|
/** Ignore Button */
|
||||||
|
public AppsAction aIgnore;
|
||||||
/** Save Button */
|
/** Save Button */
|
||||||
public AppsAction aSave;
|
public AppsAction aSave;
|
||||||
/** Private Lock Button */
|
/** Private Lock Button */
|
||||||
|
@ -1077,6 +1079,11 @@ public final class APanel extends CPanel
|
||||||
m_curAPanelTab = (APanelTab)m_curWinTab.getSelectedComponent();
|
m_curAPanelTab = (APanelTab)m_curWinTab.getSelectedComponent();
|
||||||
m_curAPanelTab.registerAPanel(this);
|
m_curAPanelTab.registerAPanel(this);
|
||||||
m_curAPanelTab.loadData();
|
m_curAPanelTab.loadData();
|
||||||
|
// Consider that APanelTab (e.g. VSortTab) is not navigable - teo_sarca [ 1705444 ]
|
||||||
|
aFirst.setEnabled(false);
|
||||||
|
aPrevious.setEnabled(false);
|
||||||
|
aNext.setEnabled(false);
|
||||||
|
aLast.setEnabled(false);
|
||||||
}
|
}
|
||||||
else // Cur Tab Setting
|
else // Cur Tab Setting
|
||||||
{
|
{
|
||||||
|
@ -1644,6 +1651,11 @@ public final class APanel extends CPanel
|
||||||
private void cmd_ignore()
|
private void cmd_ignore()
|
||||||
{
|
{
|
||||||
m_curGC.stopEditor(false);
|
m_curGC.stopEditor(false);
|
||||||
|
// Ignore changes in APanelTab (e.g. VSortTab) - teo_sarca [ 1705429 ]
|
||||||
|
if (m_curAPanelTab != null)
|
||||||
|
{
|
||||||
|
m_curAPanelTab.loadData();
|
||||||
|
}
|
||||||
m_curTab.dataIgnore();
|
m_curTab.dataIgnore();
|
||||||
m_curGC.dynamicDisplay(0);
|
m_curGC.dynamicDisplay(0);
|
||||||
} // cmd_ignore
|
} // cmd_ignore
|
||||||
|
|
|
@ -18,10 +18,16 @@ package org.compiere.grid;
|
||||||
|
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
import java.awt.event.*;
|
import java.awt.event.*;
|
||||||
|
import java.net.*;
|
||||||
import java.sql.*;
|
import java.sql.*;
|
||||||
|
import java.util.*;
|
||||||
import java.util.logging.*;
|
import java.util.logging.*;
|
||||||
|
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
|
import javax.swing.event.*;
|
||||||
|
|
||||||
import org.compiere.apps.*;
|
import org.compiere.apps.*;
|
||||||
|
import org.compiere.model.MRole;
|
||||||
import org.compiere.swing.*;
|
import org.compiere.swing.*;
|
||||||
import org.compiere.util.*;
|
import org.compiere.util.*;
|
||||||
|
|
||||||
|
@ -29,10 +35,12 @@ import org.compiere.util.*;
|
||||||
* Tab to maintain Order/Sequence
|
* Tab to maintain Order/Sequence
|
||||||
*
|
*
|
||||||
* @author Jorg Janke
|
* @author Jorg Janke
|
||||||
|
* @author Teo Sarca
|
||||||
* @version $Id: VSortTab.java,v 1.2 2006/07/30 00:51:28 jjanke Exp $
|
* @version $Id: VSortTab.java,v 1.2 2006/07/30 00:51:28 jjanke Exp $
|
||||||
*/
|
*/
|
||||||
public class VSortTab extends CPanel implements APanelTab, ActionListener
|
public class VSortTab extends CPanel implements APanelTab
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tab Order Constructor
|
* Tab Order Constructor
|
||||||
*
|
*
|
||||||
|
@ -57,19 +65,19 @@ public class VSortTab extends CPanel implements APanelTab, ActionListener
|
||||||
}
|
}
|
||||||
} // VSortTab
|
} // VSortTab
|
||||||
|
|
||||||
|
/** Logger */
|
||||||
|
static CLogger log = CLogger.getCLogger(VSortTab.class);
|
||||||
private int m_WindowNo;
|
private int m_WindowNo;
|
||||||
|
private int m_AD_Table_ID;
|
||||||
private String m_TableName = null;
|
private String m_TableName = null;
|
||||||
private String m_ColumnSortName= null;
|
private String m_ColumnSortName= null;
|
||||||
private String m_ColumnYesNoName = null;
|
private String m_ColumnYesNoName = null;
|
||||||
private String m_KeyColumnName = null;
|
private String m_KeyColumnName = null;
|
||||||
private String m_IdentifierColumnName = null;
|
private String m_IdentifierColumnName = null;
|
||||||
private boolean m_IdentifierTranslated = false;
|
private boolean m_IdentifierTranslated = false;
|
||||||
private String m_ParentColumnName = null;
|
|
||||||
|
|
||||||
private boolean m_saveSequence = false;
|
private String m_ParentColumnName = null;
|
||||||
private APanel m_aPanel = null;
|
private APanel m_aPanel = null;
|
||||||
/** Logger */
|
|
||||||
private static CLogger log = CLogger.getCLogger(VSortTab.class);
|
|
||||||
|
|
||||||
// UI variables
|
// UI variables
|
||||||
private GridBagLayout mainLayout = new GridBagLayout();
|
private GridBagLayout mainLayout = new GridBagLayout();
|
||||||
|
@ -80,62 +88,45 @@ public class VSortTab extends CPanel implements APanelTab, ActionListener
|
||||||
private CButton bUp = new CButton();
|
private CButton bUp = new CButton();
|
||||||
private CButton bDown = new CButton();
|
private CButton bDown = new CButton();
|
||||||
//
|
//
|
||||||
private DefaultListModel noModel = new DefaultListModel();
|
DefaultListModel noModel = new DefaultListModel()
|
||||||
private DefaultListModel yesModel = new DefaultListModel();
|
{
|
||||||
private JList noList = new JList(noModel);
|
public void addElement(Object obj)
|
||||||
private JList yesList = new JList(yesModel);
|
{
|
||||||
|
Object[] elements = toArray();
|
||||||
|
Arrays.sort(elements);
|
||||||
|
int index = Arrays.binarySearch(elements, obj);
|
||||||
|
if (index < 0)
|
||||||
|
index = -1 * index - 1;
|
||||||
|
if (index > elements.length)
|
||||||
|
super.addElement(obj);
|
||||||
|
else
|
||||||
|
super.add(index, obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void add(int index, Object obj)
|
||||||
|
{
|
||||||
|
addElement(obj);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
DefaultListModel yesModel = new DefaultListModel();
|
||||||
|
DefaultListCellRenderer listRenderer = new DefaultListCellRenderer() {
|
||||||
|
@Override
|
||||||
|
public Component getListCellRendererComponent(JList list, Object value, int index, boolean isSelected, boolean cellHasFocus) {
|
||||||
|
Component c = super.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
|
||||||
|
if (value != null && value instanceof ListItem && !((ListItem)value).isUpdateable()) {
|
||||||
|
Font f = c.getFont();
|
||||||
|
c.setFont(f.deriveFont(f.getStyle() | Font.ITALIC));
|
||||||
|
c.setFocusable(false);
|
||||||
|
}
|
||||||
|
return c;
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
||||||
|
JList noList = new JList(noModel);
|
||||||
|
JList yesList = new JList(yesModel);
|
||||||
private JScrollPane noPane = new JScrollPane(noList);
|
private JScrollPane noPane = new JScrollPane(noList);
|
||||||
private JScrollPane yesPane = new JScrollPane(yesList);
|
private JScrollPane yesPane = new JScrollPane(yesList);
|
||||||
|
|
||||||
/**
|
|
||||||
* Static Layout
|
|
||||||
* @throws Exception
|
|
||||||
*/
|
|
||||||
private void jbInit() throws Exception
|
|
||||||
{
|
|
||||||
this.setLayout(mainLayout);
|
|
||||||
//
|
|
||||||
noLabel.setText("No");
|
|
||||||
yesLabel.setText("Yes");
|
|
||||||
//
|
|
||||||
bAdd.setIcon(Env.getImageIcon("Detail24.gif"));
|
|
||||||
bAdd.setMargin(new Insets(2, 2, 2, 2));
|
|
||||||
bAdd.addActionListener(this);
|
|
||||||
bRemove.setIcon(Env.getImageIcon("Parent24.gif"));
|
|
||||||
bRemove.setMargin(new Insets(2, 2, 2, 2));
|
|
||||||
bRemove.addActionListener(this);
|
|
||||||
bUp.setIcon(Env.getImageIcon("Previous24.gif"));
|
|
||||||
bUp.setMargin(new Insets(2, 2, 2, 2));
|
|
||||||
bUp.addActionListener(this);
|
|
||||||
bDown.setIcon(Env.getImageIcon("Next24.gif"));
|
|
||||||
bDown.setMargin(new Insets(2, 2, 2, 2));
|
|
||||||
bDown.addActionListener(this);
|
|
||||||
//
|
|
||||||
// yesList.setBorder(BorderFactory.createLoweredBevelBorder());
|
|
||||||
yesPane.setPreferredSize(new Dimension(200, 300));
|
|
||||||
yesList.setSelectionMode(ListSelectionModel.MULTIPLE_INTERVAL_SELECTION);
|
|
||||||
// noList.setBorder(BorderFactory.createLoweredBevelBorder());
|
|
||||||
noPane.setPreferredSize(new Dimension(200, 300));
|
|
||||||
noList.setSelectionMode(ListSelectionModel.MULTIPLE_INTERVAL_SELECTION);
|
|
||||||
//
|
|
||||||
this.add(noLabel, new GridBagConstraints(0, 0, 1, 1, 0.0, 0.0
|
|
||||||
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(0, 0, 0, 0), 0, 0));
|
|
||||||
this.add(yesLabel, new GridBagConstraints(2, 0, 1, 1, 0.0, 0.0
|
|
||||||
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(0, 0, 0, 0), 0, 0));
|
|
||||||
this.add(bDown, new GridBagConstraints(3, 2, 1, 1, 0.0, 0.0
|
|
||||||
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(4, 4, 4, 4), 0, 0));
|
|
||||||
this.add(noPane, new GridBagConstraints(0, 1, 1, 3, 0.0, 0.0
|
|
||||||
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(4, 4, 4, 4), 0, 0));
|
|
||||||
this.add(yesPane, new GridBagConstraints(2, 1, 1, 3, 0.0, 0.0
|
|
||||||
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(4, 4, 4, 4), 0, 0));
|
|
||||||
this.add(bUp, new GridBagConstraints(3, 1, 1, 1, 0.0, 0.0
|
|
||||||
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(4, 4, 4, 4), 0, 0));
|
|
||||||
this.add(bRemove, new GridBagConstraints(1, 2, 1, 1, 0.0, 0.0
|
|
||||||
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(4, 4, 4, 4), 0, 0));
|
|
||||||
this.add(bAdd, new GridBagConstraints(1, 1, 1, 1, 0.0, 0.0
|
|
||||||
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(4, 4, 4, 4), 0, 0));
|
|
||||||
} // jbInit
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Dyanamic Init
|
* Dyanamic Init
|
||||||
* @param AD_Table_ID Table No
|
* @param AD_Table_ID Table No
|
||||||
|
@ -144,6 +135,7 @@ public class VSortTab extends CPanel implements APanelTab, ActionListener
|
||||||
*/
|
*/
|
||||||
private void dynInit (int AD_Table_ID, int AD_ColumnSortOrder_ID, int AD_ColumnSortYesNo_ID)
|
private void dynInit (int AD_Table_ID, int AD_ColumnSortOrder_ID, int AD_ColumnSortYesNo_ID)
|
||||||
{
|
{
|
||||||
|
m_AD_Table_ID = AD_Table_ID;
|
||||||
String sql = "SELECT t.TableName, c.AD_Column_ID, c.ColumnName, e.Name," // 1..4
|
String sql = "SELECT t.TableName, c.AD_Column_ID, c.ColumnName, e.Name," // 1..4
|
||||||
+ "c.IsParent, c.IsKey, c.IsIdentifier, c.IsTranslated " // 4..8
|
+ "c.IsParent, c.IsKey, c.IsIdentifier, c.IsTranslated " // 4..8
|
||||||
+ "FROM AD_Table t, AD_Column c, AD_Element e "
|
+ "FROM AD_Table t, AD_Column c, AD_Element e "
|
||||||
|
@ -219,116 +211,130 @@ public class VSortTab extends CPanel implements APanelTab, ActionListener
|
||||||
log.log(Level.SEVERE, sql.toString(), e);
|
log.log(Level.SEVERE, sql.toString(), e);
|
||||||
}
|
}
|
||||||
noLabel.setText(Msg.getMsg(Env.getCtx(), "Available"));
|
noLabel.setText(Msg.getMsg(Env.getCtx(), "Available"));
|
||||||
log.info(m_ColumnSortName);
|
log.fine(m_ColumnSortName);
|
||||||
} // dynInit
|
} // dynInit
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Register APanel
|
* Static Layout
|
||||||
* @param panel panel
|
* @throws Exception
|
||||||
*/
|
*/
|
||||||
public void registerAPanel (APanel panel)
|
private void jbInit() throws Exception
|
||||||
{
|
{
|
||||||
m_aPanel = panel;
|
this.setLayout(mainLayout);
|
||||||
} // registerAPanel
|
//
|
||||||
|
noLabel.setText("No");
|
||||||
|
yesLabel.setText("Yes");
|
||||||
|
|
||||||
/**
|
for (MouseMotionListener mml : noList.getMouseMotionListeners())
|
||||||
* Unregister APanel
|
noList.removeMouseMotionListener(mml);
|
||||||
*/
|
|
||||||
public void unregisterPanel ()
|
|
||||||
{
|
|
||||||
saveData();
|
|
||||||
m_aPanel = null;
|
|
||||||
} // dispoase
|
|
||||||
|
|
||||||
|
for (MouseMotionListener mml : yesList.getMouseMotionListeners())
|
||||||
|
yesList.removeMouseMotionListener(mml);
|
||||||
|
|
||||||
/**************************************************************************
|
MouseListener mouseListener = new MouseAdapter()
|
||||||
* ActionPerformed
|
|
||||||
* @param e event
|
|
||||||
*/
|
|
||||||
public void actionPerformed(ActionEvent e)
|
|
||||||
{
|
{
|
||||||
// ADD ->
|
public void mouseClicked(MouseEvent me)
|
||||||
if (e.getSource() == bAdd)
|
|
||||||
{
|
{
|
||||||
Object objects[] = noList.getSelectedValues();
|
if (me.getClickCount() > 1)
|
||||||
for (int i = 0; i < objects.length; i++)
|
|
||||||
{
|
{
|
||||||
if (objects[i] != null && noModel.removeElement(objects[i]))
|
JList list = (JList)me.getComponent();
|
||||||
{
|
Point p = me.getPoint();
|
||||||
log.config("Add=" + objects[i]);
|
int index = list.locationToIndex(p);
|
||||||
yesModel.addElement(objects[i]);
|
if (index > -1 && list.getCellBounds(index, index).contains(p))
|
||||||
yesList.setSelectedValue(objects[i], true);
|
migrateValueAcrossLists(me);
|
||||||
m_saveSequence = true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
// REMOVE <-
|
yesList.addMouseListener(mouseListener);
|
||||||
else if (e.getSource() == bRemove)
|
noList.addMouseListener(mouseListener);
|
||||||
{
|
//
|
||||||
Object objects[] = yesList.getSelectedValues();
|
yesList.setCellRenderer(listRenderer);
|
||||||
for (int i = 0; i < objects.length; i++)
|
noList.setCellRenderer(listRenderer);
|
||||||
{
|
|
||||||
if (objects[i] != null && yesModel.removeElement(objects[i]))
|
|
||||||
{
|
|
||||||
log.config("Remove=" + objects[i]);
|
|
||||||
noModel.addElement(objects[i]);
|
|
||||||
m_saveSequence = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// UP |
|
|
||||||
else if (e.getSource() == bUp)
|
|
||||||
{
|
|
||||||
int indexes[] = yesList.getSelectedIndices();
|
|
||||||
Object objects[] = yesList.getSelectedValues();
|
|
||||||
for (int i = 0; i < indexes.length; i++)
|
|
||||||
{
|
|
||||||
if (indexes[i] > 0)
|
|
||||||
{
|
|
||||||
Object obj = yesList.getSelectedValue();
|
|
||||||
log.config("Up=" + obj);
|
|
||||||
if (yesModel.removeElement(obj))
|
|
||||||
yesModel.insertElementAt(obj, indexes[i]-1);
|
|
||||||
m_saveSequence = true;
|
|
||||||
indexes[i]--;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
yesList.setSelectedIndices(indexes);
|
|
||||||
}
|
|
||||||
// DOWN |
|
|
||||||
else if (e.getSource() == bDown)
|
|
||||||
{
|
|
||||||
int indexes[] = yesList.getSelectedIndices();
|
|
||||||
for (int i = 0; i < indexes.length; i++)
|
|
||||||
{
|
|
||||||
if (indexes[i] != -1 && indexes[i] < yesModel.size()-1)
|
|
||||||
{
|
|
||||||
Object obj = yesList.getSelectedValue();
|
|
||||||
log.config("Down=" + obj);
|
|
||||||
if (yesModel.removeElement(obj))
|
|
||||||
yesModel.insertElementAt(obj, indexes[i]+1);
|
|
||||||
m_saveSequence = true;
|
|
||||||
indexes[i]++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
yesList.setSelectedIndices(indexes);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Enable explicit Save
|
ActionListener actionListener = new ActionListener()
|
||||||
if (m_saveSequence && m_aPanel != null)
|
{
|
||||||
m_aPanel.aSave.setEnabled(true);
|
public void actionPerformed(ActionEvent ae)
|
||||||
|
{
|
||||||
|
migrateValueAcrossLists(ae);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
} // actionPerformed
|
bAdd.setIcon(Env.getImageIcon("Detail24.gif"));
|
||||||
|
bAdd.setMargin(new Insets(2, 2, 2, 2));
|
||||||
|
bAdd.addActionListener(actionListener);
|
||||||
|
|
||||||
|
bRemove.setIcon(Env.getImageIcon("Parent24.gif"));
|
||||||
|
bRemove.setMargin(new Insets(2, 2, 2, 2));
|
||||||
|
bRemove.addActionListener(actionListener);
|
||||||
|
|
||||||
/**************************************************************************
|
MouseInputListener crossListMouseListener = new DragListener();
|
||||||
* Load Data
|
yesList.addMouseListener(crossListMouseListener);
|
||||||
|
yesList.addMouseMotionListener(crossListMouseListener);
|
||||||
|
noList.addMouseListener(crossListMouseListener);
|
||||||
|
noList.addMouseMotionListener(crossListMouseListener);
|
||||||
|
|
||||||
|
actionListener = new ActionListener()
|
||||||
|
{
|
||||||
|
public void actionPerformed(ActionEvent ae)
|
||||||
|
{
|
||||||
|
migrateValueWithinYesList(ae);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
bUp.setIcon(Env.getImageIcon("Previous24.gif"));
|
||||||
|
bUp.setMargin(new Insets(2, 2, 2, 2));
|
||||||
|
bUp.addActionListener(actionListener);
|
||||||
|
|
||||||
|
bDown.setIcon(Env.getImageIcon("Next24.gif"));
|
||||||
|
bDown.setMargin(new Insets(2, 2, 2, 2));
|
||||||
|
bDown.addActionListener(actionListener);
|
||||||
|
|
||||||
|
MouseMotionListener yesListMouseMotionListener = new MouseMotionAdapter()
|
||||||
|
{
|
||||||
|
public void mouseDragged(MouseEvent me)
|
||||||
|
{
|
||||||
|
JList list = (JList)me.getComponent();
|
||||||
|
Point p = me.getPoint();
|
||||||
|
int index = list.locationToIndex(p);
|
||||||
|
if (index > -1 && list.getCellBounds(index, index).contains(p))
|
||||||
|
migrateValueWithinYesList(me);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
yesList.addMouseMotionListener(yesListMouseMotionListener);
|
||||||
|
|
||||||
|
yesPane.setPreferredSize(new Dimension(200, 300));
|
||||||
|
yesList.setSelectionMode(ListSelectionModel.MULTIPLE_INTERVAL_SELECTION);
|
||||||
|
|
||||||
|
noPane.setPreferredSize(new Dimension(200, 300));
|
||||||
|
noList.setSelectionMode(ListSelectionModel.MULTIPLE_INTERVAL_SELECTION);
|
||||||
|
|
||||||
|
this.add(noLabel, new GridBagConstraints(0, 0, 1, 1, 0.0, 0.0
|
||||||
|
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(0, 0, 0, 0), 0, 0));
|
||||||
|
this.add(yesLabel, new GridBagConstraints(2, 0, 1, 1, 0.0, 0.0
|
||||||
|
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(0, 0, 0, 0), 0, 0));
|
||||||
|
this.add(bDown, new GridBagConstraints(3, 2, 1, 1, 0.0, 0.0
|
||||||
|
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(4, 4, 4, 4), 0, 0));
|
||||||
|
this.add(noPane, new GridBagConstraints(0, 1, 1, 3, 0.0, 0.0
|
||||||
|
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(4, 4, 4, 4), 0, 0));
|
||||||
|
this.add(yesPane, new GridBagConstraints(2, 1, 1, 3, 0.0, 0.0
|
||||||
|
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(4, 4, 4, 4), 0, 0));
|
||||||
|
this.add(bUp, new GridBagConstraints(3, 1, 1, 1, 0.0, 0.0
|
||||||
|
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(4, 4, 4, 4), 0, 0));
|
||||||
|
this.add(bAdd, new GridBagConstraints(1, 1, 1, 1, 0.0, 0.0
|
||||||
|
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(4, 4, 4, 4), 0, 0));
|
||||||
|
this.add(bRemove, new GridBagConstraints(1, 2, 1, 1, 0.0, 0.0
|
||||||
|
,GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets(4, 4, 4, 4), 0, 0));
|
||||||
|
} // jbInit
|
||||||
|
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see org.compiere.grid.APanelTab#loadData()
|
||||||
*/
|
*/
|
||||||
public void loadData()
|
public void loadData()
|
||||||
{
|
{
|
||||||
yesModel.removeAllElements();
|
yesModel.removeAllElements();
|
||||||
noModel.removeAllElements();
|
noModel.removeAllElements();
|
||||||
|
|
||||||
|
boolean isReadWrite = true;
|
||||||
// SELECT t.AD_Field_ID,t.Name,t.SeqNo,t.IsDisplayed FROM AD_Field t WHERE t.AD_Tab_ID=? ORDER BY 4 DESC,3,2
|
// SELECT t.AD_Field_ID,t.Name,t.SeqNo,t.IsDisplayed FROM AD_Field t WHERE t.AD_Tab_ID=? ORDER BY 4 DESC,3,2
|
||||||
// SELECT t.AD_PrintFormatItem_ID,t.Name,t.SeqNo,t.IsPrinted FROM AD_PrintFormatItem t WHERE t.AD_PrintFormat_ID=? ORDER BY 4 DESC,3,2
|
// SELECT t.AD_PrintFormatItem_ID,t.Name,t.SeqNo,t.IsPrinted FROM AD_PrintFormatItem t WHERE t.AD_PrintFormat_ID=? ORDER BY 4 DESC,3,2
|
||||||
// SELECT t.AD_PrintFormatItem_ID,t.Name,t.SortNo,t.IsOrderBy FROM AD_PrintFormatItem t WHERE t.AD_PrintFormat_ID=? ORDER BY 4 DESC,3,2
|
// SELECT t.AD_PrintFormatItem_ID,t.Name,t.SortNo,t.IsOrderBy FROM AD_PrintFormatItem t WHERE t.AD_PrintFormat_ID=? ORDER BY 4 DESC,3,2
|
||||||
|
@ -337,9 +343,10 @@ public class VSortTab extends CPanel implements APanelTab, ActionListener
|
||||||
sql.append("SELECT t.").append(m_KeyColumnName) // 1
|
sql.append("SELECT t.").append(m_KeyColumnName) // 1
|
||||||
.append(m_IdentifierTranslated ? ",tt." : ",t.")
|
.append(m_IdentifierTranslated ? ",tt." : ",t.")
|
||||||
.append(m_IdentifierColumnName) // 2
|
.append(m_IdentifierColumnName) // 2
|
||||||
.append(",t.").append(m_ColumnSortName); // 3
|
.append(",t.").append(m_ColumnSortName) // 3
|
||||||
|
.append(", t.AD_Client_ID, t.AD_Org_ID"); // 4, 5
|
||||||
if (m_ColumnYesNoName != null)
|
if (m_ColumnYesNoName != null)
|
||||||
sql.append(",t.").append(m_ColumnYesNoName); // 4
|
sql.append(",t.").append(m_ColumnYesNoName); // 6
|
||||||
// Tables
|
// Tables
|
||||||
sql.append(" FROM ").append(m_TableName).append( " t");
|
sql.append(" FROM ").append(m_TableName).append( " t");
|
||||||
if (m_IdentifierTranslated)
|
if (m_IdentifierTranslated)
|
||||||
|
@ -352,10 +359,10 @@ public class VSortTab extends CPanel implements APanelTab, ActionListener
|
||||||
// Order
|
// Order
|
||||||
sql.append(" ORDER BY ");
|
sql.append(" ORDER BY ");
|
||||||
if (m_ColumnYesNoName != null)
|
if (m_ColumnYesNoName != null)
|
||||||
sql.append("4 DESC,"); // t.IsDisplayed DESC
|
sql.append("6 DESC,"); // t.IsDisplayed DESC
|
||||||
sql.append("3,2"); // t.SeqNo, tt.Name
|
sql.append("3,2"); // t.SeqNo, tt.Name
|
||||||
int ID = Env.getContextAsInt(Env.getCtx(), m_WindowNo, m_ParentColumnName);
|
int ID = Env.getContextAsInt(Env.getCtx(), m_WindowNo, m_ParentColumnName);
|
||||||
log.config(sql.toString() + " - ID=" + ID);
|
log.fine(sql.toString() + " - ID=" + ID);
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
PreparedStatement pstmt = DB.prepareStatement(sql.toString(), null);
|
PreparedStatement pstmt = DB.prepareStatement(sql.toString(), null);
|
||||||
|
@ -369,14 +376,21 @@ public class VSortTab extends CPanel implements APanelTab, ActionListener
|
||||||
String name = rs.getString(2);
|
String name = rs.getString(2);
|
||||||
int seq = rs.getInt(3);
|
int seq = rs.getInt(3);
|
||||||
boolean isYes = seq != 0;
|
boolean isYes = seq != 0;
|
||||||
|
int AD_Client_ID = rs.getInt(4);
|
||||||
|
int AD_Org_ID = rs.getInt(5);
|
||||||
if (m_ColumnYesNoName != null)
|
if (m_ColumnYesNoName != null)
|
||||||
isYes = rs.getString(4).equals("Y");
|
isYes = rs.getString(6).equals("Y");
|
||||||
|
|
||||||
//
|
//
|
||||||
KeyNamePair pp = new KeyNamePair(key, name);
|
ListItem pp = new ListItem(key, name, seq, isYes, AD_Client_ID, AD_Org_ID);
|
||||||
if (isYes)
|
if (isYes)
|
||||||
yesModel.addElement(pp);
|
yesModel.addElement(pp);
|
||||||
else
|
else
|
||||||
noModel.addElement(pp);
|
noModel.addElement(pp);
|
||||||
|
// If the one item from "Yes" list is readonly make entire tab readonly
|
||||||
|
if (isYes && !pp.isUpdateable()) {
|
||||||
|
isReadWrite = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
rs.close();
|
rs.close();
|
||||||
pstmt.close();
|
pstmt.close();
|
||||||
|
@ -385,45 +399,412 @@ public class VSortTab extends CPanel implements APanelTab, ActionListener
|
||||||
{
|
{
|
||||||
log.log(Level.SEVERE, sql.toString(), e);
|
log.log(Level.SEVERE, sql.toString(), e);
|
||||||
}
|
}
|
||||||
m_saveSequence = false;
|
|
||||||
|
setIsChanged(false);
|
||||||
|
bAdd.setEnabled(isReadWrite);
|
||||||
|
bRemove.setEnabled(isReadWrite);
|
||||||
|
bUp.setEnabled(isReadWrite);
|
||||||
|
bDown.setEnabled(isReadWrite);
|
||||||
|
yesList.setEnabled(isReadWrite);
|
||||||
|
noList.setEnabled(isReadWrite);
|
||||||
} // loadData
|
} // loadData
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Save Data
|
* Set tab change status.
|
||||||
|
* @param value
|
||||||
|
*/
|
||||||
|
private void setIsChanged(boolean value) {
|
||||||
|
if (m_aPanel != null) {
|
||||||
|
m_aPanel.aSave.setEnabled(value);
|
||||||
|
m_aPanel.aIgnore.setEnabled(value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param event
|
||||||
|
*/
|
||||||
|
void migrateValueAcrossLists (AWTEvent event)
|
||||||
|
{
|
||||||
|
Object source = event.getSource();
|
||||||
|
Object[] selObjects = (source == bAdd || source == noList) ?
|
||||||
|
noList.getSelectedValues() : yesList.getSelectedValues();
|
||||||
|
for (int i = 0; i < selObjects.length; i++)
|
||||||
|
{
|
||||||
|
ListItem selObject = (ListItem)selObjects[i];
|
||||||
|
if (selObject == null || !selObject.isUpdateable())
|
||||||
|
continue;
|
||||||
|
|
||||||
|
DefaultListModel lmFrom = (source == bAdd || source == noList) ?
|
||||||
|
noModel : yesModel;
|
||||||
|
DefaultListModel lmTo = (lmFrom == yesModel) ? noModel : yesModel;
|
||||||
|
lmFrom.removeElement(selObject);
|
||||||
|
lmTo.addElement(selObject);
|
||||||
|
|
||||||
|
JList list = (source == bAdd || source == noList) ?
|
||||||
|
yesList : noList;
|
||||||
|
list.setSelectedValue(selObject, true);
|
||||||
|
|
||||||
|
// Enable explicit Save
|
||||||
|
setIsChanged(true);
|
||||||
|
}
|
||||||
|
} // migrateValueAcrossLists
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Move within Yes List
|
||||||
|
* @param event event
|
||||||
|
*/
|
||||||
|
void migrateValueWithinYesList (AWTEvent event)
|
||||||
|
{
|
||||||
|
Object[] selObjects = yesList.getSelectedValues();
|
||||||
|
if (selObjects == null)
|
||||||
|
return;
|
||||||
|
int length = selObjects.length;
|
||||||
|
if (length == 0)
|
||||||
|
return;
|
||||||
|
// Object selObject = selObjects[0];
|
||||||
|
// if (selObject == null)
|
||||||
|
// return;
|
||||||
|
//
|
||||||
|
int[] indices = yesList.getSelectedIndices();
|
||||||
|
//
|
||||||
|
boolean change = false;
|
||||||
|
//
|
||||||
|
Object source = event.getSource();
|
||||||
|
if (source == bUp)
|
||||||
|
{
|
||||||
|
for (int i = 0; i < length; i++) {
|
||||||
|
ListItem selObject = (ListItem)selObjects[i];
|
||||||
|
int index = indices[i];
|
||||||
|
if (index == 0)
|
||||||
|
break;
|
||||||
|
ListItem newObject = (ListItem)yesModel.getElementAt(index - 1);
|
||||||
|
if (!selObject.isUpdateable() || !newObject.isUpdateable())
|
||||||
|
break;
|
||||||
|
yesModel.setElementAt(newObject, index);
|
||||||
|
yesModel.setElementAt(selObject, index - 1);
|
||||||
|
indices[i] = index - 1;
|
||||||
|
change = true;
|
||||||
|
}
|
||||||
|
} // up
|
||||||
|
|
||||||
|
else if (source == bDown)
|
||||||
|
{
|
||||||
|
for (int i = length - 1; i >= 0; i--) {
|
||||||
|
ListItem selObject = (ListItem)selObjects[i];
|
||||||
|
int index = indices[i];
|
||||||
|
if (index >= yesModel.size () - 1)
|
||||||
|
break;
|
||||||
|
ListItem newObject = (ListItem)yesModel.getElementAt(index + 1);
|
||||||
|
if (!selObject.isUpdateable() || !newObject.isUpdateable())
|
||||||
|
break;
|
||||||
|
yesModel.setElementAt(newObject, index);
|
||||||
|
yesModel.setElementAt(selObject, index + 1);
|
||||||
|
yesList.setSelectedIndex(index + 1);
|
||||||
|
indices[i] = index + 1;
|
||||||
|
change = true;
|
||||||
|
}
|
||||||
|
} // down
|
||||||
|
|
||||||
|
else if (source == yesList)
|
||||||
|
{
|
||||||
|
// see org.compiere.grid.VSortTab.DragListener#mouseReleased(MouseEvent)
|
||||||
|
}
|
||||||
|
else
|
||||||
|
log.severe("Unknown source: " + source);
|
||||||
|
//
|
||||||
|
if (change) {
|
||||||
|
yesList.setSelectedIndices(indices);
|
||||||
|
setIsChanged(true);
|
||||||
|
}
|
||||||
|
} // migrateValueWithinYesList
|
||||||
|
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see org.compiere.grid.APanelTab#registerAPanel(APanel)
|
||||||
|
*/
|
||||||
|
public void registerAPanel (APanel panel)
|
||||||
|
{
|
||||||
|
m_aPanel = panel;
|
||||||
|
} // registerAPanel
|
||||||
|
|
||||||
|
|
||||||
|
/** (non-Javadoc)
|
||||||
|
* @see org.compiere.grid.APanelTab#saveData()
|
||||||
*/
|
*/
|
||||||
public void saveData()
|
public void saveData()
|
||||||
{
|
{
|
||||||
if (!m_saveSequence)
|
if (!m_aPanel.aSave.isEnabled())
|
||||||
return;
|
return;
|
||||||
log.info("");
|
log.fine("");
|
||||||
|
boolean ok = true;
|
||||||
|
StringBuffer info = new StringBuffer();
|
||||||
StringBuffer sql = null;
|
StringBuffer sql = null;
|
||||||
// noList - Set SortColumn to null and optional YesNo Column to 'N'
|
// noList - Set SortColumn to null and optional YesNo Column to 'N'
|
||||||
for (int i = 0; i < noModel.getSize(); i++)
|
for (int i = 0; i < noModel.getSize(); i++)
|
||||||
{
|
{
|
||||||
KeyNamePair pp = (KeyNamePair)noModel.getElementAt(i);
|
ListItem pp = (ListItem)noModel.getElementAt(i);
|
||||||
|
if (!pp.isUpdateable())
|
||||||
|
continue;
|
||||||
|
if(pp.getSortNo() == 0 && (m_ColumnYesNoName == null || !pp.isYes()))
|
||||||
|
continue; // no changes
|
||||||
|
//
|
||||||
sql = new StringBuffer();
|
sql = new StringBuffer();
|
||||||
sql.append("UPDATE ").append(m_TableName)
|
sql.append("UPDATE ").append(m_TableName)
|
||||||
.append(" SET ").append(m_ColumnSortName).append("=0");
|
.append(" SET ").append(m_ColumnSortName).append("=0");
|
||||||
if (m_ColumnYesNoName != null)
|
if (m_ColumnYesNoName != null)
|
||||||
sql.append(",").append(m_ColumnYesNoName).append("='N'");
|
sql.append(",").append(m_ColumnYesNoName).append("='N'");
|
||||||
sql.append(" WHERE ").append(m_KeyColumnName).append("=").append(pp.getKey());
|
sql.append(" WHERE ").append(m_KeyColumnName).append("=").append(pp.getKey());
|
||||||
if (DB.executeUpdate(sql.toString(), null) != 1)
|
if (DB.executeUpdate(sql.toString(), null) == 1) {
|
||||||
|
pp.setSortNo(0);
|
||||||
|
pp.setIsYes(false);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
ok = false;
|
||||||
|
if (info.length() > 0)
|
||||||
|
info.append(", ");
|
||||||
|
info.append(pp.getName());
|
||||||
log.log(Level.SEVERE, "NoModel - Not updated: " + m_KeyColumnName + "=" + pp.getKey());
|
log.log(Level.SEVERE, "NoModel - Not updated: " + m_KeyColumnName + "=" + pp.getKey());
|
||||||
}
|
}
|
||||||
|
}
|
||||||
// yesList - Set SortColumn to value and optional YesNo Column to 'Y'
|
// yesList - Set SortColumn to value and optional YesNo Column to 'Y'
|
||||||
|
int index = 0;
|
||||||
for (int i = 0; i < yesModel.getSize(); i++)
|
for (int i = 0; i < yesModel.getSize(); i++)
|
||||||
{
|
{
|
||||||
KeyNamePair pp = (KeyNamePair)yesModel.getElementAt(i);
|
ListItem pp = (ListItem)yesModel.getElementAt(i);
|
||||||
|
if (!pp.isUpdateable())
|
||||||
|
continue;
|
||||||
|
index += 10;
|
||||||
|
if(pp.getSortNo() == index && (m_ColumnYesNoName == null || pp.isYes()))
|
||||||
|
continue; // no changes
|
||||||
|
//
|
||||||
sql = new StringBuffer();
|
sql = new StringBuffer();
|
||||||
sql.append("UPDATE ").append(m_TableName)
|
sql.append("UPDATE ").append(m_TableName)
|
||||||
.append(" SET ").append(m_ColumnSortName).append("=").append(i+1).append("0"); // 10 steps
|
.append(" SET ").append(m_ColumnSortName).append("=").append(index);
|
||||||
if (m_ColumnYesNoName != null)
|
if (m_ColumnYesNoName != null)
|
||||||
sql.append(",").append(m_ColumnYesNoName).append("='Y'");
|
sql.append(",").append(m_ColumnYesNoName).append("='Y'");
|
||||||
sql.append(" WHERE ").append(m_KeyColumnName).append("=").append(pp.getKey());
|
sql.append(" WHERE ").append(m_KeyColumnName).append("=").append(pp.getKey());
|
||||||
if (DB.executeUpdate(sql.toString(), null) != 1)
|
if (DB.executeUpdate(sql.toString(), null) == 1) {
|
||||||
|
pp.setSortNo(index);
|
||||||
|
pp.setIsYes(true);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
ok = false;
|
||||||
|
if (info.length() > 0)
|
||||||
|
info.append(", ");
|
||||||
|
info.append(pp.getName());
|
||||||
log.log(Level.SEVERE, "YesModel - Not updated: " + m_KeyColumnName + "=" + pp.getKey());
|
log.log(Level.SEVERE, "YesModel - Not updated: " + m_KeyColumnName + "=" + pp.getKey());
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
//
|
||||||
|
if (ok) {
|
||||||
|
setIsChanged(false);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
ADialog.error(m_WindowNo, null, "SaveError", info.toString());
|
||||||
|
}
|
||||||
} // saveData
|
} // saveData
|
||||||
|
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see org.compiere.grid.APanelTab#unregisterPanel()
|
||||||
|
*/
|
||||||
|
public void unregisterPanel ()
|
||||||
|
{
|
||||||
|
saveData();
|
||||||
|
m_aPanel = null;
|
||||||
|
} // dispoase
|
||||||
|
|
||||||
|
/**
|
||||||
|
* List Item
|
||||||
|
* @author Teo Sarca
|
||||||
|
*/
|
||||||
|
private class ListItem extends NamePair {
|
||||||
|
private int m_key;
|
||||||
|
private int m_AD_Client_ID;
|
||||||
|
private int m_AD_Org_ID;
|
||||||
|
/** Initial seq number */
|
||||||
|
private int m_sortNo;
|
||||||
|
/** Initial selection flag */
|
||||||
|
private boolean m_isYes;
|
||||||
|
private boolean m_updateable;
|
||||||
|
|
||||||
|
public ListItem(int key, String name, int sortNo, boolean isYes, int AD_Client_ID, int AD_Org_ID) {
|
||||||
|
super(name);
|
||||||
|
this.m_key = key;
|
||||||
|
this.m_AD_Client_ID = AD_Client_ID;
|
||||||
|
this.m_AD_Org_ID = AD_Org_ID;
|
||||||
|
this.m_sortNo = sortNo;
|
||||||
|
this.m_isYes = isYes;
|
||||||
|
this.m_updateable = MRole.getDefault().canUpdate(m_AD_Client_ID, m_AD_Org_ID, m_AD_Table_ID, m_key, false);
|
||||||
|
}
|
||||||
|
public int getKey() {
|
||||||
|
return m_key;
|
||||||
|
}
|
||||||
|
public void setSortNo(int sortNo) {
|
||||||
|
m_sortNo = sortNo;
|
||||||
|
}
|
||||||
|
public int getSortNo() {
|
||||||
|
return m_sortNo;
|
||||||
|
}
|
||||||
|
public void setIsYes(boolean value) {
|
||||||
|
m_isYes = value;
|
||||||
|
}
|
||||||
|
public boolean isYes() {
|
||||||
|
return m_isYes;
|
||||||
|
}
|
||||||
|
public int getAD_Client_ID() {
|
||||||
|
return m_AD_Client_ID;
|
||||||
|
}
|
||||||
|
public int getAD_Org_ID() {
|
||||||
|
return m_AD_Org_ID;
|
||||||
|
}
|
||||||
|
public boolean isUpdateable() {
|
||||||
|
return m_updateable;
|
||||||
|
}
|
||||||
|
@Override
|
||||||
|
public String getID() {
|
||||||
|
return m_key != -1 ? String.valueOf(m_key) : null;
|
||||||
|
}
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return m_key;
|
||||||
|
}
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object obj)
|
||||||
|
{
|
||||||
|
if (obj instanceof ListItem)
|
||||||
|
{
|
||||||
|
ListItem li = (ListItem)obj;
|
||||||
|
return
|
||||||
|
li.getKey() == m_key
|
||||||
|
&& li.getName() != null
|
||||||
|
&& li.getName().equals(getName())
|
||||||
|
&& li.getAD_Client_ID() == m_AD_Client_ID
|
||||||
|
&& li.getAD_Org_ID() == m_AD_Org_ID;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
} // equals
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author eslatis
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
private class DragListener extends MouseInputAdapter
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a VSortTab.DragListener.
|
||||||
|
*/
|
||||||
|
public DragListener()
|
||||||
|
{
|
||||||
|
URL url = VSortTab.class.getResource(cursorName);
|
||||||
|
Toolkit toolkit = Toolkit.getDefaultToolkit();
|
||||||
|
Image image = toolkit.getImage(url);
|
||||||
|
customCursor = toolkit.createCustomCursor(image, new Point(0, 0), "Howdy");
|
||||||
|
}
|
||||||
|
|
||||||
|
/** The cursorName. */
|
||||||
|
private String cursorName = "/org/compiere/images/DragCursor32.gif";
|
||||||
|
|
||||||
|
/** StartList */
|
||||||
|
private JList startList = null;
|
||||||
|
|
||||||
|
/** The startModel. */
|
||||||
|
private DefaultListModel startModel = null;
|
||||||
|
|
||||||
|
/** The selObject. */
|
||||||
|
private Object selObject = null;
|
||||||
|
|
||||||
|
private boolean moved = false;
|
||||||
|
|
||||||
|
/** The customCursor. */
|
||||||
|
private Cursor customCursor;
|
||||||
|
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see javax.swing.event.MouseInputAdapter#mousePressed(java.awt.event.MouseEvent)
|
||||||
|
*/
|
||||||
|
public void mousePressed(MouseEvent me)
|
||||||
|
{
|
||||||
|
JList list = (JList)me.getComponent();
|
||||||
|
Point p = me.getPoint();
|
||||||
|
int index = list.locationToIndex(p);
|
||||||
|
if (index > -1 && list.getCellBounds(index, index).contains(p))
|
||||||
|
{
|
||||||
|
startList = list;
|
||||||
|
startModel = (list == noList) ? noModel : yesModel;
|
||||||
|
selObject = list.getModel().getElementAt(index);
|
||||||
|
}
|
||||||
|
if (list == noList)
|
||||||
|
yesList.clearSelection();
|
||||||
|
else
|
||||||
|
noList.clearSelection();
|
||||||
|
moved = false;
|
||||||
|
} // mousePressed
|
||||||
|
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see javax.swing.event.MouseInputAdapter#mouseDragged(java.awt.event.MouseEvent)
|
||||||
|
*/
|
||||||
|
public void mouseDragged(MouseEvent me)
|
||||||
|
{
|
||||||
|
if (selObject == null || !((ListItem)selObject).isUpdateable()) {
|
||||||
|
moved = false;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
moved = true;
|
||||||
|
if (getCursor() != customCursor)
|
||||||
|
setCursor(customCursor);
|
||||||
|
} // mouseDragged
|
||||||
|
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see javax.swing.event.MouseInputAdapter#mouseReleased(java.awt.event.MouseEvent)
|
||||||
|
*/
|
||||||
|
public void mouseReleased(MouseEvent me)
|
||||||
|
{
|
||||||
|
if (startModel != null && moved)
|
||||||
|
{
|
||||||
|
Point p = me.getPoint();
|
||||||
|
|
||||||
|
JList endList = yesList;
|
||||||
|
DefaultListModel endModel = yesModel;
|
||||||
|
|
||||||
|
if (me.getComponent() == yesList)
|
||||||
|
{
|
||||||
|
if (!yesList.contains (p))
|
||||||
|
{
|
||||||
|
endList = noList;
|
||||||
|
endModel = noModel;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (noList.contains (p))
|
||||||
|
{
|
||||||
|
setCursor(Cursor.getDefaultCursor());
|
||||||
|
moved = false;
|
||||||
|
return; // move within noList
|
||||||
|
}
|
||||||
|
p = SwingUtilities.convertPoint (noList, p, yesList);
|
||||||
|
}
|
||||||
|
int index = endList.locationToIndex(p);
|
||||||
|
if (index > -1) // && endList.getCellBounds(index, index).contains(p))
|
||||||
|
{
|
||||||
|
startModel.removeElement(selObject);
|
||||||
|
endModel.add(index, selObject);
|
||||||
|
//
|
||||||
|
startList.clearSelection();
|
||||||
|
endList.clearSelection();
|
||||||
|
endList.setSelectedValue(selObject, true);
|
||||||
|
//
|
||||||
|
setIsChanged(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
startList = null;
|
||||||
|
startModel = null;
|
||||||
|
selObject = null;
|
||||||
|
moved = false;
|
||||||
|
setCursor(Cursor.getDefaultCursor());
|
||||||
|
} // mouseReleased
|
||||||
|
}
|
||||||
|
|
||||||
} // VSortTab
|
} // VSortTab
|
||||||
|
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 261 B |
Loading…
Reference in New Issue