在集成环境中,经常需要在smartbi创建报表后做一些扩展,有以下2种方式实现。
请参考“插件开发框架”,创建自己的扩展包,扩展包写好后,编译打包并参考“扩展包部署”文档部署该扩展包。通过后端扩展或前端文件扩展修改,电子表格资源只能通过后端文件扩展。
java api 请参考:javaapi
1、实现:smartbi.catalogtree.ICatalogTreeListener 接口
示例:
package bof.audit.service; import smartbi.catalogtree.ICatalogElement; import smartbi.catalogtree.ICatalogTreeListener; public class ReportChangePostHandler implements ICatalogTreeListener { public void onCatalogElementCreated(ICatalogElement element) { String type = element.getType(); // type类型如下: // 1.可视化查询:BUSINESS_VIEW // 2.SQL查询:TEXT_BUSINESS_VIEW // 3.存储过程查询:PROC_BUSINESS_VIEW // 4.原生SQL查询:RAWSQL_BUSINESS_VIEW // 4.灵活分析:SIMPLE_REPORT // 5.指标类报表:METRIC_REPORT // 6.复杂报表: FREE_REPORT // 7.分析报表: BI3OLAP_REPORT // 8.仪表分析: Dashboard // 9.地图分析: DashboardMap // 10.portal页面: PAGE //TODO 扩展处理 } public void onCatalogElementDeleted(ICatalogElement element) { // TODO Auto-generated method stub //TODO 扩展处理 } public void onCatalogElementMoved(String nodeId, String originalParentId, String destParentId) { // TODO Auto-generated method stub } public void onCatalogElementDeleting(ICatalogElement element) { //TODO 扩展处理 } public void onCatalogElementUpdated(ICatalogElement element) { // TODO Auto-generated method stub } } |
2、注册Listener实现。
module类,在服务器启动的时候注册,activate方法会在服务器启动的时候执行;module类的写法和配置可参考 第六课:高级应用 之六:自定义Module 章节。
请参考“第四课:如何修改Smartbi JS文件”,扩展报表保存对象的方法,示例:
QueryView.prototype.saveQueryCallback_new = QueryView.prototype.saveQueryCallback; QueryView.prototype.saveQueryCallback = function(ret, dialog) { this.saveQueryCallback_new(ret, dialog); var folderId = ret.folderId var ret = util.remoteInvokeEx("TestService", "saveAs", [folderId]); } |
请参考“第六课:高级应用”之六:“自定义Module”创建自己的 java 文件,并在其中写好保存扩展的方法。示例:
public class TestModule implements IModule{ private static final Logger LOG = Logger.getLogger(TestModule.class); private static TestModule instance; public static TestModule getInstance() { if (instance == null) instance = new TestModule(); return instance; } public void activate() { } public void saveAs(String folderId){ // 实现自己的业务保存逻辑..... } } |
在前端 JavaScript 中调用后台方法,示例代码如下。
QueryView.prototype.saveQueryCallback_new = QueryView.prototype.saveQueryCallback; QueryView.prototype.saveQueryCallback = function(ret, dialog) { this.saveQueryCallback_new(ret, dialog); var folderId = ret.folderId var ret = util.remoteInvokeEx("TestService", "saveAs", [folderId]); if (!ret.succeeded) { modalWindow.showServerError(ret); } } |