Browse Source

Merge pull request #254 in DESIGN/design from ~YAOH.WU/design:release/10.0 to release/10.0

* commit 'acb1248c82375f9bdc755661f5369a4f722255b9':
  rename
  复用代码
  REPORT-7941 目录树
  REPORT-6700 REPORT-8957 REPORT-8941 REPORT-7941 REPORT-8392
  REPORT-8941【10.0远程设计权限管理】决策系统用户显示不全
  REPORT-3961 数据列条件分组新增的条件右侧面板不刷新
  无任务
  REPORT-8941 【10.0远程设计权限管理】决策系统用户显示不全
master
yaoh.wu 7 years ago
parent
commit
26a4e90904
  1. 41
      designer-base/src/main/java/com/fr/design/beans/FurtherBasicBeanPane.java
  2. 10
      designer-base/src/main/java/com/fr/design/condition/LiteConditionPane.java
  3. 65
      designer-base/src/main/java/com/fr/design/file/TemplateTreePane.java
  4. 363
      designer-base/src/main/java/com/fr/design/gui/icheckbox/UICheckBox.java
  5. 15
      designer-base/src/main/java/com/fr/design/gui/itree/checkboxtree/CheckBoxTreeCellRenderer.java
  6. 14
      designer-base/src/main/java/com/fr/design/gui/itree/checkboxtree/NullTristateCheckBox.java
  7. 201
      designer-base/src/main/java/com/fr/design/gui/itree/checkboxtree/TristateCheckBox.java
  8. 665
      designer-base/src/main/java/com/fr/design/gui/itree/filetree/EnvFileTree.java
  9. 64
      designer-base/src/main/java/com/fr/design/gui/itree/filetree/FileTreeIcon.java
  10. 98
      designer-base/src/main/java/com/fr/design/gui/itree/filetree/TemplateFileTree.java
  11. 51
      designer-base/src/main/java/com/fr/design/gui/itree/refreshabletree/ExpandMutableTreeNode.java
  12. 80
      designer-base/src/main/java/com/fr/design/gui/itree/refreshabletree/RefreshableJTree.java
  13. 4
      designer-base/src/main/java/com/fr/design/remote/ui/AuthorityEditorPane.java
  14. 126
      designer-base/src/main/java/com/fr/design/remote/ui/UserManagerPane.java
  15. 16
      designer-base/src/main/java/com/fr/design/remote/ui/list/AddedMemberList.java
  16. 2
      designer-base/src/main/java/com/fr/design/remote/ui/list/AddedMemberListCellRender.java
  17. 15
      designer-base/src/main/java/com/fr/design/remote/ui/list/AddingMemberList.java
  18. 13
      designer-base/src/main/java/com/fr/design/remote/ui/list/AddingMemberListCellRender.java
  19. 19
      designer-base/src/main/java/com/fr/design/remote/ui/list/MemberList.java
  20. BIN
      designer-base/src/main/resources/com/fr/design/images/gui/filetree_folder_half_authority_normal.png

41
designer-base/src/main/java/com/fr/design/beans/FurtherBasicBeanPane.java

@ -3,30 +3,31 @@ package com.fr.design.beans;
import com.fr.stable.StringUtils; import com.fr.stable.StringUtils;
/** /**
*
* @author zhou * @author zhou
* @since 2012-5-30下午12:12:42 * @since 2012-5-30下午12:12:42
*/ */
public abstract class FurtherBasicBeanPane<T> extends BasicBeanPane<T> { public abstract class FurtherBasicBeanPane<T> extends BasicBeanPane<T> {
/** /**
* 是否是指定类型 * 是否是指定类型
* @param ob 对象 *
* @return 是否是指定类型 * @param ob 对象
*/ * @return 是否是指定类型
public abstract boolean accept(Object ob); */
public abstract boolean accept(Object ob);
/** /**
* title应该是一个属性不只是对话框的标题时用到与其他组件结合时也会用得到 * title应该是一个属性不只是对话框的标题时用到与其他组件结合时也会用得到
* @return 绥化狂标题 *
*/ * @return 对话框标题
@Deprecated */
public String title4PopupWindow(){ @Override
return StringUtils.EMPTY; public String title4PopupWindow() {
} return StringUtils.EMPTY;
}
/**
* 重置
*/
public abstract void reset();
/**
* 重置
*/
public abstract void reset();
} }

10
designer-base/src/main/java/com/fr/design/condition/LiteConditionPane.java

@ -857,9 +857,10 @@ public abstract class LiteConditionPane<T extends Condition> extends BasicBeanPa
*/ */
@Override @Override
public void populateBean(Condition liteCondition) { public void populateBean(Condition liteCondition) {
if (liteCondition == null){ // liteCondition = null 时清空显示
return; // if (liteCondition == null){
} // return;
// }
// peter: 先删除所有的节点 // peter: 先删除所有的节点
DefaultTreeModel defaultTreeModel = (DefaultTreeModel) this.conditionsTree.getModel(); DefaultTreeModel defaultTreeModel = (DefaultTreeModel) this.conditionsTree.getModel();
ExpandMutableTreeNode rootTreeNode = (ExpandMutableTreeNode) defaultTreeModel.getRoot(); ExpandMutableTreeNode rootTreeNode = (ExpandMutableTreeNode) defaultTreeModel.getRoot();
@ -900,7 +901,8 @@ public abstract class LiteConditionPane<T extends Condition> extends BasicBeanPa
if (liteCondition == null) { if (liteCondition == null) {
try { try {
defaultConditionPane.checkValid(); defaultConditionPane.checkValid();
} catch (Exception e) {//not need } catch (Exception ignored) {
//not need
} }
} }
} }

65
designer-base/src/main/java/com/fr/design/file/TemplateTreePane.java

