yaoh.wu
7 years ago
16 changed files with 225 additions and 91 deletions
@ -0,0 +1,152 @@ |
|||||||
|
package com.fr.quickeditor.cellquick; |
||||||
|
|
||||||
|
import com.fr.base.Formula; |
||||||
|
import com.fr.base.Style; |
||||||
|
import com.fr.base.TextFormat; |
||||||
|
import com.fr.design.gui.itextfield.UITextField; |
||||||
|
import com.fr.grid.selection.CellSelection; |
||||||
|
import com.fr.quickeditor.CellQuickEditor; |
||||||
|
import com.fr.report.ReportHelper; |
||||||
|
import com.fr.report.cell.DefaultTemplateCellElement; |
||||||
|
import com.fr.stable.ColumnRow; |
||||||
|
import com.fr.stable.StringUtils; |
||||||
|
|
||||||
|
import javax.swing.*; |
||||||
|
import javax.swing.event.DocumentEvent; |
||||||
|
import javax.swing.event.DocumentListener; |
||||||
|
import java.awt.*; |
||||||
|
import java.awt.event.KeyAdapter; |
||||||
|
import java.awt.event.KeyEvent; |
||||||
|
|
||||||
|
/** |
||||||
|
* 公式快速编辑面板,同文本数字编辑拆分 |
||||||
|
* |
||||||
|
* @author yaoh.wu |
||||||
|
* @version 2017年8月7日10点44分 |
||||||
|
* @since 9.0 |
||||||
|
*/ |
||||||
|
public class CellFormulaQuickEditor extends CellQuickEditor { |
||||||
|
//文本域
|
||||||
|
private UITextField stringTextField; |
||||||
|
//编辑状态
|
||||||
|
private boolean isEditing = false; |
||||||
|
|
||||||
|
//编辑的是公式,要保留公式里的这些属性,不然在公式和字符串转化时,就会丢失这些属性设置。
|
||||||
|
private boolean reserveInResult = false; |
||||||
|
private boolean reserveOnWriteOrAnaly = true; |
||||||
|
|
||||||
|
private DocumentListener documentListener = new DocumentListener() { |
||||||
|
@Override |
||||||
|
public void insertUpdate(DocumentEvent e) { |
||||||
|
changeReportPaneCell(stringTextField.getText().trim()); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public void removeUpdate(DocumentEvent e) { |
||||||
|
changeReportPaneCell(stringTextField.getText().trim()); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public void changedUpdate(DocumentEvent e) { |
||||||
|
changeReportPaneCell(stringTextField.getText().trim()); |
||||||
|
} |
||||||
|
|
||||||
|
}; |
||||||
|
|
||||||
|
private CellFormulaQuickEditor() { |
||||||
|
super(); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 详细信息面板 |
||||||
|
*/ |
||||||
|
@Override |
||||||
|
public JComponent createCenterBody() { |
||||||
|
JPanel content = new JPanel(new BorderLayout()); |
||||||
|
content.setBorder(BorderFactory.createEmptyBorder(0, 10, 0, 15)); |
||||||
|
stringTextField = new UITextField(); |
||||||
|
stringTextField.addKeyListener(new KeyAdapter() { |
||||||
|
@Override |
||||||
|
public void keyReleased(KeyEvent e) { |
||||||
|
if (tc != null) { |
||||||
|
tc.getGrid().dispatchEvent(e); |
||||||
|
} |
||||||
|
} |
||||||
|
}); |
||||||
|
content.add(stringTextField, BorderLayout.CENTER); |
||||||
|
return content; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
private void changeReportPaneCell(String tmpText) { |
||||||
|
isEditing = true; |
||||||
|
//refresh一下,如果单元格内有新添加的控件,此时并不知道
|
||||||
|
CellSelection cs1 = (CellSelection) tc.getSelection(); |
||||||
|
ColumnRow columnRow = ColumnRow.valueOf(cs1.getColumn(), cs1.getRow()); |
||||||
|
columnRowTextField.setText(columnRow.toString()); |
||||||
|
cellElement = tc.getEditingElementCase().getTemplateCellElement(cs1.getColumn(), cs1.getRow()); |
||||||
|
|
||||||
|
if (cellElement == null) { |
||||||
|
CellSelection cs = (CellSelection) tc.getSelection(); |
||||||
|
cellElement = new DefaultTemplateCellElement(cs.getColumn(), cs.getRow()); |
||||||
|
tc.getEditingElementCase().addCellElement(cellElement, false); |
||||||
|
} |
||||||
|
if (tmpText != null && (tmpText.length() > 0 && tmpText.charAt(0) == '=')) { |
||||||
|
Formula textFormula = new Formula(tmpText); |
||||||
|
textFormula.setReserveInResult(reserveInResult); |
||||||
|
textFormula.setReserveOnWriteOrAnaly(reserveOnWriteOrAnaly); |
||||||
|
cellElement.setValue(textFormula); |
||||||
|
} else { |
||||||
|
Style style = cellElement.getStyle(); |
||||||
|
if (style != null && style.getFormat() != null && style.getFormat() == TextFormat.getInstance()) { |
||||||
|
cellElement.setValue(tmpText); |
||||||
|
} else { |
||||||
|
cellElement.setValue(ReportHelper.convertGeneralStringAccordingToExcel(tmpText)); |
||||||
|
} |
||||||
|
} |
||||||
|
fireTargetModified(); |
||||||
|
stringTextField.requestFocus(); |
||||||
|
isEditing = false; |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 刷新详细内容 |
||||||
|
*/ |
||||||
|
@Override |
||||||
|
protected void refreshDetails() { |
||||||
|
String str; |
||||||
|
if (cellElement == null) { |
||||||
|
str = StringUtils.EMPTY; |
||||||
|
} else { |
||||||
|
Object value = cellElement.getValue(); |
||||||
|
if (value == null) { |
||||||
|
str = StringUtils.EMPTY; |
||||||
|
} else if (value instanceof Formula) { |
||||||
|
Formula formula = (Formula) value; |
||||||
|
str = formula.getContent(); |
||||||
|
reserveInResult = formula.isReserveInResult(); |
||||||
|
reserveOnWriteOrAnaly = formula.isReserveOnWriteOrAnaly(); |
||||||
|
} else { |
||||||
|
str = value.toString(); |
||||||
|
} |
||||||
|
} |
||||||
|
showText(str); |
||||||
|
stringTextField.setEditable(tc.isSelectedOneCell()); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 显示文本 |
||||||
|
* |
||||||
|
* @param str 文本 |
||||||
|
*/ |
||||||
|
public void showText(String str) { |
||||||
|
// 正在编辑时不处理
|
||||||
|
if (isEditing) { |
||||||
|
return; |
||||||
|
} |
||||||
|
stringTextField.getDocument().removeDocumentListener(documentListener); |
||||||
|
stringTextField.setText(str); |
||||||
|
stringTextField.getDocument().addDocumentListener(documentListener); |
||||||
|
} |
||||||
|
|
||||||
|
} |
Loading…
Reference in new issue