forked from fanruan/design
Browse Source
Merge in DESIGN/design from ~VITO/c-design:feature/10.0 to feature/10.0 * commit '6f0afeacd5668f4e49d82ef405428bc80b877b9d': REPORT-52942 处理插件提到公共模块稍后展示feature/10.0
vito
4 years ago
3 changed files with 85 additions and 64 deletions
@ -0,0 +1,83 @@ |
|||||||
|
package com.fr.design.mainframe.app; |
||||||
|
|
||||||
|
import com.fr.design.dialog.DialogActionAdapter; |
||||||
|
import com.fr.design.dialog.UIExpandDialog; |
||||||
|
import com.fr.design.extra.exe.callback.InstallOnlineCallback; |
||||||
|
import com.fr.design.extra.exe.callback.ModifyStatusCallback; |
||||||
|
import com.fr.design.i18n.Toolkit; |
||||||
|
import com.fr.design.mainframe.DesignerContext; |
||||||
|
import com.fr.design.ui.util.UIUtil; |
||||||
|
import com.fr.io.TemplateIOErrorUtils; |
||||||
|
import com.fr.plugin.context.PluginMarker; |
||||||
|
import com.fr.plugin.context.PluginMarkerAdapter; |
||||||
|
import com.fr.plugin.manage.PluginManager; |
||||||
|
import com.fr.plugin.manage.control.PluginControllerHelper; |
||||||
|
import com.fr.plugin.manage.control.PluginTask; |
||||||
|
import com.fr.third.guava.collect.Multimap; |
||||||
|
import com.fr.workspace.WorkContext; |
||||||
|
|
||||||
|
import java.util.Collection; |
||||||
|
|
||||||
|
/** |
||||||
|
* 设计器app共用工具类 |
||||||
|
* |
||||||
|
* @author vito |
||||||
|
* @version 10.0 |
||||||
|
* Created by vito on 2021/5/27 |
||||||
|
*/ |
||||||
|
public class DesignerAppUtils { |
||||||
|
|
||||||
|
/** |
||||||
|
* 处理模板读取时的异常 |
||||||
|
* |
||||||
|
* @param path 模板路径 |
||||||
|
*/ |
||||||
|
public static void dealWithTemplateIOError(String path) { |
||||||
|
// 试图获取多行读取错误提示并缓存待处理列表
|
||||||
|
String detail = TemplateIOErrorUtils.dealWithErrorDetailMultiLineAndCache(path); |
||||||
|
if (detail.length() > 0) { |
||||||
|
UIUtil.invokeLaterIfNeeded(() -> { |
||||||
|
if (WorkContext.getCurrent().isLocal()) { |
||||||
|
UIExpandDialog.Builder() |
||||||
|
.owner(DesignerContext.getDesignerFrame()) |
||||||
|
.title(Toolkit.i18nText("Fine-Design_Basic_Tool_Tips")) |
||||||
|
.message(Toolkit.i18nText("Fine-Design_Template_Plugin_Error_Message_Local")) |
||||||
|
.detail(detail) |
||||||
|
.okText(Toolkit.i18nText("Fine-Design_Template_Plugin_Error_OK_Btn")) |
||||||
|
.cancelText(Toolkit.i18nText("Fine-Design_Template_Plugin_Error_Cancel_Btn")) |
||||||
|
.dialogActionListener(new DialogActionAdapter() { |
||||||
|
public void doOk() { |
||||||
|
installAndEnablePlugin(path); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public void doCancel() { |
||||||
|
TemplateIOErrorUtils.invalidatePlugins(path); |
||||||
|
} |
||||||
|
}).build().setVisible(true); |
||||||
|
} else { |
||||||
|
UIExpandDialog.Builder().owner(DesignerContext.getDesignerFrame()) |
||||||
|
.title(Toolkit.i18nText("Fine-Design_Basic_Tool_Tips")) |
||||||
|
.message(Toolkit.i18nText("Fine-Design_Template_Plugin_Error_Message_Remote")) |
||||||
|
.detail(detail) |
||||||
|
.build() |
||||||
|
.setVisible(true); |
||||||
|
} |
||||||
|
}); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
private static void installAndEnablePlugin(String key) { |
||||||
|
Multimap<String, PluginMarkerAdapter> stringPluginMarkerAdapterMultimap = TemplateIOErrorUtils.popPluginInfoMap(key); |
||||||
|
Collection<PluginMarkerAdapter> disablePlugins = stringPluginMarkerAdapterMultimap.get(TemplateIOErrorUtils.DISABLE_PLUGIN); |
||||||
|
for (PluginMarkerAdapter disablePlugin : disablePlugins) { |
||||||
|
PluginManager.getController().enable(disablePlugin, new ModifyStatusCallback(false)); |
||||||
|
} |
||||||
|
|
||||||
|
Collection<PluginMarkerAdapter> uninstallPlugins = stringPluginMarkerAdapterMultimap.get(TemplateIOErrorUtils.NOT_INSTALLED_PLUGIN); |
||||||
|
for (PluginMarker uninstallPlugin : uninstallPlugins) { |
||||||
|
PluginTask pluginTask = PluginTask.installTask(uninstallPlugin); |
||||||
|
PluginControllerHelper.installOnline(uninstallPlugin, new InstallOnlineCallback(pluginTask)); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue