richie
6 years ago
commit
b0cbc811c6
9 changed files with 291 additions and 0 deletions
@ -0,0 +1,5 @@
|
||||
*.iml |
||||
.idea/ |
||||
lib/report/*.jar |
||||
.DS_Store |
||||
.classpath |
@ -0,0 +1,130 @@
|
||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?> |
||||
<project basedir="." default="jar" name="plugin"> |
||||
<!-- JDK路径,根据自己机器上实际位置修改--> |
||||
<property name="jdk.home" value="/Library/Java/JavaVirtualMachines/jdk1.8/Contents/Home"/> |
||||
|
||||
<property name="libs" value="${basedir}/lib"/> |
||||
<property name="publicLibs" value=""/> |
||||
<property name="reportLibs" value="${basedir}/../webroot/WEB-INF/lib"/> |
||||
<property name="destLoc" value="."/> |
||||
<property name="classes" value="classes"/> |
||||
<xmlproperty file="${basedir}/plugin.xml"/> |
||||
<property name="current-version" value="${plugin.version}"/> |
||||
|
||||
<!-- 插件版本--> |
||||
<property name="plugin-version" value="${current-version}"/> |
||||
<!-- 插件名字--> |
||||
<property name="plugin-name" value="dynamic-sheet"/> |
||||
<property name="plugin-jar" value="fr-plugin-${plugin-name}-${plugin-version}.jar"/> |
||||
|
||||
<target name="prepare"> |
||||
<delete dir="${classes}"/> |
||||
<delete dir="fr-plugin-${plugin-name}-${plugin-version}"/> |
||||
<xmlproperty file="${basedir}/plugin.xml"/> |
||||
<delete dir="${destLoc}/${plugin.name}"/> |
||||
</target> |
||||
<path id="compile.classpath"> |
||||
<fileset dir="${libs}"> |
||||
<include name="**/*.jar"/> |
||||
</fileset> |
||||
<fileset dir="${publicLibs}"> |
||||
<include name="**/*.jar"/> |
||||
</fileset> |
||||
<fileset dir="${reportLibs}"> |
||||
<include name="**/*.jar"/> |
||||
</fileset> |
||||
</path> |
||||
<patternset id="resources4Jar"> |
||||
<exclude name="**/.settings/**"/> |
||||
<exclude name=".classpath"/> |
||||
<exclude name=".project"/> |
||||
|
||||
<exclude name="**/*.java"/> |
||||
<exclude name="**/*.db"/> |
||||
<exclude name="**/*.g"/> |
||||
<exclude name="**/package.html"/> |
||||
</patternset> |
||||
<target name="copy_resources"> |
||||
<echo message="从${resources_from}拷贝图片,JS,CSS等资源文件"/> |
||||
<delete dir="tmp"/> |
||||
<copy todir="tmp"> |
||||
<fileset dir="${resources_from}/src/main/resources"> |
||||
<patternset refid="resources4Jar"/> |
||||
</fileset> |
||||
</copy> |
||||
<copy todir="${classes}"> |
||||
<fileset dir="tmp"/> |
||||
</copy> |
||||
<delete dir="tmp"/> |
||||
</target> |
||||
<target name="compile_javas"> |
||||
<echo message="编译${compile_files}下的Java文件"/> |
||||
<javac destdir="${classes}" debug="false" optimize="on" source="${source_jdk_version}" |
||||
target="${target_jdk_version}" |
||||
fork="true" memoryMaximumSize="512m" listfiles="false" srcdir="${basedir}" |
||||
executable="${compile_jdk_version}/bin/javac"> |
||||
<src path="${basedir}/src/main/java"/> |
||||
<exclude name="**/.svn/**"/> |
||||
<compilerarg line="-encoding UTF8 "/> |
||||
<classpath refid="compile.classpath"/> |
||||
</javac> |
||||
<taskdef name="pretreatment" classname="com.fr.plugin.pack.PluginPretreatmentTask"> |
||||
<classpath refid="compile.classpath"/> |
||||
</taskdef> |
||||
<pretreatment baseDir="${basedir}"/> |
||||
</target> |
||||
|
||||
<target name="jar_classes"> |
||||
<echo message="打Jar包:${jar_name}"/> |
||||
<delete file="${basedir}/${jar_name}"/> |
||||
<jar jarfile="${basedir}/${jar_name}"> |
||||
<fileset dir="${classes}"> |
||||
</fileset> |
||||
</jar> |
||||
</target> |
||||
|
||||
<target name="super_jar" depends="prepare"> |
||||
<antcall target="copy_resources"> |
||||
<param name="resources_from" value="${basedir}"/> |
||||
</antcall> |
||||
<antcall target="compile_javas"> |
||||
<param name="source_jdk_version" value="1.6"/> |
||||
<param name="target_jdk_version" value="1.6"/> |
||||
<param name="compile_jdk_version" value="${jdk.home}"/> |
||||
<param name="compile_files" value="${basedir}/src"/> |
||||
</antcall> |
||||
<echo message="compile plugin success!"/> |
||||
|
||||
<antcall target="jar_classes"> |
||||
<param name="jar_name" value="${plugin-jar}"/> |
||||
</antcall> |
||||
<delete dir="${classes}"/> |
||||
|
||||
</target> |
||||
|
||||
<target name="jar" depends="super_jar"> |
||||
<antcall target="zip"/> |
||||
</target> |
||||
|
||||
<target name="zip"> |
||||
<property name="plugin-folder" value="fr-plugin-${plugin-name}-${plugin-version}"/> |
||||
<echo message="----------zip files----------"/> |
||||
<mkdir dir="${plugin-folder}"/> |
||||
<copy todir="${plugin-folder}"> |
||||
<fileset dir="."> |
||||
<include name="${plugin-jar}"/> |
||||
<include name="plugin.xml"/> |
||||
</fileset> |
||||
<fileset dir="${libs}"> |
||||
<include name="*.jar"/> |
||||
<include name="*.dll"/> |
||||
</fileset> |
||||
</copy> |
||||
<zip destfile="${basedir}/${plugin-folder}.zip" basedir="."> |
||||
<include name="${plugin-folder}/*.jar"/> |
||||
<include name="${plugin-folder}/*.dll"/> |
||||
<include name="${plugin-folder}/plugin.xml"/> |
||||
</zip> |
||||
<move file="${plugin-folder}.zip" todir="${destLoc}/install"/> |
||||
</target> |
||||
</project> |
@ -0,0 +1,18 @@
|
||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?><plugin> |
||||
<id>com.fr.plugin.preview.sheet.control</id> |
||||
<name><![CDATA[根据参数显示不同的sheet]]></name> |
||||
<active>yes</active> |
||||
<version>1.0</version> |
||||
<env-version>10.0</env-version> |
||||
<jartime>2018-10-09</jartime> |
||||
<vendor>author</vendor> |
||||
<description><![CDATA[指定显示sheet]]></description> |
||||
<change-notes><![CDATA[无]]></change-notes> |
||||
<extra-core> |
||||
|
||||
</extra-core> |
||||
<extra-report> |
||||
<ActorProvider class="com.fr.plugin.control.SheetControlActorBridge"/> |
||||
</extra-report> |
||||
<function-recorder class="com.fr.plugin.control.actor.SheetControlActor"/> |
||||
</plugin> |
@ -0,0 +1,18 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?> |
||||
<project xmlns="http://maven.apache.org/POM/4.0.0" |
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" |
||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> |
||||
<modelVersion>4.0.0</modelVersion> |
||||
|
||||
<parent> |
||||
<groupId>com.fr.plugin</groupId> |
||||
<artifactId>starter</artifactId> |
||||
<version>10.0</version> |
||||
</parent> |
||||
<packaging>jar</packaging> |
||||
<artifactId>demo-dynamic-sheet</artifactId> |
||||
<build> |
||||
<!---如果要更改调试插件,改这里的配置就可以了--> |
||||
<outputDirectory>${project.basedir}/../webroot/WEB-INF/plugins/plugin-com.fr.plugin.preview.sheet.control-1.0/classes</outputDirectory> |
||||
</build> |
||||
</project> |
@ -0,0 +1,21 @@
|
||||
# 动态显示sheet示例 |
||||
|
||||
给多sheet模板添加参数,形如 |
||||
|
||||
``` |
||||
/decision/view/report?viewlet=WorkBook6.cpt&op=write&SHEETNOTSHOW=0 |
||||
``` |
||||
|
||||
如果这个模板有sheet1、sheet2、sheet3三个sheet,就只会展示出来sheet2和sheet3 |
||||
|
||||
该参数也可以传sheet的名字 |
||||
|
||||
``` |
||||
/decision/view/report?viewlet=WorkBook6.cpt&op=write&SHEETNOTSHOW=sheet1 |
||||
``` |
||||
|
||||
效果一样 |
||||
|
||||
## 注意事项 |
||||
|
||||
如果需要更加灵活的控制sheet展示,比如可以只展示允许的sheet,需要自行对代码做二次开发。 |
@ -0,0 +1,23 @@
|
||||
package com.fr.plugin.control; |
||||
|
||||
import com.fr.plugin.control.actor.SheetControlActor; |
||||
import com.fr.report.fun.impl.AbstractActorProvider; |
||||
import com.fr.report.stable.fun.Actor; |
||||
|
||||
/** |
||||
* @author richie |
||||
* @date 2015-03-21 |
||||
* @since 8.0 |
||||
*/ |
||||
public class SheetControlActorBridge extends AbstractActorProvider { |
||||
|
||||
@Override |
||||
public int currentAPILevel() { |
||||
return CURRENT_LEVEL; |
||||
} |
||||
|
||||
@Override |
||||
public Actor[] createActor() { |
||||
return new Actor[]{new SheetControlActor()}; |
||||
} |
||||
} |
@ -0,0 +1,76 @@
|
||||
package com.fr.plugin.control.actor; |
||||
|
||||
import com.fr.general.ComparatorUtils; |
||||
import com.fr.general.GeneralUtils; |
||||
import com.fr.intelli.record.Focus; |
||||
import com.fr.intelli.record.Original; |
||||
import com.fr.json.JSON; |
||||
import com.fr.json.JSONArray; |
||||
import com.fr.json.JSONFactory; |
||||
import com.fr.main.TemplateWorkBook; |
||||
import com.fr.main.workbook.ResultWorkBook; |
||||
import com.fr.record.analyzer.EnableMetrics; |
||||
import com.fr.report.core.sheet.SheetSequenceExecutor; |
||||
import com.fr.stable.WriteActor; |
||||
import com.fr.stable.web.Repository; |
||||
import com.fr.web.RTypeService; |
||||
import com.fr.web.RepositoryHelper; |
||||
import com.fr.web.core.ReportSession; |
||||
|
||||
import java.util.Map; |
||||
|
||||
/** |
||||
* @author richie |
||||
* @date 2015-03-21 |
||||
* @since 8.0 |
||||
*/ |
||||
@EnableMetrics |
||||
public class SheetControlActor extends WriteActor { |
||||
|
||||
private static final String SHEET_INDEX_NOT_BE_SHOW_PARA_NAME = "SHEETNOTSHOW"; |
||||
|
||||
@Override |
||||
public ResultWorkBook executeWorkBook(TemplateWorkBook workBook, Map parameterMap) { |
||||
if (parameterMap.containsKey(SHEET_INDEX_NOT_BE_SHOW_PARA_NAME)) { |
||||
removeUnnecessary(workBook, parameterMap); |
||||
} |
||||
return new SheetSequenceExecutor(workBook, parameterMap).execute(this); |
||||
} |
||||
|
||||
@Focus(id = "com.fr.plugin.preview.sheet.control", text = "", source = Original.PLUGIN) |
||||
private void removeUnnecessary(TemplateWorkBook workBook, Map parameterMap) { |
||||
Number index = GeneralUtils.objectToNumber(parameterMap.get(SHEET_INDEX_NOT_BE_SHOW_PARA_NAME), true); |
||||
if (index != null) { |
||||
workBook.removeReport(index.intValue()); |
||||
} else { |
||||
workBook.removeReport(GeneralUtils.objectToString(parameterMap.get(SHEET_INDEX_NOT_BE_SHOW_PARA_NAME))); |
||||
} |
||||
} |
||||
|
||||
public JSONArray processMultipleSheet(Repository repository) { |
||||
Map map = repository.getReportParameterMap(); |
||||
int sheetIndex = -1; |
||||
String sheetName = null; |
||||
if (map.containsKey(SHEET_INDEX_NOT_BE_SHOW_PARA_NAME)) { |
||||
Number index = GeneralUtils.objectToNumber(map.get(SHEET_INDEX_NOT_BE_SHOW_PARA_NAME), true); |
||||
if (index != null) { |
||||
sheetIndex = index.intValue(); |
||||
} else { |
||||
sheetName = GeneralUtils.objectToString(map.get(SHEET_INDEX_NOT_BE_SHOW_PARA_NAME)); |
||||
} |
||||
} |
||||
JSONArray ja = JSONFactory.createJSON(JSON.ARRAY); |
||||
int reportCount = getReportCountInRepo(repository); |
||||
for (int i = 0; i < reportCount; i++) { |
||||
ReportSession sessionIDInfo = (ReportSession) RepositoryHelper.getSessionIDInfor(repository); |
||||
String title = sessionIDInfo.getReportName(i); |
||||
if (i == sheetIndex || ComparatorUtils.equals(sheetName, title)) { |
||||
continue; |
||||
} |
||||
RTypeService.executeSheetName(repository, title, ja, i); |
||||
} |
||||
return ja; |
||||
} |
||||
|
||||
|
||||
} |
Loading…
Reference in new issue