Browse Source

动态展示sheet示例

master
richie 6 years ago
commit
b0cbc811c6
  1. 5
      .gitignore
  2. 130
      build.xml
  3. 0
      lib/report/.gitkeep
  4. 18
      plugin.xml
  5. 18
      pom.xml
  6. 21
      readme.md
  7. 23
      src/main/java/com/fr/plugin/control/SheetControlActorBridge.java
  8. 76
      src/main/java/com/fr/plugin/control/actor/SheetControlActor.java
  9. 0
      src/main/resources/.gitkeep

5
.gitignore vendored

@ -0,0 +1,5 @@
*.iml
.idea/
lib/report/*.jar
.DS_Store
.classpath

130
build.xml

@ -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
lib/report/.gitkeep

18
plugin.xml

@ -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>

18
pom.xml

@ -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>

21
readme.md

@ -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,需要自行对代码做二次开发。

23
src/main/java/com/fr/plugin/control/SheetControlActorBridge.java

@ -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()};
}
}

76
src/main/java/com/fr/plugin/control/actor/SheetControlActor.java

@ -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;
}
}

0
src/main/resources/.gitkeep

Loading…
Cancel
Save