Merge remote-tracking branch 'origin/main'

new
JilingLee 1 year ago
commit f5362b5c19

@ -1,5 +1,5 @@
-- 簿
CREATE TABLE `lyr-one`.`Untitled` (
CREATE TABLE `lyr-one`.`archives_accounting_book` (
`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '簿id',
`uri` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '簿uri',
`name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '簿',

@ -0,0 +1,119 @@
SET FOREIGN_KEY_CHECKS=0;
-- ----------------------------
-- for ea_electronic_contracts
-- ----------------------------
DROP TABLE IF EXISTS `ea_electronic_contracts`;
CREATE TABLE `ea_electronic_contracts` (
`id` bigint NOT NULL AUTO_INCREMENT COMMENT '',
`create_by` varchar(20) DEFAULT NULL COMMENT '',
`creator` varchar(20) DEFAULT NULL COMMENT '',
`create_time` datetime DEFAULT NULL COMMENT '',
`company_id` bigint unsigned DEFAULT NULL COMMENT 'id',
`company` varchar(30) DEFAULT NULL COMMENT '',
`update_time` datetime DEFAULT NULL COMMENT '',
`dept_id` bigint DEFAULT NULL COMMENT 'id',
`dept_name` varchar(30) DEFAULT NULL COMMENT '',
`contract_code` varchar(64) DEFAULT NULL COMMENT '',
`contract_title` varchar(100) DEFAULT NULL COMMENT '',
`contract_type` varchar(50) DEFAULT NULL COMMENT '',
`signatory` varchar(50) DEFAULT NULL COMMENT '',
`sign_date` date DEFAULT NULL COMMENT '',
`effective_date` date DEFAULT NULL COMMENT '',
`expiry_date` date DEFAULT NULL COMMENT '',
`contract_status` varchar(50) DEFAULT NULL COMMENT '',
`contract_amount` decimal(10,0) DEFAULT NULL COMMENT '',
`contract_attachment` varchar(200) DEFAULT NULL COMMENT '',
`handle_result` varchar(500) DEFAULT NULL COMMENT '',
`year` varchar(20) DEFAULT NULL COMMENT '',
`period` varchar(20) DEFAULT NULL COMMENT '',
`borrow_status` varchar(2) DEFAULT NULL COMMENT '',
`record_time` varchar(20) DEFAULT NULL COMMENT '',
`position` varchar(255) DEFAULT NULL COMMENT '',
`cherks` int DEFAULT NULL COMMENT '',
`record_id` bigint DEFAULT NULL COMMENT 'idid',
`user_id` bigint DEFAULT NULL COMMENT 'id',
`deleted` bit(1) DEFAULT b'0' COMMENT '',
`updater` varchar(20) DEFAULT NULL COMMENT '',
`file_status` varchar(64) DEFAULT NULL COMMENT '',
`tenant_id` bigint NOT NULL COMMENT '/',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='';
-- ----------------------------
-- for ea_electronic_employee
-- ----------------------------
DROP TABLE IF EXISTS `ea_electronic_employee`;
CREATE TABLE `ea_electronic_employee` (
`id` bigint NOT NULL AUTO_INCREMENT COMMENT '',
`create_by` varchar(20) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`creator` varchar(20) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`create_time` datetime DEFAULT NULL COMMENT '',
`company_id` bigint DEFAULT NULL COMMENT 'id',
`company` varchar(30) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`update_time` datetime DEFAULT NULL COMMENT '',
`dept_id` bigint DEFAULT NULL COMMENT 'id',
`dept_name` varchar(30) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`name` varchar(100) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`gender` varchar(10) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`birthdate` date DEFAULT NULL COMMENT '',
`nationality` varchar(50) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`address` varchar(200) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`contact_number` varchar(20) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`id_card_number` varchar(20) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`passport_number` varchar(20) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`graduation_school` varchar(100) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`major` varchar(100) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`education` varchar(50) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`education_experience` text COLLATE utf8mb4_general_ci COMMENT '',
`work_experience` text COLLATE utf8mb4_general_ci COMMENT '',
`job_title` varchar(100) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`job_level` varchar(50) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`job_description` text COLLATE utf8mb4_general_ci COMMENT '',
`salary` decimal(10,0) DEFAULT NULL COMMENT '',
`health_condition` text COLLATE utf8mb4_general_ci COMMENT '',
`medical_records` text COLLATE utf8mb4_general_ci COMMENT '',
`disease_history` text COLLATE utf8mb4_general_ci COMMENT '',
`social_insurance` varchar(50) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`pension_insurance` decimal(10,0) DEFAULT NULL COMMENT '',
`medical_insurance` decimal(10,0) DEFAULT NULL COMMENT '',
`unemployment_insurance` decimal(10,0) DEFAULT NULL COMMENT '',
`work_injury_insurance` decimal(10,0) DEFAULT NULL COMMENT '',
`leave_records` text COLLATE utf8mb4_general_ci COMMENT '',
`overtime_records` text COLLATE utf8mb4_general_ci COMMENT '',
`welfare_benefits` text COLLATE utf8mb4_general_ci COMMENT '',
`performance_evaluation` text COLLATE utf8mb4_general_ci COMMENT '',
`rewards_punishments` text COLLATE utf8mb4_general_ci COMMENT '',
`training_records` text COLLATE utf8mb4_general_ci COMMENT '',
`personal_description` text COLLATE utf8mb4_general_ci COMMENT '',
`year` varchar(20) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`period` varchar(20) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`borrow_status` varchar(2) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`record_time` varchar(20) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`position` varchar(255) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`cherks` int DEFAULT NULL COMMENT '',
`record_id` bigint DEFAULT NULL COMMENT 'id',
`user_id` bigint DEFAULT NULL COMMENT 'id',
`deleted` bit(1) DEFAULT b'0' COMMENT '',
`updater` varchar(20) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`file_status` varchar(64) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '',
`tenant_id` bigint NOT NULL COMMENT '',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='';
--
INSERT INTO `lyr-one`.`system_menu` (`id`, `name`, `permission`, `type`, `sort`, `parent_id`, `path`, `icon`, `component`, `component_name`, `status`, `visible`, `keep_alive`, `always_show`, `creator`, `create_time`, `updater`, `update_time`, `deleted`) VALUES ('2415', '', '', '2', '0', '2383', 'electronic-contracts', 'clipboard', 'ea/electronicContracts/index', 'ElectronicContracts', '0', b'1', b'1', b'1', '', '2023-09-20 11:29:50', '', '2023-09-20 15:45:07', b'0');
INSERT INTO `lyr-one`.`system_menu` (`id`, `name`, `permission`, `type`, `sort`, `parent_id`, `path`, `icon`, `component`, `component_name`, `status`, `visible`, `keep_alive`, `always_show`, `creator`, `create_time`, `updater`, `update_time`, `deleted`) VALUES ('2416', '', 'ea:electronic-contracts:query', '3', '1', '2415', '', '', '', NULL, '0', b'1', b'1', b'1', '', '2023-09-20 11:29:50', '', '2023-09-20 11:29:50', b'0');
INSERT INTO `lyr-one`.`system_menu` (`id`, `name`, `permission`, `type`, `sort`, `parent_id`, `path`, `icon`, `component`, `component_name`, `status`, `visible`, `keep_alive`, `always_show`, `creator`, `create_time`, `updater`, `update_time`, `deleted`) VALUES ('2417', '', 'ea:electronic-contracts:create', '3', '2', '2415', '', '', '', NULL, '0', b'1', b'1', b'1', '', '2023-09-20 11:29:50', '', '2023-09-20 11:29:50', b'0');
INSERT INTO `lyr-one`.`system_menu` (`id`, `name`, `permission`, `type`, `sort`, `parent_id`, `path`, `icon`, `component`, `component_name`, `status`, `visible`, `keep_alive`, `always_show`, `creator`, `create_time`, `updater`, `update_time`, `deleted`) VALUES ('2418', '', 'ea:electronic-contracts:update', '3', '3', '2415', '', '', '', NULL, '0', b'1', b'1', b'1', '', '2023-09-20 11:29:50', '', '2023-09-20 11:29:50', b'0');
INSERT INTO `lyr-one`.`system_menu` (`id`, `name`, `permission`, `type`, `sort`, `parent_id`, `path`, `icon`, `component`, `component_name`, `status`, `visible`, `keep_alive`, `always_show`, `creator`, `create_time`, `updater`, `update_time`, `deleted`) VALUES ('2419', '', 'ea:electronic-contracts:delete', '3', '4', '2415', '', '', '', NULL, '0', b'1', b'1', b'1', '', '2023-09-20 11:29:50', '', '2023-09-20 11:29:50', b'0');
INSERT INTO `lyr-one`.`system_menu` (`id`, `name`, `permission`, `type`, `sort`, `parent_id`, `path`, `icon`, `component`, `component_name`, `status`, `visible`, `keep_alive`, `always_show`, `creator`, `create_time`, `updater`, `update_time`, `deleted`) VALUES ('2420', '', 'ea:electronic-contracts:export', '3', '5', '2415', '', '', '', NULL, '0', b'1', b'1', b'1', '', '2023-09-20 11:29:50', '', '2023-09-20 11:29:50', b'0');
--
INSERT INTO `lyr-one`.`system_menu` (`id`, `name`, `permission`, `type`, `sort`, `parent_id`, `path`, `icon`, `component`, `component_name`, `status`, `visible`, `keep_alive`, `always_show`, `creator`, `create_time`, `updater`, `update_time`, `deleted`) VALUES ('2439', '', '', '2', '0', '2383', 'electronic-employee', 'clipboard', 'ea/electronicEmployee/index', 'ElectronicEmployee', '0', b'1', b'1', b'1', '', '2023-09-22 14:53:59', '', '2023-09-22 14:53:59', b'0');
INSERT INTO `lyr-one`.`system_menu` (`id`, `name`, `permission`, `type`, `sort`, `parent_id`, `path`, `icon`, `component`, `component_name`, `status`, `visible`, `keep_alive`, `always_show`, `creator`, `create_time`, `updater`, `update_time`, `deleted`) VALUES ('2440', '', 'ea:electronic-employee:query', '3', '1', '2439', '', '', '', NULL, '0', b'1', b'1', b'1', '', '2023-09-22 14:53:59', '', '2023-09-22 14:53:59', b'0');
INSERT INTO `lyr-one`.`system_menu` (`id`, `name`, `permission`, `type`, `sort`, `parent_id`, `path`, `icon`, `component`, `component_name`, `status`, `visible`, `keep_alive`, `always_show`, `creator`, `create_time`, `updater`, `update_time`, `deleted`) VALUES ('2441', '', 'ea:electronic-employee:create', '3', '2', '2439', '', '', '', NULL, '0', b'1', b'1', b'1', '', '2023-09-22 14:53:59', '', '2023-09-22 14:53:59', b'0');
INSERT INTO `lyr-one`.`system_menu` (`id`, `name`, `permission`, `type`, `sort`, `parent_id`, `path`, `icon`, `component`, `component_name`, `status`, `visible`, `keep_alive`, `always_show`, `creator`, `create_time`, `updater`, `update_time`, `deleted`) VALUES ('2442', '', 'ea:electronic-employee:update', '3', '3', '2439', '', '', '', NULL, '0', b'1', b'1', b'1', '', '2023-09-22 14:53:59', '', '2023-09-22 14:53:59', b'0');
INSERT INTO `lyr-one`.`system_menu` (`id`, `name`, `permission`, `type`, `sort`, `parent_id`, `path`, `icon`, `component`, `component_name`, `status`, `visible`, `keep_alive`, `always_show`, `creator`, `create_time`, `updater`, `update_time`, `deleted`) VALUES ('2443', '', 'ea:electronic-employee:delete', '3', '4', '2439', '', '', '', NULL, '0', b'1', b'1', b'1', '', '2023-09-22 14:53:59', '', '2023-09-22 14:53:59', b'0');
INSERT INTO `lyr-one`.`system_menu` (`id`, `name`, `permission`, `type`, `sort`, `parent_id`, `path`, `icon`, `component`, `component_name`, `status`, `visible`, `keep_alive`, `always_show`, `creator`, `create_time`, `updater`, `update_time`, `deleted`) VALUES ('2444', '', 'ea:electronic-employee:export', '3', '5', '2439', '', '', '', NULL, '0', b'1', b'1', b'1', '', '2023-09-22 14:53:59', '', '2023-09-22 14:53:59', b'0');

@ -10,4 +10,6 @@ public interface ErrorCodeConstants {
ErrorCode BORROW_APPLY_NOT_EXISTS = new ErrorCode(300200,"借阅申请不存在");
ErrorCode AUTHENTICATE_NOT_EXISTS = new ErrorCode(300300,"档案鉴定历史不存在");
ErrorCode FLOW_NOT_EXISTS = new ErrorCode(300400, "审批流程不存在");
}

@ -0,0 +1,102 @@
package cn.iocoder.yudao.module.archives.controller.admin.flow;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import org.springframework.validation.annotation.Validated;
import org.springframework.security.access.prepost.PreAuthorize;
import io.swagger.v3.oas.annotations.tags.Tag;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.Operation;
import javax.validation.constraints.*;
import javax.validation.*;
import javax.servlet.http.*;
import java.util.*;
import java.io.IOException;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.pojo.CommonResult;
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils;
import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog;
import static cn.iocoder.yudao.framework.operatelog.core.enums.OperateTypeEnum.*;
import cn.iocoder.yudao.module.archives.controller.admin.flow.vo.*;
import cn.iocoder.yudao.module.archives.dal.dataobject.flow.FlowDO;
import cn.iocoder.yudao.module.archives.convert.flow.FlowConvert;
import cn.iocoder.yudao.module.archives.service.flow.FlowService;
@Tag(name = "管理后台 - 审批流程")
@RestController
@RequestMapping("/archives/flow")
@Validated
public class FlowController {
@Resource
private FlowService flowService;
@PostMapping("/create")
@Operation(summary = "创建审批流程")
@PreAuthorize("@ss.hasPermission('archives:flow:create')")
public CommonResult<Long> createFlow(@Valid @RequestBody FlowCreateReqVO createReqVO) {
return success(flowService.createFlow(createReqVO));
}
@PutMapping("/update")
@Operation(summary = "更新审批流程")
@PreAuthorize("@ss.hasPermission('archives:flow:update')")
public CommonResult<Boolean> updateFlow(@Valid @RequestBody FlowUpdateReqVO updateReqVO) {
flowService.updateFlow(updateReqVO);
return success(true);
}
@DeleteMapping("/delete")
@Operation(summary = "删除审批流程")
@Parameter(name = "id", description = "编号", required = true)
@PreAuthorize("@ss.hasPermission('archives:flow:delete')")
public CommonResult<Boolean> deleteFlow(@RequestParam("id") Long id) {
flowService.deleteFlow(id);
return success(true);
}
@GetMapping("/get")
@Operation(summary = "获得审批流程")
@Parameter(name = "id", description = "编号", required = true, example = "1024")
@PreAuthorize("@ss.hasPermission('archives:flow:query')")
public CommonResult<FlowRespVO> getFlow(@RequestParam("id") Long id) {
FlowDO flow = flowService.getFlow(id);
return success(FlowConvert.INSTANCE.convert(flow));
}
@GetMapping("/list")
@Operation(summary = "获得审批流程列表")
@Parameter(name = "ids", description = "编号列表", required = true, example = "1024,2048")
@PreAuthorize("@ss.hasPermission('archives:flow:query')")
public CommonResult<List<FlowRespVO>> getFlowList(@RequestParam("ids") Collection<Long> ids) {
List<FlowDO> list = flowService.getFlowList(ids);
return success(FlowConvert.INSTANCE.convertList(list));
}
@GetMapping("/page")
@Operation(summary = "获得审批流程分页")
@PreAuthorize("@ss.hasPermission('archives:flow:query')")
public CommonResult<PageResult<FlowRespVO>> getFlowPage(@Valid FlowPageReqVO pageVO) {
PageResult<FlowDO> pageResult = flowService.getFlowPage(pageVO);
return success(FlowConvert.INSTANCE.convertPage(pageResult));
}
@GetMapping("/export-excel")
@Operation(summary = "导出审批流程 Excel")
@PreAuthorize("@ss.hasPermission('archives:flow:export')")
@OperateLog(type = EXPORT)
public void exportFlowExcel(@Valid FlowExportReqVO exportReqVO,
HttpServletResponse response) throws IOException {
List<FlowDO> list = flowService.getFlowList(exportReqVO);
// 导出 Excel
List<FlowExcelVO> datas = FlowConvert.INSTANCE.convertList02(list);
ExcelUtils.write(response, "审批流程.xls", "数据", FlowExcelVO.class, datas);
}
}

@ -0,0 +1,69 @@
package cn.iocoder.yudao.module.archives.controller.admin.flow.vo;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*;
import java.util.*;
import java.time.LocalDateTime;
import java.time.LocalDateTime;
import java.time.LocalDateTime;
import javax.validation.constraints.*;
/**
* Base VO VO 使
* VO Swagger
*/
@Data
public class FlowBaseVO {
@Schema(description = "OA/ERP流程编号")
private String flowCode;
@Schema(description = "凭证id", example = "19145")
private Long voucherId;
@Schema(description = "凭证号")
private String voucherNum;
@Schema(description = "业务id", example = "21987")
private Long businessId;
@Schema(description = "业务类型", example = "2")
private String businessType;
@Schema(description = "业务实体id", example = "8805")
private Long companyId;
@Schema(description = "业务实体")
private String company;
@Schema(description = "删除状态", example = "2")
private String delStatus;
@Schema(description = "文件后缀")
private String suffix;
@Schema(description = "文件地址", example = "https://www.iocoder.cn")
private String fileUrl;
@Schema(description = "绝对路径")
private String fileAp;
@Schema(description = "流程号", example = "13373")
private String flowId;
@Schema(description = "摘要")
private String note;
@Schema(description = "部门id", example = "31515")
private Long deptId;
@Schema(description = "部门名称", example = "张三")
private String deptName;
@Schema(description = "归档id", example = "3820")
private Long archiveId;
@Schema(description = "归档状态")
private String archiveState;
}

@ -0,0 +1,14 @@
package cn.iocoder.yudao.module.archives.controller.admin.flow.vo;
import lombok.*;
import java.util.*;
import io.swagger.v3.oas.annotations.media.Schema;
import javax.validation.constraints.*;
@Schema(description = "管理后台 - 审批流程创建 Request VO")
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
public class FlowCreateReqVO extends FlowBaseVO {
}

@ -0,0 +1,77 @@
package cn.iocoder.yudao.module.archives.controller.admin.flow.vo;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*;
import java.util.*;
import java.time.LocalDateTime;
import java.time.LocalDateTime;
import java.time.LocalDateTime;
import com.alibaba.excel.annotation.ExcelProperty;
/**
* Excel VO
*
* @author
*/
@Data
public class FlowExcelVO {
@ExcelProperty("主键Id")
private Long id;
@ExcelProperty("OA/ERP流程编号")
private String flowCode;
@ExcelProperty("凭证id")
private Long voucherId;
@ExcelProperty("凭证号")
private String voucherNum;
@ExcelProperty("业务id")
private Long businessId;
@ExcelProperty("业务类型")
private String businessType;
@ExcelProperty("创建时间")
private LocalDateTime createTime;
@ExcelProperty("业务实体id")
private Long companyId;
@ExcelProperty("业务实体")
private String company;
@ExcelProperty("删除状态")
private String delStatus;
@ExcelProperty("文件后缀")
private String suffix;
@ExcelProperty("文件地址")
private String fileUrl;
@ExcelProperty("绝对路径")
private String fileAp;
@ExcelProperty("流程号")
private String flowId;
@ExcelProperty("摘要")
private String note;
@ExcelProperty("部门id")
private Long deptId;
@ExcelProperty("部门名称")
private String deptName;
@ExcelProperty("归档id")
private Long archiveId;
@ExcelProperty("归档状态")
private String archiveState;
}

@ -0,0 +1,71 @@
package cn.iocoder.yudao.module.archives.controller.admin.flow.vo;
import lombok.*;
import java.util.*;
import io.swagger.v3.oas.annotations.media.Schema;
import cn.iocoder.yudao.framework.common.pojo.PageParam;
import java.time.LocalDateTime;
import org.springframework.format.annotation.DateTimeFormat;
import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
@Schema(description = "管理后台 - 审批流程 Excel 导出 Request VO参数和 FlowPageReqVO 是一致的")
@Data
public class FlowExportReqVO {
@Schema(description = "OA/ERP流程编号")
private String flowCode;
@Schema(description = "凭证id", example = "19145")
private Long voucherId;
@Schema(description = "凭证号")
private String voucherNum;
@Schema(description = "业务id", example = "21987")
private Long businessId;
@Schema(description = "业务类型", example = "2")
private String businessType;
@Schema(description = "创建时间")
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
private LocalDateTime[] createTime;
@Schema(description = "业务实体id", example = "8805")
private Long companyId;
@Schema(description = "业务实体")
private String company;
@Schema(description = "删除状态", example = "2")
private String delStatus;
@Schema(description = "文件后缀")
private String suffix;
@Schema(description = "文件地址", example = "https://www.iocoder.cn")
private String fileUrl;
@Schema(description = "绝对路径")
private String fileAp;
@Schema(description = "流程号", example = "13373")
private String flowId;
@Schema(description = "摘要")
private String note;
@Schema(description = "部门id", example = "31515")
private Long deptId;
@Schema(description = "部门名称", example = "张三")
private String deptName;
@Schema(description = "归档id", example = "3820")
private Long archiveId;
@Schema(description = "归档状态")
private String archiveState;
}

@ -0,0 +1,73 @@
package cn.iocoder.yudao.module.archives.controller.admin.flow.vo;
import lombok.*;
import java.util.*;
import io.swagger.v3.oas.annotations.media.Schema;
import cn.iocoder.yudao.framework.common.pojo.PageParam;
import org.springframework.format.annotation.DateTimeFormat;
import java.time.LocalDateTime;
import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
@Schema(description = "管理后台 - 审批流程分页 Request VO")
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
public class FlowPageReqVO extends PageParam {
@Schema(description = "OA/ERP流程编号")
private String flowCode;
@Schema(description = "凭证id", example = "19145")
private Long voucherId;
@Schema(description = "凭证号")
private String voucherNum;
@Schema(description = "业务id", example = "21987")
private Long businessId;
@Schema(description = "业务类型", example = "2")
private String businessType;
@Schema(description = "创建时间")
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
private LocalDateTime[] createTime;
@Schema(description = "业务实体id", example = "8805")
private Long companyId;
@Schema(description = "业务实体")
private String company;
@Schema(description = "删除状态", example = "2")
private String delStatus;
@Schema(description = "文件后缀")
private String suffix;
@Schema(description = "文件地址", example = "https://www.iocoder.cn")
private String fileUrl;
@Schema(description = "绝对路径")
private String fileAp;
@Schema(description = "流程号", example = "13373")
private String flowId;
@Schema(description = "摘要")
private String note;
@Schema(description = "部门id", example = "31515")
private Long deptId;
@Schema(description = "部门名称", example = "张三")
private String deptName;
@Schema(description = "归档id", example = "3820")
private Long archiveId;
@Schema(description = "归档状态")
private String archiveState;
}

@ -0,0 +1,19 @@
package cn.iocoder.yudao.module.archives.controller.admin.flow.vo;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*;
import java.time.LocalDateTime;
@Schema(description = "管理后台 - 审批流程 Response VO")
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
public class FlowRespVO extends FlowBaseVO {
@Schema(description = "主键Id", requiredMode = Schema.RequiredMode.REQUIRED, example = "3083")
private Long id;
@Schema(description = "创建时间")
private LocalDateTime createTime;
}

@ -0,0 +1,18 @@
package cn.iocoder.yudao.module.archives.controller.admin.flow.vo;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*;
import java.util.*;
import javax.validation.constraints.*;
@Schema(description = "管理后台 - 审批流程更新 Request VO")
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
public class FlowUpdateReqVO extends FlowBaseVO {
@Schema(description = "主键Id", requiredMode = Schema.RequiredMode.REQUIRED, example = "3083")
@NotNull(message = "主键Id不能为空")
private Long id;
}

@ -0,0 +1,34 @@
package cn.iocoder.yudao.module.archives.convert.flow;
import java.util.*;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import org.mapstruct.Mapper;
import org.mapstruct.factory.Mappers;
import cn.iocoder.yudao.module.archives.controller.admin.flow.vo.*;
import cn.iocoder.yudao.module.archives.dal.dataobject.flow.FlowDO;
/**
* Convert
*
* @author
*/
@Mapper
public interface FlowConvert {
FlowConvert INSTANCE = Mappers.getMapper(FlowConvert.class);
FlowDO convert(FlowCreateReqVO bean);
FlowDO convert(FlowUpdateReqVO bean);
FlowRespVO convert(FlowDO bean);
List<FlowRespVO> convertList(List<FlowDO> list);
PageResult<FlowRespVO> convertPage(PageResult<FlowDO> page);
List<FlowExcelVO> convertList02(List<FlowDO> list);
}

@ -0,0 +1,100 @@
package cn.iocoder.yudao.module.archives.dal.dataobject.flow;
import lombok.*;
import java.util.*;
import java.time.LocalDateTime;
import java.time.LocalDateTime;
import java.time.LocalDateTime;
import com.baomidou.mybatisplus.annotation.*;
import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;
/**
* DO
*
* @author
*/
@TableName("archives_flow")
@KeySequence("archives_flow_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class FlowDO extends BaseDO {
/**
* Id
*/
@TableId
private Long id;
/**
* OA/ERP
*/
private String flowCode;
/**
* id
*/
private Long voucherId;
/**
*
*/
private String voucherNum;
/**
* id
*/
private Long businessId;
/**
*
*/
private String businessType;
/**
* id
*/
private Long companyId;
/**
*
*/
private String company;
/**
*
*/
private String delStatus;
/**
*
*/
private String suffix;
/**
*
*/
private String fileUrl;
/**
*
*/
private String fileAp;
/**
*
*/
private String flowId;
/**
*
*/
private String note;
/**
* id
*/
private Long deptId;
/**
*
*/
private String deptName;
/**
* id
*/
private Long archiveId;
/**
*
*/
private String archiveState;
}

@ -0,0 +1,66 @@
package cn.iocoder.yudao.module.archives.dal.mysql.flow;
import java.util.*;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
import cn.iocoder.yudao.module.archives.dal.dataobject.flow.FlowDO;
import org.apache.ibatis.annotations.Mapper;
import cn.iocoder.yudao.module.archives.controller.admin.flow.vo.*;
/**
* Mapper
*
* @author
*/
@Mapper
public interface FlowMapper extends BaseMapperX<FlowDO> {
default PageResult<FlowDO> selectPage(FlowPageReqVO reqVO) {
return selectPage(reqVO, new LambdaQueryWrapperX<FlowDO>()
.eqIfPresent(FlowDO::getFlowCode, reqVO.getFlowCode())
.eqIfPresent(FlowDO::getVoucherId, reqVO.getVoucherId())
.eqIfPresent(FlowDO::getVoucherNum, reqVO.getVoucherNum())
.eqIfPresent(FlowDO::getBusinessId, reqVO.getBusinessId())
.eqIfPresent(FlowDO::getBusinessType, reqVO.getBusinessType())
.betweenIfPresent(FlowDO::getCreateTime, reqVO.getCreateTime())
.eqIfPresent(FlowDO::getCompanyId, reqVO.getCompanyId())
.eqIfPresent(FlowDO::getCompany, reqVO.getCompany())
.eqIfPresent(FlowDO::getDelStatus, reqVO.getDelStatus())
.eqIfPresent(FlowDO::getSuffix, reqVO.getSuffix())
.eqIfPresent(FlowDO::getFileUrl, reqVO.getFileUrl())
.eqIfPresent(FlowDO::getFileAp, reqVO.getFileAp())
.eqIfPresent(FlowDO::getFlowId, reqVO.getFlowId())
.eqIfPresent(FlowDO::getNote, reqVO.getNote())
.eqIfPresent(FlowDO::getDeptId, reqVO.getDeptId())
.likeIfPresent(FlowDO::getDeptName, reqVO.getDeptName())
.eqIfPresent(FlowDO::getArchiveId, reqVO.getArchiveId())
.eqIfPresent(FlowDO::getArchiveState, reqVO.getArchiveState())
.orderByDesc(FlowDO::getId));
}
default List<FlowDO> selectList(FlowExportReqVO reqVO) {
return selectList(new LambdaQueryWrapperX<FlowDO>()
.eqIfPresent(FlowDO::getFlowCode, reqVO.getFlowCode())
.eqIfPresent(FlowDO::getVoucherId, reqVO.getVoucherId())
.eqIfPresent(FlowDO::getVoucherNum, reqVO.getVoucherNum())
.eqIfPresent(FlowDO::getBusinessId, reqVO.getBusinessId())
.eqIfPresent(FlowDO::getBusinessType, reqVO.getBusinessType())
.betweenIfPresent(FlowDO::getCreateTime, reqVO.getCreateTime())
.eqIfPresent(FlowDO::getCompanyId, reqVO.getCompanyId())
.eqIfPresent(FlowDO::getCompany, reqVO.getCompany())
.eqIfPresent(FlowDO::getDelStatus, reqVO.getDelStatus())
.eqIfPresent(FlowDO::getSuffix, reqVO.getSuffix())
.eqIfPresent(FlowDO::getFileUrl, reqVO.getFileUrl())
.eqIfPresent(FlowDO::getFileAp, reqVO.getFileAp())
.eqIfPresent(FlowDO::getFlowId, reqVO.getFlowId())
.eqIfPresent(FlowDO::getNote, reqVO.getNote())
.eqIfPresent(FlowDO::getDeptId, reqVO.getDeptId())
.likeIfPresent(FlowDO::getDeptName, reqVO.getDeptName())
.eqIfPresent(FlowDO::getArchiveId, reqVO.getArchiveId())
.eqIfPresent(FlowDO::getArchiveState, reqVO.getArchiveState())
.orderByDesc(FlowDO::getId));
}
}

@ -0,0 +1,70 @@
package cn.iocoder.yudao.module.archives.service.flow;
import java.util.*;
import javax.validation.*;
import cn.iocoder.yudao.module.archives.controller.admin.flow.vo.*;
import cn.iocoder.yudao.module.archives.dal.dataobject.flow.FlowDO;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
/**
* Service
*
* @author
*/
public interface FlowService {
/**
*
*
* @param createReqVO
* @return
*/
Long createFlow(@Valid FlowCreateReqVO createReqVO);
/**
*
*
* @param updateReqVO
*/
void updateFlow(@Valid FlowUpdateReqVO updateReqVO);
/**
*
*
* @param id
*/
void deleteFlow(Long id);
/**
*
*
* @param id
* @return
*/
FlowDO getFlow(Long id);
/**
*
*
* @param ids
* @return
*/
List<FlowDO> getFlowList(Collection<Long> ids);
/**
*
*
* @param pageReqVO
* @return
*/
PageResult<FlowDO> getFlowPage(FlowPageReqVO pageReqVO);
/**
* , Excel
*
* @param exportReqVO
* @return
*/
List<FlowDO> getFlowList(FlowExportReqVO exportReqVO);
}

@ -0,0 +1,82 @@
package cn.iocoder.yudao.module.archives.service.flow;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import org.springframework.validation.annotation.Validated;
import java.util.*;
import cn.iocoder.yudao.module.archives.controller.admin.flow.vo.*;
import cn.iocoder.yudao.module.archives.dal.dataobject.flow.FlowDO;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.module.archives.convert.flow.FlowConvert;
import cn.iocoder.yudao.module.archives.dal.mysql.flow.FlowMapper;
import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
import static cn.iocoder.yudao.module.archives.enums.ErrorCodeConstants.*;
/**
* Service
*
* @author
*/
@Service
@Validated
public class FlowServiceImpl implements FlowService {
@Resource
private FlowMapper flowMapper;
@Override
public Long createFlow(FlowCreateReqVO createReqVO) {
// 插入
FlowDO flow = FlowConvert.INSTANCE.convert(createReqVO);
flowMapper.insert(flow);
// 返回
return flow.getId();
}
@Override
public void updateFlow(FlowUpdateReqVO updateReqVO) {
// 校验存在
validateFlowExists(updateReqVO.getId());
// 更新
FlowDO updateObj = FlowConvert.INSTANCE.convert(updateReqVO);
flowMapper.updateById(updateObj);
}
@Override
public void deleteFlow(Long id) {
// 校验存在
validateFlowExists(id);
// 删除
flowMapper.deleteById(id);
}
private void validateFlowExists(Long id) {
if (flowMapper.selectById(id) == null) {
throw exception(FLOW_NOT_EXISTS);
}
}
@Override
public FlowDO getFlow(Long id) {
return flowMapper.selectById(id);
}
@Override
public List<FlowDO> getFlowList(Collection<Long> ids) {
return flowMapper.selectBatchIds(ids);
}
@Override
public PageResult<FlowDO> getFlowPage(FlowPageReqVO pageReqVO) {
return flowMapper.selectPage(pageReqVO);
}
@Override
public List<FlowDO> getFlowList(FlowExportReqVO exportReqVO) {
return flowMapper.selectList(exportReqVO);
}
}

@ -0,0 +1,12 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.iocoder.yudao.module.archives.dal.mysql.flow.FlowMapper">
<!--
一般情况下,尽可能使用 Mapper 进行 CRUD 增删改查即可。
无法满足的场景,例如说多表关联查询,才使用 XML 编写 SQL。
代码生成器暂时只生成 Mapper XML 文件本身,更多推荐 MybatisX 快速开发插件来生成查询。
文档可见https://www.iocoder.cn/MyBatis/x-plugins/
-->
</mapper>

@ -2,7 +2,11 @@ package cn.iocoder.yudao.module.ea.enums;
import cn.iocoder.yudao.framework.common.exception.ErrorCode;
/**
* @author HP
*/
public interface ErrorCodeConstants {
ErrorCode ELECTRONIC_ASSETS_NOT_EXISTS = new ErrorCode(300010, "资产档案不存在");
ErrorCode ELECTRONIC_CONTRACTS_NOT_EXISTS = new ErrorCode(300011, "合同档案不存在");
ErrorCode ELECTRONIC_EMPLOYEE_NOT_EXISTS = new ErrorCode(300012, "员工档案不存在");
}

@ -1,36 +1,36 @@
package cn.iocoder.yudao.module.ea.controller.admin.electroniccontracts;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import org.springframework.validation.annotation.Validated;
import org.springframework.security.access.prepost.PreAuthorize;
import io.swagger.v3.oas.annotations.tags.Tag;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.Operation;
import javax.validation.constraints.*;
import javax.validation.*;
import javax.servlet.http.*;
import java.util.*;
import java.io.IOException;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.pojo.CommonResult;
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils;
import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog;
import static cn.iocoder.yudao.framework.operatelog.core.enums.OperateTypeEnum.*;
import cn.iocoder.yudao.module.ea.controller.admin.electroniccontracts.vo.*;
import cn.iocoder.yudao.module.ea.dal.dataobject.electroniccontracts.ElectronicContractsDO;
import cn.iocoder.yudao.module.ea.convert.electroniccontracts.ElectronicContractsConvert;
import cn.iocoder.yudao.module.ea.dal.dataobject.electroniccontracts.ElectronicContractsDO;
import cn.iocoder.yudao.module.ea.service.electroniccontracts.ElectronicContractsService;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.tags.Tag;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletResponse;
import javax.validation.Valid;
import java.io.IOException;
import java.util.Collection;
import java.util.List;
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
import static cn.iocoder.yudao.framework.operatelog.core.enums.OperateTypeEnum.EXPORT;
/**
* @author HP
*/
@Tag(name = "管理后台 - 合同档案")
@RestController
@RequestMapping("/ea/electronic-contracts")
@RequestMapping("/ea/electronicContracts")
@Validated
public class ElectronicContractsController {

@ -0,0 +1,102 @@
package cn.iocoder.yudao.module.ea.controller.admin.electronicemployee;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import org.springframework.validation.annotation.Validated;
import org.springframework.security.access.prepost.PreAuthorize;
import io.swagger.v3.oas.annotations.tags.Tag;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.Operation;
import javax.validation.constraints.*;
import javax.validation.*;
import javax.servlet.http.*;
import java.util.*;
import java.io.IOException;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.pojo.CommonResult;
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils;
import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog;
import static cn.iocoder.yudao.framework.operatelog.core.enums.OperateTypeEnum.*;
import cn.iocoder.yudao.module.ea.controller.admin.electronicemployee.vo.*;
import cn.iocoder.yudao.module.ea.dal.dataobject.electronicemployee.ElectronicEmployeeDO;
import cn.iocoder.yudao.module.ea.convert.electronicemployee.ElectronicEmployeeConvert;
import cn.iocoder.yudao.module.ea.service.electronicemployee.ElectronicEmployeeService;
@Tag(name = "管理后台 - 员工档案")
@RestController
@RequestMapping("/ea/electronic-employee")
@Validated
public class ElectronicEmployeeController {
@Resource
private ElectronicEmployeeService electronicEmployeeService;
@PostMapping("/create")
@Operation(summary = "创建员工档案")
@PreAuthorize("@ss.hasPermission('ea:electronic-employee:create')")
public CommonResult<Long> createElectronicEmployee(@Valid @RequestBody ElectronicEmployeeCreateReqVO createReqVO) {
return success(electronicEmployeeService.createElectronicEmployee(createReqVO));
}
@PutMapping("/update")
@Operation(summary = "更新员工档案")
@PreAuthorize("@ss.hasPermission('ea:electronic-employee:update')")
public CommonResult<Boolean> updateElectronicEmployee(@Valid @RequestBody ElectronicEmployeeUpdateReqVO updateReqVO) {
electronicEmployeeService.updateElectronicEmployee(updateReqVO);
return success(true);
}
@DeleteMapping("/delete")
@Operation(summary = "删除员工档案")
@Parameter(name = "id", description = "编号", required = true)
@PreAuthorize("@ss.hasPermission('ea:electronic-employee:delete')")
public CommonResult<Boolean> deleteElectronicEmployee(@RequestParam("id") Long id) {
electronicEmployeeService.deleteElectronicEmployee(id);
return success(true);
}
@GetMapping("/get")
@Operation(summary = "获得员工档案")
@Parameter(name = "id", description = "编号", required = true, example = "1024")
@PreAuthorize("@ss.hasPermission('ea:electronic-employee:query')")
public CommonResult<ElectronicEmployeeRespVO> getElectronicEmployee(@RequestParam("id") Long id) {
ElectronicEmployeeDO electronicEmployee = electronicEmployeeService.getElectronicEmployee(id);
return success(ElectronicEmployeeConvert.INSTANCE.convert(electronicEmployee));
}
@GetMapping("/list")
@Operation(summary = "获得员工档案列表")
@Parameter(name = "ids", description = "编号列表", required = true, example = "1024,2048")
@PreAuthorize("@ss.hasPermission('ea:electronic-employee:query')")
public CommonResult<List<ElectronicEmployeeRespVO>> getElectronicEmployeeList(@RequestParam("ids") Collection<Long> ids) {
List<ElectronicEmployeeDO> list = electronicEmployeeService.getElectronicEmployeeList(ids);
return success(ElectronicEmployeeConvert.INSTANCE.convertList(list));
}
@GetMapping("/page")
@Operation(summary = "获得员工档案分页")
@PreAuthorize("@ss.hasPermission('ea:electronic-employee:query')")
public CommonResult<PageResult<ElectronicEmployeeRespVO>> getElectronicEmployeePage(@Valid ElectronicEmployeePageReqVO pageVO) {
PageResult<ElectronicEmployeeDO> pageResult = electronicEmployeeService.getElectronicEmployeePage(pageVO);
return success(ElectronicEmployeeConvert.INSTANCE.convertPage(pageResult));
}
@GetMapping("/export-excel")
@Operation(summary = "导出员工档案 Excel")
@PreAuthorize("@ss.hasPermission('ea:electronic-employee:export')")
@OperateLog(type = EXPORT)
public void exportElectronicEmployeeExcel(@Valid ElectronicEmployeeExportReqVO exportReqVO,
HttpServletResponse response) throws IOException {
List<ElectronicEmployeeDO> list = electronicEmployeeService.getElectronicEmployeeList(exportReqVO);
// 导出 Excel
List<ElectronicEmployeeExcelVO> datas = ElectronicEmployeeConvert.INSTANCE.convertList02(list);
ExcelUtils.write(response, "员工档案.xls", "数据", ElectronicEmployeeExcelVO.class, datas);
}
}

@ -0,0 +1,65 @@
package cn.iocoder.yudao.module.ea.controller.admin.electronicemployee.vo;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*;
import java.util.*;
import java.time.LocalDateTime;
import java.time.LocalDateTime;
import javax.validation.constraints.*;
/**
* Base VO VO 使
* VO Swagger
*/
@Data
public class ElectronicEmployeeBaseVO {
@Schema(description = "id" )
private Long id;
@Schema(description = "制单人")
private String createBy;
@Schema(description = "业务实体")
private String company;
@Schema(description = "所属部门", example = "王五")
private String deptName;
@Schema(description = "员工姓名", example = "张三")
private String name;
@Schema(description = "性别")
private String gender;
@Schema(description = "国籍")
private String nationality;
@Schema(description = "联系方式")
private String contactNumber;
@Schema(description = "身份证号")
private String idCardNumber;
@Schema(description = "年度")
private String year;
@Schema(description = "月份")
private String period;
@Schema(description = "借阅状态", example = "2")
private String borrowStatus;
@Schema(description = "归档时间")
private String recordTime;
@Schema(description = "纸档位置")
private String position;
@Schema(description = "完整性")
private Integer cherks;
@Schema(description = "归档状态", example = "2")
private String fileStatus;
}

@ -0,0 +1,100 @@
package cn.iocoder.yudao.module.ea.controller.admin.electronicemployee.vo;
import lombok.*;
import java.time.LocalDate;
import java.util.*;
import io.swagger.v3.oas.annotations.media.Schema;
import javax.validation.constraints.*;
/**
* @author HP
*/
@Schema(description = "管理后台 - 员工档案创建 Request VO")
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
public class ElectronicEmployeeCreateReqVO extends ElectronicEmployeeBaseVO {
@Schema(description = "出生日期")
private LocalDate birthdate;
@Schema(description = "地址")
private String address;
@Schema(description = "护照号码")
private String passportNumber;
@Schema(description = "毕业学校")
private String graduationSchool;
@Schema(description = "专业")
private String major;
@Schema(description = "学历")
private String education;
@Schema(description = "教育经历")
private String educationExperience;
@Schema(description = "工作经历")
private String workExperience;
@Schema(description = "职位")
private String jobTitle;
@Schema(description = "职位级别")
private String jobLevel;
@Schema(description = "职位描述", example = "你说的对")
private String jobDescription;
@Schema(description = "薪酬")
private Long salary;
@Schema(description = "身体状况")
private String healthCondition;
@Schema(description = "体检记录")
private String medicalRecords;
@Schema(description = "疾病史")
private String diseaseHistory;
@Schema(description = "养老保险")
private String socialInsurance;
@Schema(description = "医疗保险")
private Long pensionInsurance;
@Schema(description = "失业保险")
private Long medicalInsurance;
@Schema(description = "失业保险")
private Long unemploymentInsurance;
@Schema(description = "工伤保险")
private Long workInjuryInsurance;
@Schema(description = "考核评价")
private String leaveRecords;
@Schema(description = "奖惩记录")
private String overtimeRecords;
@Schema(description = "培训计划")
private String welfareBenefits;
@Schema(description = "培训成果")
private String performanceEvaluation;
@Schema(description = "个人标签")
private String rewardsPunishments;
@Schema(description = "兴趣爱好")
private String trainingRecords;
@Schema(description = "特长", example = "你说的对")
private String personalDescription;
}

@ -0,0 +1,69 @@
package cn.iocoder.yudao.module.ea.controller.admin.electronicemployee.vo;
import cn.iocoder.yudao.framework.excel.core.annotations.DictFormat;
import cn.iocoder.yudao.framework.excel.core.convert.DictConvert;
import com.alibaba.excel.annotation.ExcelProperty;
import lombok.Data;
import java.time.LocalDateTime;
/**
* Excel VO
*
* @author
*/
@Data
public class ElectronicEmployeeExcelVO {
@ExcelProperty("制单人")
private String createBy;
@ExcelProperty("创建日期")
private LocalDateTime createTime;
@ExcelProperty("业务实体")
private String company;
@ExcelProperty("所属部门")
private String deptName;
@ExcelProperty("员工姓名")
private String name;
@ExcelProperty(value = "性别", converter = DictConvert.class)
@DictFormat("system_user_sex") // TODO 代码优化:建议设置到对应的 XXXDictTypeConstants 枚举类中
private String gender;
@ExcelProperty("国籍")
private String nationality;
@ExcelProperty("联系方式")
private String contactNumber;
@ExcelProperty("身份证号")
private String idCardNumber;
@ExcelProperty("年度")
private String year;
@ExcelProperty("月份")
private String period;
@ExcelProperty(value = "借阅状态", converter = DictConvert.class)
@DictFormat("infra_boolean_string") // TODO 代码优化:建议设置到对应的 XXXDictTypeConstants 枚举类中
private String borrowStatus;
@ExcelProperty("归档时间")
private String recordTime;
@ExcelProperty("纸档位置")
private String position;
@ExcelProperty("完整性")
private Integer cherks;
@ExcelProperty("归档状态")
private String fileStatus;
}

@ -0,0 +1,66 @@
package cn.iocoder.yudao.module.ea.controller.admin.electronicemployee.vo;
import lombok.*;
import java.util.*;
import io.swagger.v3.oas.annotations.media.Schema;
import cn.iocoder.yudao.framework.common.pojo.PageParam;
import java.time.LocalDateTime;
import org.springframework.format.annotation.DateTimeFormat;
import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
@Schema(description = "管理后台 - 员工档案 Excel 导出 Request VO参数和 ElectronicEmployeePageReqVO 是一致的")
@Data
public class ElectronicEmployeeExportReqVO {
@Schema(description = "制单人")
private String createBy;
@Schema(description = "创建日期")
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
private LocalDateTime[] createTime;
@Schema(description = "业务实体")
private String company;
@Schema(description = "所属部门", example = "王五")
private String deptName;
@Schema(description = "员工姓名", example = "张三")
private String name;
@Schema(description = "性别")
private String gender;
@Schema(description = "国籍")
private String nationality;
@Schema(description = "联系方式")
private String contactNumber;
@Schema(description = "身份证号")
private String idCardNumber;
@Schema(description = "年度")
private String year;
@Schema(description = "月份")
private String period;
@Schema(description = "借阅状态", example = "2")
private String borrowStatus;
@Schema(description = "归档时间")
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
private String[] recordTime;
@Schema(description = "纸档位置")
private String position;
@Schema(description = "完整性")
private Integer cherks;
@Schema(description = "归档状态", example = "2")
private String fileStatus;
}

@ -0,0 +1,68 @@
package cn.iocoder.yudao.module.ea.controller.admin.electronicemployee.vo;
import lombok.*;
import java.util.*;
import io.swagger.v3.oas.annotations.media.Schema;
import cn.iocoder.yudao.framework.common.pojo.PageParam;
import org.springframework.format.annotation.DateTimeFormat;
import java.time.LocalDateTime;
import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
@Schema(description = "管理后台 - 员工档案分页 Request VO")
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
public class ElectronicEmployeePageReqVO extends PageParam {
@Schema(description = "制单人")
private String createBy;
@Schema(description = "创建日期")
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
private LocalDateTime[] createTime;
@Schema(description = "业务实体")
private String company;
@Schema(description = "所属部门", example = "王五")
private String deptName;
@Schema(description = "员工姓名", example = "张三")
private String name;
@Schema(description = "性别")
private String gender;
@Schema(description = "国籍")
private String nationality;
@Schema(description = "联系方式")
private String contactNumber;
@Schema(description = "身份证号")
private String idCardNumber;
@Schema(description = "年度")
private String year;
@Schema(description = "月份")
private String period;
@Schema(description = "借阅状态", example = "2")
private String borrowStatus;
@Schema(description = "归档时间")
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
private String[] recordTime;
@Schema(description = "纸档位置")
private String position;
@Schema(description = "完整性")
private Integer cherks;
@Schema(description = "归档状态", example = "2")
private String fileStatus;
}

@ -0,0 +1,16 @@
package cn.iocoder.yudao.module.ea.controller.admin.electronicemployee.vo;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*;
import java.time.LocalDateTime;
@Schema(description = "管理后台 - 员工档案 Response VO")
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
public class ElectronicEmployeeRespVO extends ElectronicEmployeeBaseVO {
@Schema(description = "创建日期")
private LocalDateTime createTime;
}

@ -0,0 +1,97 @@
package cn.iocoder.yudao.module.ea.controller.admin.electronicemployee.vo;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*;
import java.time.LocalDate;
import java.util.*;
import javax.validation.constraints.*;
@Schema(description = "管理后台 - 员工档案更新 Request VO")
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
public class ElectronicEmployeeUpdateReqVO extends ElectronicEmployeeBaseVO {
@Schema(description = "出生日期")
private LocalDate birthdate;
@Schema(description = "地址")
private String address;
@Schema(description = "护照号码")
private String passportNumber;
@Schema(description = "毕业学校")
private String graduationSchool;
@Schema(description = "专业")
private String major;
@Schema(description = "学历")
private String education;
@Schema(description = "教育经历")
private String educationExperience;
@Schema(description = "工作经历")
private String workExperience;
@Schema(description = "职位")
private String jobTitle;
@Schema(description = "职位级别")
private String jobLevel;
@Schema(description = "职位描述", example = "你说的对")
private String jobDescription;
@Schema(description = "薪酬")
private Long salary;
@Schema(description = "身体状况")
private String healthCondition;
@Schema(description = "体检记录")
private String medicalRecords;
@Schema(description = "疾病史")
private String diseaseHistory;
@Schema(description = "养老保险")
private String socialInsurance;
@Schema(description = "医疗保险")
private Long pensionInsurance;
@Schema(description = "失业保险")
private Long medicalInsurance;
@Schema(description = "失业保险")
private Long unemploymentInsurance;
@Schema(description = "工伤保险")
private Long workInjuryInsurance;
@Schema(description = "考核评价")
private String leaveRecords;
@Schema(description = "奖惩记录")
private String overtimeRecords;
@Schema(description = "培训计划")
private String welfareBenefits;
@Schema(description = "培训成果")
private String performanceEvaluation;
@Schema(description = "个人标签")
private String rewardsPunishments;
@Schema(description = "兴趣爱好")
private String trainingRecords;
@Schema(description = "特长", example = "你说的对")
private String personalDescription;
}

@ -0,0 +1,34 @@
package cn.iocoder.yudao.module.ea.convert.electronicemployee;
import java.util.*;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import org.mapstruct.Mapper;
import org.mapstruct.factory.Mappers;
import cn.iocoder.yudao.module.ea.controller.admin.electronicemployee.vo.*;
import cn.iocoder.yudao.module.ea.dal.dataobject.electronicemployee.ElectronicEmployeeDO;
/**
* Convert
*
* @author
*/
@Mapper
public interface ElectronicEmployeeConvert {
ElectronicEmployeeConvert INSTANCE = Mappers.getMapper(ElectronicEmployeeConvert.class);
ElectronicEmployeeDO convert(ElectronicEmployeeCreateReqVO bean);
ElectronicEmployeeDO convert(ElectronicEmployeeUpdateReqVO bean);
ElectronicEmployeeRespVO convert(ElectronicEmployeeDO bean);
List<ElectronicEmployeeRespVO> convertList(List<ElectronicEmployeeDO> list);
PageResult<ElectronicEmployeeRespVO> convertPage(PageResult<ElectronicEmployeeDO> page);
List<ElectronicEmployeeExcelVO> convertList02(List<ElectronicEmployeeDO> list);
}

@ -0,0 +1,225 @@
package cn.iocoder.yudao.module.ea.dal.dataobject.electronicemployee;
import lombok.*;
import java.time.LocalDate;
import java.util.*;
import java.time.LocalDateTime;
import java.time.LocalDateTime;
import com.baomidou.mybatisplus.annotation.*;
import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;
/**
* DO
*
* @author
*/
@TableName("ea_electronic_employee")
@KeySequence("ea_electronic_employee_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class ElectronicEmployeeDO extends BaseDO {
/**
*
*/
@TableId
private Long id;
/**
*
*/
private String createBy;
/**
* id
*/
private Long companyId;
/**
*
*/
private String company;
/**
* id
*/
private Long deptId;
/**
*
*/
private String deptName;
/**
*
*/
private String name;
/**
*
*
*
*/
private String gender;
/**
*
*/
private LocalDate birthdate;
/**
*
*/
private String nationality;
/**
*
*/
private String address;
/**
*
*/
private String contactNumber;
/**
*
*/
private String idCardNumber;
/**
*
*/
private String passportNumber;
/**
*
*/
private String graduationSchool;
/**
*
*/
private String major;
/**
*
*/
private String education;
/**
*
*/
private String educationExperience;
/**
*
*/
private String workExperience;
/**
*
*/
private String jobTitle;
/**
*
*/
private String jobLevel;
/**
*
*/
private String jobDescription;
/**
*
*/
private Long salary;
/**
*
*/
private String healthCondition;
/**
*
*/
private String medicalRecords;
/**
*
*
*
*/
private String diseaseHistory;
/**
*
*
*
*/
private String socialInsurance;
/**
*
*/
private Long pensionInsurance;
/**
*
*/
private Long medicalInsurance;
/**
*
*/
private Long unemploymentInsurance;
/**
*
*/
private Long workInjuryInsurance;
/**
*
*/
private String leaveRecords;
/**
*
*/
private String overtimeRecords;
/**
*
*/
private String welfareBenefits;
/**
*
*/
private String performanceEvaluation;
/**
*
*/
private String rewardsPunishments;
/**
*
*/
private String trainingRecords;
/**
*
*/
private String personalDescription;
/**
*
*/
private String year;
/**
*
*/
private String period;
/**
*
*
*
*/
private String borrowStatus;
/**
*
*/
private String recordTime;
/**
*
*/
private String position;
/**
*
*/
private Integer cherks;
/**
* id
*/
private Long recordId;
/**
* id
*/
private Long userId;
/**
*
*/
private String fileStatus;
}

@ -0,0 +1,62 @@
package cn.iocoder.yudao.module.ea.dal.mysql.electronicemployee;
import java.util.*;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
import cn.iocoder.yudao.module.ea.dal.dataobject.electronicemployee.ElectronicEmployeeDO;
import org.apache.ibatis.annotations.Mapper;
import cn.iocoder.yudao.module.ea.controller.admin.electronicemployee.vo.*;
/**
* Mapper
*
* @author
*/
@Mapper
public interface ElectronicEmployeeMapper extends BaseMapperX<ElectronicEmployeeDO> {
default PageResult<ElectronicEmployeeDO> selectPage(ElectronicEmployeePageReqVO reqVO) {
return selectPage(reqVO, new LambdaQueryWrapperX<ElectronicEmployeeDO>()
.eqIfPresent(ElectronicEmployeeDO::getCreateBy, reqVO.getCreateBy())
.betweenIfPresent(ElectronicEmployeeDO::getCreateTime, reqVO.getCreateTime())
.eqIfPresent(ElectronicEmployeeDO::getCompany, reqVO.getCompany())
.likeIfPresent(ElectronicEmployeeDO::getDeptName, reqVO.getDeptName())
.likeIfPresent(ElectronicEmployeeDO::getName, reqVO.getName())
.eqIfPresent(ElectronicEmployeeDO::getGender, reqVO.getGender())
.eqIfPresent(ElectronicEmployeeDO::getNationality, reqVO.getNationality())
.eqIfPresent(ElectronicEmployeeDO::getContactNumber, reqVO.getContactNumber())
.eqIfPresent(ElectronicEmployeeDO::getIdCardNumber, reqVO.getIdCardNumber())
.eqIfPresent(ElectronicEmployeeDO::getYear, reqVO.getYear())
.eqIfPresent(ElectronicEmployeeDO::getPeriod, reqVO.getPeriod())
.eqIfPresent(ElectronicEmployeeDO::getBorrowStatus, reqVO.getBorrowStatus())
.betweenIfPresent(ElectronicEmployeeDO::getRecordTime, reqVO.getRecordTime())
.eqIfPresent(ElectronicEmployeeDO::getPosition, reqVO.getPosition())
.eqIfPresent(ElectronicEmployeeDO::getCherks, reqVO.getCherks())
.eqIfPresent(ElectronicEmployeeDO::getFileStatus, reqVO.getFileStatus())
.orderByDesc(ElectronicEmployeeDO::getId));
}
default List<ElectronicEmployeeDO> selectList(ElectronicEmployeeExportReqVO reqVO) {
return selectList(new LambdaQueryWrapperX<ElectronicEmployeeDO>()
.eqIfPresent(ElectronicEmployeeDO::getCreateBy, reqVO.getCreateBy())
.betweenIfPresent(ElectronicEmployeeDO::getCreateTime, reqVO.getCreateTime())
.eqIfPresent(ElectronicEmployeeDO::getCompany, reqVO.getCompany())
.likeIfPresent(ElectronicEmployeeDO::getDeptName, reqVO.getDeptName())
.likeIfPresent(ElectronicEmployeeDO::getName, reqVO.getName())
.eqIfPresent(ElectronicEmployeeDO::getGender, reqVO.getGender())
.eqIfPresent(ElectronicEmployeeDO::getNationality, reqVO.getNationality())
.eqIfPresent(ElectronicEmployeeDO::getContactNumber, reqVO.getContactNumber())
.eqIfPresent(ElectronicEmployeeDO::getIdCardNumber, reqVO.getIdCardNumber())
.eqIfPresent(ElectronicEmployeeDO::getYear, reqVO.getYear())
.eqIfPresent(ElectronicEmployeeDO::getPeriod, reqVO.getPeriod())
.eqIfPresent(ElectronicEmployeeDO::getBorrowStatus, reqVO.getBorrowStatus())
.betweenIfPresent(ElectronicEmployeeDO::getRecordTime, reqVO.getRecordTime())
.eqIfPresent(ElectronicEmployeeDO::getPosition, reqVO.getPosition())
.eqIfPresent(ElectronicEmployeeDO::getCherks, reqVO.getCherks())
.eqIfPresent(ElectronicEmployeeDO::getFileStatus, reqVO.getFileStatus())
.orderByDesc(ElectronicEmployeeDO::getId));
}
}

@ -0,0 +1,70 @@
package cn.iocoder.yudao.module.ea.service.electronicemployee;
import java.util.*;
import javax.validation.*;
import cn.iocoder.yudao.module.ea.controller.admin.electronicemployee.vo.*;
import cn.iocoder.yudao.module.ea.dal.dataobject.electronicemployee.ElectronicEmployeeDO;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
/**
* Service
*
* @author
*/
public interface ElectronicEmployeeService {
/**
*
*
* @param createReqVO
* @return
*/
Long createElectronicEmployee(@Valid ElectronicEmployeeCreateReqVO createReqVO);
/**
*
*
* @param updateReqVO
*/
void updateElectronicEmployee(@Valid ElectronicEmployeeUpdateReqVO updateReqVO);
/**
*
*
* @param id
*/
void deleteElectronicEmployee(Long id);
/**
*
*
* @param id
* @return
*/
ElectronicEmployeeDO getElectronicEmployee(Long id);
/**
*
*
* @param ids
* @return
*/
List<ElectronicEmployeeDO> getElectronicEmployeeList(Collection<Long> ids);
/**
*
*
* @param pageReqVO
* @return
*/
PageResult<ElectronicEmployeeDO> getElectronicEmployeePage(ElectronicEmployeePageReqVO pageReqVO);
/**
* , Excel
*
* @param exportReqVO
* @return
*/
List<ElectronicEmployeeDO> getElectronicEmployeeList(ElectronicEmployeeExportReqVO exportReqVO);
}

@ -0,0 +1,82 @@
package cn.iocoder.yudao.module.ea.service.electronicemployee;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import org.springframework.validation.annotation.Validated;
import java.util.*;
import cn.iocoder.yudao.module.ea.controller.admin.electronicemployee.vo.*;
import cn.iocoder.yudao.module.ea.dal.dataobject.electronicemployee.ElectronicEmployeeDO;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.module.ea.convert.electronicemployee.ElectronicEmployeeConvert;
import cn.iocoder.yudao.module.ea.dal.mysql.electronicemployee.ElectronicEmployeeMapper;
import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
import static cn.iocoder.yudao.module.ea.enums.ErrorCodeConstants.*;
/**
* Service
*
* @author
*/
@Service
@Validated
public class ElectronicEmployeeServiceImpl implements ElectronicEmployeeService {
@Resource
private ElectronicEmployeeMapper electronicEmployeeMapper;
@Override
public Long createElectronicEmployee(ElectronicEmployeeCreateReqVO createReqVO) {
// 插入
ElectronicEmployeeDO electronicEmployee = ElectronicEmployeeConvert.INSTANCE.convert(createReqVO);
electronicEmployeeMapper.insert(electronicEmployee);
// 返回
return electronicEmployee.getId();
}
@Override
public void updateElectronicEmployee(ElectronicEmployeeUpdateReqVO updateReqVO) {
// 校验存在
validateElectronicEmployeeExists(updateReqVO.getId());
// 更新
ElectronicEmployeeDO updateObj = ElectronicEmployeeConvert.INSTANCE.convert(updateReqVO);
electronicEmployeeMapper.updateById(updateObj);
}
@Override
public void deleteElectronicEmployee(Long id) {
// 校验存在
validateElectronicEmployeeExists(id);
// 删除
electronicEmployeeMapper.deleteById(id);
}
private void validateElectronicEmployeeExists(Long id) {
if (electronicEmployeeMapper.selectById(id) == null) {
throw exception(ELECTRONIC_EMPLOYEE_NOT_EXISTS);
}
}
@Override
public ElectronicEmployeeDO getElectronicEmployee(Long id) {
return electronicEmployeeMapper.selectById(id);
}
@Override
public List<ElectronicEmployeeDO> getElectronicEmployeeList(Collection<Long> ids) {
return electronicEmployeeMapper.selectBatchIds(ids);
}
@Override
public PageResult<ElectronicEmployeeDO> getElectronicEmployeePage(ElectronicEmployeePageReqVO pageReqVO) {
return electronicEmployeeMapper.selectPage(pageReqVO);
}
@Override
public List<ElectronicEmployeeDO> getElectronicEmployeeList(ElectronicEmployeeExportReqVO exportReqVO) {
return electronicEmployeeMapper.selectList(exportReqVO);
}
}

@ -0,0 +1,35 @@
package cn.iocoder.yudao.module.ea.utils.enums;
import com.baomidou.mybatisplus.annotation.EnumValue;
import com.fasterxml.jackson.annotation.JsonValue;
import lombok.Getter;
/**
* author: zk
* date: 2023/9/22
* description:
* @author HP
*/
@Getter
public enum BorrowStatusEnum {
/**
*
*/
BORROWSTATUS_TRUE("true", "1"),
BORROWSTATUS_FALSE("false", "0")
;
@JsonValue
private final String status;
/**
*
*/
@EnumValue
private final String isStatus;
BorrowStatusEnum(String status, String isStatus) {
this.status = status;
this.isStatus = isStatus;
}
}

@ -0,0 +1,12 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.iocoder.yudao.module.ea.dal.mysql.electronicemployee.ElectronicEmployeeMapper">
<!--
一般情况下,尽可能使用 Mapper 进行 CRUD 增删改查即可。
无法满足的场景,例如说多表关联查询,才使用 XML 编写 SQL。
代码生成器暂时只生成 Mapper XML 文件本身,更多推荐 MybatisX 快速开发插件来生成查询。
文档可见https://www.iocoder.cn/MyBatis/x-plugins/
-->
</mapper>
Loading…
Cancel
Save