After Width: | Height: | Size: 7.4 KiB |
After Width: | Height: | Size: 13 KiB |
@ -0,0 +1,3 @@
|
||||
## 新增报表
|
||||
data:image/s3,"s3://crabby-images/b2f40/b2f40fa8aa7c86e1ab26c8658e8a3941f087076a" alt="img" <br>
|
||||
状态默认为已启用。
|
After Width: | Height: | Size: 33 KiB |
After Width: | Height: | Size: 13 KiB |
After Width: | Height: | Size: 26 KiB |
After Width: | Height: | Size: 31 KiB |
After Width: | Height: | Size: 4.9 KiB |
After Width: | Height: | Size: 34 KiB |
After Width: | Height: | Size: 15 KiB |
After Width: | Height: | Size: 15 KiB |
Before Width: | Height: | Size: 24 KiB |
After Width: | Height: | Size: 23 KiB |
After Width: | Height: | Size: 136 KiB |
Before Width: | Height: | Size: 23 KiB |
After Width: | Height: | Size: 34 KiB |
After Width: | Height: | Size: 8.7 KiB |
After Width: | Height: | Size: 31 KiB |
After Width: | Height: | Size: 64 KiB |
After Width: | Height: | Size: 40 KiB |
After Width: | Height: | Size: 20 KiB |
After Width: | Height: | Size: 101 KiB |
After Width: | Height: | Size: 49 KiB |
After Width: | Height: | Size: 37 KiB |
After Width: | Height: | Size: 31 KiB |
After Width: | Height: | Size: 49 KiB |
After Width: | Height: | Size: 55 KiB |
@ -0,0 +1,73 @@
|
||||
package com.anjiplus.template.gaea.business.enums;
|
||||
|
||||
/**
|
||||
* @author zhouhang
|
||||
* @description EXCEL居中方式
|
||||
* @date 2021/4/26
|
||||
*/
|
||||
public enum ExcelCenterStyleEnum {
|
||||
/**
|
||||
* 左对齐
|
||||
*/
|
||||
LEFT((short) 1, 1, "左对齐"),
|
||||
/**
|
||||
* 右对齐
|
||||
*/
|
||||
RIGHT((short) 3, 2, "右对齐"),
|
||||
/**
|
||||
* 居中
|
||||
*/
|
||||
CENTER((short) 2, 0, "居中"),
|
||||
;
|
||||
|
||||
/**
|
||||
* excel居中code
|
||||
*/
|
||||
private final short excelCode;
|
||||
|
||||
/**
|
||||
* 在线文档居中code
|
||||
*/
|
||||
private final Integer onlineExcelCode;
|
||||
|
||||
/**
|
||||
* 名称
|
||||
*/
|
||||
private final String name;
|
||||
|
||||
|
||||
public Integer getOnlineExcelCode() {
|
||||
return onlineExcelCode;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
|
||||
public short getExcelCode() {
|
||||
return excelCode;
|
||||
}
|
||||
|
||||
ExcelCenterStyleEnum(short excelCode, Integer onlineExcelCode, String name) {
|
||||
this.excelCode = excelCode;
|
||||
this.onlineExcelCode = onlineExcelCode;
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param code excel居中样式code
|
||||
* @return Enum_ExcelCenterStyle
|
||||
* @description 根据excel居中样式获取在线文档居中样式
|
||||
* @author zhouhang
|
||||
* @date 2021/4/26
|
||||
*/
|
||||
public static ExcelCenterStyleEnum getExcelCenterStyleByExcelCenterCode(short code) {
|
||||
for (ExcelCenterStyleEnum value : ExcelCenterStyleEnum.values()) {
|
||||
if (code == value.getExcelCode()) {
|
||||
return value;
|
||||
}
|
||||
}
|
||||
return CENTER;
|
||||
}
|
||||
|
||||
}
|
@ -0,0 +1,30 @@
|
||||
package com.anjiplus.template.gaea.business.enums;
|
||||
|
||||
/**
|
||||
* Created by raodeming on 2021/9/3.
|
||||
*/
|
||||
public enum ExportTypeEnum {
|
||||
|
||||
/**gaea_excel*/
|
||||
GAEA_TEMPLATE_EXCEL("gaea_template_excel", "gaea_template_excel"),
|
||||
/**gaea_pdf*/
|
||||
GAEA_TEMPLATE_PDF("gaea_template_pdf", "gaea_template_pdf"),
|
||||
;
|
||||
|
||||
private String codeValue;
|
||||
private String codeDesc;
|
||||
|
||||
private ExportTypeEnum(String codeValue, String codeDesc) {
|
||||
this.codeValue = codeValue;
|
||||
this.codeDesc = codeDesc;
|
||||
}
|
||||
|
||||
public String getCodeValue() {
|
||||
return this.codeValue;
|
||||
}
|
||||
|
||||
public String getCodeDesc() {
|
||||
return this.codeDesc;
|
||||
}
|
||||
|
||||
}
|
@ -0,0 +1,78 @@
|
||||
package com.anjiplus.template.gaea.business.modules.reportexcel.controller;
|
||||
|
||||
import com.anji.plus.gaea.annotation.Permission;
|
||||
import com.anji.plus.gaea.annotation.log.GaeaAuditLog;
|
||||
import com.anji.plus.gaea.bean.ResponseBean;
|
||||
import com.anji.plus.gaea.code.ResponseCode;
|
||||
import com.anji.plus.gaea.curd.controller.GaeaBaseController;
|
||||
import com.anji.plus.gaea.curd.service.GaeaBaseService;
|
||||
import com.anjiplus.template.gaea.business.modules.reportexcel.controller.dto.ReportExcelDto;
|
||||
import com.anjiplus.template.gaea.business.modules.reportexcel.controller.param.ReportExcelParam;
|
||||
import com.anjiplus.template.gaea.business.modules.reportexcel.dao.entity.ReportExcel;
|
||||
import com.anjiplus.template.gaea.business.modules.reportexcel.service.ReportExcelService;
|
||||
import io.swagger.annotations.Api;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
|
||||
/**
|
||||
* @author chenkening
|
||||
* @date 2021/4/13 15:12
|
||||
*/
|
||||
@RestController
|
||||
@Api(tags = "报表表格管理")
|
||||
@Permission(code = "excelManage", name = "报表管理")
|
||||
@RequestMapping("/reportExcel")
|
||||
public class ReportExcelController extends GaeaBaseController<ReportExcelParam, ReportExcel, ReportExcelDto> {
|
||||
|
||||
@Autowired
|
||||
private ReportExcelService reportExcelService;
|
||||
|
||||
@Override
|
||||
public GaeaBaseService<ReportExcelParam, ReportExcel> getService() {
|
||||
return reportExcelService;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ReportExcel getEntity() {
|
||||
return new ReportExcel();
|
||||
}
|
||||
|
||||
@Override
|
||||
public ReportExcelDto getDTO() {
|
||||
return new ReportExcelDto();
|
||||
}
|
||||
|
||||
@GetMapping("/detailByReportCode/{reportCode}")
|
||||
@Permission(code = "query", name = "详情")
|
||||
@GaeaAuditLog(pageTitle = "详情")
|
||||
public ResponseBean detailByReportCode(@PathVariable String reportCode) {
|
||||
ReportExcelDto reportExcelDto = reportExcelService.detailByReportCode(reportCode);
|
||||
return ResponseBean.builder().data(reportExcelDto).build();
|
||||
}
|
||||
|
||||
@PostMapping("/preview")
|
||||
@Permission(code = "view", name = "预览")
|
||||
@GaeaAuditLog(pageTitle = "预览")
|
||||
public ResponseBean preview(@RequestBody ReportExcelDto reportExcelDto) {
|
||||
ReportExcelDto result = reportExcelService.preview(reportExcelDto);
|
||||
return ResponseBean.builder().data(result).build();
|
||||
}
|
||||
|
||||
|
||||
@PostMapping("/exportExcel")
|
||||
@Permission(code = "export", name = "导出")
|
||||
@GaeaAuditLog(pageTitle = "报表导出")
|
||||
public ResponseBean exportExcel(@RequestBody ReportExcelDto reportExcelDto) {
|
||||
|
||||
return ResponseBean.builder().code(ResponseCode.SUCCESS_CODE)
|
||||
.data(reportExcelService.exportExcel(reportExcelDto))
|
||||
.message("导出成功,请稍后在文件管理中查看").build();
|
||||
}
|
||||
|
||||
// @PostMapping("/exportPdf")
|
||||
// public ResponseBean exportPdf(@RequestBody ReportExcelDto reportExcelDto) {
|
||||
// reportExcelService.exportPdf(reportExcelDto);
|
||||
// return ResponseBean.builder().code(ResponseCode.SUCCESS_CODE)
|
||||
// .build();
|
||||
// }
|
||||
}
|
@ -0,0 +1,58 @@
|
||||
package com.anjiplus.template.gaea.business.modules.reportexcel.controller.dto;
|
||||
|
||||
|
||||
import com.alibaba.fastjson.JSONObject;
|
||||
import lombok.Data;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 存储对象类
|
||||
*
|
||||
* @author Administrator
|
||||
*/
|
||||
@Data
|
||||
public class GridRecordDataModel {
|
||||
/**
|
||||
* 记录序列
|
||||
*/
|
||||
Long id;
|
||||
/**
|
||||
* 文档ID
|
||||
*/
|
||||
String list_id;
|
||||
/**
|
||||
* 本记录的行_列
|
||||
*/
|
||||
String row_col;
|
||||
/**
|
||||
* sheet序号
|
||||
*/
|
||||
String index;
|
||||
/**
|
||||
* 状态是否当前sheet页
|
||||
*/
|
||||
Integer status;
|
||||
/**
|
||||
* 块编号 第一块 fblock
|
||||
*/
|
||||
String block_id;
|
||||
/**
|
||||
* json串
|
||||
*/
|
||||
JSONObject json_data;
|
||||
/**
|
||||
* 排序位置
|
||||
*/
|
||||
Integer order;
|
||||
/**
|
||||
* 是否删除
|
||||
*/
|
||||
Integer is_delete;
|
||||
|
||||
/**
|
||||
* sheet页数据 未编号分组
|
||||
*/
|
||||
List<JSONObject> dataList;
|
||||
|
||||
}
|
@ -0,0 +1,18 @@
|
||||
|
||||
package com.anjiplus.template.gaea.business.modules.reportexcel.controller.param;
|
||||
|
||||
import com.anji.plus.gaea.curd.params.PageParam;
|
||||
import lombok.Data;
|
||||
|
||||
import java.io.Serializable;
|
||||
|
||||
|
||||
/**
|
||||
* @author chenkening
|
||||
* @date 2021/4/13 15:12
|
||||
*/
|
||||
@Data
|
||||
public class ReportExcelParam extends PageParam implements Serializable {
|
||||
|
||||
|
||||
}
|
@ -0,0 +1,11 @@
|
||||
package com.anjiplus.template.gaea.business.modules.reportexcel.dao;
|
||||
|
||||
import com.anji.plus.gaea.curd.mapper.GaeaBaseMapper;
|
||||
import com.anjiplus.template.gaea.business.modules.reportexcel.dao.entity.ReportExcel;
|
||||
|
||||
/**
|
||||
* @author chenkening
|
||||
* @date 2021/4/13 15:11
|
||||
*/
|
||||
public interface ReportExcelMapper extends GaeaBaseMapper<ReportExcel> {
|
||||
}
|
@ -0,0 +1,33 @@
|
||||
package com.anjiplus.template.gaea.business.modules.reportexcel.dao.entity;
|
||||
|
||||
import com.anji.plus.gaea.curd.entity.GaeaBaseEntity;
|
||||
import com.baomidou.mybatisplus.annotation.TableName;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
|
||||
/**
|
||||
* @author chenkening
|
||||
* @date 2021/4/13 15:11
|
||||
*/
|
||||
@TableName(value = "gaea_report_excel")
|
||||
@Data
|
||||
public class ReportExcel extends GaeaBaseEntity {
|
||||
|
||||
@ApiModelProperty(value = "报表编码")
|
||||
private String reportCode;
|
||||
|
||||
@ApiModelProperty(value = "数据集编码,以|分割")
|
||||
private String setCodes;
|
||||
|
||||
@ApiModelProperty(value = "数据集查询参数")
|
||||
private String setParam;
|
||||
|
||||
@ApiModelProperty(value = "报表json字符串")
|
||||
private String jsonStr;
|
||||
|
||||
@ApiModelProperty(value = "0--已禁用 1--已启用 DIC_NAME=ENABLE_FLAG")
|
||||
private Integer enableFlag;
|
||||
|
||||
@ApiModelProperty(value = "0--未删除 1--已删除 DIC_NAME=DELETE_FLAG")
|
||||
private Integer deleteFlag;
|
||||
}
|
@ -0,0 +1,43 @@
|
||||
package com.anjiplus.template.gaea.business.modules.reportexcel.service;
|
||||
|
||||
|
||||
import com.anji.plus.gaea.curd.service.GaeaBaseService;
|
||||
import com.anjiplus.template.gaea.business.modules.reportexcel.controller.dto.ReportExcelDto;
|
||||
import com.anjiplus.template.gaea.business.modules.reportexcel.controller.param.ReportExcelParam;
|
||||
import com.anjiplus.template.gaea.business.modules.reportexcel.dao.entity.ReportExcel;
|
||||
|
||||
/**
|
||||
* TODO
|
||||
*
|
||||
* @author chenkening
|
||||
* @date 2021/4/13 15:14
|
||||
*/
|
||||
public interface ReportExcelService extends GaeaBaseService<ReportExcelParam, ReportExcel> {
|
||||
|
||||
/**
|
||||
* 根据报表编码查询详情
|
||||
*
|
||||
* @param reportCode
|
||||
* @return
|
||||
*/
|
||||
ReportExcelDto detailByReportCode(String reportCode);
|
||||
|
||||
/**
|
||||
* 报表预览
|
||||
*
|
||||
* @param reportExcelDto
|
||||
* @return
|
||||
*/
|
||||
ReportExcelDto preview(ReportExcelDto reportExcelDto);
|
||||
|
||||
|
||||
/**
|
||||
* 导出为excel
|
||||
*
|
||||
* @param reportExcelDto
|
||||
* @return
|
||||
*/
|
||||
Boolean exportExcel(ReportExcelDto reportExcelDto);
|
||||
|
||||
// Boolean exportPdf(ReportExcelDto reportExcelDto);
|
||||
}
|
@ -0,0 +1,28 @@
|
||||
package com.anjiplus.template.gaea.business.modules.reportexcel.util;
|
||||
|
||||
public class MSExcelUtil {
|
||||
public static final short EXCEL_COLUMN_WIDTH_FACTOR = 256;
|
||||
public static final short EXCEL_ROW_HEIGHT_FACTOR = 20;
|
||||
public static final int UNIT_OFFSET_LENGTH = 7;
|
||||
public static final int[] UNIT_OFFSET_MAP = new int[]{0, 36, 73, 109, 146, 182, 219};
|
||||
|
||||
public static short pixel2WidthUnits(int pxs) {
|
||||
short widthUnits = (short) (EXCEL_COLUMN_WIDTH_FACTOR * (pxs / UNIT_OFFSET_LENGTH));
|
||||
widthUnits += UNIT_OFFSET_MAP[(pxs % UNIT_OFFSET_LENGTH)];
|
||||
return widthUnits;
|
||||
}
|
||||
|
||||
public static int widthUnits2Pixel(short widthUnits) {
|
||||
int pixels = (widthUnits / EXCEL_COLUMN_WIDTH_FACTOR) * UNIT_OFFSET_LENGTH;
|
||||
int offsetWidthUnits = widthUnits % EXCEL_COLUMN_WIDTH_FACTOR;
|
||||
pixels += Math.floor((float) offsetWidthUnits / ((float) EXCEL_COLUMN_WIDTH_FACTOR / UNIT_OFFSET_LENGTH));
|
||||
return pixels;
|
||||
}
|
||||
|
||||
public static int heightUnits2Pixel(short heightUnits) {
|
||||
int pixels = (heightUnits / EXCEL_ROW_HEIGHT_FACTOR);
|
||||
int offsetWidthUnits = heightUnits % EXCEL_ROW_HEIGHT_FACTOR;
|
||||
pixels += Math.floor((float) offsetWidthUnits / ((float) EXCEL_ROW_HEIGHT_FACTOR / UNIT_OFFSET_LENGTH));
|
||||
return pixels;
|
||||
}
|
||||
}
|
@ -0,0 +1,33 @@
|
||||
use
|
||||
aj_report;
|
||||
|
||||
|
||||
CREATE TABLE `gaea_report_excel`
|
||||
(
|
||||
`id` bigint(11) NOT NULL AUTO_INCREMENT,
|
||||
`report_code` varchar(100) DEFAULT NULL COMMENT '报表编码',
|
||||
`set_codes` varchar(255) DEFAULT NULL COMMENT '数据集编码,以|分割',
|
||||
`set_param` varchar(1024) DEFAULT NULL COMMENT '数据集查询参数',
|
||||
`json_str` text COMMENT '报表json串',
|
||||
`enable_flag` int(1) DEFAULT '1' COMMENT '0--已禁用 1--已启用 DIC_NAME=ENABLE_FLAG',
|
||||
`delete_flag` int(1) DEFAULT '0' COMMENT '0--未删除 1--已删除 DIC_NAME=DELETE_FLAG',
|
||||
`create_by` varchar(255) DEFAULT NULL COMMENT '创建人',
|
||||
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
|
||||
`update_by` varchar(255) DEFAULT NULL COMMENT '更新人',
|
||||
`update_time` datetime DEFAULT NULL COMMENT '更新时间',
|
||||
`version` int(8) DEFAULT NULL COMMENT '版本号',
|
||||
PRIMARY KEY (`id`) USING BTREE,
|
||||
UNIQUE KEY `UNIQUE_REPORT_CODE` (`report_code`) USING BTREE
|
||||
) ENGINE=InnoDB AUTO_INCREMENT=215 DEFAULT CHARSET=utf8;
|
||||
|
||||
|
||||
INSERT INTO `aj_report`.`access_authority`(`id`, `parent_target`, `target`, `target_name`, `action`, `action_name`, `sort`, `enable_flag`, `delete_flag`, `create_by`, `create_time`, `update_by`, `update_time`, `version`) VALUES (234, 'report', 'bigScreenManage', '大屏报表', 'export', '导出大屏', 234, 1, 0, 'admin', '2019-07-23 15:59:40', 'admin', '2019-07-23 15:59:40', 1);
|
||||
INSERT INTO `aj_report`.`access_authority`(`id`, `parent_target`, `target`, `target_name`, `action`, `action_name`, `sort`, `enable_flag`, `delete_flag`, `create_by`, `create_time`, `update_by`, `update_time`, `version`) VALUES (235, 'report', 'bigScreenManage', '大屏报表', 'import', '导入大屏', 235, 1, 0, 'admin', '2019-07-23 15:59:40', 'admin', '2019-07-23 15:59:40', 1);
|
||||
INSERT INTO `aj_report`.`access_authority`(`id`, `parent_target`, `target`, `target_name`, `action`, `action_name`, `sort`, `enable_flag`, `delete_flag`, `create_by`, `create_time`, `update_by`, `update_time`, `version`) VALUES (236, 'report', 'excelManage', '表格报表', 'query', '查询报表', 236, 1, 0, 'admin', '2019-07-23 15:59:40', 'admin', '2019-07-23 15:59:40', 1);
|
||||
|
||||
INSERT INTO `aj_report`.`access_role_authority`(`id`, `role_code`, `target`, `action`) VALUES (default , 'root', 'bigScreenManage', 'export');
|
||||
INSERT INTO `aj_report`.`access_role_authority`(`id`, `role_code`, `target`, `action`) VALUES (default , 'root', 'bigScreenManage', 'import');
|
||||
|
||||
|
||||
UPDATE `aj_report`.`gaea_report` SET `report_type` = 'report_screen' WHERE `report_code` in ('log_ajreport', 'car_ajreport', 'acc_ajreport');
|
||||
|
@ -0,0 +1,22 @@
|
||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||
<mapper namespace="com.anjiplus.template.gaea.business.modules.data.reportexcel.dao.ReportExcelMapper">
|
||||
|
||||
<resultMap type="com.anjiplus.template.gaea.business.modules.reportexcel.dao.entity.ReportExcel" id="ReportMap">
|
||||
<!--jdbcType="{column.columnType}"-->
|
||||
<result property="id" column="id" />
|
||||
<result property="reportCode" column="report_code" />
|
||||
<result property="setCodes" column="set_codes" />
|
||||
<result property="setParam" column="set_param" />
|
||||
<result property="jsonStr" column="json_str" />
|
||||
<result property="enableFlag" column="enable_flag" />
|
||||
<result property="deleteFlag" column="delete_flag" />
|
||||
<result property="createBy" column="create_by" />
|
||||
<result property="createTime" column="create_time" />
|
||||
<result property="updateBy" column="update_by" />
|
||||
<result property="updateTime" column="update_time" />
|
||||
<result property="version" column="version" />
|
||||
|
||||
</resultMap>
|
||||
|
||||
|
||||
</mapper>
|