Browse Source
修改核心逻辑。 遇到不明确的异常, 则将异常添加进来后,进行匹配检测 遇到明确的异常,通过 DetectorType 进行匹配处理 统一检测时,直接调用feature/x
20 changed files with 916 additions and 108 deletions
@ -0,0 +1,17 @@ |
|||||||
|
package com.fr.env.detect.bean; |
||||||
|
|
||||||
|
/** |
||||||
|
* created by Harrison on 2022/05/27 |
||||||
|
**/ |
||||||
|
public enum DetectorStatus { |
||||||
|
|
||||||
|
/** |
||||||
|
* 正常 |
||||||
|
*/ |
||||||
|
NORMAL, |
||||||
|
|
||||||
|
/** |
||||||
|
* 异常 |
||||||
|
*/ |
||||||
|
EXCEPTION, |
||||||
|
} |
@ -1,24 +1,36 @@ |
|||||||
package com.fr.env.detect.bean; |
package com.fr.env.detect.bean; |
||||||
|
|
||||||
|
import com.fr.log.FineLoggerFactory; |
||||||
|
|
||||||
/** |
/** |
||||||
* created by Harrison on 2022/05/13 |
* created by Harrison on 2022/05/13 |
||||||
**/ |
**/ |
||||||
public class ExceptionLog { |
public class ExceptionLog { |
||||||
|
|
||||||
private final String errorCode; |
private final String template; |
||||||
|
|
||||||
|
private final Object[] args; |
||||||
|
|
||||||
|
private ExceptionLog(String template, Object... args) { |
||||||
|
this.template = template; |
||||||
|
this.args = args; |
||||||
|
} |
||||||
|
|
||||||
|
public static ExceptionLog create(String template, Object... args) { |
||||||
|
|
||||||
|
return new ExceptionLog(template, args); |
||||||
|
} |
||||||
|
|
||||||
private final String locale; |
public void log() { |
||||||
|
|
||||||
public ExceptionLog(String errorCode, String locale) { |
FineLoggerFactory.getLogger().error(template, args); |
||||||
this.errorCode = errorCode; |
|
||||||
this.locale = locale; |
|
||||||
} |
} |
||||||
|
|
||||||
public String getErrorCode() { |
public String getTemplate() { |
||||||
return errorCode; |
return template; |
||||||
} |
} |
||||||
|
|
||||||
public String getLocale() { |
public Object[] getArgs() { |
||||||
return locale; |
return args; |
||||||
} |
} |
||||||
} |
} |
||||||
|
@ -0,0 +1,16 @@ |
|||||||
|
package com.fr.env.detect.impl; |
||||||
|
|
||||||
|
import com.fr.env.detect.base.CatchExceptionDetector; |
||||||
|
import com.fr.env.detect.bean.DetectorType; |
||||||
|
import com.fr.env.detect.impl.converter.FineDbLockedConverter; |
||||||
|
|
||||||
|
/** |
||||||
|
* created by Harrison on 2022/05/26 |
||||||
|
**/ |
||||||
|
public class FineDbLockedDetector extends CatchExceptionDetector { |
||||||
|
|
||||||
|
public FineDbLockedDetector() { |
||||||
|
super(DetectorType.FINE_DB_LOCKED, new FineDbLockedConverter()); |
||||||
|
} |
||||||
|
|
||||||
|
} |
@ -0,0 +1,15 @@ |
|||||||
|
package com.fr.env.detect.impl; |
||||||
|
|
||||||
|
import com.fr.env.detect.base.CatchExceptionDetector; |
||||||
|
import com.fr.env.detect.bean.DetectorType; |
||||||
|
import com.fr.env.detect.impl.converter.FineDbPermissionConverter; |
||||||
|
|
||||||
|
/** |
||||||
|
* created by Harrison on 2022/05/26 |
||||||
|
**/ |
||||||
|
public class FineDbPermissionDetector extends CatchExceptionDetector { |
||||||
|
|
||||||
|
public FineDbPermissionDetector() { |
||||||
|
super(DetectorType.FINE_DB_PERMISSION, new FineDbPermissionConverter()); |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,15 @@ |
|||||||
|
package com.fr.env.detect.impl; |
||||||
|
|
||||||
|
import com.fr.env.detect.base.CatchExceptionDetector; |
||||||
|
import com.fr.env.detect.bean.DetectorType; |
||||||
|
import com.fr.env.detect.impl.converter.ClassConfictConvertor; |
||||||
|
|
||||||
|
/** |
||||||
|
* created by Harrison on 2022/05/26 |
||||||
|
**/ |
||||||
|
public class JarConflictDetector extends CatchExceptionDetector { |
||||||
|
|
||||||
|
public JarConflictDetector() { |
||||||
|
super(DetectorType.JAR_CONFLICT, new ClassConfictConvertor()); |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,595 @@ |
|||||||
|
package com.fr.env.detect.ui; |
||||||
|
|
||||||
|
import com.fr.base.svg.IconUtils; |
||||||
|
import com.fr.design.components.notification.NotificationAction; |
||||||
|
import com.fr.design.components.notification.NotificationDialog; |
||||||
|
import com.fr.design.components.notification.NotificationDialogProperties; |
||||||
|
import com.fr.design.components.notification.NotificationMessage; |
||||||
|
import com.fr.design.components.notification.NotificationModel; |
||||||
|
import com.fr.design.components.notification.NotificationType; |
||||||
|
import com.fr.design.components.table.TablePanel; |
||||||
|
import com.fr.design.constants.DesignerColor; |
||||||
|
import com.fr.design.gui.ibutton.UIButton; |
||||||
|
import com.fr.design.gui.ibutton.UIButtonUI; |
||||||
|
import com.fr.design.gui.icheckbox.UICheckBox; |
||||||
|
import com.fr.design.gui.ilable.UILabel; |
||||||
|
import com.fr.design.i18n.Toolkit; |
||||||
|
import com.fr.design.layout.FRGUIPaneFactory; |
||||||
|
import com.fr.design.ui.util.UIUtil; |
||||||
|
import com.fr.design.utils.gui.GUICoreUtils; |
||||||
|
import com.fr.design.utils.gui.GUIPaintUtils; |
||||||
|
import com.fr.env.detect.base.DetectorBridge; |
||||||
|
import com.fr.env.detect.bean.DetectorResult; |
||||||
|
import com.fr.env.detect.bean.DetectorStatus; |
||||||
|
import com.fr.env.detect.bean.DetectorType; |
||||||
|
import com.fr.env.detect.bean.ExceptionSolution; |
||||||
|
import com.fr.env.detect.bean.ExceptionTips; |
||||||
|
import com.fr.env.detect.bean.Message; |
||||||
|
import com.fr.env.detect.bean.SolutionAction; |
||||||
|
import com.fr.third.guava.collect.Lists; |
||||||
|
import org.jetbrains.annotations.NotNull; |
||||||
|
|
||||||
|
import javax.swing.BorderFactory; |
||||||
|
import javax.swing.ImageIcon; |
||||||
|
import javax.swing.JDialog; |
||||||
|
import javax.swing.JPanel; |
||||||
|
import javax.swing.SwingWorker; |
||||||
|
import javax.swing.plaf.ButtonUI; |
||||||
|
import java.awt.BorderLayout; |
||||||
|
import java.awt.Color; |
||||||
|
import java.awt.Component; |
||||||
|
import java.awt.Dimension; |
||||||
|
import java.awt.Frame; |
||||||
|
import java.awt.Graphics2D; |
||||||
|
import java.awt.Image; |
||||||
|
import java.awt.event.MouseAdapter; |
||||||
|
import java.awt.event.MouseEvent; |
||||||
|
import java.net.URL; |
||||||
|
import java.util.ArrayList; |
||||||
|
import java.util.Collection; |
||||||
|
import java.util.LinkedHashMap; |
||||||
|
import java.util.List; |
||||||
|
import java.util.Map; |
||||||
|
import java.util.Objects; |
||||||
|
import java.util.Optional; |
||||||
|
import java.util.concurrent.TimeUnit; |
||||||
|
import java.util.function.Function; |
||||||
|
import java.util.stream.Collectors; |
||||||
|
import java.util.stream.Stream; |
||||||
|
|
||||||
|
/** |
||||||
|
* created by Harrison on 2022/05/26 |
||||||
|
**/ |
||||||
|
public class EnvDetectorDialog extends JDialog { |
||||||
|
|
||||||
|
private static final ImageIcon LOADING_ICON = getLoadingIcon(); |
||||||
|
|
||||||
|
private JPanel body; |
||||||
|
|
||||||
|
private final JPanel headerPanel; |
||||||
|
|
||||||
|
private final TablePanel tablePanel; |
||||||
|
|
||||||
|
private final JPanel tailPanel; |
||||||
|
|
||||||
|
/* 数据 model */ |
||||||
|
|
||||||
|
private EnvDetectorModel model = new EnvDetectorModel(); |
||||||
|
|
||||||
|
/* 流程 model */ |
||||||
|
|
||||||
|
/** |
||||||
|
* 默认是第一个要检测 |
||||||
|
*/ |
||||||
|
private int currentDetectIndex = 0; |
||||||
|
|
||||||
|
private EnvDetectorButtonStatus buttonStatus = EnvDetectorButtonStatus.START; |
||||||
|
|
||||||
|
private SwingWorker<Void, Void> detectWorker = null; |
||||||
|
|
||||||
|
public EnvDetectorDialog(Frame owner) { |
||||||
|
super(owner); |
||||||
|
|
||||||
|
configProperties(); |
||||||
|
|
||||||
|
this.body = FRGUIPaneFactory.createBorderLayout_L_Pane(); |
||||||
|
Color backgroundColor = new Color(240, 240, 243, 1); |
||||||
|
this.body.setBackground( backgroundColor); |
||||||
|
|
||||||
|
this.headerPanel = createHeaderPanel(); |
||||||
|
body.add(headerPanel, BorderLayout.NORTH); |
||||||
|
|
||||||
|
this.tablePanel = createTablePanel(); |
||||||
|
body.add(tablePanel, BorderLayout.CENTER); |
||||||
|
|
||||||
|
/* tailPanel*/ |
||||||
|
this.tailPanel = createTailPanel(); |
||||||
|
body.add(tailPanel, BorderLayout.SOUTH); |
||||||
|
|
||||||
|
add(body); |
||||||
|
|
||||||
|
Dimension preferredSize = body.getPreferredSize(); |
||||||
|
setSize(preferredSize); |
||||||
|
|
||||||
|
repaint(); |
||||||
|
pack(); |
||||||
|
|
||||||
|
GUICoreUtils.centerWindow(this); |
||||||
|
} |
||||||
|
|
||||||
|
@NotNull |
||||||
|
private JPanel createHeaderPanel() { |
||||||
|
|
||||||
|
JPanel headerPanel = FRGUIPaneFactory.createBorderLayout_S_Pane(); |
||||||
|
headerPanel.setBorder(BorderFactory.createEmptyBorder(5, 0, 12, 0)); |
||||||
|
UIButton detectButton = new UIButton(buttonStatus.getDesc()) { |
||||||
|
@Override |
||||||
|
public ButtonUI getUI() { |
||||||
|
|
||||||
|
return new UIButtonUI() { |
||||||
|
@Override |
||||||
|
protected void doExtraPainting(UIButton b, Graphics2D g2d, int w, int h, String selectedRoles) { |
||||||
|
if (isPressed(b) && b.isPressedPainted()) { |
||||||
|
GUIPaintUtils.fillPressed(g2d, 0, 0, w, h, b.isRoundBorder(), b.getRectDirection(), b.isDoneAuthorityEdited(selectedRoles), |
||||||
|
DesignerColor.Button.Primary.PRESSED); |
||||||
|
} else if (isRollOver(b)) { |
||||||
|
GUIPaintUtils.fillRollOver(g2d, 0, 0, w, h, b.isRoundBorder(), b.getRectDirection(), b.isDoneAuthorityEdited(selectedRoles), b.isPressedPainted(), |
||||||
|
DesignerColor.Button.Primary.HOVER); |
||||||
|
} else if (b.isNormalPainted()) { |
||||||
|
GUIPaintUtils.fillNormal(g2d, 0, 0, w, h, b.isRoundBorder(), b.getRectDirection(), b.isDoneAuthorityEdited(selectedRoles), b.isPressedPainted(), |
||||||
|
DesignerColor.Button.Primary.NORMAL); |
||||||
|
} |
||||||
|
} |
||||||
|
}; |
||||||
|
} |
||||||
|
}; |
||||||
|
detectButton.setForeground(Color.WHITE); |
||||||
|
detectButton.addActionListener(event -> { |
||||||
|
if (buttonStatus.isNotExecuting()) { |
||||||
|
startDetecting(detectButton); |
||||||
|
} else { |
||||||
|
stopDetecting(detectButton); |
||||||
|
} |
||||||
|
}); |
||||||
|
detectButton.setPreferredSize(new Dimension(68, 20)); |
||||||
|
detectButton.setBorderPainted(false); |
||||||
|
detectButton.setContentAreaFilled(false); |
||||||
|
headerPanel.add(detectButton, BorderLayout.WEST); |
||||||
|
|
||||||
|
return headerPanel; |
||||||
|
} |
||||||
|
|
||||||
|
private void startDetecting(UIButton detectButton) { |
||||||
|
|
||||||
|
// 执行前
|
||||||
|
buttonStatus = buttonStatus.next(); |
||||||
|
UIUtil.invokeLaterIfNeeded(() -> detectButton.setText(buttonStatus.getDesc())); |
||||||
|
detectWorker = new SwingWorker<Void, Void>() { |
||||||
|
|
||||||
|
@Override |
||||||
|
protected Void doInBackground() throws Exception { |
||||||
|
List<EnvDetectorItem> items = model.getItems(); |
||||||
|
// 执行刷新
|
||||||
|
for (int i = currentDetectIndex; i < items.size(); i++) { |
||||||
|
|
||||||
|
// 看一下是否关闭了, 有可能已经关闭了。
|
||||||
|
if (buttonStatus.isNotExecuting()) { |
||||||
|
return null; |
||||||
|
} |
||||||
|
|
||||||
|
// 刷新一下面板-开始执行啦
|
||||||
|
UIUtil.invokeLaterIfNeeded(EnvDetectorDialog.this::refresh); |
||||||
|
|
||||||
|
EnvDetectorItem item = items.get(i); |
||||||
|
DetectorType type = item.getType(); |
||||||
|
|
||||||
|
// 执行检测, UI-当前在检测中
|
||||||
|
Optional<DetectorResult> detect = UIUtil.waitUntil( |
||||||
|
() -> DetectorBridge.getInstance().detect(type), |
||||||
|
1000, TimeUnit.MILLISECONDS); |
||||||
|
// 获取结果,更新UI
|
||||||
|
detect.ifPresent(item::setResult); |
||||||
|
|
||||||
|
// 只有还在运行中,才会真正的刷新面板
|
||||||
|
if (buttonStatus.isExecuting()) { |
||||||
|
// 在刷新一下面板
|
||||||
|
UIUtil.invokeLaterIfNeeded(EnvDetectorDialog.this::refresh); |
||||||
|
currentDetectIndex++; |
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
|
return null; |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
protected void done() { |
||||||
|
|
||||||
|
if (buttonStatus.isExecuting()) { |
||||||
|
// 执行结束
|
||||||
|
buttonStatus = buttonStatus.next(); |
||||||
|
UIUtil.invokeLaterIfNeeded(() -> detectButton.setText(buttonStatus.getDesc())); |
||||||
|
} |
||||||
|
} |
||||||
|
}; |
||||||
|
// 开始执行
|
||||||
|
detectWorker.execute(); |
||||||
|
} |
||||||
|
|
||||||
|
private void stopDetecting(UIButton detectButton) { |
||||||
|
|
||||||
|
buttonStatus = buttonStatus.next(); |
||||||
|
|
||||||
|
// 先停止
|
||||||
|
detectWorker.cancel(false); |
||||||
|
// 更改-UI
|
||||||
|
// 执行中
|
||||||
|
UIUtil.invokeLaterIfNeeded(() -> { |
||||||
|
// 刷新按钮
|
||||||
|
detectButton.setText(buttonStatus.getDesc()); |
||||||
|
// 刷新面板
|
||||||
|
refresh(); |
||||||
|
}); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
@NotNull |
||||||
|
private TablePanel createTablePanel() { |
||||||
|
|
||||||
|
TablePanel tablePanel = new TablePanel(18, 3); |
||||||
|
tablePanel.updateHeaders(new String[] { |
||||||
|
Toolkit.i18nText("Fine-Design_Basic_Detect_Kind"), |
||||||
|
Toolkit.i18nText("Fine-Design_Basic_Detect_Item"), |
||||||
|
Toolkit.i18nText("Fine-Design_Basic_Detect_Result")}); |
||||||
|
|
||||||
|
updateTable(tablePanel); |
||||||
|
|
||||||
|
return tablePanel; |
||||||
|
} |
||||||
|
|
||||||
|
private void updateTable(TablePanel tablePanel) { |
||||||
|
|
||||||
|
Map<DetectorType.Kind, List<EnvDetectorItem>> itemMap = model.getItemMap(); |
||||||
|
|
||||||
|
// 行号, 这边更新是通过 行/列 。 不是索引
|
||||||
|
int row = 1; |
||||||
|
for (Map.Entry<DetectorType.Kind, List<EnvDetectorItem>> entry : itemMap.entrySet()) { |
||||||
|
|
||||||
|
DetectorType.Kind kind = entry.getKey(); |
||||||
|
List<EnvDetectorItem> items = entry.getValue(); |
||||||
|
for (int i = 0; i < items.size(); i++) { |
||||||
|
if (i == 0) { |
||||||
|
tablePanel.updateCell(row, 1, kind.getDescription()); |
||||||
|
} |
||||||
|
EnvDetectorItem item = items.get(i); |
||||||
|
tablePanel.updateCell(row, 2, new UILabel(item.getDescription())); |
||||||
|
DetectorResult result = item.getResult(); |
||||||
|
|
||||||
|
int detectRow = currentDetectIndex + 1; |
||||||
|
|
||||||
|
if (result == null) { |
||||||
|
// 处于非正在检测状态 或者 索引不等于当前行号的时候
|
||||||
|
UILabel label; |
||||||
|
if (buttonStatus.isExecuting() && detectRow == row) { |
||||||
|
// 正在检测索引
|
||||||
|
label = new UILabel(LOADING_ICON, UILabel.LEADING); |
||||||
|
} else { |
||||||
|
label = new UILabel("-"); |
||||||
|
} |
||||||
|
tablePanel.updateCell(row, 3, label); |
||||||
|
} else { |
||||||
|
Component resultComponent = createResultComponent(result); |
||||||
|
tablePanel.updateCell(row, 3, resultComponent); |
||||||
|
} |
||||||
|
row++; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
private static ImageIcon getLoadingIcon() { |
||||||
|
|
||||||
|
URL resource = EnvDetectorDialog.class.getResource("/com/fr/design/standard/loading/loading-120.gif"); |
||||||
|
if (resource == null) { |
||||||
|
return null; |
||||||
|
} |
||||||
|
ImageIcon loadingIcon = new ImageIcon(resource); |
||||||
|
int width = 16; |
||||||
|
int height = 16; |
||||||
|
loadingIcon.setImage(loadingIcon.getImage().getScaledInstance(width, height, Image.SCALE_DEFAULT)); |
||||||
|
return loadingIcon; |
||||||
|
} |
||||||
|
|
||||||
|
private Component createResultComponent(DetectorResult result) { |
||||||
|
|
||||||
|
JPanel statusPanel = FRGUIPaneFactory.createBorderLayout_S_Pane(); |
||||||
|
if (result.getStatus() == DetectorStatus.NORMAL) { |
||||||
|
statusPanel.add(new UILabel(IconUtils.readIcon("/com/fr/design/standard/reminder/reminder_success.svg")), BorderLayout.WEST); |
||||||
|
statusPanel.add(new UILabel(Toolkit.i18nText("Fine-Design_Basic_Normal")), BorderLayout.CENTER); |
||||||
|
} else { |
||||||
|
statusPanel.add(new UILabel(IconUtils.readIcon("/com/fr/design/standard/reminder/reminder_error.svg")), BorderLayout.WEST); |
||||||
|
statusPanel.add(new UILabel(Toolkit.i18nText("Fine-Design_Basic_Exception")), BorderLayout.CENTER); |
||||||
|
UILabel detailLabel = new UILabel(Toolkit.i18nText("Fine_Designer_Look_Detail")); |
||||||
|
detailLabel.setForeground(new Color(65, 155, 249)); |
||||||
|
detailLabel.addMouseListener(new MouseAdapter() { |
||||||
|
@Override |
||||||
|
public void mouseClicked(MouseEvent mouseEvent) { |
||||||
|
NotificationDialogProperties properties = new NotificationDialogProperties((Frame) EnvDetectorDialog.this.getOwner(), Toolkit.i18nText("Fine-Design_Basic_Detect_Notification_Title")); |
||||||
|
Stream<DetectorResult> results = model.getResults(); |
||||||
|
List<NotificationModel> notificationModels = results |
||||||
|
.filter(Objects::nonNull) |
||||||
|
.filter((e) -> e.getStatus() == DetectorStatus.EXCEPTION) |
||||||
|
.map(EnvDetectorDialog.this::convertDetectorResult) |
||||||
|
.collect(Collectors.toList()); |
||||||
|
|
||||||
|
NotificationDialog dialog = new NotificationDialog(properties, notificationModels); |
||||||
|
dialog.open(); |
||||||
|
} |
||||||
|
}); |
||||||
|
statusPanel.add(detailLabel); |
||||||
|
} |
||||||
|
return statusPanel; |
||||||
|
} |
||||||
|
|
||||||
|
private NotificationModel convertDetectorResult(DetectorResult result) { |
||||||
|
|
||||||
|
List<NotificationMessage> messages = new ArrayList<>(); |
||||||
|
|
||||||
|
Function<Message, Optional<NotificationMessage>> convert2NotificationMsg = message -> { |
||||||
|
|
||||||
|
NotificationMessage notificationMessage = null; |
||||||
|
if (message != null) { |
||||||
|
Message.Type type = message.getType(); |
||||||
|
switch (type) { |
||||||
|
case SIMPLE: |
||||||
|
notificationMessage = (new NotificationMessage.SimpleMessage(message.get())); |
||||||
|
break; |
||||||
|
case LINK: |
||||||
|
Message.Link linkMsg = (Message.Link) message; |
||||||
|
notificationMessage = new NotificationMessage.LinkMessage(linkMsg.getText(), linkMsg.getLink()); |
||||||
|
break; |
||||||
|
default: |
||||||
|
break; |
||||||
|
} |
||||||
|
} |
||||||
|
return Optional.ofNullable(notificationMessage); |
||||||
|
}; |
||||||
|
|
||||||
|
ExceptionTips tips = result.getTips(); |
||||||
|
convert2NotificationMsg |
||||||
|
.apply(tips.getMessage()) |
||||||
|
.ifPresent(messages::add); |
||||||
|
|
||||||
|
ExceptionSolution solution = result.getSolution(); |
||||||
|
convert2NotificationMsg.apply(solution.getMessage()) |
||||||
|
.ifPresent(messages::add); |
||||||
|
|
||||||
|
NotificationAction notificationAction = null; |
||||||
|
SolutionAction solutionAction = solution.getAction(); |
||||||
|
if (solutionAction != null) { |
||||||
|
notificationAction = new NotificationAction() { |
||||||
|
@Override |
||||||
|
public String name() { |
||||||
|
return solutionAction.name(); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public void run(Object... args) { |
||||||
|
solutionAction.run(); |
||||||
|
} |
||||||
|
}; |
||||||
|
} |
||||||
|
|
||||||
|
return new NotificationModel(NotificationType.WARNING, notificationAction, messages); |
||||||
|
} |
||||||
|
|
||||||
|
private void refresh() { |
||||||
|
|
||||||
|
updateTable(this.tablePanel); |
||||||
|
pack(); |
||||||
|
repaint(); |
||||||
|
} |
||||||
|
|
||||||
|
@NotNull |
||||||
|
private JPanel createTailPanel() { |
||||||
|
|
||||||
|
JPanel tailPanel = FRGUIPaneFactory.createBorderLayout_S_Pane(); |
||||||
|
tailPanel.setBorder(BorderFactory.createEmptyBorder(20, 0, 0, 0)); |
||||||
|
|
||||||
|
JPanel configPanel = FRGUIPaneFactory.createBorderLayout_S_Pane(); |
||||||
|
{ |
||||||
|
UICheckBox checkBox = new UICheckBox(); |
||||||
|
configPanel.add(checkBox, BorderLayout.WEST); |
||||||
|
UILabel description = new UILabel(Toolkit.i18nText("Fine-Design_Basic_Detect_Switch")); |
||||||
|
configPanel.add(description, BorderLayout.EAST); |
||||||
|
} |
||||||
|
tailPanel.add(configPanel, BorderLayout.WEST); |
||||||
|
|
||||||
|
JPanel actionsPanel = FRGUIPaneFactory.createBorderLayout_S_Pane(); |
||||||
|
actionsPanel.setLayout(FRGUIPaneFactory.createM_BorderLayout()); |
||||||
|
{ |
||||||
|
UIButton confirmButton = new UIButton(Toolkit.i18nText("Fine-Design_Basic_Confirm")); |
||||||
|
confirmButton.addActionListener((e) -> { |
||||||
|
setVisible(false); |
||||||
|
dispose(); |
||||||
|
// 配置处理
|
||||||
|
// todo
|
||||||
|
}); |
||||||
|
actionsPanel.add(confirmButton, BorderLayout.WEST); |
||||||
|
|
||||||
|
UIButton cancelButton = new UIButton(Toolkit.i18nText("Fine-Design_Basic_Cancel")); |
||||||
|
cancelButton.addActionListener((e) -> { |
||||||
|
setVisible(false); |
||||||
|
dispose(); |
||||||
|
}); |
||||||
|
actionsPanel.add(cancelButton, BorderLayout.EAST); |
||||||
|
} |
||||||
|
tailPanel.add(actionsPanel, BorderLayout.EAST); |
||||||
|
return tailPanel; |
||||||
|
} |
||||||
|
|
||||||
|
private void configProperties() { |
||||||
|
|
||||||
|
setTitle(Toolkit.i18nText("Fine-Design_Basic_Detect_Title")); |
||||||
|
setModal(false); |
||||||
|
setFocusable(false); |
||||||
|
setAutoRequestFocus(false); |
||||||
|
setResizable(false); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 数据 model |
||||||
|
* |
||||||
|
* kind-list_item |
||||||
|
*/ |
||||||
|
private class EnvDetectorModel { |
||||||
|
|
||||||
|
private Map<DetectorType.Kind, List<EnvDetectorItem>> itemMap = new LinkedHashMap<>(); |
||||||
|
|
||||||
|
public EnvDetectorModel() { |
||||||
|
|
||||||
|
itemMap.put(DetectorType.Kind.JAR, Lists.newArrayList(new EnvDetectorItem(DetectorType.LACK_OF_JAR), new EnvDetectorItem(DetectorType.JAR_IN_CONSISTENCE), new EnvDetectorItem(DetectorType.JAR_CONFLICT))); |
||||||
|
|
||||||
|
itemMap.put(DetectorType.Kind.FINE_DB, Lists.newArrayList(new EnvDetectorItem(DetectorType.FINE_DB_LOCKED), new EnvDetectorItem(DetectorType.FINE_DB_PERMISSION), new EnvDetectorItem(DetectorType.FINE_DB_DIRTY))); |
||||||
|
} |
||||||
|
|
||||||
|
public void update(DetectorType type, DetectorResult result) { |
||||||
|
|
||||||
|
List<EnvDetectorItem> items = itemMap.get(type.getKind()); |
||||||
|
items.stream() |
||||||
|
.filter((e) -> e.getType() == type) |
||||||
|
.findFirst() |
||||||
|
.ifPresent((e) -> {e.setResult(result);}); |
||||||
|
} |
||||||
|
|
||||||
|
public Stream<DetectorResult> getResults() { |
||||||
|
|
||||||
|
return getItems().stream() |
||||||
|
.map(EnvDetectorItem::getResult); |
||||||
|
} |
||||||
|
|
||||||
|
public List<EnvDetectorItem> getItems() { |
||||||
|
|
||||||
|
return itemMap.values().stream() |
||||||
|
.flatMap(Collection::stream) |
||||||
|
.collect(Collectors.toList()); |
||||||
|
} |
||||||
|
|
||||||
|
public Map<DetectorType.Kind, List<EnvDetectorItem>> getItemMap() { |
||||||
|
|
||||||
|
return this.itemMap; |
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
private class EnvDetectorItem { |
||||||
|
|
||||||
|
private DetectorType type; |
||||||
|
|
||||||
|
private DetectorResult result; |
||||||
|
|
||||||
|
public EnvDetectorItem(DetectorType detectorType) { |
||||||
|
this.type = detectorType; |
||||||
|
} |
||||||
|
|
||||||
|
public DetectorType getType() { |
||||||
|
return type; |
||||||
|
} |
||||||
|
|
||||||
|
public String getKind() { |
||||||
|
return this.type.getKind().getDescription(); |
||||||
|
} |
||||||
|
|
||||||
|
public String getDescription() { |
||||||
|
return this.type.getDescription(); |
||||||
|
} |
||||||
|
|
||||||
|
public DetectorResult getResult() { |
||||||
|
return result; |
||||||
|
} |
||||||
|
|
||||||
|
public void setResult(DetectorResult result) { |
||||||
|
this.result = result; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 按钮的当前状态 |
||||||
|
*/ |
||||||
|
private enum EnvDetectorButtonStatus { |
||||||
|
|
||||||
|
/** |
||||||
|
* 开始 -> 停止 |
||||||
|
*/ |
||||||
|
START("Fine-Design_Basic_Detect_Start") { |
||||||
|
@Override |
||||||
|
public EnvDetectorButtonStatus next() { |
||||||
|
return STOP; |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
/** |
||||||
|
* 停止 -> 继续 |
||||||
|
*/ |
||||||
|
STOP("Fine-Design_Basic_Detect_Stop") { |
||||||
|
@Override |
||||||
|
public EnvDetectorButtonStatus next() { |
||||||
|
return CONTINUE; |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
/** |
||||||
|
* 继续 -> 停止 |
||||||
|
*/ |
||||||
|
CONTINUE("Fine-Design_Basic_Detect_Continue") { |
||||||
|
@Override |
||||||
|
public EnvDetectorButtonStatus next() { |
||||||
|
return STOP; |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
/** |
||||||
|
* 重新 -> 停止 |
||||||
|
*/ |
||||||
|
A_NEW("Fine-Design_Basic_Detect_A_New") { |
||||||
|
@Override |
||||||
|
public EnvDetectorButtonStatus next() { |
||||||
|
return STOP; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
; |
||||||
|
|
||||||
|
private String descLocale; |
||||||
|
|
||||||
|
EnvDetectorButtonStatus(String descLocale) { |
||||||
|
|
||||||
|
this.descLocale = descLocale; |
||||||
|
} |
||||||
|
|
||||||
|
public String getDesc() { |
||||||
|
|
||||||
|
return Toolkit.i18nText(descLocale); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 在执行中 |
||||||
|
* |
||||||
|
* @return 是/否 |
||||||
|
*/ |
||||||
|
public boolean isExecuting() { |
||||||
|
|
||||||
|
return this == EnvDetectorButtonStatus.STOP; |
||||||
|
}; |
||||||
|
|
||||||
|
/** |
||||||
|
* 不在执行中 |
||||||
|
* |
||||||
|
* @return 是/否 |
||||||
|
*/ |
||||||
|
public boolean isNotExecuting() { |
||||||
|
|
||||||
|
return !isExecuting(); |
||||||
|
} |
||||||
|
|
||||||
|
public abstract EnvDetectorButtonStatus next(); |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue