|
|
@ -8,9 +8,7 @@ import java.awt.event.ActionEvent; |
|
|
|
|
|
|
|
|
|
|
|
import javax.swing.BorderFactory; |
|
|
|
import javax.swing.BorderFactory; |
|
|
|
import javax.swing.JDialog; |
|
|
|
import javax.swing.JDialog; |
|
|
|
import javax.swing.JLayeredPane; |
|
|
|
|
|
|
|
import javax.swing.JPanel; |
|
|
|
import javax.swing.JPanel; |
|
|
|
import javax.swing.JRootPane; |
|
|
|
|
|
|
|
import javax.swing.JTable; |
|
|
|
import javax.swing.JTable; |
|
|
|
import javax.swing.SwingUtilities; |
|
|
|
import javax.swing.SwingUtilities; |
|
|
|
import javax.swing.table.DefaultTableCellRenderer; |
|
|
|
import javax.swing.table.DefaultTableCellRenderer; |
|
|
@ -43,12 +41,15 @@ import com.fr.grid.selection.FloatSelection; |
|
|
|
import com.fr.grid.selection.Selection; |
|
|
|
import com.fr.grid.selection.Selection; |
|
|
|
import com.fr.stable.ColumnRow; |
|
|
|
import com.fr.stable.ColumnRow; |
|
|
|
import com.fr.stable.ColumnRowGroup; |
|
|
|
import com.fr.stable.ColumnRowGroup; |
|
|
|
|
|
|
|
import com.fr.stable.StringUtils; |
|
|
|
import com.fr.write.DMLConfigJob; |
|
|
|
import com.fr.write.DMLConfigJob; |
|
|
|
|
|
|
|
|
|
|
|
public class SmartInsertDBManipulationPane extends DBManipulationPane { |
|
|
|
public class SmartInsertDBManipulationPane extends DBManipulationPane { |
|
|
|
private static final Selection NO_SELECTION = new CellSelection(-1, -1, -1, -1); |
|
|
|
private static final Selection NO_SELECTION = new CellSelection(-1, -1, -1, -1); |
|
|
|
private ElementCasePane ePane; |
|
|
|
private ElementCasePane ePane; |
|
|
|
private static int CELL_GROUP_LIMIT = 6; |
|
|
|
private static int CELL_GROUP_LIMIT = 6; |
|
|
|
|
|
|
|
private static int TOP_PADDING = 30; |
|
|
|
|
|
|
|
private static int LEFT_COLUMN_MAX_WIDTH = 40; |
|
|
|
|
|
|
|
|
|
|
|
public SmartInsertDBManipulationPane(ElementCasePane ePane) { |
|
|
|
public SmartInsertDBManipulationPane(ElementCasePane ePane) { |
|
|
|
super(ValueEditorPaneFactory.extendedCellGroupEditors()); |
|
|
|
super(ValueEditorPaneFactory.extendedCellGroupEditors()); |
|
|
@ -57,6 +58,10 @@ public class SmartInsertDBManipulationPane extends DBManipulationPane { |
|
|
|
|
|
|
|
|
|
|
|
public SmartInsertDBManipulationPane() { |
|
|
|
public SmartInsertDBManipulationPane() { |
|
|
|
super(ValueEditorPaneFactory.extendedCellGroupEditors()); |
|
|
|
super(ValueEditorPaneFactory.extendedCellGroupEditors()); |
|
|
|
|
|
|
|
init(); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private void init() { |
|
|
|
JTemplate jTemplate = DesignerContext.getDesignerFrame().getSelectedJTemplate(); |
|
|
|
JTemplate jTemplate = DesignerContext.getDesignerFrame().getSelectedJTemplate(); |
|
|
|
this.ePane = ((JWorkBook) jTemplate).getEditingElementCasePane(); |
|
|
|
this.ePane = ((JWorkBook) jTemplate).getEditingElementCasePane(); |
|
|
|
} |
|
|
|
} |
|
|
@ -123,7 +128,7 @@ public class SmartInsertDBManipulationPane extends DBManipulationPane { |
|
|
|
} |
|
|
|
} |
|
|
|
}; |
|
|
|
}; |
|
|
|
bPane.setLayout(FRGUIPaneFactory.createBorderLayout()); |
|
|
|
bPane.setLayout(FRGUIPaneFactory.createBorderLayout()); |
|
|
|
bPane.setBorder(BorderFactory.createEmptyBorder(30, 0, 0, 0)); |
|
|
|
bPane.setBorder(BorderFactory.createEmptyBorder(TOP_PADDING, 0, 0, 0)); |
|
|
|
final UIBasicSpinner columnSpinner = new UIBasicSpinner(); |
|
|
|
final UIBasicSpinner columnSpinner = new UIBasicSpinner(); |
|
|
|
final UIBasicSpinner rowSpinner = new UIBasicSpinner(); |
|
|
|
final UIBasicSpinner rowSpinner = new UIBasicSpinner(); |
|
|
|
Component[][] coms = new Component[][] { { new UILabel(Inter.getLocText("RWA-Row_Offset")), rowSpinner },{ new UILabel(Inter.getLocText("RWA-Column_Offset")), columnSpinner } }; |
|
|
|
Component[][] coms = new Component[][] { { new UILabel(Inter.getLocText("RWA-Row_Offset")), rowSpinner },{ new UILabel(Inter.getLocText("RWA-Column_Offset")), columnSpinner } }; |
|
|
@ -289,11 +294,6 @@ public class SmartInsertDBManipulationPane extends DBManipulationPane { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private boolean possibleParentContainer(Container p) { |
|
|
|
|
|
|
|
return p instanceof Dialog || p instanceof BasicPane || |
|
|
|
|
|
|
|
p instanceof JPanel || p instanceof JRootPane || p instanceof JLayeredPane; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private class SmartJTablePane4DB extends SmartJTablePane { |
|
|
|
private class SmartJTablePane4DB extends SmartJTablePane { |
|
|
|
|
|
|
|
|
|
|
|
// 是否是单元格组
|
|
|
|
// 是否是单元格组
|
|
|
@ -329,7 +329,7 @@ public class SmartInsertDBManipulationPane extends DBManipulationPane { |
|
|
|
* set Width |
|
|
|
* set Width |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
TableColumn column0 = table.getColumnModel().getColumn(0); |
|
|
|
TableColumn column0 = table.getColumnModel().getColumn(0); |
|
|
|
column0.setMaxWidth(40); |
|
|
|
column0.setMaxWidth(LEFT_COLUMN_MAX_WIDTH); |
|
|
|
/* |
|
|
|
/* |
|
|
|
* 设置Column 1的Renderer |
|
|
|
* 设置Column 1的Renderer |
|
|
|
*/ |
|
|
|
*/ |
|
|
@ -410,7 +410,7 @@ public class SmartInsertDBManipulationPane extends DBManipulationPane { |
|
|
|
// 要考虑多选的情况 要结合之前的看看 可能是增加 也可能需要减少
|
|
|
|
// 要考虑多选的情况 要结合之前的看看 可能是增加 也可能需要减少
|
|
|
|
ColumnRowGroup add = new ColumnRowGroup(); |
|
|
|
ColumnRowGroup add = new ColumnRowGroup(); |
|
|
|
int removeCount = 0; |
|
|
|
int removeCount = 0; |
|
|
|
if (oriCellSelection != null && sameStartPoint(cellselection, oriCellSelection)) { |
|
|
|
if (oriCellSelection != null && isSameStartPoint(cellselection, oriCellSelection)) { |
|
|
|
removeCount = dealDragSelection(add, cellselection); |
|
|
|
removeCount = dealDragSelection(add, cellselection); |
|
|
|
} else if (cellselection.getSelectedType() == CellSelection.CHOOSE_ROW || cellselection.getSelectedType() == CellSelection.CHOOSE_COLUMN) { |
|
|
|
} else if (cellselection.getSelectedType() == CellSelection.CHOOSE_ROW || cellselection.getSelectedType() == CellSelection.CHOOSE_COLUMN) { |
|
|
|
dealSelectColRow(add, cellselection); |
|
|
|
dealSelectColRow(add, cellselection); |
|
|
@ -441,7 +441,7 @@ public class SmartInsertDBManipulationPane extends DBManipulationPane { |
|
|
|
return newValue; |
|
|
|
return newValue; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private boolean sameStartPoint(CellSelection cs1, CellSelection cs2) { |
|
|
|
private boolean isSameStartPoint(CellSelection cs1, CellSelection cs2) { |
|
|
|
return cs1.getColumn() == cs2.getColumn() && cs1.getRow() == cs2.getRow(); |
|
|
|
return cs1.getColumn() == cs2.getColumn() && cs1.getRow() == cs2.getRow(); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -479,6 +479,7 @@ public class SmartInsertDBManipulationPane extends DBManipulationPane { |
|
|
|
private SmartJTablePaneAction a = new AbstractSmartJTablePaneAction(this, SmartInsertDBManipulationPane.this) { |
|
|
|
private SmartJTablePaneAction a = new AbstractSmartJTablePaneAction(this, SmartInsertDBManipulationPane.this) { |
|
|
|
@Override |
|
|
|
@Override |
|
|
|
public void doOk() { |
|
|
|
public void doOk() { |
|
|
|
|
|
|
|
// 遗留代码
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
@Override |
|
|
@ -507,7 +508,7 @@ public class SmartInsertDBManipulationPane extends DBManipulationPane { |
|
|
|
if (((ColumnValue)value).obj != null) { |
|
|
|
if (((ColumnValue)value).obj != null) { |
|
|
|
this.setText(((ColumnValue)value).obj.toString()); |
|
|
|
this.setText(((ColumnValue)value).obj.toString()); |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
this.setText(""); |
|
|
|
this.setText(StringUtils.EMPTY); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -535,12 +536,12 @@ public class SmartInsertDBManipulationPane extends DBManipulationPane { |
|
|
|
Object cv = ((ColumnValue) value).obj; |
|
|
|
Object cv = ((ColumnValue) value).obj; |
|
|
|
if (cv instanceof ColumnRowGroup && ((ColumnRowGroup)cv).getSize() >= CELL_GROUP_LIMIT) { |
|
|
|
if (cv instanceof ColumnRowGroup && ((ColumnRowGroup)cv).getSize() >= CELL_GROUP_LIMIT) { |
|
|
|
text.setText("[" + Inter.getLocText(new String[]{"Has_Selected", "Classifier-Ge", "Cell"}, |
|
|
|
text.setText("[" + Inter.getLocText(new String[]{"Has_Selected", "Classifier-Ge", "Cell"}, |
|
|
|
new String[]{((ColumnRowGroup)cv).getSize()+"", ""}) + "]"); |
|
|
|
new String[]{((ColumnRowGroup)cv).getSize()+StringUtils.EMPTY, StringUtils.EMPTY}) + "]"); |
|
|
|
tip = cv.toString() + " " + tip; |
|
|
|
tip = cv.toString() + " " + tip; |
|
|
|
} else if (cv != null) { |
|
|
|
} else if (cv != null) { |
|
|
|
text.setText(cv.toString()); |
|
|
|
text.setText(cv.toString()); |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
text.setText(""); |
|
|
|
text.setText(StringUtils.EMPTY); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -568,12 +569,12 @@ public class SmartInsertDBManipulationPane extends DBManipulationPane { |
|
|
|
Object cv = ((ColumnValue) value).obj; |
|
|
|
Object cv = ((ColumnValue) value).obj; |
|
|
|
if (cv instanceof ColumnRowGroup && ((ColumnRowGroup)cv).getSize() >= CELL_GROUP_LIMIT) { |
|
|
|
if (cv instanceof ColumnRowGroup && ((ColumnRowGroup)cv).getSize() >= CELL_GROUP_LIMIT) { |
|
|
|
this.setText("[" + Inter.getLocText(new String[]{"Has_Selected", "Classifier-Ge", "Cell"}, |
|
|
|
this.setText("[" + Inter.getLocText(new String[]{"Has_Selected", "Classifier-Ge", "Cell"}, |
|
|
|
new String[]{((ColumnRowGroup)cv).getSize()+"", ""}) + "]"); |
|
|
|
new String[]{((ColumnRowGroup)cv).getSize()+StringUtils.EMPTY, StringUtils.EMPTY}) + "]"); |
|
|
|
tip = cv.toString() + " " + tip; |
|
|
|
tip = cv.toString() + " " + tip; |
|
|
|
} else if (cv != null) { |
|
|
|
} else if (cv != null) { |
|
|
|
this.setText(cv.toString()); |
|
|
|
this.setText(cv.toString()); |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
this.setText(""); |
|
|
|
this.setText(StringUtils.EMPTY); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|