@ -23,9 +23,13 @@ import com.fr.stable.StableUtils;
import com.fr.stable.project.ProjectConstants; import com.fr.stable.project.ProjectConstants;
import com.fr.workspace.WorkContext; import com.fr.workspace.WorkContext;
import javax.swing.*; import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.ToolTipManager;
import javax.swing.tree.DefaultMutableTreeNode; import javax.swing.tree.DefaultMutableTreeNode;
import java.awt.*; import java.awt.BorderLayout;
import java.awt.Desktop;
import java.awt.Dimension;
import java.awt.event.KeyEvent; import java.awt.event.KeyEvent;
import java.awt.event.KeyListener; import java.awt.event.KeyListener;
import java.awt.event.MouseAdapter; import java.awt.event.MouseAdapter;
@ -59,9 +63,27 @@ public class TemplateTreePane extends JPanel implements FileOperations {
scrollPane.setBorder(null); scrollPane.setBorder(null);
contentPane.add(scrollPane, BorderLayout.CENTER); contentPane.add(scrollPane, BorderLayout.CENTER);
this.reportletsTree.addMouseListener(mouseFileTreeListener);// lx: add /*
// mouse * Tree.MouseAdapter
// listener */
MouseListener mouseFileTreeListener = new MouseAdapter() {
@Override
public void mousePressed(MouseEvent evt) {
if (evt.getClickCount() == 2) {
openSelectedReport();
}
}
@Override
public void mouseReleased(MouseEvent e) {
if (toobarStateChangeListener != null) {
toobarStateChangeListener.stateChange();
}
}
};
// lx: add mouse listener
this.reportletsTree.addMouseListener(mouseFileTreeListener);
this.reportletsTree.addKeyListener(new KeyListener() { this.reportletsTree.addKeyListener(new KeyListener() {
@Override @Override
@ -102,42 +124,21 @@ public class TemplateTreePane extends JPanel implements FileOperations {
reportletsTree.refreshEnv(); reportletsTree.refreshEnv();
} }
/*
* Tree.MouseAdapter
*/
MouseListener mouseFileTreeListener = new MouseAdapter() {
@Override
public void mousePressed(MouseEvent evt) {
if (SwingUtilities.isRightMouseButton(evt)) {
return;
} else if (evt.getClickCount() == 2) {
openSelectedReport();
}
}
public void mouseReleased(MouseEvent e) {
if (toobarStateChangeListener != null) {
toobarStateChangeListener.stateChange();
}
}
};
/** /**
* 打开选中的报表文件 * 打开选中的报表文件
*/ */
@Override
public void openSelectedReport() { public void openSelectedReport() {
String reportPath = reportletsTree.getSelectedTemplatePath(); String reportPath = reportletsTree.getSelectedTemplatePath();
final String selectedFilePath = StableUtils.pathJoin(new String[]{ProjectConstants.REPORTLETS_NAME, reportPath}); final String selectedFilePath = StableUtils.pathJoin(ProjectConstants.REPORTLETS_NAME, reportPath);
DesignerContext.getDesignerFrame().openTemplate(new FileNodeFILE(new FileNode(selectedFilePath, false))); DesignerContext.getDesignerFrame().openTemplate(new FileNodeFILE(new FileNode(selectedFilePath, false)));
} }
/** /**
* 打开文件夹 * 打开文件夹
*/ */
@Override
public void openContainerFolder() { public void openContainerFolder() {
FileNode fn = TemplateTreePane.this.reportletsTree.getSelectedFileNode(); FileNode fn = TemplateTreePane.this.reportletsTree.getSelectedFileNode();
String filePath = StableUtils.pathJoin(WorkContext.getCurrent().getPath(), fn.getEnvPath()); String filePath = StableUtils.pathJoin(WorkContext.getCurrent().getPath(), fn.getEnvPath());
@ -152,6 +153,7 @@ public class TemplateTreePane extends JPanel implements FileOperations {
/** /**
* 刷新 * 刷新
*/ */
@Override
public void refresh() { public void refresh() {
reportletsTree.refresh(); reportletsTree.refresh();
FineLoggerFactory.getLogger().info(Inter.getLocText(new String[]{"File-tree", "Refresh_Successfully"}) + "!"); FineLoggerFactory.getLogger().info(Inter.getLocText(new String[]{"File-tree", "Refresh_Successfully"}) + "!");
@ -160,6 +162,7 @@ public class TemplateTreePane extends JPanel implements FileOperations {
/** /**
* 删除文件 * 删除文件
*/ */
@Override
public void deleteFile() { public void deleteFile() {
String[] reportPaths = reportletsTree.getSelectedTemplatePaths(); String[] reportPaths = reportletsTree.getSelectedTemplatePaths();
if (reportPaths.length == 0) { if (reportPaths.length == 0) {
@ -169,7 +172,7 @@ public class TemplateTreePane extends JPanel implements FileOperations {
return; return;
} }
for (String reportPath : reportPaths) { for (String reportPath : reportPaths) {
FileNodeFILE nodeFile = new FileNodeFILE(new FileNode(StableUtils.pathJoin(new String[]{ProjectConstants.REPORTLETS_NAME, reportPath}), false)); FileNodeFILE nodeFile = new FileNodeFILE(new FileNode(StableUtils.pathJoin(ProjectConstants.REPORTLETS_NAME, reportPath), false));
if (nodeFile.isLocked()) { if (nodeFile.isLocked()) {
if (JOptionPane.showConfirmDialog(DesignerContext.getDesignerFrame(), Inter.getLocText("fileLocked_undeleted"), if (JOptionPane.showConfirmDialog(DesignerContext.getDesignerFrame(), Inter.getLocText("fileLocked_undeleted"),
@ -226,6 +229,7 @@ public class TemplateTreePane extends JPanel implements FileOperations {
} }
@Override
public String getSelectedTemplatePath() { public String getSelectedTemplatePath() {
return reportletsTree.getSelectedTemplatePath(); return reportletsTree.getSelectedTemplatePath();
} }
@ -242,6 +246,7 @@ public class TemplateTreePane extends JPanel implements FileOperations {
* @param suffix 后缀名 * @param suffix 后缀名
* @return 是否存在 * @return 是否存在
*/ */
@Override
public boolean isNameAlreadyExist(String newName, String oldName, String suffix) { public boolean isNameAlreadyExist(String newName, String oldName, String suffix) {
boolean isNameAlreadyExist = false; boolean isNameAlreadyExist = false;

363
designer-base/src/main/java/com/fr/design/gui/icheckbox/UICheckBox.java

@ -5,199 +5,198 @@ import com.fr.design.event.GlobalNameListener;
import com.fr.design.event.GlobalNameObserver; import com.fr.design.event.GlobalNameObserver;
import com.fr.design.event.UIObserver; import com.fr.design.event.UIObserver;
import com.fr.design.event.UIObserverListener; import com.fr.design.event.UIObserverListener;
import com.fr.design.utils.gui.GUICoreUtils;
import com.fr.design.utils.gui.GUIPaintUtils; import com.fr.design.utils.gui.GUIPaintUtils;
import com.fr.stable.Constants; import com.fr.stable.Constants;
import sun.swing.SwingUtilities2; import sun.swing.SwingUtilities2;
import javax.swing.*; import javax.swing.AbstractButton;
import javax.swing.ButtonModel;
import javax.swing.Icon;
import javax.swing.JCheckBox;
import javax.swing.JComponent;
import javax.swing.SwingUtilities;
import javax.swing.plaf.basic.BasicHTML; import javax.swing.plaf.basic.BasicHTML;
import javax.swing.plaf.metal.MetalCheckBoxUI; import javax.swing.plaf.metal.MetalCheckBoxUI;
import javax.swing.text.View; import javax.swing.text.View;
import java.awt.*; import java.awt.Dimension;
import java.awt.Font;
import java.awt.FontMetrics;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.Insets;
import java.awt.Rectangle;
import java.awt.RenderingHints;
import java.awt.event.ItemEvent; import java.awt.event.ItemEvent;
import java.awt.event.ItemListener; import java.awt.event.ItemListener;
public class UICheckBox extends JCheckBox implements UIObserver, GlobalNameObserver { public class UICheckBox extends JCheckBox implements UIObserver, GlobalNameObserver {
private UIObserverListener uiObserverListener; private UIObserverListener uiObserverListener;
private GlobalNameListener globalNameListener = null; private GlobalNameListener globalNameListener = null;
private String checkboxName = ""; private String checkboxName = "";
public UICheckBox(String string) { public UICheckBox(String string) {
super(string); super(string);
setUI(new UICheckBoxUI()); setUI(new UICheckBoxUI());
initListener(); initListener();
} }
public UICheckBox() { public UICheckBox() {
super(); super();
setUI(new UICheckBoxUI()); setUI(new UICheckBoxUI());
initListener(); initListener();
} }
public UICheckBox(String locText, boolean b) { public UICheckBox(String locText, boolean b) {
super(locText, b); super(locText, b);
setUI(new UICheckBoxUI()); setUI(new UICheckBoxUI());
initListener(); initListener();
} }
public UICheckBox(String text, Icon icon) { public UICheckBox(String text, Icon icon) {
super(text, icon); super(text, icon);
setUI(new UICheckBoxUI()); setUI(new UICheckBoxUI());
initListener(); initListener();
} }
private void initListener() { private void initListener() {
if (shouldResponseChangeListener()) { if (shouldResponseChangeListener()) {
this.addItemListener(new ItemListener() { this.addItemListener(new ItemListener() {
@Override @Override
public void itemStateChanged(ItemEvent e) { public void itemStateChanged(ItemEvent e) {
if (uiObserverListener == null) { if (uiObserverListener == null) {
return; return;
} }
if (globalNameListener != null && shouldResponseNameListener()) { if (globalNameListener != null && shouldResponseNameListener()) {
globalNameListener.setGlobalName(checkboxName); globalNameListener.setGlobalName(checkboxName);
} }
uiObserverListener.doChange(); uiObserverListener.doChange();
} }
}); });
} }
} }
/** /**
* 给组件登记一个观察者监听事件 * 给组件登记一个观察者监听事件
* *
* @param listener 观察者监听事件 * @param listener 观察者监听事件
*/ */
public void registerChangeListener(UIObserverListener listener) { @Override
this.uiObserverListener = listener; public void registerChangeListener(UIObserverListener listener) {
} this.uiObserverListener = listener;
}
public void setGlobalName(String name) {
checkboxName = name; @Override
} public void setGlobalName(String name) {
checkboxName = name;
/** }
* 组件是否需要响应添加的观察者事件
* /**
* @return 如果需要响应观察者事件则返回true否则返回false * 组件是否需要响应添加的观察者事件
*/ *
public boolean shouldResponseChangeListener() { * @return 如果需要响应观察者事件则返回true否则返回false
return true; */
} @Override
public boolean shouldResponseChangeListener() {
/** return true;
* 注册观察者监听事件 }
* @param listener 观察者监听事件
*/ /**
public void registerNameListener(GlobalNameListener listener) { * 注册观察者监听事件
globalNameListener = listener; *
} * @param listener 观察者监听事件
*/
/** @Override
* 组件是否需要响应观察者事件 public void registerNameListener(GlobalNameListener listener) {
* @return 如果需要响应观察者事件则返回true否则返回false globalNameListener = listener;
*/ }
public boolean shouldResponseNameListener() {
return true; /**
} * 组件是否需要响应观察者事件
*
private class UICheckBoxUI extends MetalCheckBoxUI { * @return 如果需要响应观察者事件则返回true否则返回false
public void paint(Graphics g, JComponent c) { */
synchronized (this) { @Override
AbstractButton b = (AbstractButton) c; public boolean shouldResponseNameListener() {
ButtonModel model = b.getModel(); return true;
Dimension size = c.getSize(); }
Font f = c.getFont();
g.setFont(f); private class UICheckBoxUI extends MetalCheckBoxUI {
FontMetrics fm = SwingUtilities2.getFontMetrics(c, g, f); @Override
public void paint(Graphics g, JComponent c) {
Rectangle viewRect = new Rectangle(size); synchronized (this) {
Rectangle iconRect = new Rectangle(); AbstractButton b = (AbstractButton) c;
Rectangle textRect = new Rectangle(); ButtonModel model = b.getModel();
Dimension size = c.getSize();
Insets i = c.getInsets(); Font f = c.getFont();
viewRect.x += i.left; g.setFont(f);
viewRect.y += i.top; FontMetrics fm = SwingUtilities2.getFontMetrics(c, g, f);
viewRect.width -= (i.right + viewRect.x);
viewRect.height -= (i.bottom + viewRect.y); Rectangle viewRect = new Rectangle(size);
Rectangle iconRect = new Rectangle();
Icon altIcon = b.getIcon(); Rectangle textRect = new Rectangle();
String text = SwingUtilities.layoutCompoundLabel( Insets i = c.getInsets();
c, fm, b.getText(), altIcon != null ? altIcon : getDefaultIcon(), viewRect.x += i.left;
b.getVerticalAlignment(), b.getHorizontalAlignment(), viewRect.y += i.top;
b.getVerticalTextPosition(), b.getHorizontalTextPosition(), viewRect.width -= (i.right + viewRect.x);
viewRect, iconRect, textRect, b.getIconTextGap()); viewRect.height -= (i.bottom + viewRect.y);
// fill background Icon altIcon = b.getIcon();
if (c.isOpaque()) {
g.setColor(b.getBackground()); String text = SwingUtilities.layoutCompoundLabel(
g.fillRect(0, 0, size.width, size.height); c, fm, b.getText(), altIcon != null ? altIcon : getDefaultIcon(),
} b.getVerticalAlignment(), b.getHorizontalAlignment(),
b.getVerticalTextPosition(), b.getHorizontalTextPosition(),
Graphics2D g2d = (Graphics2D) g; viewRect, iconRect, textRect, b.getIconTextGap());
g2d.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
if ( model.isSelected()) { // fill background
GUIPaintUtils.fillPaint(g2d, iconRect.x, iconRect.y, iconRect.width, iconRect.height,false, Constants.NULL, if (c.isOpaque()) {
model.isEnabled() ? UIConstants.CHECKBOX_HOVER_SELECTED : UIConstants.DISABLED_ICON_COLOR, 0); g.setColor(b.getBackground());
} else if (model.isRollover() && ! model.isSelected()) { g.fillRect(0, 0, size.width, size.height);
}
Graphics2D g2d = (Graphics2D) g;
g2d.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
if (model.isSelected()) {
GUIPaintUtils.fillPaint(g2d, iconRect.x, iconRect.y, iconRect.width, iconRect.height, false, Constants.NULL,
model.isEnabled() ? UIConstants.CHECKBOX_HOVER_SELECTED : UIConstants.DISABLED_ICON_COLOR, 0);
} else if (model.isRollover() && !model.isSelected()) {
g.setColor(UIConstants.CHECKBOX_HOVER_SELECTED); g.setColor(UIConstants.CHECKBOX_HOVER_SELECTED);
g2d.drawRoundRect(iconRect.x, iconRect.y, iconRect.width - 1, iconRect.height - 1, UIConstants.ARC, UIConstants.ARC); g2d.drawRoundRect(iconRect.x, iconRect.y, iconRect.width - 1, iconRect.height - 1, UIConstants.ARC, UIConstants.ARC);
}else{ } else {
g.setColor(UIConstants.LINE_COLOR); g.setColor(UIConstants.LINE_COLOR);
g2d.drawRoundRect(iconRect.x, iconRect.y, iconRect.width - 1, iconRect.height - 1, UIConstants.ARC, UIConstants.ARC); g2d.drawRoundRect(iconRect.x, iconRect.y, iconRect.width - 1, iconRect.height - 1, UIConstants.ARC, UIConstants.ARC);
} }
if (model.isSelected()) { if (model.isSelected()) {
UIConstants.YES_ICON.paintIcon(c, g, iconRect.x + 2, iconRect.y + 2); UIConstants.YES_ICON.paintIcon(c, g, iconRect.x + 2, iconRect.y + 2);
} }
g2d.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_OFF); g2d.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_OFF);
// Draw the Text // Draw the Text
drawLine(text, g, b, c, textRect, fm); drawLine(text, g, b, c, textRect, fm);
} }
} }
private void drawLine(String text, Graphics g, AbstractButton b, JComponent c, Rectangle textRect, FontMetrics fm) { private void drawLine(String text, Graphics g, AbstractButton b, JComponent c, Rectangle textRect, FontMetrics fm) {
if (text != null) { if (text != null) {
View v = (View) c.getClientProperty(BasicHTML.propertyKey); View v = (View) c.getClientProperty(BasicHTML.propertyKey);
if (v != null) { if (v != null) {
v.paint(g, textRect); v.paint(g, textRect);
} else { } else {
int mnemIndex = b.getDisplayedMnemonicIndex(); int mnemIndex = b.getDisplayedMnemonicIndex();
if (model.isEnabled()) { if (model.isEnabled()) {
g.setColor(b.getForeground()); g.setColor(b.getForeground());
} else { } else {
g.setColor(getDisabledTextColor()); g.setColor(getDisabledTextColor());
} }
SwingUtilities2.drawStringUnderlineCharAt(c, g, text, SwingUtilities2.drawStringUnderlineCharAt(c, g, text,
mnemIndex, textRect.x, textRect.y + fm.getAscent()); mnemIndex, textRect.x, textRect.y + fm.getAscent());
} }
} }
} }
} }
/**
* 测试
* @param args 参数
*/
public static void main(String... args) {
LayoutManager layoutManager = null;
JFrame jf = new JFrame("test");
jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
JPanel content = (JPanel) jf.getContentPane();
content.setLayout(layoutManager);
UICheckBox bb = new UICheckBox("sdf");
bb.setEnabled(false);
bb.setBounds(20, 20, bb.getPreferredSize().width, bb.getPreferredSize().height);
content.add(bb);
GUICoreUtils.centerWindow(jf);
jf.setSize(400, 400);
jf.setVisible(true);
}
} }

15
designer-base/src/main/java/com/fr/design/gui/itree/checkboxtree/CheckBoxTreeCellRenderer.java

@ -10,12 +10,17 @@ import com.fr.design.gui.icheckbox.UICheckBox;
import com.fr.design.gui.ilable.UILabel; import com.fr.design.gui.ilable.UILabel;
import com.fr.design.layout.FRGUIPaneFactory; import com.fr.design.layout.FRGUIPaneFactory;
import javax.swing.*; import javax.swing.BorderFactory;
import javax.swing.JComponent;
import javax.swing.JTree;
import javax.swing.border.Border; import javax.swing.border.Border;
import javax.swing.border.EmptyBorder; import javax.swing.border.EmptyBorder;
import javax.swing.tree.TreeCellRenderer; import javax.swing.tree.TreeCellRenderer;
import javax.swing.tree.TreePath; import javax.swing.tree.TreePath;
import java.awt.*; import java.awt.BorderLayout;
import java.awt.Component;
import java.awt.Dimension;
import java.awt.Point;
import java.awt.event.MouseEvent; import java.awt.event.MouseEvent;
import java.io.Serializable; import java.io.Serializable;
@ -77,10 +82,10 @@ public class CheckBoxTreeCellRenderer extends NullPanel implements TreeCellRende
_checkBox.setEnabled(((CheckBoxTree) tree).isCheckBoxEnabled() && ((CheckBoxTree) tree).isCheckBoxEnabled(path)); _checkBox.setEnabled(((CheckBoxTree) tree).isCheckBoxEnabled() && ((CheckBoxTree) tree).isCheckBoxEnabled(path));
if (selectionModel.isPathSelected(path, selectionModel.isDigIn())) { if (selectionModel.isPathSelected(path, selectionModel.isDigIn())) {
_checkBox.setState(TristateCheckBox.SELECTED); _checkBox.setState(TristateCheckBox.SELECTED);
_checkBox.setSelected(true); } else if (selectionModel.isDigIn() && selectionModel.isPartiallySelected(path)) {
_checkBox.setState(TristateCheckBox.DO_NOT_CARE);
} else { } else {
_checkBox.setState(selectionModel.isDigIn() && selectionModel.isPartiallySelected(path) ? null : TristateCheckBox.NOT_SELECTED); _checkBox.setState(TristateCheckBox.NOT_SELECTED);
_checkBox.setSelected(false);
} }
} }
} }

14
designer-base/src/main/java/com/fr/design/gui/itree/checkboxtree/NullTristateCheckBox.java

@ -42,10 +42,7 @@ import javax.swing.Icon;
* </code></pre> * </code></pre>
* *
* @see NullPanel * @see NullPanel
* @see NullButton
* @see NullJideButton
* @see NullLabel * @see NullLabel
* @see NullRadioButton
*/ */
public class NullTristateCheckBox extends TristateCheckBox { public class NullTristateCheckBox extends TristateCheckBox {
public NullTristateCheckBox() { public NullTristateCheckBox() {
@ -63,7 +60,7 @@ public class NullTristateCheckBox extends TristateCheckBox {
super(text, icon, initial); super(text, icon, initial);
} }
// @Override @Override
public void updateUI() { public void updateUI() {
clearAttribute(); clearAttribute();
} }
@ -73,4 +70,13 @@ public class NullTristateCheckBox extends TristateCheckBox {
setBackground(null); setBackground(null);
setForeground(null); setForeground(null);
} }
@Override
protected State getNextState(State current) {
if (SELECTED.equals(current)) {
return NOT_SELECTED;
} else {
return SELECTED;
}
}
} }

201
designer-base/src/main/java/com/fr/design/gui/itree/checkboxtree/TristateCheckBox.java

@ -1,28 +1,44 @@
package com.fr.design.gui.itree.checkboxtree; package com.fr.design.gui.itree.checkboxtree;
import java.awt.event.ActionEvent; import com.fr.design.constants.UIConstants;
import java.awt.event.ActionListener; import com.fr.design.gui.icheckbox.UICheckBox;
import java.awt.event.ItemListener; import com.fr.design.utils.gui.GUIPaintUtils;
import java.awt.event.MouseAdapter; import com.fr.stable.Constants;
import java.awt.event.MouseEvent; import sun.swing.SwingUtilities2;
import java.awt.event.MouseListener;
import javax.swing.AbstractAction; import javax.swing.AbstractAction;
import javax.swing.AbstractButton;
import javax.swing.ActionMap; import javax.swing.ActionMap;
import javax.swing.ButtonGroup; import javax.swing.ButtonGroup;
import javax.swing.ButtonModel; import javax.swing.ButtonModel;
import javax.swing.Icon; import javax.swing.Icon;
import javax.swing.JComponent;
import javax.swing.SwingUtilities; import javax.swing.SwingUtilities;
import javax.swing.event.ChangeListener; import javax.swing.event.ChangeListener;
import javax.swing.plaf.ActionMapUIResource; import javax.swing.plaf.ActionMapUIResource;
import javax.swing.plaf.basic.BasicHTML;
import com.fr.design.gui.icheckbox.UICheckBox; import javax.swing.plaf.metal.MetalCheckBoxUI;
import javax.swing.text.View;
import java.awt.Dimension;
import java.awt.Font;
import java.awt.FontMetrics;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.Insets;
import java.awt.Rectangle;
import java.awt.RenderingHints;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.ItemListener;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.awt.event.MouseListener;
/** /**
* Maintenance tip - There were some tricks to getting this code * Maintenance tip - There were some tricks to getting this code
* working: * working:
* <p/> * <p/>
* 1. You have to overwite addMouseListener() to do nothing * 1. You have to overwrite addMouseListener() to do nothing
* 2. You have to add a mouse event on mousePressed by calling * 2. You have to add a mouse event on mousePressed by calling
* super.addMouseListener() * super.addMouseListener()
* 3. You have to replace the UIActionMap for the keyboard event * 3. You have to replace the UIActionMap for the keyboard event
@ -41,21 +57,30 @@ public class TristateCheckBox extends UICheckBox {
* This is a type-safe enumerated type * This is a type-safe enumerated type
*/ */
public static class State { public static class State {
private State() { private String type;
private State(String type) {
this.type = type;
}
@Override
public String toString() {
return this.type;
} }
} }
public static final State NOT_SELECTED = new State(); public static final State NOT_SELECTED = new State("NOT_SELECTED");
public static final State SELECTED = new State(); public static final State SELECTED = new State("SELECTED");
public static final State DONT_CARE = new State(); public static final State DO_NOT_CARE = new State("DO_NOT_CARE");
private final TristateDecorator model; private final TristateDecorator model;
public TristateCheckBox(String text, Icon icon, State initial) { public TristateCheckBox(String text, Icon icon, State initial) {
super(text, icon); super(text, icon);
setUI(new TristateCheckBoxUI());
// Add a listener for when the mouse is pressed // Add a listener for when the mouse is pressed
super.addMouseListener(new MouseAdapter() { super.addMouseListener(new MouseAdapter() {
// @Override @Override
public void mousePressed(MouseEvent e) { public void mousePressed(MouseEvent e) {
grabFocus(); grabFocus();
model.setState(getNextState(model.getState())); model.setState(getNextState(model.getState()));
@ -64,6 +89,7 @@ public class TristateCheckBox extends UICheckBox {
// Reset the keyboard action map // Reset the keyboard action map
ActionMap map = new ActionMapUIResource(); ActionMap map = new ActionMapUIResource();
map.put("pressed", new AbstractAction() { map.put("pressed", new AbstractAction() {
@Override
public void actionPerformed(ActionEvent e) { public void actionPerformed(ActionEvent e) {
grabFocus(); grabFocus();
model.setState(getNextState(model.getState())); model.setState(getNextState(model.getState()));
@ -79,26 +105,29 @@ public class TristateCheckBox extends UICheckBox {
public TristateCheckBox(String text, State initial) { public TristateCheckBox(String text, State initial) {
this(text, null, initial); this(text, null, initial);
setUI(new TristateCheckBoxUI());
} }
public TristateCheckBox(String text) { public TristateCheckBox(String text) {
this(text, DONT_CARE); this(text, DO_NOT_CARE);
setUI(new TristateCheckBoxUI());
} }
public TristateCheckBox() { public TristateCheckBox() {
this(null); this(null);
setUI(new TristateCheckBoxUI());
} }
/** /**
* No one may add mouse listeners, not even Swing! * No one may add mouse listeners, not even Swing!
*/ */
// @Override @Override
public void addMouseListener(MouseListener l) { public void addMouseListener(MouseListener l) {
} }
/** /**
* Set the new state to either SELECTED, NOT_SELECTED or * Set the new state to either SELECTED, NOT_SELECTED or
* DONT_CARE. If state == null, it is treated as DONT_CARE. * DO_NOT_CARE. If state == null, it is treated as DO_NOT_CARE.
*/ */
public void setState(State state) { public void setState(State state) {
model.setState(state); model.setState(state);
@ -112,15 +141,6 @@ public class TristateCheckBox extends UICheckBox {
return model.getState(); return model.getState();
} }
// @Override
public void setSelected(boolean b) {
if (b) {
setState(SELECTED);
}
else {
setState(NOT_SELECTED);
}
}
/** /**
* Exactly which Design Pattern is this? Is it an Adapter, * Exactly which Design Pattern is this? Is it an Adapter,
@ -140,13 +160,13 @@ public class TristateCheckBox extends UICheckBox {
other.setArmed(false); other.setArmed(false);
setPressed(false); setPressed(false);
setSelected(false); setSelected(false);
} } else if (state == SELECTED) {
else if (state == SELECTED) {
other.setArmed(false); other.setArmed(false);
setPressed(false); setPressed(false);
setSelected(true); setSelected(true);
} }
else { // either "null" or DONT_CARE // either "null" or DO_NOT_CARE
else {
other.setArmed(true); other.setArmed(true);
setPressed(true); setPressed(true);
setSelected(true); setSelected(true);
@ -158,7 +178,7 @@ public class TristateCheckBox extends UICheckBox {
* state of the model. * state of the model.
* <p/> * <p/>
* We return the SELECTED state when the checkbox is selected * We return the SELECTED state when the checkbox is selected
* but not armed, DONT_CARE state when the checkbox is * but not armed, DO_NOT_CARE state when the checkbox is
* selected and armed (grey) and NOT_SELECTED when the * selected and armed (grey) and NOT_SELECTED when the
* checkbox is deselected. * checkbox is deselected.
*/ */
@ -166,12 +186,10 @@ public class TristateCheckBox extends UICheckBox {
if (isSelected() && !isArmed()) { if (isSelected() && !isArmed()) {
// normal black tick // normal black tick
return SELECTED; return SELECTED;
} } else if (isSelected() && isArmed()) {
else if (isSelected() && isArmed()) {
// don't care grey tick // don't care grey tick
return DONT_CARE; return DO_NOT_CARE;
} } else {
else {
// normal deselected // normal deselected
return NOT_SELECTED; return NOT_SELECTED;
} }
@ -180,6 +198,7 @@ public class TristateCheckBox extends UICheckBox {
/** /**
* Filter: No one may change the armed status except us. * Filter: No one may change the armed status except us.
*/ */
@Override
public void setArmed(boolean b) { public void setArmed(boolean b) {
} }
@ -187,6 +206,7 @@ public class TristateCheckBox extends UICheckBox {
* We disable focusing on the component when it is not * We disable focusing on the component when it is not
* enabled. * enabled.
*/ */
@Override
public void setEnabled(boolean b) { public void setEnabled(boolean b) {
setFocusable(b); setFocusable(b);
other.setEnabled(b); other.setEnabled(b);
@ -196,89 +216,109 @@ public class TristateCheckBox extends UICheckBox {
* All these methods simply delegate to the "other" model * All these methods simply delegate to the "other" model
* that is being decorated. * that is being decorated.
*/ */
@Override
public boolean isArmed() { public boolean isArmed() {
return other.isArmed(); return other.isArmed();
} }
@Override
public boolean isSelected() { public boolean isSelected() {
return other.isSelected(); return other.isSelected();
} }
@Override
public boolean isEnabled() { public boolean isEnabled() {
return other.isEnabled(); return other.isEnabled();
} }
@Override
public boolean isPressed() { public boolean isPressed() {
return other.isPressed(); return other.isPressed();
} }
@Override
public boolean isRollover() { public boolean isRollover() {
return other.isRollover(); return other.isRollover();
} }
@Override
public void setSelected(boolean b) { public void setSelected(boolean b) {
other.setSelected(b); other.setSelected(b);
} }
@Override
public void setPressed(boolean b) { public void setPressed(boolean b) {
other.setPressed(b); other.setPressed(b);
} }
@Override
public void setRollover(boolean b) { public void setRollover(boolean b) {
other.setRollover(b); other.setRollover(b);
} }
@Override
public void setMnemonic(int key) { public void setMnemonic(int key) {
other.setMnemonic(key); other.setMnemonic(key);
} }
@Override
public int getMnemonic() { public int getMnemonic() {
return other.getMnemonic(); return other.getMnemonic();
} }
@Override
public void setActionCommand(String s) { public void setActionCommand(String s) {
other.setActionCommand(s); other.setActionCommand(s);
} }
@Override
public String getActionCommand() { public String getActionCommand() {
return other.getActionCommand(); return other.getActionCommand();
} }
@Override
public void setGroup(ButtonGroup group) { public void setGroup(ButtonGroup group) {
other.setGroup(group); other.setGroup(group);
} }
@Override
public void addActionListener(ActionListener l) { public void addActionListener(ActionListener l) {
other.addActionListener(l); other.addActionListener(l);
} }
@Override
public void removeActionListener(ActionListener l) { public void removeActionListener(ActionListener l) {
other.removeActionListener(l); other.removeActionListener(l);
} }
@Override
public void addItemListener(ItemListener l) { public void addItemListener(ItemListener l) {
other.addItemListener(l); other.addItemListener(l);
} }
@Override
public void removeItemListener(ItemListener l) { public void removeItemListener(ItemListener l) {
other.removeItemListener(l); other.removeItemListener(l);
} }
@Override
public void addChangeListener(ChangeListener l) { public void addChangeListener(ChangeListener l) {
other.addChangeListener(l); other.addChangeListener(l);
} }
@Override
public void removeChangeListener(ChangeListener l) { public void removeChangeListener(ChangeListener l) {
other.removeChangeListener(l); other.removeChangeListener(l);
} }
@Override
public Object[] getSelectedObjects() { public Object[] getSelectedObjects() {
return other.getSelectedObjects(); return other.getSelectedObjects();
} }
} }
/** /**
* We rotate between NOT_SELECTED, SELECTED and DONT_CARE. Subclass can * We rotate between NOT_SELECTED, SELECTED and DO_NOT_CARE. Subclass can
* override this method to tell the check box what next state is. Here is * override this method to tell the check box what next state is. Here is
* the default implementation. * the default implementation.
* <code><pre> * <code><pre>
@ -286,7 +326,7 @@ public class TristateCheckBox extends UICheckBox {
* return SELECTED; * return SELECTED;
* } * }
* else if (current == SELECTED) { * else if (current == SELECTED) {
* return DONT_CARE; * return DO_NOT_CARE;
* } * }
* else { * else {
* return NOT_SELECTED; * return NOT_SELECTED;
@ -296,12 +336,91 @@ public class TristateCheckBox extends UICheckBox {
protected State getNextState(State current) { protected State getNextState(State current) {
if (current == NOT_SELECTED) { if (current == NOT_SELECTED) {
return SELECTED; return SELECTED;
} else if (current == SELECTED) {
return DO_NOT_CARE;
} else {
return NOT_SELECTED;
} }
else if (current == SELECTED) { }
return DONT_CARE;
private class TristateCheckBoxUI extends MetalCheckBoxUI {
@Override
public void paint(Graphics g, JComponent c) {
synchronized (this) {
AbstractButton b = (AbstractButton) c;
ButtonModel model = b.getModel();
Dimension size = c.getSize();
Font f = c.getFont();
g.setFont(f);
FontMetrics fm = SwingUtilities2.getFontMetrics(c, g, f);
Rectangle viewRect = new Rectangle(size);
Rectangle iconRect = new Rectangle();
Rectangle textRect = new Rectangle();
Insets i = c.getInsets();
viewRect.x += i.left;
viewRect.y += i.top;
viewRect.width -= (i.right + viewRect.x);
viewRect.height -= (i.bottom + viewRect.y);
Icon altIcon = b.getIcon();
String text = SwingUtilities.layoutCompoundLabel(
c, fm, b.getText(), altIcon != null ? altIcon : getDefaultIcon(),
b.getVerticalAlignment(), b.getHorizontalAlignment(),
b.getVerticalTextPosition(), b.getHorizontalTextPosition(),
viewRect, iconRect, textRect, b.getIconTextGap());
// fill background
if (c.isOpaque()) {
g.setColor(b.getBackground());
g.fillRect(0, 0, size.width, size.height);
}
Graphics2D g2d = (Graphics2D) g;
g2d.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
if (SELECTED.equals(getState())) {
GUIPaintUtils.fillPaint(g2d, iconRect.x, iconRect.y, iconRect.width, iconRect.height, false, Constants.NULL,
model.isEnabled() ? UIConstants.CHECKBOX_HOVER_SELECTED : UIConstants.DISABLED_ICON_COLOR, 0);
} else if (model.isRollover() && !SELECTED.equals(getState())) {
g.setColor(UIConstants.CHECKBOX_HOVER_SELECTED);
g2d.drawRoundRect(iconRect.x, iconRect.y, iconRect.width - 1, iconRect.height - 1, UIConstants.ARC, UIConstants.ARC);
} else {
g.setColor(UIConstants.LINE_COLOR);
g2d.drawRoundRect(iconRect.x, iconRect.y, iconRect.width - 1, iconRect.height - 1, UIConstants.ARC, UIConstants.ARC);
}
if (SELECTED.equals(getState())) {
UIConstants.YES_ICON.paintIcon(c, g, iconRect.x + 2, iconRect.y + 2);
} else if (DO_NOT_CARE.equals(getState())) {
g.setColor(UIConstants.CHECKBOX_HOVER_SELECTED);
g2d.fillRoundRect(iconRect.x + 2, iconRect.y + 2, iconRect.width - 4, iconRect.height - 4, UIConstants.ARC, UIConstants.ARC);
}
g2d.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_OFF);
// Draw the Text
drawLine(text, g, b, c, textRect, fm);
}
} }
else /*if (current == DONT_CARE)*/ {
return NOT_SELECTED; private void drawLine(String text, Graphics g, AbstractButton b, JComponent c, Rectangle textRect, FontMetrics fm) {
if (text != null) {
View v = (View) c.getClientProperty(BasicHTML.propertyKey);
if (v != null) {
v.paint(g, textRect);
} else {
int mnemIndex = b.getDisplayedMnemonicIndex();
if (model.isEnabled()) {
g.setColor(b.getForeground());
} else {
g.setColor(getDisabledTextColor());
}
SwingUtilities2.drawStringUnderlineCharAt(c, g, text,
mnemIndex, textRect.x, textRect.y + fm.getAscent());
}
}
} }
} }
} }

665
designer-base/src/main/java/com/fr/design/gui/itree/filetree/EnvFileTree.java

@ -8,16 +8,19 @@ import com.fr.design.gui.itree.refreshabletree.RefreshableJTree;
import com.fr.file.filetree.FileNode; import com.fr.file.filetree.FileNode;
import com.fr.file.filetree.FileNodeFilter; import com.fr.file.filetree.FileNodeFilter;
import com.fr.general.ComparatorUtils; import com.fr.general.ComparatorUtils;
import com.fr.general.Inter; import com.fr.locale.InterProviderFactory;
import com.fr.log.FineLoggerFactory;
import com.fr.stable.CoreConstants; import com.fr.stable.CoreConstants;
import com.fr.stable.StableUtils; import com.fr.stable.StableUtils;
import com.fr.workspace.WorkContext; import com.fr.workspace.WorkContext;
import javax.swing.*; import javax.swing.JTree;
import javax.swing.tree.DefaultTreeCellRenderer; import javax.swing.tree.DefaultTreeCellRenderer;
import javax.swing.tree.DefaultTreeModel; import javax.swing.tree.DefaultTreeModel;
import javax.swing.tree.TreePath; import javax.swing.tree.TreePath;
import java.awt.*; import java.awt.Color;
import java.awt.Component;
import java.awt.Dimension;
import java.io.File; import java.io.File;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
@ -27,330 +30,334 @@ import java.util.Arrays;
*/ */
public class EnvFileTree extends RefreshableJTree { public class EnvFileTree extends RefreshableJTree {
protected FileNodeFilter filter; protected FileNodeFilter filter;
protected String treeRootPath = ""; protected String treeRootPath = "";
protected String[] subPathes; protected String[] subPaths;
public EnvFileTree() { public EnvFileTree() {
this(null, null); this(null, null);
} }
public EnvFileTree(String[] subPathes, FileNodeFilter filter) { public EnvFileTree(String[] subPaths, FileNodeFilter filter) {
this("", subPathes, filter); this("", subPaths, filter);
} }
public EnvFileTree(String treeRootPath, String[] subPathes, FileNodeFilter filter) { public EnvFileTree(String treeRootPath, String[] subPaths, FileNodeFilter filter) {
super(new FileNode(treeRootPath, true)); super(new FileNode(treeRootPath, true));
this.setTreeRootPath(treeRootPath); this.setTreeRootPath(treeRootPath);
this.setFileNodeFilter(filter); this.setFileNodeFilter(filter);
this.setSubPathes(subPathes); this.setSubPaths(subPaths);
/*一些自己的 init 放在这里,防止直接错误重写了父类的 init 方法导致子类不能使用 CheckBoxTree 的一些特性。*/ /*一些自己的 init 放在这里,防止直接错误重写了父类的 init 方法导致子类不能使用 CheckBoxTree 的一些特性。*/
this.putClientProperty("JTree.lineStyle", "Angled"); this.putClientProperty("JTree.lineStyle", "Angled");
this.setCellRenderer(fileTreeCellRenderer); // CellRenderer
// 这里新建一个Label作为render是因为JTree在动态刷新的时候,节点上render画布的的宽度不会变,会使得一部分比较长的数据显示为
this.setRootVisible(false); DefaultTreeCellRenderer fileTreeCellRenderer = new DefaultTreeCellRenderer() {
this.setShowsRootHandles(true);
this.setEditable(false); @Override
} public Component getTreeCellRendererComponent(JTree tree, Object value, boolean selected, boolean expanded, boolean leaf, int row,
boolean hasFocus) {
private void setTreeRootPath(String path) { super.getTreeCellRendererComponent(tree, value, selected, expanded, leaf, row, hasFocus);
if (path == null) { ExpandMutableTreeNode treeNode = (ExpandMutableTreeNode) value;
path = ""; Object userObj = treeNode.getUserObject();
} if (userObj instanceof FileNode) {
FileNode node = (FileNode) userObj;
this.treeRootPath = path; String lock = node.getLock();
} String name = node.getName();
if (treeNode.hasFullAuthority()) {
public void setFileNodeFilter(FileNodeFilter filter) { if (lock != null && !node.getUserID().equals(lock)) {
this.filter = filter; name = name + InterProviderFactory.getProvider().getLocText("Locked");
} this.setIcon(FileTreeIcon.getIcon(node));
} else {
// CellRenderer this.setIcon(FileTreeIcon.getIcon(node, false));
private DefaultTreeCellRenderer fileTreeCellRenderer = new DefaultTreeCellRenderer() { }
} else {
@Override this.setIcon(FileTreeIcon.getFolderHalfImageIcon());
public Component getTreeCellRendererComponent(JTree tree, Object value, boolean selected, boolean expanded, boolean leaf, int row, }
boolean hasFocus) { this.setText(name);
super.getTreeCellRendererComponent(tree, value, selected, expanded, leaf, row, hasFocus); } else if (userObj == PENDING) {
ExpandMutableTreeNode treeNode = (ExpandMutableTreeNode) value; this.setIcon(null);
Object userObj = treeNode.getUserObject(); this.setText(PENDING.toString());
if (userObj instanceof FileNode) { }
FileNode node = (FileNode) userObj; // 这里新建一个Label作为render是因为JTree在动态刷新的时候,节点上render画布的的宽度不会变,会使得一部分比较长的数据显示为"..."
String lock = node.getLock(); UILabel label = new UILabel();
String name = node.getName(); label.setText(getText());
if (lock != null && !node.getUserID().equals(lock)) { label.setIcon(getIcon());
name = name + Inter.getLocText("Locked"); this.setSize(label.getPreferredSize());
this.setIcon(FileTreeIcon.getIcon(node)); Dimension dim = label.getPreferredSize();
}else { dim.height += 2;
this.setIcon(FileTreeIcon.getIcon(node, false)); this.setPreferredSize(dim);
} this.setBackgroundNonSelectionColor(UIConstants.TREE_BACKGROUND);
this.setText(name); this.setTextSelectionColor(Color.WHITE);
} else if (userObj == PENDING) { this.setBackgroundSelectionColor(UIConstants.FLESH_BLUE);
this.setIcon(null); return this;
this.setText(PENDING.toString()); }
} };
// 这里新建一个Label作为render是因为JTree在动态刷新的时候,节点上render画布的的宽度不会变,会使得一部分比较长的数据显示为"..." this.setCellRenderer(fileTreeCellRenderer);
UILabel label = new UILabel();
label.setText(getText()); this.setRootVisible(false);
label.setIcon(getIcon()); this.setShowsRootHandles(true);
this.setSize(label.getPreferredSize()); this.setEditable(false);
Dimension dim = label.getPreferredSize(); }
dim.height += 2;
this.setPreferredSize(dim); private void setTreeRootPath(String path) {
this.setBackgroundNonSelectionColor(UIConstants.TREE_BACKGROUND); if (path == null) {
this.setTextSelectionColor(Color.WHITE); path = "";
this.setBackgroundSelectionColor(UIConstants.FLESH_BLUE); }
return this;
} this.treeRootPath = path;
}; }
/* public void setFileNodeFilter(FileNodeFilter filter) {
* 在当前tree中选中currentPath this.filter = filter;
*/ }
public void selectPath(String currentPath) {
if (currentPath == null) { /*
return; * 在当前tree中选中currentPath
} */
public void selectPath(String currentPath) {
DefaultTreeModel m_model = (DefaultTreeModel) this.getModel(); if (currentPath == null) {
ExpandMutableTreeNode treeNode = (ExpandMutableTreeNode) m_model.getRoot(); return;
for (int i = 0, len = treeNode.getChildCount(); i < len; i++) { }
// 取出当前的childTreeNode,并append到searchingPath后面
ExpandMutableTreeNode childTreeNode = (ExpandMutableTreeNode) treeNode.getChildAt(i); DefaultTreeModel m_model = (DefaultTreeModel) this.getModel();
ExpandMutableTreeNode treeNode = (ExpandMutableTreeNode) m_model.getRoot();
if (selectFilePath(childTreeNode, "", currentPath, m_model)) { for (int i = 0, len = treeNode.getChildCount(); i < len; i++) {
break; // 取出当前的childTreeNode,并append到searchingPath后面
} ExpandMutableTreeNode childTreeNode = (ExpandMutableTreeNode) treeNode.getChildAt(i);
}
if (selectFilePath(childTreeNode, "", currentPath, m_model)) {
TreePath selectedTreePath = this.getSelectionPath(); break;
if (selectedTreePath != null) { }
this.scrollPathToVisible(selectedTreePath); }
}
} TreePath selectedTreePath = this.getSelectionPath();
if (selectedTreePath != null) {
/* this.scrollPathToVisible(selectedTreePath);
* 在currentTreeNode下找寻filePath }
* }
* prefix + currentTreeNode.getName() = currentTreeNode所对应的Path
* /*
* 返回currentTreeNode下是否找到了filePath * 在currentTreeNode下找寻filePath
*/ *
private boolean selectFilePath(ExpandMutableTreeNode currentTreeNode, String prefix, String filePath, DefaultTreeModel m_model) { * prefix + currentTreeNode.getName() = currentTreeNode所对应的Path
FileNode fileNode = (FileNode) currentTreeNode.getUserObject(); *
String nodePath = fileNode.getName(); * 返回currentTreeNode下是否找到了filePath
String currentTreePath = prefix + nodePath; */
private boolean selectFilePath(ExpandMutableTreeNode currentTreeNode, String prefix, String filePath, DefaultTreeModel m_model) {
// 如果equals,说明找到了,不必再找下去了 FileNode fileNode = (FileNode) currentTreeNode.getUserObject();
if (ComparatorUtils.equals(new File(currentTreePath), new File(filePath))) { String nodePath = fileNode.getName();
this.setSelectionPath(new TreePath(m_model.getPathToRoot(currentTreeNode))); String currentTreePath = prefix + nodePath;
return true;
} // 如果当前路径是currentFilePath的ParnetFile,则expandTreeNode,并继续往下找 // 如果equals,说明找到了,不必再找下去了
else if (EnvFileTree.isParentFile(currentTreePath, filePath)) { if (ComparatorUtils.equals(new File(currentTreePath), new File(filePath))) {
this.loadPendingChildTreeNode(currentTreeNode); this.setSelectionPath(new TreePath(m_model.getPathToRoot(currentTreeNode)));
return true;
prefix = currentTreePath + CoreConstants.SEPARATOR; }
for (int i = 0, len = currentTreeNode.getChildCount(); i < len; i++) { // 如果当前路径是currentFilePath的ParentFile,则expandTreeNode,并继续往下找
ExpandMutableTreeNode childTreeNode = (ExpandMutableTreeNode) currentTreeNode.getChildAt(i); else if (EnvFileTree.isParentFile(currentTreePath, filePath)) {
this.loadPendingChildTreeNode(currentTreeNode);
if (selectFilePath(childTreeNode, prefix, filePath, m_model)) {
return true; prefix = currentTreePath + CoreConstants.SEPARATOR;
} for (int i = 0, len = currentTreeNode.getChildCount(); i < len; i++) {
} ExpandMutableTreeNode childTreeNode = (ExpandMutableTreeNode) currentTreeNode.getChildAt(i);
return false;
} if (selectFilePath(childTreeNode, prefix, filePath, m_model)) {
return true;
return false; }
} }
return false;
/* }
* 求当前TreeNode下所有的FileNode.
*/ return false;
private FileNode[] listFileNodes(ExpandMutableTreeNode currentTreeNode) { }
if (currentTreeNode == null) {
return new FileNode[0]; /*
} * 求当前TreeNode下所有的FileNode.
*/
Object object = currentTreeNode.getUserObject(); private FileNode[] listFileNodes(ExpandMutableTreeNode currentTreeNode) {
if (currentTreeNode == null) {
if (object instanceof FileNode) { return new FileNode[0];
return this.listFileNodes(((FileNode) object).getEnvPath()); }
}
Object object = currentTreeNode.getUserObject();
return new FileNode[0];
} if (object instanceof FileNode) {
return this.listFileNodes(((FileNode) object).getEnvPath());
/* }
* 求filePath这个String,求其路径下面的所有的FileNode
*/ return new FileNode[0];
private FileNode[] listFileNodes(String filePath) { }
FileNode[] res_fns = null;
/*
try { * 求filePath这个String,求其路径下面的所有的FileNode
res_fns = WorkContext.getCurrent() == null ? new FileNode[0] : FRContext.getFileNodes().list(filePath); */
} catch (Exception e) { private FileNode[] listFileNodes(String filePath) {
FRContext.getLogger().error(e.getMessage(), e); FileNode[] resFns = null;
}
try {
if (res_fns == null) { resFns = WorkContext.getCurrent() == null ? new FileNode[0] : FRContext.getFileNodes().list(filePath);
res_fns = new FileNode[0]; } catch (Exception e) {
} FineLoggerFactory.getLogger().error(e.getMessage(), e);
}
// 用FileNodeFilter过滤一下
if (filter != null) { if (resFns == null) {
java.util.List<FileNode> t_list = new ArrayList<FileNode>(); resFns = new FileNode[0];
for (int i = 0; i < res_fns.length; i++) { }
if (filter.accept(res_fns[i])) {
t_list.add(res_fns[i]); // 用FileNodeFilter过滤一下
} if (filter != null) {
} java.util.List<FileNode> tList = new ArrayList<FileNode>();
for (int i = 0; i < resFns.length; i++) {
res_fns = t_list.toArray(new FileNode[t_list.size()]); if (filter.accept(resFns[i])) {
} tList.add(resFns[i]);
}
Arrays.sort(res_fns, new FileNodeComparator()); }
return res_fns; resFns = tList.toArray(new FileNode[tList.size()]);
} }
/* Arrays.sort(resFns, new FileNodeComparator());
* 获取当前选中的FilePath的String,这个FilePath是需要拼起来的
*/ return resFns;
public FileNode getSelectedFileNode() { }
TreePath selectedTreePath = this.getSelectionPath();
if (selectedTreePath == null) { /*
return null; * 获取当前选中的FilePath的String,这个FilePath是需要拼起来的
} */
public FileNode getSelectedFileNode() {
ExpandMutableTreeNode currentTreeNode = (ExpandMutableTreeNode) selectedTreePath.getLastPathComponent(); TreePath selectedTreePath = this.getSelectionPath();
Object userObject = currentTreeNode.getUserObject(); if (selectedTreePath == null) {
return null;
if (userObject instanceof FileNode) { }
return (FileNode) userObject;
} ExpandMutableTreeNode currentTreeNode = (ExpandMutableTreeNode) selectedTreePath.getLastPathComponent();
Object userObject = currentTreeNode.getUserObject();
return null;
} if (userObject instanceof FileNode) {
return (FileNode) userObject;
/* }
* 改变Env后,根据构造函数时设置的RootPathes,重新加载
*/ return null;
public void refreshEnv() { }
DefaultTreeModel m_model = (DefaultTreeModel) this.getModel(); /*
ExpandMutableTreeNode rootTreeNode = (ExpandMutableTreeNode) m_model.getRoot(); * 改变Env后,根据构造函数时设置的RootPaths,重新加载
rootTreeNode.removeAllChildren(); */
public void refreshEnv() {
FileNode[] fns;
DefaultTreeModel m_model = (DefaultTreeModel) this.getModel();
// 如果rootPaths是null的话列出所有文件 ExpandMutableTreeNode rootTreeNode = (ExpandMutableTreeNode) m_model.getRoot();
if (subPathes == null) { rootTreeNode.removeAllChildren();
fns = listFileNodes(this.treeRootPath);
} else { FileNode[] fns;
// 重新加载新的FileDirectoryNode
fns = new FileNode[subPathes.length]; // 如果rootPaths是null的话列出所有文件
for (int i = 0; i < subPathes.length; i++) { if (subPaths == null) {
fns[i] = new FileNode(StableUtils.pathJoin(new String[]{this.treeRootPath, subPathes[i]}), true); fns = listFileNodes(this.treeRootPath);
} } else {
} // 重新加载新的FileDirectoryNode
fns = new FileNode[subPaths.length];
for (int i = 0; i < subPaths.length; i++) {
ExpandMutableTreeNode[] sub_tree_node_array = fileNodeArray2TreeNodeArray(fns); fns[i] = new FileNode(StableUtils.pathJoin(this.treeRootPath, subPaths[i]), true);
}
for (int i = 0; i < sub_tree_node_array.length; i++) { }
ExpandMutableTreeNode node = sub_tree_node_array[i];
rootTreeNode.add(node);
} ExpandMutableTreeNode[] subTreeNodeArray = fileNodeArray2TreeNodeArray(fns);
m_model.reload(rootTreeNode); for (int i = 0; i < subTreeNodeArray.length; i++) {
} ExpandMutableTreeNode node = subTreeNodeArray[i];
rootTreeNode.add(node);
/* }
* 设置当前Tree的rootPathes
*/ m_model.reload(rootTreeNode);
private void setSubPathes(String[] subPathes) { }
this.subPathes = subPathes;
} /*
* 设置当前Tree的rootPaths
/** */
* currentTreeNode下面如果是PENDING的节点,加载之... private void setSubPaths(String[] subPaths) {
*/ this.subPaths = subPaths;
protected void loadPendingChildTreeNode(ExpandMutableTreeNode currentTreeNode) { }
if (currentTreeNode.isLeaf()) {
return; /**
} * currentTreeNode下面如果是PENDING的节点,加载之...
*/
// 判断第一个孩子节点.UserObject是不是PENDING,如果是PENDING的话,需要重新加载这个TreeNode protected void loadPendingChildTreeNode(ExpandMutableTreeNode currentTreeNode) {
ExpandMutableTreeNode flag = (ExpandMutableTreeNode) currentTreeNode.getFirstChild(); if (currentTreeNode.isLeaf()) {
if (flag == null || flag.getUserObject() != PENDING) { return;
return; }
}
currentTreeNode.removeAllChildren(); // 删除所有的节点. // 判断第一个孩子节点.UserObject是不是PENDING,如果是PENDING的话,需要重新加载这个TreeNode
ExpandMutableTreeNode flag = (ExpandMutableTreeNode) currentTreeNode.getFirstChild();
ExpandMutableTreeNode[] children = loadChildTreeNodes(currentTreeNode); if (flag == null || flag.getUserObject() != PENDING) {
for (ExpandMutableTreeNode c : children) { return;
currentTreeNode.add(c); }
} // 删除所有的节点.
} currentTreeNode.removeAllChildren();
/* ExpandMutableTreeNode[] children = loadChildTreeNodes(currentTreeNode);
* 判断eTreeNode是否需要Refresh,可提前中止,返回true则表示提前中止,不需要Refresh for (ExpandMutableTreeNode c : children) {
*/ currentTreeNode.add(c);
protected boolean interceptRefresh(ExpandMutableTreeNode eTreeNode) { }
Object userObject = eTreeNode.getUserObject(); }
if (userObject instanceof FileNode && !((FileNode) userObject).isDirectory()) {
return true; /*
} * 判断eTreeNode是否需要Refresh,可提前中止,返回true则表示提前中止,不需要Refresh
*/
return eTreeNode.getChildCount() == 1 && ((ExpandMutableTreeNode) eTreeNode.getFirstChild()).getUserObject() == PENDING; @Override
} protected boolean interceptRefresh(ExpandMutableTreeNode eTreeNode) {
Object userObject = eTreeNode.getUserObject();
/* if (userObject instanceof FileNode && !((FileNode) userObject).isDirectory()) {
* 得到treeNode的子节点ExpandMutableTreeNode的数组 return true;
*/ }
protected ExpandMutableTreeNode[] loadChildTreeNodes(ExpandMutableTreeNode treeNode) {
FileNode[] fn_array = listFileNodes(treeNode); return eTreeNode.getChildCount() == 1 && ((ExpandMutableTreeNode) eTreeNode.getFirstChild()).getUserObject() == PENDING;
}
return fileNodeArray2TreeNodeArray(fn_array);
} /*
* 得到treeNode的子节点ExpandMutableTreeNode的数组
/* */
* 把FileNode[]转成ExpandMutableTreeNode[] @Override
*/ protected ExpandMutableTreeNode[] loadChildTreeNodes(ExpandMutableTreeNode treeNode) {
private ExpandMutableTreeNode[] fileNodeArray2TreeNodeArray(FileNode[] fn_array) { FileNode[] fnArray = listFileNodes(treeNode);
ExpandMutableTreeNode[] res = new ExpandMutableTreeNode[fn_array.length];
for (int i = 0; i < res.length; i++) { return fileNodeArray2TreeNodeArray(fnArray);
FileNode fn = fn_array[i]; }
res[i] = new ExpandMutableTreeNode(fn);
if (fn.isDirectory()) { /*
res[i].add(new ExpandMutableTreeNode()); * 把FileNode[]转成ExpandMutableTreeNode[]
} */
} private ExpandMutableTreeNode[] fileNodeArray2TreeNodeArray(FileNode[] fn_array) {
ExpandMutableTreeNode[] res = new ExpandMutableTreeNode[fn_array.length];
return res; for (int i = 0; i < res.length; i++) {
} FileNode fn = fn_array[i];
res[i] = new ExpandMutableTreeNode(fn);
/* if (fn.isDirectory()) {
* 是否是父子关系的文件. res[i].add(new ExpandMutableTreeNode());
*/ }
protected static boolean isParentFile(String parentFilePath, String childFilePath) { }
File parentFile = new File(parentFilePath);
File childFile = new File(childFilePath); return res;
}
while (true) {
if (ComparatorUtils.equals(parentFile, childFile)) { /*
return true; * 是否是父子关系的文件.
} */
protected static boolean isParentFile(String parentFilePath, String childFilePath) {
childFile = childFile.getParentFile(); File parentFile = new File(parentFilePath);
if (childFile == null) { File childFile = new File(childFilePath);
break;
} do {
} if (ComparatorUtils.equals(parentFile, childFile)) {
return true;
return false; }
} childFile = childFile.getParentFile();
} while (childFile != null);
return false;
}
} }

64
designer-base/src/main/java/com/fr/design/gui/itree/filetree/FileTreeIcon.java

@ -1,22 +1,26 @@
package com.fr.design.gui.itree.filetree; package com.fr.design.gui.itree.filetree;
import com.fr.base.BaseUtils; import com.fr.base.BaseUtils;
import com.fr.base.FRContext;
import com.fr.design.icon.LockIcon; import com.fr.design.icon.LockIcon;
import com.fr.file.filetree.FileNode; import com.fr.file.filetree.FileNode;
import com.fr.stable.StableUtils; import com.fr.stable.StableUtils;
import com.fr.workspace.WorkContext; import com.fr.workspace.WorkContext;
import javax.swing.*; import javax.swing.Icon;
import javax.swing.UIManager;
import javax.swing.filechooser.FileSystemView; import javax.swing.filechooser.FileSystemView;
import java.io.File; import java.io.File;
public class FileTreeIcon { public class FileTreeIcon {
private FileTreeIcon() {} private FileTreeIcon() {
}
public static final Icon BLANK_IMAGE_ICON = BaseUtils.readIcon("/com/fr/design/images/gui/blank.gif"); public static final Icon BLANK_IMAGE_ICON = BaseUtils.readIcon("/com/fr/design/images/gui/blank.gif");
public static final Icon FOLDER_IMAGE_ICON = BaseUtils.readIcon("/com/fr/design/images/gui/folder.png"); public static final Icon FOLDER_IMAGE_ICON = BaseUtils.readIcon("/com/fr/design/images/gui/folder.png");
public static final Icon FOLDER_HALF_IMAGE_ICON =
BaseUtils.readIcon("/com/fr/design/images/gui/filetree_folder_half_authority_normal.png");
public static final Icon FILE_IMAGE_ICON = UIManager.getIcon("FileView.fileIcon"); public static final Icon FILE_IMAGE_ICON = UIManager.getIcon("FileView.fileIcon");
public static final Icon JAVA_FILE_IMAGE_ICON = BaseUtils.readIcon("/com/fr/design/images/gui/javaFile.gif"); public static final Icon JAVA_FILE_IMAGE_ICON = BaseUtils.readIcon("/com/fr/design/images/gui/javaFile.gif");
@ -63,9 +67,9 @@ public class FileTreeIcon {
public static final LockIcon CPT_FILE_LOCK_ICON = public static final LockIcon CPT_FILE_LOCK_ICON =
new LockIcon(BaseUtils.readImage("/com/fr/base/images/oem/cptlocked.png")); new LockIcon(BaseUtils.readImage("/com/fr/base/images/oem/cptlocked.png"));
public static final LockIcon FRM_FILE_LOCK_ICON = public static final LockIcon FRM_FILE_LOCK_ICON =
new LockIcon(BaseUtils.readImage("/com/fr/design/images/gui/frmlocked.png")); new LockIcon(BaseUtils.readImage("/com/fr/design/images/gui/frmlocked.png"));
public static final LockIcon CHT_FILE_LOCK_ICON = public static final LockIcon CHT_FILE_LOCK_ICON =
new LockIcon(BaseUtils.readImage("/com/fr/design/images/gui/frmlocked.png")); new LockIcon(BaseUtils.readImage("/com/fr/design/images/gui/frmlocked.png"));
/** /**
* file types * file types
*/ */
@ -109,27 +113,31 @@ public class FileTreeIcon {
return FileTreeIcon.getIcon(FileTreeIcon.getFileType(file.getName()), isLocked); return FileTreeIcon.getIcon(FileTreeIcon.getFileType(file.getName()), isLocked);
} }
public static Icon getIcon(FileNode node) { public static Icon getFolderHalfImageIcon() {
return getIcon(node, node.getLock() != null); return FOLDER_HALF_IMAGE_ICON;
}
public static Icon getIcon(FileNode node) {
return getIcon(node, node.getLock() != null);
} }
public static Icon getIcon(FileNode node, boolean isShowLock) { public static Icon getIcon(FileNode node, boolean isShowLock) {
String path = StableUtils.pathJoin(new String[]{WorkContext.getCurrent().getPath(), node.getEnvPath()}); String path = StableUtils.pathJoin(WorkContext.getCurrent().getPath(), node.getEnvPath());
if (WorkContext.getCurrent().isLocal()) { if (WorkContext.getCurrent().isLocal()) {
File ff = new File(path); File ff = new File(path);
if (ff.exists()) { if (ff.exists()) {
if(node.isDirectory()){ if (node.isDirectory()) {
return FileTreeIcon.FOLDER_IMAGE_ICON; return FileTreeIcon.FOLDER_IMAGE_ICON;
} }
return FileSystemView.getFileSystemView().getSystemIcon(new File(path)); return FileSystemView.getFileSystemView().getSystemIcon(new File(path));
} }
} }
if(node.isDirectory()) { if (node.isDirectory()) {
return FileTreeIcon.FOLDER_IMAGE_ICON; return FileTreeIcon.FOLDER_IMAGE_ICON;
} else { } else {
return FileTreeIcon.getIcon(FileTreeIcon.getFileType(node.getName()), isShowLock); return FileTreeIcon.getIcon(FileTreeIcon.getFileType(node.getName()), isShowLock);
} }
} }
private static Icon getIcon(int fileType, boolean isLocked) { private static Icon getIcon(int fileType, boolean isLocked) {
@ -200,13 +208,13 @@ public class FileTreeIcon {
return FileTreeIcon.CPT_FILE_IMAGE_ICON; return FileTreeIcon.CPT_FILE_IMAGE_ICON;
} }
} else if (fileType == FRM_FILE) { //form frm } else if (fileType == FRM_FILE) { //form frm
if (isLocked) { if (isLocked) {
return FileTreeIcon.FRM_FILE_LOCK_ICON; return FileTreeIcon.FRM_FILE_LOCK_ICON;
} else { } else {
return FileTreeIcon.FRM_FILE_IMAGE_ICON; return FileTreeIcon.FRM_FILE_IMAGE_ICON;
} }
} else if (fileType == CHT_FILE) { //chart cht } else if (fileType == CHT_FILE) { //chart cht
if (isLocked) { if (isLocked) {
return FileTreeIcon.CHT_FILE_LOCK_ICON; return FileTreeIcon.CHT_FILE_LOCK_ICON;
} else { } else {
return FileTreeIcon.CHT_FILE_IMAGE_ICON; return FileTreeIcon.CHT_FILE_IMAGE_ICON;
@ -249,22 +257,22 @@ public class FileTreeIcon {
return CLASS_FILE; return CLASS_FILE;
} else if (fileName.endsWith(".jar") || fileName.endsWith(".zip")) { } else if (fileName.endsWith(".jar") || fileName.endsWith(".zip")) {
return ZIP_FILE; return ZIP_FILE;
} else if( fileName.endsWith(".ear") || fileName.endsWith(".war")){ } else if (fileName.endsWith(".ear") || fileName.endsWith(".war")) {
return ZIP_FILE; return ZIP_FILE;
}else if (fileName.endsWith(".gif")) { } else if (fileName.endsWith(".gif")) {
return GIF_FILE; return GIF_FILE;
} else if (fileName.endsWith(".jpg") || fileName.endsWith(".jpe")) { } else if (fileName.endsWith(".jpg") || fileName.endsWith(".jpe")) {
return JPG_FILE; return JPG_FILE;
} else if( fileName.endsWith(".jpeg")){ } else if (fileName.endsWith(".jpeg")) {
return JPG_FILE; return JPG_FILE;
}else if (fileName.endsWith(".bmp")) { } else if (fileName.endsWith(".bmp")) {
return BMP_FILE; return BMP_FILE;
} else if (fileName.endsWith(".cpt")) { } else if (fileName.endsWith(".cpt")) {
return CPT_FILE; return CPT_FILE;
} else if (fileName.endsWith(".frm") || fileName.endsWith(".form")){ } else if (fileName.endsWith(".frm") || fileName.endsWith(".form")) {
return FRM_FILE; return FRM_FILE;
} else if (fileName.endsWith(".cht") || fileName.endsWith(".chart")){ } else if (fileName.endsWith(".cht") || fileName.endsWith(".chart")) {
return CHT_FILE; return CHT_FILE;
} else { } else {
return TEXT_FILE; return TEXT_FILE;
} }

98
designer-base/src/main/java/com/fr/design/gui/itree/filetree/TemplateFileTree.java

@ -4,10 +4,15 @@ import com.fr.base.FRContext;
import com.fr.base.extension.FileExtension; import com.fr.base.extension.FileExtension;
import com.fr.design.gui.itree.refreshabletree.ExpandMutableTreeNode; import com.fr.design.gui.itree.refreshabletree.ExpandMutableTreeNode;
import com.fr.file.filetree.FileNode; import com.fr.file.filetree.FileNode;
import com.fr.general.ComparatorUtils;
import com.fr.log.FineLoggerFactory; import com.fr.log.FineLoggerFactory;
import com.fr.report.DesignAuthority;
import com.fr.stable.ArrayUtils; import com.fr.stable.ArrayUtils;
import com.fr.stable.CoreConstants;
import com.fr.stable.StableUtils; import com.fr.stable.StableUtils;
import com.fr.stable.project.ProjectConstants; import com.fr.stable.project.ProjectConstants;
import com.fr.workspace.WorkContext;
import com.fr.workspace.server.authority.AuthorityOperator;
import javax.swing.text.Position; import javax.swing.text.Position;
import javax.swing.tree.DefaultTreeModel; import javax.swing.tree.DefaultTreeModel;
@ -22,6 +27,11 @@ import java.util.List;
public class TemplateFileTree extends EnvFileTree { public class TemplateFileTree extends EnvFileTree {
/**
* 远程设计拥有全部权限的文件夹路径
*/
private ArrayList<String> paths = new ArrayList<>();
public TemplateFileTree() { public TemplateFileTree() {
super(ProjectConstants.REPORTLETS_NAME, null, null); super(ProjectConstants.REPORTLETS_NAME, null, null);
} }
@ -73,6 +83,7 @@ public class TemplateFileTree extends EnvFileTree {
return selectedPathList.toArray(new String[0]); return selectedPathList.toArray(new String[0]);
} }
@Override
public TreePath getNextMatch(String prefix, int startingRow, Position.Bias bias) { public TreePath getNextMatch(String prefix, int startingRow, Position.Bias bias) {
int max = getRowCount(); int max = getRowCount();
@ -100,16 +111,45 @@ public class TemplateFileTree extends EnvFileTree {
return null; return null;
} }
public FileNode[] listFile(String path) throws Exception { public FileNode[] listFile(String path) {
return FRContext.getFileNodes().list( return FRContext.getFileNodes().list(
path, path,
new FileExtension[]{FileExtension.CPT, FileExtension.FRM, FileExtension.CHT,FileExtension.XLS,FileExtension.XLSX}); new FileExtension[]{FileExtension.CPT, FileExtension.FRM, FileExtension.CHT, FileExtension.XLS, FileExtension.XLSX});
} }
/* /*
* 改变Env后,根据构造函数时设置的RootPaths,重新加载 * 改变Env后,根据构造函数时设置的RootPaths,重新加载
*/ */
@Override
public void refreshEnv() { public void refreshEnv() {
paths.clear();
if (!WorkContext.getCurrent().isLocal()) {
try {
String username = WorkContext.getConnector().currentUser();
// 远程设计获取全部设计成员的权限列表
DesignAuthority[] authorities = WorkContext.getCurrent().get(AuthorityOperator.class).getAuthorities();
DesignAuthority authority = null;
if (authorities != null) {
for (DesignAuthority designAuthority : authorities) {
if (ComparatorUtils.equals(designAuthority.getUsername(), username)) {
authority = designAuthority;
}
}
}
if (authority != null) {
for (DesignAuthority.Item item : authority.getItems()) {
if (item.getType()) {
paths.add(item.getPath());
}
}
}
} catch (Exception exception) {
FineLoggerFactory.getLogger().error(exception.getMessage(), exception);
}
}
DefaultTreeModel defaultTreeModel = (DefaultTreeModel) this.getModel(); DefaultTreeModel defaultTreeModel = (DefaultTreeModel) this.getModel();
ExpandMutableTreeNode rootTreeNode = (ExpandMutableTreeNode) defaultTreeModel.getRoot(); ExpandMutableTreeNode rootTreeNode = (ExpandMutableTreeNode) defaultTreeModel.getRoot();
@ -118,13 +158,13 @@ public class TemplateFileTree extends EnvFileTree {
FileNode[] fns; FileNode[] fns;
// 如果rootPaths是null的话列出所有文件 // 如果rootPaths是null的话列出所有文件
if (subPathes == null) { if (subPaths == null) {
fns = listFileNodes(this.treeRootPath); fns = listFileNodes(this.treeRootPath);
} else { } else {
// 重新加载新的FileDirectoryNode // 重新加载新的FileDirectoryNode
fns = new FileNode[subPathes.length]; fns = new FileNode[subPaths.length];
for (int i = 0; i < subPathes.length; i++) { for (int i = 0; i < subPaths.length; i++) {
fns[i] = new FileNode(StableUtils.pathJoin(this.treeRootPath, subPathes[i]), true); fns[i] = new FileNode(StableUtils.pathJoin(this.treeRootPath, subPaths[i]), true);
} }
} }
@ -137,28 +177,70 @@ public class TemplateFileTree extends EnvFileTree {
defaultTreeModel.reload(rootTreeNode); defaultTreeModel.reload(rootTreeNode);
} }
@Override
protected ExpandMutableTreeNode[] loadChildTreeNodes(ExpandMutableTreeNode treeNode) { protected ExpandMutableTreeNode[] loadChildTreeNodes(ExpandMutableTreeNode treeNode) {
FileNode[] fn_array = listFileNodes(treeNode); FileNode[] fnArray = listFileNodes(treeNode);
return fileNodeArray2TreeNodeArray(fn_array); return fileNodeArray2TreeNodeArray(fnArray);
} }
/* /*
* 把FileNode[]转成ExpandMutableTreeNode[] * 把FileNode[]转成ExpandMutableTreeNode[]
*/ */
private ExpandMutableTreeNode[] fileNodeArray2TreeNodeArray(FileNode[] fileNodes) { private ExpandMutableTreeNode[] fileNodeArray2TreeNodeArray(FileNode[] fileNodes) {
boolean isLocal = WorkContext.getCurrent().isLocal();
ExpandMutableTreeNode[] res = new ExpandMutableTreeNode[fileNodes.length]; ExpandMutableTreeNode[] res = new ExpandMutableTreeNode[fileNodes.length];
for (int i = 0; i < res.length; i++) { for (int i = 0; i < res.length; i++) {
FileNode fn = fileNodes[i]; FileNode fn = fileNodes[i];
res[i] = new ExpandMutableTreeNode(fn); res[i] = new ExpandMutableTreeNode(fn);
if (fn.isDirectory()) { if (fn.isDirectory()) {
res[i].add(new ExpandMutableTreeNode()); res[i].add(new ExpandMutableTreeNode());
if (isLocal || WorkContext.getCurrent().isRoot()) {
res[i].setFullAuthority(true);
} else {
boolean hasFullAuthority = isContained(fn);
res[i].setFullAuthority(hasFullAuthority);
}
} }
} }
return res; return res;
} }
private boolean isContained(FileNode fileNode) {
for (String auPath : paths) {
if (isContained(auPath, fileNode)) {
return true;
}
}
return false;
}
private boolean isContained(String auPath, FileNode fileNode) {
auPath = ProjectConstants.REPORTLETS_NAME + CoreConstants.SEPARATOR + auPath;
String fileName = fileNode.getEnvPath();
String[] auPaths = auPath.split(CoreConstants.SEPARATOR);
String[] nodePaths = fileName.split(CoreConstants.SEPARATOR);
if (auPaths.length == nodePaths.length) {
for (int i = 0; i < auPaths.length; i++) {
if (!auPaths[i].equals(nodePaths[i])) {
return false;
}
}
return fileNode.isDirectory();
} else {
int len = Math.min(auPaths.length, nodePaths.length);
for (int i = 0; i < len; i++) {
if (!auPaths[i].equals(nodePaths[i])) {
return false;
}
}
return true;
}
}
private FileNode[] listFileNodes(String filePath) { private FileNode[] listFileNodes(String filePath) {
FileNode[] fileNodes = null; FileNode[] fileNodes = null;

51
designer-base/src/main/java/com/fr/design/gui/itree/refreshabletree/ExpandMutableTreeNode.java

@ -1,29 +1,46 @@
package com.fr.design.gui.itree.refreshabletree; package com.fr.design.gui.itree.refreshabletree;
import com.fr.design.utils.gui.GUICoreUtils;
import javax.swing.JTree; import javax.swing.JTree;
import javax.swing.tree.DefaultMutableTreeNode; import javax.swing.tree.DefaultMutableTreeNode;
import com.fr.design.utils.gui.GUICoreUtils;
/** /**
* Enhanced, expand state and get treepath from node. * Enhanced, expand state and get treepath from node.
*/ */
public class ExpandMutableTreeNode extends DefaultMutableTreeNode { public class ExpandMutableTreeNode extends DefaultMutableTreeNode {
private boolean isExpanded = false; //the expend state /**
* the expend state
//默认显示:“正在加载”,如需要显示tree,则传入相应userobject */
private boolean isExpanded = false;
private boolean hasFullAuthority = true;
/**
* 默认显示:正在加载如需要显示tree则传入相应userobject
*/
public ExpandMutableTreeNode() { public ExpandMutableTreeNode() {
this(RefreshableJTree.PENDING); this(RefreshableJTree.PENDING);
} }
public ExpandMutableTreeNode(Object userObject) { public ExpandMutableTreeNode(Object userObject) {
this(userObject, false); this(userObject, false);
} }
public ExpandMutableTreeNode(Object userObject, boolean isExpanded) { public ExpandMutableTreeNode(Object userObject, boolean isExpanded) {
super(userObject); super(userObject);
this.setExpanded(isExpanded); this.setExpanded(isExpanded);
}
public boolean hasFullAuthority() {
return hasFullAuthority;
}
public void setFullAuthority(boolean hasFullAuthority) {
this.hasFullAuthority = hasFullAuthority;
} }
public boolean isExpanded() { public boolean isExpanded() {
return this.isExpanded; return this.isExpanded;
} }
@ -36,12 +53,12 @@ public class ExpandMutableTreeNode extends DefaultMutableTreeNode {
* 展开所有Expanded为true的TreeNode * 展开所有Expanded为true的TreeNode
*/ */
public void expandCurrentTreeNode(JTree tree) { public void expandCurrentTreeNode(JTree tree) {
if (this.isExpanded) { if (this.isExpanded) {
tree.expandPath(GUICoreUtils.getTreePath(this)); tree.expandPath(GUICoreUtils.getTreePath(this));
this.setExpanded(true); this.setExpanded(true);
this.expandSubTreeNodes(tree); this.expandSubTreeNodes(tree);
} }
} }
/** /**
@ -69,10 +86,10 @@ public class ExpandMutableTreeNode extends DefaultMutableTreeNode {
} }
} }
} }
public void addChildTreeNodes(ExpandMutableTreeNode[] newChildNodes) { public void addChildTreeNodes(ExpandMutableTreeNode[] newChildNodes) {
for (int i = 0; i < newChildNodes.length; i ++) { for (int i = 0; i < newChildNodes.length; i++) {
this.add(newChildNodes[i]); this.add(newChildNodes[i]);
} }
} }
} }

80
designer-base/src/main/java/com/fr/design/gui/itree/refreshabletree/RefreshableJTree.java

@ -4,16 +4,28 @@ import com.fr.design.constants.UIConstants;
import com.fr.design.gui.itooltip.UIToolTip; import com.fr.design.gui.itooltip.UIToolTip;
import com.fr.design.gui.itree.checkboxtree.CheckBoxTree; import com.fr.design.gui.itree.checkboxtree.CheckBoxTree;
import com.fr.general.ComparatorUtils; import com.fr.general.ComparatorUtils;
import com.fr.general.Inter;
import com.fr.general.NameObject; import com.fr.general.NameObject;
import com.fr.locale.InterProviderFactory;
import com.fr.stable.StringUtils; import com.fr.stable.StringUtils;
import javax.swing.*; import javax.swing.Icon;
import javax.swing.ImageIcon;
import javax.swing.JComponent;
import javax.swing.JToolTip;
import javax.swing.SwingWorker;
import javax.swing.event.TreeExpansionEvent; import javax.swing.event.TreeExpansionEvent;
import javax.swing.event.TreeExpansionListener; import javax.swing.event.TreeExpansionListener;
import javax.swing.event.TreeWillExpandListener; import javax.swing.event.TreeWillExpandListener;
import javax.swing.tree.*; import javax.swing.tree.DefaultMutableTreeNode;
import java.awt.*; import javax.swing.tree.DefaultTreeCellRenderer;
import javax.swing.tree.DefaultTreeModel;
import javax.swing.tree.ExpandVetoException;
import javax.swing.tree.TreeCellRenderer;
import javax.swing.tree.TreeNode;
import javax.swing.tree.TreePath;
import java.awt.Component;
import java.awt.Point;
import java.awt.Rectangle;
import java.awt.event.MouseEvent; import java.awt.event.MouseEvent;
public abstract class RefreshableJTree extends CheckBoxTree { public abstract class RefreshableJTree extends CheckBoxTree {
@ -24,16 +36,19 @@ public abstract class RefreshableJTree extends CheckBoxTree {
@Override @Override
public String toString() { public String toString() {
return Inter.getLocText("Loading") + "..."; return InterProviderFactory.getProvider().getLocText("Loading") + "...";
} }
}; };
public RefreshableJTree() { public RefreshableJTree() {
this(null); this(null);
} }
@Override
public boolean isCheckBoxVisible(TreePath path) { public boolean isCheckBoxVisible(TreePath path) {
return false; return false;
} }
public RefreshableJTree(Object rootObj) { public RefreshableJTree(Object rootObj) {
super(new DefaultTreeModel(new ExpandMutableTreeNode(rootObj))); super(new DefaultTreeModel(new ExpandMutableTreeNode(rootObj)));
DefaultTreeModel model = (DefaultTreeModel) getModel(); DefaultTreeModel model = (DefaultTreeModel) getModel();
@ -101,8 +116,7 @@ public abstract class RefreshableJTree extends CheckBoxTree {
treeNode.remove(0); treeNode.remove(0);
} }
treeModel.nodeStructureChanged(treeNode); treeModel.nodeStructureChanged(treeNode);
long usedTime = System.currentTimeMillis() - startTime; return System.currentTimeMillis() - startTime;
return usedTime;
} }
@Override @Override
@ -118,15 +132,15 @@ public abstract class RefreshableJTree extends CheckBoxTree {
}; };
/** /**
* @return * @return is template showing
*/ */
public boolean isTemplateShowing() { public boolean isTemplateShowing() {
return ((ExpandMutableTreeNode) this.getModel().getRoot()).getChildCount() == 0 ? false : true; return ((ExpandMutableTreeNode) this.getModel().getRoot()).getChildCount() != 0;
} }
/* /*
* 刷新 * 刷新
*/ */
public void refresh() { public void refresh() {
refresh((ExpandMutableTreeNode) this.getModel().getRoot(), StringUtils.EMPTY); refresh((ExpandMutableTreeNode) this.getModel().getRoot(), StringUtils.EMPTY);
} }
@ -136,8 +150,8 @@ public abstract class RefreshableJTree extends CheckBoxTree {
} }
/* /*
* 刷新expandRoot节点下所有已打开的节点的UserObject,并打开isExpanded为true的TreeNode * 刷新expandRoot节点下所有已打开的节点的UserObject,并打开isExpanded为true的TreeNode
*/ */
private void refresh(ExpandMutableTreeNode expandRoot, String childName) { private void refresh(ExpandMutableTreeNode expandRoot, String childName) {
if (expandRoot == null) { if (expandRoot == null) {
return; return;
@ -152,8 +166,8 @@ public abstract class RefreshableJTree extends CheckBoxTree {
} }
/* /*
* 刷新eTreeNode下面所有的已完成过取数的非叶子节点的子叶内容UserObject * 刷新eTreeNode下面所有的已完成过取数的非叶子节点的子叶内容UserObject
*/ */
protected void refreshTreeNode(ExpandMutableTreeNode eTreeNode, String childName) { protected void refreshTreeNode(ExpandMutableTreeNode eTreeNode, String childName) {
// 如果eTreeNode是未取数状态,不用expand // 如果eTreeNode是未取数状态,不用expand
if (interceptRefresh(eTreeNode)) { if (interceptRefresh(eTreeNode)) {
@ -161,12 +175,12 @@ public abstract class RefreshableJTree extends CheckBoxTree {
} }
// 刷新当前eTreeNode下面的子节点的UserObject的数组 // 刷新当前eTreeNode下面的子节点的UserObject的数组
ExpandMutableTreeNode[] new_nodes = loadChildTreeNodes(eTreeNode); ExpandMutableTreeNode[] newNodes = loadChildTreeNodes(eTreeNode);
/* /*
* 保存下当前eTreeNode下的ChildTreeNode于childTreeNodeList 移除所有ChildTreeNode * 保存下当前eTreeNode下的ChildTreeNode于childTreeNodeList 移除所有ChildTreeNode
* 根据childUserObjects与childTreeNodeList的比对,重新构建eTreeNode * 根据childUserObjects与childTreeNodeList的比对,重新构建eTreeNode
*/ */
java.util.List<DefaultMutableTreeNode> childTreeNodeList = new java.util.ArrayList<DefaultMutableTreeNode>(); java.util.List<DefaultMutableTreeNode> childTreeNodeList = new java.util.ArrayList<DefaultMutableTreeNode>();
for (int i = 0, len = eTreeNode.getChildCount(); i < len; i++) { for (int i = 0, len = eTreeNode.getChildCount(); i < len; i++) {
if (eTreeNode.getChildAt(i) instanceof ExpandMutableTreeNode) { if (eTreeNode.getChildAt(i) instanceof ExpandMutableTreeNode) {
@ -178,29 +192,29 @@ public abstract class RefreshableJTree extends CheckBoxTree {
eTreeNode.removeAllChildren(); eTreeNode.removeAllChildren();
for (int ci = 0; ci < new_nodes.length; ci++) { for (int ci = 0; ci < newNodes.length; ci++) {
Object cUserObject = new_nodes[ci].getUserObject(); Object cUserObject = newNodes[ci].getUserObject();
for (int ni = 0, nlen = childTreeNodeList.size(); ni < nlen; ni++) { for (int ni = 0, len = childTreeNodeList.size(); ni < len; ni++) {
ExpandMutableTreeNode cTreeNode = (ExpandMutableTreeNode) childTreeNodeList.get(ni); ExpandMutableTreeNode cTreeNode = (ExpandMutableTreeNode) childTreeNodeList.get(ni);
if (ComparatorUtils.equals(cTreeNode.getUserObject(), cUserObject)) { if (ComparatorUtils.equals(cTreeNode.getUserObject(), cUserObject)) {
new_nodes[ci].setExpanded(cTreeNode.isExpanded()); newNodes[ci].setExpanded(cTreeNode.isExpanded());
break; break;
} }
} }
eTreeNode.add(new_nodes[ci]); eTreeNode.add(newNodes[ci]);
} }
} }
/* /*
* 判断eTreeNode是否需要Refresh,可提前中止,返回true则表示提前中止,不需要Refresh * 判断eTreeNode是否需要Refresh,可提前中止,返回true则表示提前中止,不需要Refresh
*/ */
protected abstract boolean interceptRefresh(ExpandMutableTreeNode eTreeNode); protected abstract boolean interceptRefresh(ExpandMutableTreeNode eTreeNode);
/* /*
* 得到treeNode的子节点ExpandMutableTreeNode的数组 * 得到treeNode的子节点ExpandMutableTreeNode的数组
*/ */
protected abstract ExpandMutableTreeNode[] loadChildTreeNodes(ExpandMutableTreeNode treeNode); protected abstract ExpandMutableTreeNode[] loadChildTreeNodes(ExpandMutableTreeNode treeNode);
public NameObject getSelectedNameObject() { public NameObject getSelectedNameObject() {
@ -223,6 +237,7 @@ public abstract class RefreshableJTree extends CheckBoxTree {
return null; return null;
} }
@Override
public String getToolTipText(MouseEvent event) { public String getToolTipText(MouseEvent event) {
String tip = null; String tip = null;
icon = new ImageIcon(); icon = new ImageIcon();
@ -238,7 +253,7 @@ public abstract class RefreshableJTree extends CheckBoxTree {
Object lastPath = path.getLastPathComponent(); Object lastPath = path.getLastPathComponent();
if (lastPath instanceof TreeNode) { if (lastPath instanceof TreeNode) {
TreeNode treeNode = (TreeNode) lastPath; TreeNode treeNode = (TreeNode) lastPath;
while (treeNode.getParent() instanceof TreeNode) { while (treeNode.getParent() != null) {
i++; i++;
treeNode = treeNode.getParent(); treeNode = treeNode.getParent();
} }
@ -260,6 +275,7 @@ public abstract class RefreshableJTree extends CheckBoxTree {
return tip; return tip;
} }
@Override
public Point getToolTipLocation(MouseEvent event) { public Point getToolTipLocation(MouseEvent event) {
if (event != null) { if (event != null) {
Point p = event.getPoint(); Point p = event.getPoint();
@ -268,12 +284,16 @@ public abstract class RefreshableJTree extends CheckBoxTree {
if (selRow != -1 && r != null) { if (selRow != -1 && r != null) {
TreePath path = getPathForRow(selRow); TreePath path = getPathForRow(selRow);
Rectangle pathBounds = getPathBounds(path); Rectangle pathBounds = getPathBounds(path);
return new Point(pathBounds.x - 2, pathBounds.y - 1); if (pathBounds != null) {
return new Point(pathBounds.x - 2, pathBounds.y - 1);
}
return null;
} }
} }
return null; return null;
} }
@Override
public JToolTip createToolTip() { public JToolTip createToolTip() {
UIToolTip tip = new UIToolTip(icon); UIToolTip tip = new UIToolTip(icon);
tip.setComponent(this); tip.setComponent(this);

4
designer-base/src/main/java/com/fr/design/remote/ui/AuthorityEditorPane.java

@ -12,10 +12,10 @@ import com.fr.general.Inter;
import com.fr.report.DesignAuthority; import com.fr.report.DesignAuthority;
import com.fr.stable.CoreConstants; import com.fr.stable.CoreConstants;
import javax.swing.*; import javax.swing.BorderFactory;
import javax.swing.border.EmptyBorder; import javax.swing.border.EmptyBorder;
import javax.swing.tree.TreePath; import javax.swing.tree.TreePath;
import java.awt.*; import java.awt.BorderLayout;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;

126
designer-base/src/main/java/com/fr/design/remote/ui/UserManagerPane.java

@ -13,7 +13,7 @@ import com.fr.design.remote.ui.list.AddedMemberListCellRender;
import com.fr.design.remote.ui.list.AddingMemberList; import com.fr.design.remote.ui.list.AddingMemberList;
import com.fr.design.remote.ui.list.AddingMemberListCellRender; import com.fr.design.remote.ui.list.AddingMemberListCellRender;
import com.fr.design.remote.ui.list.MemberListSelectedChangeListener; import com.fr.design.remote.ui.list.MemberListSelectedChangeListener;
import com.fr.general.Inter; import com.fr.locale.InterProviderFactory;
import com.fr.stable.StringUtils; import com.fr.stable.StringUtils;
import com.fr.third.guava.collect.ImmutableList; import com.fr.third.guava.collect.ImmutableList;
import com.fr.workspace.WorkContext; import com.fr.workspace.WorkContext;
@ -23,9 +23,12 @@ import com.fr.workspace.server.authority.decision.DecisionOperator;
import javax.swing.BorderFactory; import javax.swing.BorderFactory;
import javax.swing.DefaultListModel; import javax.swing.DefaultListModel;
import javax.swing.JPanel; import javax.swing.JPanel;
import javax.swing.JViewport;
import javax.swing.ListSelectionModel; import javax.swing.ListSelectionModel;
import javax.swing.SwingWorker; import javax.swing.SwingWorker;
import javax.swing.border.EmptyBorder; import javax.swing.border.EmptyBorder;
import javax.swing.event.DocumentEvent;
import javax.swing.event.DocumentListener;
import java.awt.BorderLayout; import java.awt.BorderLayout;
import java.awt.Color; import java.awt.Color;
import java.awt.Component; import java.awt.Component;
@ -33,10 +36,15 @@ import java.awt.Dimension;
import java.awt.FlowLayout; import java.awt.FlowLayout;
import java.awt.event.ActionEvent; import java.awt.event.ActionEvent;
import java.awt.event.ActionListener; import java.awt.event.ActionListener;
import java.awt.event.AdjustmentEvent;
import java.awt.event.AdjustmentListener;
import java.awt.event.KeyAdapter; import java.awt.event.KeyAdapter;
import java.awt.event.KeyEvent; import java.awt.event.KeyEvent;
import java.awt.event.MouseWheelEvent;
import java.awt.event.MouseWheelListener;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.Collection;
import java.util.List; import java.util.List;
@ -45,10 +53,15 @@ import java.util.List;
*/ */
public class UserManagerPane extends BasicPane { public class UserManagerPane extends BasicPane {
/**
* 每页个数
*/
private final int DEFAULT_NUM_EACH_PAGE = 50;
/** /**
* 获取的决策平台成员 * 获取的决策平台成员
*/ */
private List<RemoteDesignMember> addingMembers = new ArrayList<>(); private final List<RemoteDesignMember> addingMembers = new ArrayList<>();
/** /**
* 添加到设计的决策平台成员 * 添加到设计的决策平台成员
*/ */
@ -73,7 +86,7 @@ public class UserManagerPane extends BasicPane {
private ActionListener keyButtonActionListener = new ActionListener() { private ActionListener keyButtonActionListener = new ActionListener() {
@Override @Override
public void actionPerformed(ActionEvent e) { public void actionPerformed(ActionEvent e) {
searchAddingMembers(keyField.getText()); searchAddingMembers(keyWord);
} }
}; };
@ -84,9 +97,9 @@ public class UserManagerPane extends BasicPane {
@Override @Override
public void keyReleased(KeyEvent e) { public void keyReleased(KeyEvent e) {
// 判断按下的键是否是回车键 // 判断按下的键是否是回车键
// todo 对话框回车键绑定的是对话框的确定按钮 // 对话框回车键绑定的是对话框的确定按钮,因此按确定没有办法搜索
if (e.getKeyCode() == KeyEvent.VK_ENTER) { if (e.getKeyCode() == KeyEvent.VK_ENTER) {
searchAddingMembers(keyField.getText()); searchAddingMembers(keyWord);
} }
} }
}; };
@ -125,7 +138,7 @@ public class UserManagerPane extends BasicPane {
sync2AddedMembersFormAdded(); sync2AddedMembersFormAdded();
// 不需要重复更新右侧列表显示 但是更新一下计数显示 // 不需要重复更新右侧列表显示 但是更新一下计数显示
countLabel.setText( countLabel.setText(
Inter.getLocText("Fine-Designer_Remote_Design_Selected_Member_Count", InterProviderFactory.getProvider().getLocText("Fine-Designer_Remote_Design_Selected_Member_Count",
String.valueOf(addedMembers.size()) String.valueOf(addedMembers.size())
) )
); );
@ -134,9 +147,47 @@ public class UserManagerPane extends BasicPane {
} }
}; };
/**
* 已经添加的成员列表
*/
private AddedMemberList addedList; private AddedMemberList addedList;
/**
* 待添加的成员列表
*/
private AddingMemberList addingList; private AddingMemberList addingList;
/**
* 搜索关键字
*/
private String keyWord;
/**
* 搜索关键词变更监听
*/
private DocumentListener documentListener = new DocumentListener() {
@Override
public void insertUpdate(DocumentEvent e) {
keyWord = keyField.getText();
}
@Override
public void removeUpdate(DocumentEvent e) {
keyWord = keyField.getText();
}
@Override
public void changedUpdate(DocumentEvent e) {
keyWord = keyField.getText();
}
};
/**
* 当前分页计数
*/
private int pageNum = 1;
public UserManagerPane() { public UserManagerPane() {
this.setBorder(BorderFactory.createEmptyBorder()); this.setBorder(BorderFactory.createEmptyBorder());
@ -155,7 +206,7 @@ public class UserManagerPane extends BasicPane {
@Override @Override
protected String title4PopupWindow() { protected String title4PopupWindow() {
return Inter.getLocText("Fine-Designer_Remote_Design_Add_Member"); return InterProviderFactory.getProvider().getLocText("Fine-Designer_Remote_Design_Add_Member");
} }
private JPanel createLeftPanel() { private JPanel createLeftPanel() {
@ -165,7 +216,7 @@ public class UserManagerPane extends BasicPane {
BorderFactory.createCompoundBorder( BorderFactory.createCompoundBorder(
new EmptyBorder(6, 0, 0, 0), new EmptyBorder(6, 0, 0, 0),
UITitledBorder.createBorderWithTitle( UITitledBorder.createBorderWithTitle(
Inter.getLocText("Fine-Designer_Remote_Design_Decision_Member") InterProviderFactory.getProvider().getLocText("Fine-Designer_Remote_Design_Decision_Member")
) )
) )
); );
@ -176,7 +227,8 @@ public class UserManagerPane extends BasicPane {
keyField.setPreferredSize(new Dimension(250, 20)); keyField.setPreferredSize(new Dimension(250, 20));
keyField.requestFocus(); keyField.requestFocus();
keyField.addKeyListener(keyFieldKeyListener); keyField.addKeyListener(keyFieldKeyListener);
keyButton.setText(Inter.getLocText("Fine-Designer_Remote_Design_Search")); keyField.getDocument().addDocumentListener(documentListener);
keyButton.setText(InterProviderFactory.getProvider().getLocText("Fine-Designer_Remote_Design_Search"));
keyButton.addActionListener(keyButtonActionListener); keyButton.addActionListener(keyButtonActionListener);
searchPanel.add(keyField); searchPanel.add(keyField);
searchPanel.add(keyButton); searchPanel.add(keyButton);
@ -189,7 +241,25 @@ public class UserManagerPane extends BasicPane {
resetMembers(); resetMembers();
addToMemberList(); addToMemberList();
searchAddingMembers(StringUtils.EMPTY); searchAddingMembers(StringUtils.EMPTY);
UIScrollPane listPane = new UIScrollPane(addingList); final UIScrollPane listPane = new UIScrollPane(addingList);
listPane.addMouseWheelListener(new MouseWheelListener() {
@Override
public void mouseWheelMoved(MouseWheelEvent e) {
JViewport vp = listPane.getViewport();
if (vp.getView().getHeight() <= vp.getHeight() + vp.getViewPosition().y) {
loadMoreAddingMembers(keyWord, DEFAULT_NUM_EACH_PAGE);
}
}
});
listPane.getVerticalScrollBar().addAdjustmentListener(new AdjustmentListener() {
@Override
public void adjustmentValueChanged(AdjustmentEvent e) {
JViewport vp = listPane.getViewport();
if (vp.getView().getHeight() <= vp.getHeight() + vp.getViewPosition().y && e.getValueIsAdjusting()) {
loadMoreAddingMembers(keyWord, DEFAULT_NUM_EACH_PAGE);
}
}
});
listPane.setBorder(BorderFactory.createEmptyBorder()); listPane.setBorder(BorderFactory.createEmptyBorder());
content.add(searchPanel, BorderLayout.NORTH); content.add(searchPanel, BorderLayout.NORTH);
@ -205,14 +275,14 @@ public class UserManagerPane extends BasicPane {
BorderFactory.createCompoundBorder( BorderFactory.createCompoundBorder(
new EmptyBorder(6, 0, 0, 0), new EmptyBorder(6, 0, 0, 0),
UITitledBorder.createBorderWithTitle( UITitledBorder.createBorderWithTitle(
Inter.getLocText("Fine-Designer_Remote_Design_Selected_Member") InterProviderFactory.getProvider().getLocText("Fine-Designer_Remote_Design_Selected_Member")
) )
) )
); );
// 计数 // 计数
countLabel.setText( countLabel.setText(
Inter.getLocText("Fine-Designer_Remote_Design_Selected_Member_Count", InterProviderFactory.getProvider().getLocText("Fine-Designer_Remote_Design_Selected_Member_Count",
String.valueOf(addedMembers.size())) String.valueOf(addedMembers.size()))
); );
countLabel.setBorder(BorderFactory.createEmptyBorder(7, 12, 8, 0)); countLabel.setBorder(BorderFactory.createEmptyBorder(7, 12, 8, 0));
@ -258,7 +328,7 @@ public class UserManagerPane extends BasicPane {
addedList.revalidate(); addedList.revalidate();
addedList.repaint(); addedList.repaint();
countLabel.setText( countLabel.setText(
Inter.getLocText("Fine-Designer_Remote_Design_Selected_Member_Count", InterProviderFactory.getProvider().getLocText("Fine-Designer_Remote_Design_Selected_Member_Count",
String.valueOf(addedMembers.size()) String.valueOf(addedMembers.size())
)); ));
} }
@ -280,7 +350,10 @@ public class UserManagerPane extends BasicPane {
protected List<RemoteDesignMember> doInBackground() { protected List<RemoteDesignMember> doInBackground() {
addingMembers.clear(); addingMembers.clear();
String username = WorkContext.getConnector().currentUser(); String username = WorkContext.getConnector().currentUser();
addingMembers.addAll(WorkContext.getCurrent().get(DecisionOperator.class).getMembers(username, keyword)); synchronized (addingMembers) {
addingMembers.addAll(WorkContext.getCurrent().get(DecisionOperator.class).getMembers(username, keyword));
pageNum = 1;
}
return addingMembers; return addingMembers;
} }
@ -292,6 +365,31 @@ public class UserManagerPane extends BasicPane {
getMemberWorker.execute(); getMemberWorker.execute();
} }
private void loadMoreAddingMembers(final String keyword, final int count) {
final SwingWorker loadMoreWorker = new SwingWorker<List<RemoteDesignMember>, Void>() {
@Override
protected List<RemoteDesignMember> doInBackground() {
String username = WorkContext.getConnector().currentUser();
synchronized (addingMembers) {
Collection<RemoteDesignMember> more =
WorkContext.getCurrent().get(DecisionOperator.class).getMembers(username, keyword, pageNum + 1, count);
if (!more.isEmpty()) {
pageNum += 1;
}
addingMembers.addAll(more);
}
return addingMembers;
}
@Override
protected void done() {
addToMemberList();
}
};
loadMoreWorker.execute();
}
private void sync2AddedMembersFromAdding() { private void sync2AddedMembersFromAdding() {
RemoteDesignMember[] members = new RemoteDesignMember[addingListModel.getSize()]; RemoteDesignMember[] members = new RemoteDesignMember[addingListModel.getSize()];

16
designer-base/src/main/java/com/fr/design/remote/ui/list/AddedMemberList.java

@ -3,8 +3,6 @@ package com.fr.design.remote.ui.list;
import com.fr.workspace.server.authority.RemoteDesignMember; import com.fr.workspace.server.authority.RemoteDesignMember;
import javax.swing.DefaultListModel; import javax.swing.DefaultListModel;
import java.awt.Point;
import java.awt.event.MouseEvent;
import java.util.Vector; import java.util.Vector;
public class AddedMemberList extends MemberList { public class AddedMemberList extends MemberList {
@ -25,20 +23,6 @@ public class AddedMemberList extends MemberList {
super(listData); super(listData);
} }
@Override
protected boolean shouldDisplaySelected(MouseEvent e) {
Point point = e.getPoint();
int rX = point.x;
int rY = point.y;
int index = this.getSelectedIndex();
int x = 280;
int y = 25 * index;
int width = 20;
int height = 25;
return x <= rX && rX <= x + width && y <= rY && rY <= y + height;
}
@Override @Override
protected void displaySelected() { protected void displaySelected() {
RemoteDesignMember member = getSelectedValue(); RemoteDesignMember member = getSelectedValue();

2
designer-base/src/main/java/com/fr/design/remote/ui/list/AddedMemberListCellRender.java

@ -24,7 +24,7 @@ public class AddedMemberListCellRender extends JPanel implements ListCellRendere
label = new UILabel(); label = new UILabel();
label.setIcon(BaseUtils.readIcon("com/fr/design/remote/images/icon_Member_normal@1x.png")); label.setIcon(BaseUtils.readIcon("com/fr/design/remote/images/icon_Member_normal@1x.png"));
label.setPreferredSize(new Dimension(270, 20)); label.setPreferredSize(new Dimension(260, 20));
this.setPreferredSize(new Dimension(this.getPreferredSize().width, 25)); this.setPreferredSize(new Dimension(this.getPreferredSize().width, 25));
this.add(label); this.add(label);

15
designer-base/src/main/java/com/fr/design/remote/ui/list/AddingMemberList.java

@ -3,8 +3,6 @@ package com.fr.design.remote.ui.list;
import com.fr.workspace.server.authority.RemoteDesignMember; import com.fr.workspace.server.authority.RemoteDesignMember;
import javax.swing.DefaultListModel; import javax.swing.DefaultListModel;
import java.awt.Point;
import java.awt.event.MouseEvent;
import java.util.Vector; import java.util.Vector;
public class AddingMemberList extends MemberList { public class AddingMemberList extends MemberList {
@ -36,19 +34,6 @@ public class AddingMemberList extends MemberList {
repaint(); repaint();
fireSelectedChange(); fireSelectedChange();
} }
@Override
protected boolean shouldDisplaySelected(MouseEvent e) {
Point point = e.getPoint();
int rX = point.x;
int rY = point.y;
int index = this.getSelectedIndex();
int x = 280;
int y = 25 * index;
int width = 25;
int height = 25;
return x <= rX && rX <= x + width && y <= rY && rY <= y + height;
}
} }

13
designer-base/src/main/java/com/fr/design/remote/ui/list/AddingMemberListCellRender.java

@ -24,7 +24,7 @@ public class AddingMemberListCellRender extends JPanel implements ListCellRender
this.setLayout(new FlowLayout(FlowLayout.LEFT)); this.setLayout(new FlowLayout(FlowLayout.LEFT));
label = new UILabel(); label = new UILabel();
label.setPreferredSize(new Dimension(270, 20)); label.setPreferredSize(new Dimension(260, 20));
this.setPreferredSize(new Dimension(this.getPreferredSize().width, 25)); this.setPreferredSize(new Dimension(this.getPreferredSize().width, 25));
label.setIcon(BaseUtils.readIcon("com/fr/design/remote/images/icon_Member_normal@1x.png")); label.setIcon(BaseUtils.readIcon("com/fr/design/remote/images/icon_Member_normal@1x.png"));
@ -39,8 +39,15 @@ public class AddingMemberListCellRender extends JPanel implements ListCellRender
@Override @Override
public Component getListCellRendererComponent(JList list, RemoteDesignMember member, int index, boolean isSelected, boolean cellHasFocus) { public Component getListCellRendererComponent(JList list, RemoteDesignMember member, int index, boolean isSelected, boolean cellHasFocus) {
this.setLabelText(member.getRealName() + "(" + member.getUsername() + ")");
check.setSelected(member.isSelected()); if (member.equals(RemoteDesignMember.DEFAULT_MEMBER)) {
this.setLabelText(member.getUsername());
check.setVisible(false);
} else {
this.setLabelText(member.getRealName() + "(" + member.getUsername() + ")");
check.setVisible(true);
check.setSelected(member.isSelected());
}
return this; return this;
} }

19
designer-base/src/main/java/com/fr/design/remote/ui/list/MemberList.java

@ -7,6 +7,7 @@ import javax.swing.DefaultListModel;
import javax.swing.JList; import javax.swing.JList;
import javax.swing.ListSelectionModel; import javax.swing.ListSelectionModel;
import java.awt.Color; import java.awt.Color;
import java.awt.Point;
import java.awt.event.KeyAdapter; import java.awt.event.KeyAdapter;
import java.awt.event.KeyEvent; import java.awt.event.KeyEvent;
import java.awt.event.MouseAdapter; import java.awt.event.MouseAdapter;
@ -14,6 +15,12 @@ import java.awt.event.MouseEvent;
import java.util.Vector; import java.util.Vector;
public abstract class MemberList extends JList<RemoteDesignMember> { public abstract class MemberList extends JList<RemoteDesignMember> {
static final int TRIGGER_AREA_X = 270;
static final int TRIGGER_AREA_Y_EACH = 25;
static final int TRIGGER_AREA_WIDTH = 25;
static final int TRIGGER_AREA_HEIGHT = 25;
public MemberList(DefaultListModel<RemoteDesignMember> dataModel) { public MemberList(DefaultListModel<RemoteDesignMember> dataModel) {
super(dataModel); super(dataModel);
@ -79,7 +86,13 @@ public abstract class MemberList extends JList<RemoteDesignMember> {
abstract protected void displaySelected(); abstract protected void displaySelected();
abstract protected boolean shouldDisplaySelected(MouseEvent e); protected boolean shouldDisplaySelected(MouseEvent e) {
Point point = e.getPoint();
int rX = point.x;
int rY = point.y;
int index = this.getSelectedIndex();
int x = TRIGGER_AREA_X;
int y = TRIGGER_AREA_Y_EACH * index;
return x <= rX && rX <= x + TRIGGER_AREA_WIDTH && y <= rY && rY <= y + TRIGGER_AREA_HEIGHT;
}
} }

BIN
designer-base/src/main/resources/com/fr/design/images/gui/filetree_folder_half_authority_normal.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 337 B

Loading…
Cancel
Save