From 0146a1483a3368f75daa6eb03aa42c714943e6b2 Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期三, 17 九月 2025 14:11:28 +0800
Subject: [PATCH] Merge branch 'feature_asset'

---
 ruoyi-system/src/main/java/com/ruoyi/system/emums/ApprovalTypeEnum.java                                |   37 +
 ruoyi-system/src/main/java/com/ruoyi/system/service/AssetTypeService.java                              |    7 
 ruoyi-system/src/main/java/com/ruoyi/system/emums/AssetTypeEnum.java                                   |   23 +
 ruoyi-system/src/main/java/com/ruoyi/system/model/OaApprovalApplications.java                          |    2 
 ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationPurchaseDTO.java            |    2 
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationStorageServiceImpl.java  |  619 ++++++++++++++++++++++++++++
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/OaApprovalApplicationPurchaseController.java    |    2 
 ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationStoragePropertyDTO.java     |  155 +++++++
 ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationStorageDTO.java             |   67 +++
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/AssetTypeServiceImpl.java                     |   30 +
 ruoyi-system/src/main/java/com/ruoyi/system/service/OaApprovalApplicationStorageService.java           |   23 +
 ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationStorageVehicleDTO.java      |  129 +++++
 ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationStorageGeneralDTO.java      |  138 ++++++
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationPurchaseServiceImpl.java |   20 
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/OaApprovalApplicationStorageController.java     |   51 ++
 ruoyi-system/src/main/java/com/ruoyi/system/model/AssetMain.java                                       |    2 
 ruoyi-system/src/main/java/com/ruoyi/system/model/OaApprovalTodo.java                                  |    4 
 ruoyi-system/src/main/java/com/ruoyi/system/service/OaApprovalApplicationPurchaseService.java          |    2 
 18 files changed, 1,288 insertions(+), 25 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/OaApprovalApplicationPurchaseController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/OaApprovalApplicationPurchaseController.java
index 0c575d8..0bdf9c3 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/OaApprovalApplicationPurchaseController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/OaApprovalApplicationPurchaseController.java
@@ -3,7 +3,7 @@
 import com.ruoyi.common.annotation.Log;
 import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.enums.BusinessType;
-import com.ruoyi.system.dto.OaApprovalApplicationPurchaseDTO;
+import com.ruoyi.system.dto.asset.OaApprovalApplicationPurchaseDTO;
 import com.ruoyi.system.service.OaApprovalApplicationPurchaseService;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/OaApprovalApplicationStorageController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/OaApprovalApplicationStorageController.java
index 449a6ac..483dcdb 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/OaApprovalApplicationStorageController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/OaApprovalApplicationStorageController.java
@@ -1,20 +1,61 @@
 package com.ruoyi.web.controller.api;
 
-
+import com.ruoyi.common.annotation.Log;
+import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.enums.BusinessType;
+import com.ruoyi.system.dto.asset.OaApprovalApplicationStorageGeneralDTO;
+import com.ruoyi.system.dto.asset.OaApprovalApplicationStoragePropertyDTO;
+import com.ruoyi.system.dto.asset.OaApprovalApplicationStorageVehicleDTO;
+import com.ruoyi.system.service.OaApprovalApplicationStorageService;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import lombok.RequiredArgsConstructor;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.RequestBody;
 import org.springframework.web.bind.annotation.RequestMapping;
 import org.springframework.web.bind.annotation.RestController;
 
+import javax.validation.Valid;
+
 /**
  * <p>
- * 资产入库申请明细表 前端控制器
+ * 资产入库申请 前端控制器
  * </p>
  *
- * @author WuGuanFengYue
- * @since 2025-09-15
+ * @author CodeBuddy
+ * @since 2025-09-17
  */
+@Api(tags = {"OA审批-资产入库申请相关接口"})
+@Validated
 @RestController
 @RequestMapping("/oa-approval-application-storage")
+@RequiredArgsConstructor
 public class OaApprovalApplicationStorageController {
 
-}
+    private final OaApprovalApplicationStorageService oaApprovalApplicationStorageService;
 
+    @ApiOperation("提交通用资产入库申请")
+    @PostMapping("/submit-general")
+    @Log(title = "通用资产入库申请-提交", businessType = BusinessType.INSERT)
+    public R<Void> submitGeneralAssetStorage(@Valid @RequestBody OaApprovalApplicationStorageGeneralDTO dto) {
+        oaApprovalApplicationStorageService.submitGeneralAssetStorage(dto);
+        return R.ok();
+    }
+
+    @ApiOperation("提交房产资产入库申请")
+    @PostMapping("/submit-property")
+    @Log(title = "房产资产入库申请-提交", businessType = BusinessType.INSERT)
+    public R<Void> submitPropertyAssetStorage(@Valid @RequestBody OaApprovalApplicationStoragePropertyDTO dto) {
+        oaApprovalApplicationStorageService.submitPropertyAssetStorage(dto);
+        return R.ok();
+    }
+
+    @ApiOperation("提交车辆资产入库申请")
+    @PostMapping("/submit-vehicle")
+    @Log(title = "车辆资产入库申请-提交", businessType = BusinessType.INSERT)
+    public R<Void> submitVehicleAssetStorage(@Valid @RequestBody OaApprovalApplicationStorageVehicleDTO dto) {
+        oaApprovalApplicationStorageService.submitVehicleAssetStorage(dto);
+        return R.ok();
+    }
+}
\ No newline at end of file
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/dto/OaApprovalApplicationPurchaseDTO.java b/ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationPurchaseDTO.java
similarity index 98%
rename from ruoyi-system/src/main/java/com/ruoyi/system/dto/OaApprovalApplicationPurchaseDTO.java
rename to ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationPurchaseDTO.java
index aa5086b..5a5c334 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/dto/OaApprovalApplicationPurchaseDTO.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationPurchaseDTO.java
@@ -1,4 +1,4 @@
-package com.ruoyi.system.dto;
+package com.ruoyi.system.dto.asset;
 
 import io.swagger.annotations.ApiModel;
 import io.swagger.annotations.ApiModelProperty;
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationStorageDTO.java b/ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationStorageDTO.java
new file mode 100644
index 0000000..8aef70f
--- /dev/null
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationStorageDTO.java
@@ -0,0 +1,67 @@
+package com.ruoyi.system.dto.asset;
+
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import org.springframework.format.annotation.DateTimeFormat;
+
+import javax.validation.constraints.NotBlank;
+import javax.validation.constraints.NotNull;
+import javax.validation.constraints.Size;
+import java.time.LocalDate;
+
+/**
+ * 资产入库申请基础DTO
+ *
+ * @author CodeBuddy
+ * @since 2025-09-17
+ */
+@Data
+@ApiModel(value = "OaApprovalApplicationStorageDTO", description = "资产入库申请基础DTO")
+public class OaApprovalApplicationStorageDTO {
+
+    @ApiModelProperty(value = "申请部门ID")
+    @NotNull(message = "申请部门不能为空")
+    private Integer deptId;
+
+    @ApiModelProperty(value = "申请部门名称")
+    @NotBlank(message = "申请部门名称不能为空")
+    private String deptName;
+
+    @ApiModelProperty(value = "申请人ID")
+    @NotNull(message = "申请人不能为空")
+    private Integer applicantUserId;
+
+    @ApiModelProperty(value = "申请人姓名")
+    @NotBlank(message = "申请人姓名不能为空")
+    private String applicantName;
+
+    @ApiModelProperty(value = "申请日期")
+    @NotNull(message = "申请日期不能为空")
+    @DateTimeFormat(pattern = "yyyy-MM-dd")
+    private LocalDate applicationDate;
+
+    @ApiModelProperty(value = "入库备注")
+    @Size(max = 500, message = "入库备注不能超过500字符")
+    private String applicationReason;
+
+    @ApiModelProperty(value = "附件地址,多个使用英文逗号拼接")
+    private String attachmentUrl;
+
+    @ApiModelProperty(value = "事项标题")
+    @NotBlank(message = "事项标题不能为空")
+    private String title;
+
+    @ApiModelProperty(value = "资产类型ID")
+    @NotNull(message = "资产类型不能为空")
+    private Integer assetTypeId;
+
+    @ApiModelProperty(value = "入库类型 0-正常入库")
+    @NotNull(message = "入库类型不能为空")
+    private Boolean storageType;
+
+    @ApiModelProperty(value = "入库日期")
+    @NotNull(message = "入库日期不能为空")
+    @DateTimeFormat(pattern = "yyyy-MM-dd")
+    private LocalDate storageTime;
+}
\ No newline at end of file
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationStorageGeneralDTO.java b/ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationStorageGeneralDTO.java
new file mode 100644
index 0000000..3848cb6
--- /dev/null
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationStorageGeneralDTO.java
@@ -0,0 +1,138 @@
+package com.ruoyi.system.dto.asset;
+
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import org.springframework.format.annotation.DateTimeFormat;
+
+import javax.validation.Valid;
+import javax.validation.constraints.NotBlank;
+import javax.validation.constraints.NotNull;
+import javax.validation.constraints.Size;
+import java.math.BigDecimal;
+import java.time.LocalDate;
+import java.util.List;
+
+/**
+ * 通用资产入库申请DTO
+ *
+ * @author CodeBuddy
+ * @since 2025-09-17
+ */
+@Data
+@EqualsAndHashCode(callSuper = true)
+@ApiModel(value = "OaApprovalApplicationStorageGeneralDTO", description = "通用资产入库申请DTO")
+public class OaApprovalApplicationStorageGeneralDTO extends OaApprovalApplicationStorageDTO {
+
+    @ApiModelProperty(value = "通用资产明细列表")
+    @Valid
+    @Size(min = 1, message = "资产明细不能为空")
+    private List<GeneralAssetItemDTO> assetItems;
+
+    @Data
+    @ApiModel(value = "GeneralAssetItemDTO", description = "通用资产明细DTO")
+    public static class GeneralAssetItemDTO {
+
+        // 资产主表字段
+        @ApiModelProperty(value = "资产原编码")
+        private String assetOriginalCode;
+
+        @ApiModelProperty(value = "资产名称")
+        @NotBlank(message = "资产名称不能为空")
+        private String assetName;
+
+        @ApiModelProperty(value = "规格型号")
+        private String specificationModel;
+
+        @ApiModelProperty(value = "计量单位")
+        @NotBlank(message = "计量单位不能为空")
+        private String measurementUnit;
+
+        @ApiModelProperty(value = "数量")
+        @NotNull(message = "数量不能为空")
+        private BigDecimal quantity;
+
+        @ApiModelProperty(value = "单价")
+        @NotNull(message = "单价不能为空")
+        private BigDecimal unitPrice;
+
+        @ApiModelProperty(value = "使用年限(年)")
+        private Integer usefulLife;
+
+        @ApiModelProperty(value = "权属单位/部门ID")
+        private Integer ownershipDeptId;
+
+        @ApiModelProperty(value = "使用人")
+        private String userName;
+
+        @ApiModelProperty(value = "使用部门/位置ID")
+        private Integer useDeptId;
+
+        @ApiModelProperty(value = "仓库ID")
+        private Integer warehouseId;
+
+        @ApiModelProperty(value = "仓库名称")
+        private String warehouseName;
+
+        @ApiModelProperty(value = "所在位置")
+        private String address;
+
+        @ApiModelProperty(value = "资产状态")
+        private String assetStatus;
+
+        @ApiModelProperty(value = "备注")
+        private String remarks;
+
+        @ApiModelProperty(value = "入账状态")
+        private String accountingStatus;
+
+        @ApiModelProperty(value = "入账时间")
+        @DateTimeFormat(pattern = "yyyy-MM-dd")
+        private LocalDate accountingDate;
+
+        @ApiModelProperty(value = "会计凭证号")
+        private String accountingVoucherNo;
+
+        @ApiModelProperty(value = "会计科目")
+        private String accountingSubject;
+
+        @ApiModelProperty(value = "入账金额")
+        private BigDecimal accountingAmount;
+
+        // 通用资产扩展表字段
+        @ApiModelProperty(value = "供应商名称")
+        private String supplierName;
+
+        @ApiModelProperty(value = "采购日期")
+        @DateTimeFormat(pattern = "yyyy-MM-dd")
+        private LocalDate purchaseDate;
+
+        @ApiModelProperty(value = "保修期(月)")
+        private Integer warrantyPeriod;
+
+        @ApiModelProperty(value = "保修到期日期")
+        @DateTimeFormat(pattern = "yyyy-MM-dd")
+        private LocalDate warrantyExpireDate;
+
+        @ApiModelProperty(value = "折旧方法")
+        private String depreciationMethod;
+
+        @ApiModelProperty(value = "折旧率")
+        private BigDecimal depreciationRate;
+
+        @ApiModelProperty(value = "净值")
+        private BigDecimal netValue;
+
+        @ApiModelProperty(value = "维护周期(月)")
+        private Integer maintenanceCycle;
+
+        @ApiModelProperty(value = "上次维护日期")
+        @DateTimeFormat(pattern = "yyyy-MM-dd")
+        private LocalDate lastMaintenanceDate;
+
+        @ApiModelProperty(value = "下次维护日期")
+        @DateTimeFormat(pattern = "yyyy-MM-dd")
+        private LocalDate nextMaintenanceDate;
+    }
+}
\ No newline at end of file
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationStoragePropertyDTO.java b/ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationStoragePropertyDTO.java
new file mode 100644
index 0000000..06ec290
--- /dev/null
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationStoragePropertyDTO.java
@@ -0,0 +1,155 @@
+package com.ruoyi.system.dto.asset;
+
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import org.springframework.format.annotation.DateTimeFormat;
+
+import javax.validation.Valid;
+import javax.validation.constraints.NotBlank;
+import javax.validation.constraints.NotNull;
+import javax.validation.constraints.Size;
+import java.math.BigDecimal;
+import java.time.LocalDate;
+import java.util.List;
+
+/**
+ * 房产资产入库申请DTO
+ *
+ * @author CodeBuddy
+ * @since 2025-09-17
+ */
+@Data
+@EqualsAndHashCode(callSuper = true)
+@ApiModel(value = "OaApprovalApplicationStoragePropertyDTO", description = "房产资产入库申请DTO")
+public class OaApprovalApplicationStoragePropertyDTO extends OaApprovalApplicationStorageDTO {
+
+    @ApiModelProperty(value = "房产资产明细列表")
+    @Valid
+    @Size(min = 1, message = "资产明细不能为空")
+    private List<PropertyAssetItemDTO> assetItems;
+
+    @Data
+    @ApiModel(value = "PropertyAssetItemDTO", description = "房产资产明细DTO")
+    public static class PropertyAssetItemDTO {
+
+        // 资产主表字段
+        @ApiModelProperty(value = "资产原编码")
+        private String assetOriginalCode;
+
+        @ApiModelProperty(value = "资产名称")
+        @NotBlank(message = "资产名称不能为空")
+        private String assetName;
+
+        @ApiModelProperty(value = "规格型号")
+        private String specificationModel;
+
+        @ApiModelProperty(value = "计量单位")
+        @NotBlank(message = "计量单位不能为空")
+        private String measurementUnit;
+
+        @ApiModelProperty(value = "数量")
+        @NotNull(message = "数量不能为空")
+        private BigDecimal quantity;
+
+        @ApiModelProperty(value = "单价")
+        @NotNull(message = "单价不能为空")
+        private BigDecimal unitPrice;
+
+        @ApiModelProperty(value = "使用年限(年)")
+        private Integer usefulLife;
+
+        @ApiModelProperty(value = "权属单位/部门ID")
+        private Integer ownershipDeptId;
+
+        @ApiModelProperty(value = "使用人")
+        private String userName;
+
+        @ApiModelProperty(value = "使用部门/位置ID")
+        private Integer useDeptId;
+
+        @ApiModelProperty(value = "仓库ID")
+        private Integer warehouseId;
+
+        @ApiModelProperty(value = "仓库名称")
+        private String warehouseName;
+
+        @ApiModelProperty(value = "所在位置")
+        private String address;
+
+        @ApiModelProperty(value = "资产状态")
+        private String assetStatus;
+
+        @ApiModelProperty(value = "备注")
+        private String remarks;
+
+        @ApiModelProperty(value = "入账状态")
+        private String accountingStatus;
+
+        @ApiModelProperty(value = "入账时间")
+        @DateTimeFormat(pattern = "yyyy-MM-dd")
+        private LocalDate accountingDate;
+
+        @ApiModelProperty(value = "会计凭证号")
+        private String accountingVoucherNo;
+
+        @ApiModelProperty(value = "会计科目")
+        private String accountingSubject;
+
+        @ApiModelProperty(value = "入账金额")
+        private BigDecimal accountingAmount;
+
+        // 房产资产扩展表字段
+        @ApiModelProperty(value = "所在区域")
+        private String region;
+
+        @ApiModelProperty(value = "设计用途")
+        private String designPurpose;
+
+        @ApiModelProperty(value = "楼栋")
+        private String building;
+
+        @ApiModelProperty(value = "房间号")
+        private String roomNumber;
+
+        @ApiModelProperty(value = "建筑面积(平方米)")
+        private BigDecimal constructionArea;
+
+        @ApiModelProperty(value = "结构")
+        private String structureType;
+
+        @ApiModelProperty(value = "权证编号")
+        private String certificateNumber;
+
+        @ApiModelProperty(value = "建成年月")
+        @DateTimeFormat(pattern = "yyyy-MM-dd")
+        private LocalDate completionDate;
+
+        @ApiModelProperty(value = "详细位置")
+        private String detailedLocation;
+
+        @ApiModelProperty(value = "省资产平台填报价值")
+        private BigDecimal provincialPlatformValue;
+
+        @ApiModelProperty(value = "安置情况")
+        private String resettlementSituation;
+
+        @ApiModelProperty(value = "是否抵押:0-否,1-是")
+        private Boolean isMortgaged;
+
+        @ApiModelProperty(value = "承租方")
+        private String tenantName;
+
+        @ApiModelProperty(value = "租金")
+        private BigDecimal rentalAmount;
+
+        @ApiModelProperty(value = "租赁期限起")
+        @DateTimeFormat(pattern = "yyyy-MM-dd")
+        private LocalDate leaseStartDate;
+
+        @ApiModelProperty(value = "租赁期限止")
+        @DateTimeFormat(pattern = "yyyy-MM-dd")
+        private LocalDate leaseEndDate;
+    }
+}
\ No newline at end of file
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationStorageVehicleDTO.java b/ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationStorageVehicleDTO.java
new file mode 100644
index 0000000..e0d5a2a
--- /dev/null
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/dto/asset/OaApprovalApplicationStorageVehicleDTO.java
@@ -0,0 +1,129 @@
+package com.ruoyi.system.dto.asset;
+
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import org.springframework.format.annotation.DateTimeFormat;
+
+import javax.validation.Valid;
+import javax.validation.constraints.NotBlank;
+import javax.validation.constraints.NotNull;
+import javax.validation.constraints.Size;
+import java.math.BigDecimal;
+import java.time.LocalDate;
+import java.util.List;
+
+/**
+ * 车辆资产入库申请DTO
+ *
+ * @author CodeBuddy
+ * @since 2025-09-17
+ */
+@Data
+@EqualsAndHashCode(callSuper = true)
+@ApiModel(value = "OaApprovalApplicationStorageVehicleDTO", description = "车辆资产入库申请DTO")
+public class OaApprovalApplicationStorageVehicleDTO extends OaApprovalApplicationStorageDTO {
+
+    @ApiModelProperty(value = "车辆资产明细列表")
+    @Valid
+    @Size(min = 1, message = "资产明细不能为空")
+    private List<VehicleAssetItemDTO> assetItems;
+
+    @Data
+    @ApiModel(value = "VehicleAssetItemDTO", description = "车辆资产明细DTO")
+    public static class VehicleAssetItemDTO {
+
+        // 资产主表字段
+        @ApiModelProperty(value = "资产原编码")
+        private String assetOriginalCode;
+
+        @ApiModelProperty(value = "资产名称")
+        @NotBlank(message = "资产名称不能为空")
+        private String assetName;
+
+        @ApiModelProperty(value = "规格型号")
+        private String specificationModel;
+
+        @ApiModelProperty(value = "计量单位")
+        @NotBlank(message = "计量单位不能为空")
+        private String measurementUnit;
+
+        @ApiModelProperty(value = "数量")
+        @NotNull(message = "数量不能为空")
+        private BigDecimal quantity;
+
+        @ApiModelProperty(value = "单价")
+        @NotNull(message = "单价不能为空")
+        private BigDecimal unitPrice;
+
+        @ApiModelProperty(value = "使用年限(年)")
+        private Integer usefulLife;
+
+        @ApiModelProperty(value = "权属单位/部门ID")
+        private Integer ownershipDeptId;
+
+        @ApiModelProperty(value = "使用人")
+        private String userName;
+
+        @ApiModelProperty(value = "使用部门/位置ID")
+        private Integer useDeptId;
+
+        @ApiModelProperty(value = "仓库ID")
+        private Integer warehouseId;
+
+        @ApiModelProperty(value = "仓库名称")
+        private String warehouseName;
+
+        @ApiModelProperty(value = "所在位置")
+        private String address;
+
+        @ApiModelProperty(value = "资产状态")
+        private String assetStatus;
+
+        @ApiModelProperty(value = "备注")
+        private String remarks;
+
+        @ApiModelProperty(value = "入账状态")
+        private String accountingStatus;
+
+        @ApiModelProperty(value = "入账时间")
+        @DateTimeFormat(pattern = "yyyy-MM-dd")
+        private LocalDate accountingDate;
+
+        @ApiModelProperty(value = "会计凭证号")
+        private String accountingVoucherNo;
+
+        @ApiModelProperty(value = "会计科目")
+        private String accountingSubject;
+
+        @ApiModelProperty(value = "入账金额")
+        private BigDecimal accountingAmount;
+
+        // 车辆资产扩展表字段
+        @ApiModelProperty(value = "车牌号")
+        private String licensePlate;
+
+        @ApiModelProperty(value = "车辆识别代码")
+        private String vinCode;
+
+        @ApiModelProperty(value = "发动机号")
+        private String engineNumber;
+
+        @ApiModelProperty(value = "排量")
+        private String displacement;
+
+        @ApiModelProperty(value = "编制情况")
+        private String staffingSituation;
+
+        @ApiModelProperty(value = "产地")
+        private String origin;
+
+        @ApiModelProperty(value = "取得日期")
+        @DateTimeFormat(pattern = "yyyy-MM-dd")
+        private LocalDate acquisitionDate;
+
+        @ApiModelProperty(value = "产权形式")
+        private String propertyRightForm;
+    }
+}
\ No newline at end of file
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/emums/ApprovalTypeEnum.java b/ruoyi-system/src/main/java/com/ruoyi/system/emums/ApprovalTypeEnum.java
new file mode 100644
index 0000000..9adf171
--- /dev/null
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/emums/ApprovalTypeEnum.java
@@ -0,0 +1,37 @@
+package com.ruoyi.system.emums;
+
+import lombok.Getter;
+import lombok.AllArgsConstructor;
+@Getter
+@AllArgsConstructor
+public enum ApprovalTypeEnum {
+	LEAVE(1, "请假申请"),
+	OUT(2, "外出申请"),
+	BUSINESS_TRIP(3, "出差申请"),
+	LEAVE_DESTROY(4, "销假申请"),
+	PURCHASE(5, "采购申请"),
+	IN_STOCK(6, "资产入库"),
+	GRAB(7, "物品领用"),
+	BURROW(8, "物品借用"),
+	RETURN(9, "借用归还"),
+	ASSET_DISPOSE(10, "资产处置"),
+	ASSET_CHANGE(11, "资产表更"),
+	REIMBURSEMENT(12, "报销申请"),
+	MONEY(13, "款项申请"),
+	CONTRACT(14, "合同文件"),
+	PAYMENT(15, "进度款支付"),
+	CONTACT(16, "内部联系单"),
+	ADVERTISEMENT(17, "广告制作申请");
+
+	private final Integer code;
+	private final String desc;
+
+	public static ApprovalTypeEnum getEnumByCode(Integer code) {
+		for (ApprovalTypeEnum e : ApprovalTypeEnum.values()) {
+			if (e.code.equals(code)) {
+				return e;
+			}
+		}
+		return null;
+	}
+} 
\ No newline at end of file
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/emums/AssetTypeEnum.java b/ruoyi-system/src/main/java/com/ruoyi/system/emums/AssetTypeEnum.java
new file mode 100644
index 0000000..0fa8a1c
--- /dev/null
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/emums/AssetTypeEnum.java
@@ -0,0 +1,23 @@
+package com.ruoyi.system.emums;
+
+import lombok.Getter;
+import lombok.AllArgsConstructor;
+@Getter
+@AllArgsConstructor
+public enum AssetTypeEnum {
+	GENERAL(0, "通用资产"),
+	HOUSE(1, "房产资产"),
+	VEHICLE(2, "车辆资产");
+
+	private final Integer code;
+	private final String desc;
+
+	public static AssetTypeEnum getEnumByCode(Integer code) {
+		for (AssetTypeEnum e : AssetTypeEnum.values()) {
+			if (e.code.equals(code)) {
+				return e;
+			}
+		}
+		return null;
+	}
+} 
\ No newline at end of file
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/model/AssetMain.java b/ruoyi-system/src/main/java/com/ruoyi/system/model/AssetMain.java
index 325f511..8be23d1 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/model/AssetMain.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/model/AssetMain.java
@@ -64,7 +64,7 @@
 
     @ApiModelProperty(value = "资产主类型:0-通用资产,1-房产资产,2-车辆资产")
     @TableField("asset_main_type")
-    private Boolean assetMainType;
+    private Integer assetMainType;
 
     @ApiModelProperty(value = "计量单位")
     @TableField("measurement_unit")
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/model/OaApprovalApplications.java b/ruoyi-system/src/main/java/com/ruoyi/system/model/OaApprovalApplications.java
index 9b46af2..4e3b3a3 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/model/OaApprovalApplications.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/model/OaApprovalApplications.java
@@ -31,7 +31,7 @@
 
     @ApiModelProperty(value = "主键")
     @TableId(value = "id", type = IdType.AUTO)
-    private Long id;
+    private Integer id;
 
     @ApiModelProperty(value = "申请单号")
     @TableField("application_code")
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/model/OaApprovalTodo.java b/ruoyi-system/src/main/java/com/ruoyi/system/model/OaApprovalTodo.java
index 4cf52c2..05f04aa 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/model/OaApprovalTodo.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/model/OaApprovalTodo.java
@@ -30,11 +30,11 @@
 
     @ApiModelProperty(value = "主键")
     @TableId(value = "id", type = IdType.AUTO)
-    private Long id;
+    private Integer id;
 
     @ApiModelProperty(value = "申请ID")
     @TableField("application_id")
-    private Long applicationId;
+    private Integer applicationId;
 
     @ApiModelProperty(value = "申请单号")
     @TableField("application_code")
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/AssetTypeService.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/AssetTypeService.java
index a37323f..a015c00 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/AssetTypeService.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/AssetTypeService.java
@@ -47,4 +47,11 @@
      */
     void batchDeleteAssetType(List<Integer> ids);
 
+    /**
+     * 根据资产类型ID获取资产编码前缀
+     * @param assetTypeId 资产类型ID
+     * @return 资产编码前缀(一级分类简写+二级分类简写)
+     */
+    String getAssetCodePrefix(Integer assetTypeId);
+
 }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/OaApprovalApplicationPurchaseService.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/OaApprovalApplicationPurchaseService.java
index 4535d08..13f37ef 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/OaApprovalApplicationPurchaseService.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/OaApprovalApplicationPurchaseService.java
@@ -1,7 +1,7 @@
 package com.ruoyi.system.service;
 
 import com.baomidou.mybatisplus.extension.service.IService;
-import com.ruoyi.system.dto.OaApprovalApplicationPurchaseDTO;
+import com.ruoyi.system.dto.asset.OaApprovalApplicationPurchaseDTO;
 import com.ruoyi.system.model.OaApprovalApplicationPurchase;
 
 /**
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/OaApprovalApplicationStorageService.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/OaApprovalApplicationStorageService.java
index d976490..3c8ead4 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/OaApprovalApplicationStorageService.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/OaApprovalApplicationStorageService.java
@@ -1,6 +1,9 @@
 package com.ruoyi.system.service;
 
 import com.baomidou.mybatisplus.extension.service.IService;
+import com.ruoyi.system.dto.asset.OaApprovalApplicationStorageGeneralDTO;
+import com.ruoyi.system.dto.asset.OaApprovalApplicationStoragePropertyDTO;
+import com.ruoyi.system.dto.asset.OaApprovalApplicationStorageVehicleDTO;
 import com.ruoyi.system.model.OaApprovalApplicationStorage;
 
 /**
@@ -13,4 +16,24 @@
  */
 public interface OaApprovalApplicationStorageService extends IService<OaApprovalApplicationStorage> {
 
+    /**
+     * 提交通用资产入库申请
+     *
+     * @param dto 通用资产入库申请DTO
+     */
+    void submitGeneralAssetStorage(OaApprovalApplicationStorageGeneralDTO dto);
+
+    /**
+     * 提交房产资产入库申请
+     *
+     * @param dto 房产资产入库申请DTO
+     */
+    void submitPropertyAssetStorage(OaApprovalApplicationStoragePropertyDTO dto);
+
+    /**
+     * 提交车辆资产入库申请
+     *
+     * @param dto 车辆资产入库申请DTO
+     */
+    void submitVehicleAssetStorage(OaApprovalApplicationStorageVehicleDTO dto);
 }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/AssetTypeServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/AssetTypeServiceImpl.java
index e7e0f4d..583b616 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/AssetTypeServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/AssetTypeServiceImpl.java
@@ -233,4 +233,34 @@
         }
     }
 
+    @Override
+    public String getAssetCodePrefix(Integer assetTypeId) {
+        if (assetTypeId == null) {
+            throw new ServiceException("资产类型ID不能为空");
+        }
+
+        // 查询当前资产类型
+        AssetType currentAssetType = this.getById(assetTypeId);
+        if (currentAssetType == null) {
+            throw new ServiceException("资产类型不存在");
+        }
+
+        String parentTypeCode = "";
+        String subTypeCode = currentAssetType.getTypeCode();
+
+        // 如果是二级分类,需要获取父级分类的简写
+        if (currentAssetType.getLevel() == 2 && currentAssetType.getParentId() != null && currentAssetType.getParentId() != 0) {
+            AssetType parentAssetType = this.getById(currentAssetType.getParentId());
+            if (parentAssetType != null) {
+                parentTypeCode = parentAssetType.getTypeCode();
+            }
+        } else if (currentAssetType.getLevel() == 1) {
+            // 如果是一级分类,父级简写为空,子类简写就是当前类型简写
+            parentTypeCode = currentAssetType.getTypeCode();
+            subTypeCode = "";
+        }
+
+        return parentTypeCode + subTypeCode;
+    }
+
 }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationPurchaseServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationPurchaseServiceImpl.java
index f00eb9b..7d16f94 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationPurchaseServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationPurchaseServiceImpl.java
@@ -5,7 +5,7 @@
 import com.ruoyi.common.core.domain.entity.SysDept;
 import com.ruoyi.common.core.domain.entity.SysUser;
 import com.ruoyi.common.exception.ServiceException;
-import com.ruoyi.system.dto.OaApprovalApplicationPurchaseDTO;
+import com.ruoyi.system.dto.asset.OaApprovalApplicationPurchaseDTO;
 import com.ruoyi.system.emums.ApprovalStatusEnum;
 import com.ruoyi.system.mapper.OaApprovalApplicationPurchaseMapper;
 import com.ruoyi.system.model.OaApprovalApplicationPurchase;
@@ -96,7 +96,7 @@
     /**
      * 创建待办数据
      */
-    private void createApprovalTodo(Long applicationId, String applicationCode, OaApprovalFlowNode flowNode, Integer deptId) {
+    private void createApprovalTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode, Integer deptId) {
         // 根据审批类型创建待办数据
         Integer approvalType = flowNode.getApprovalType();
         if (approvalType == null) {
@@ -120,7 +120,7 @@
     /**
      * 创建上级部门审批待办
      */
-    private void createUpperDeptTodo(Long applicationId, String applicationCode, OaApprovalFlowNode flowNode, Integer deptId) {
+    private void createUpperDeptTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode, Integer deptId) {
         // 1. 获取申请部门信息
         if (deptId == null) {
             throw new ServiceException("未填写申请部门信息");
@@ -154,7 +154,7 @@
     /**
      * 创建指定部门审批待办
      */
-    private void createSpecifiedDeptTodo(Long applicationId, String applicationCode, OaApprovalFlowNode flowNode) {
+    private void createSpecifiedDeptTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode) {
         if (StringUtils.isBlank(flowNode.getApprovalIds())) {
             throw new ServiceException("操作失败,审批流程配置异常");
         }
@@ -174,7 +174,7 @@
     /**
      * 创建指定人员审批待办
      */
-    private void createSpecifiedUserTodo(Long applicationId, String applicationCode, OaApprovalFlowNode flowNode) {
+    private void createSpecifiedUserTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode) {
         if (StringUtils.isBlank(flowNode.getApprovalIds())) {
             throw new ServiceException("操作失败,审批流程配置异常");
         }
@@ -192,7 +192,7 @@
     /**
      * 创建待办数据项
      */
-    private void createTodoItem(Long applicationId, String applicationCode, OaApprovalFlowNode flowNode, List<SysUser> userList) {
+    private void createTodoItem(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode, List<SysUser> userList) {
         List<OaApprovalTodo> approvalTodoList = userList.stream().map(item -> {
             OaApprovalTodo todo = new OaApprovalTodo();
             todo.setApplicationId(applicationId);
@@ -236,9 +236,9 @@
     /**
      * 构建采购申请详情数据
      */
-    private OaApprovalApplicationPurchase buildOaApprovalApplicationPurchase(OaApprovalApplicationPurchaseDTO dto, Long applicationId) {
+    private OaApprovalApplicationPurchase buildOaApprovalApplicationPurchase(OaApprovalApplicationPurchaseDTO dto, Integer applicationId) {
         OaApprovalApplicationPurchase purchase = new OaApprovalApplicationPurchase();
-        purchase.setApprovalApplicationId(applicationId.intValue());
+        purchase.setApprovalApplicationId(applicationId);
         // 使用事项标题,而非采购说明
         purchase.setTitle(dto.getTitle());
         // 表结构中无 application_date 字段,此处不再设置
@@ -251,11 +251,11 @@
     /**
      * 构建采购资产明细数据
      */
-    private List<OaApprovalApplicationPurchaseItem> buildOaApprovalApplicationPurchaseItems(OaApprovalApplicationPurchaseDTO dto, Long applicationId) {
+    private List<OaApprovalApplicationPurchaseItem> buildOaApprovalApplicationPurchaseItems(OaApprovalApplicationPurchaseDTO dto, Integer applicationId) {
         return dto.getPurchaseItems().stream()
                 .map(item -> {
                     OaApprovalApplicationPurchaseItem purchaseItem = new OaApprovalApplicationPurchaseItem();
-                    purchaseItem.setApprovalApplicationId(applicationId.intValue());
+                    purchaseItem.setApprovalApplicationId(applicationId);
                     purchaseItem.setAssetName(item.getAssetName());
                     purchaseItem.setAssetTypeId(item.getAssetTypeId());
                     purchaseItem.setSpec(item.getSpec());
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationStorageServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationStorageServiceImpl.java
index 8526ff6..1e91e6b 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationStorageServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationStorageServiceImpl.java
@@ -1,10 +1,33 @@
 package com.ruoyi.system.service.impl;
 
+import cn.hutool.core.collection.CollUtil;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.common.core.domain.entity.SysDept;
+import com.ruoyi.common.core.domain.entity.SysUser;
+import com.ruoyi.common.exception.ServiceException;
+import com.ruoyi.system.dto.asset.OaApprovalApplicationStorageGeneralDTO;
+import com.ruoyi.system.dto.asset.OaApprovalApplicationStoragePropertyDTO;
+import com.ruoyi.system.dto.asset.OaApprovalApplicationStorageVehicleDTO;
+import com.ruoyi.system.emums.ApprovalStatusEnum;
+import com.ruoyi.system.emums.ApprovalTypeEnum;
+import com.ruoyi.system.emums.AssetTypeEnum;
 import com.ruoyi.system.mapper.OaApprovalApplicationStorageMapper;
-import com.ruoyi.system.model.OaApprovalApplicationStorage;
-import com.ruoyi.system.service.OaApprovalApplicationStorageService;
+import com.ruoyi.system.model.*;
+import com.ruoyi.system.service.*;
+import lombok.RequiredArgsConstructor;
+import org.apache.commons.lang3.StringUtils;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+import org.springframework.util.CollectionUtils;
+
+import java.math.BigDecimal;
+import java.time.LocalDate;
+import java.time.LocalDateTime;
+import java.time.format.DateTimeFormatter;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.List;
+import java.util.stream.Collectors;
 
 /**
  * <p>
@@ -15,6 +38,596 @@
  * @since 2025-09-15
  */
 @Service
+@RequiredArgsConstructor
 public class OaApprovalApplicationStorageServiceImpl extends ServiceImpl<OaApprovalApplicationStorageMapper, OaApprovalApplicationStorage> implements OaApprovalApplicationStorageService {
 
-}
+    private final OaApprovalApplicationsService oaApprovalApplicationsService;
+    private final AssetMainService assetMainService;
+    private final AssetGeneralExtService assetGeneralExtService;
+    private final AssetPropertyExtService assetPropertyExtService;
+    private final AssetVehicleExtService assetVehicleExtService;
+    private final AssetTypeService assetTypeService;
+    private final OaApprovalFlowNodeService oaApprovalFlowNodeService;
+    private final OaApprovalTodoService oaApprovalTodoService;
+    private final ISysUserService sysUserService;
+    private final ISysDeptService sysDeptService;
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public void submitGeneralAssetStorage(OaApprovalApplicationStorageGeneralDTO dto) {
+        // 1. 保存审批申请主表数据
+        OaApprovalApplications applications = buildOaApprovalApplications(dto);
+        
+        // 2. 获取流程节点并创建待办
+        OaApprovalFlowNode firstFlowNode = getFirstFlowNode(ApprovalTypeEnum.IN_STOCK.getCode());
+        applications.setCurrentFlowNodeId(firstFlowNode.getId());
+        oaApprovalApplicationsService.save(applications);
+
+        // 3. 创建待办事项记录
+        createApprovalTodo(applications.getId(), applications.getApplicationCode(), firstFlowNode, dto.getDeptId());
+
+        // 4. 保存资产入库申请明细数据
+        OaApprovalApplicationStorage storage = buildOaApprovalApplicationStorage(dto, applications.getId());
+        save(storage);
+
+        // 5. 保存通用资产数据
+        saveGeneralAssets(dto.getAssetItems(), applications.getId(), dto.getAssetTypeId(), dto.getStorageTime());
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public void submitPropertyAssetStorage(OaApprovalApplicationStoragePropertyDTO dto) {
+        // 1. 保存审批申请主表数据
+        OaApprovalApplications applications = buildOaApprovalApplications(dto);
+        
+        // 2. 获取流程节点并创建待办
+        OaApprovalFlowNode firstFlowNode = getFirstFlowNode(ApprovalTypeEnum.IN_STOCK.getCode());
+        applications.setCurrentFlowNodeId(firstFlowNode.getId());
+        oaApprovalApplicationsService.save(applications);
+
+        // 3. 创建待办事项记录
+        createApprovalTodo(applications.getId(), applications.getApplicationCode(), firstFlowNode, dto.getDeptId());
+
+        // 4. 保存资产入库申请明细数据
+        OaApprovalApplicationStorage storage = buildOaApprovalApplicationStorage(dto, applications.getId());
+        save(storage);
+
+        // 5. 保存房产资产数据
+        savePropertyAssets(dto.getAssetItems(), applications.getId(), dto.getAssetTypeId(), dto.getStorageTime());
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public void submitVehicleAssetStorage(OaApprovalApplicationStorageVehicleDTO dto) {
+        // 1. 保存审批申请主表数据
+        OaApprovalApplications applications = buildOaApprovalApplications(dto);
+        
+        // 2. 获取流程节点并创建待办
+        OaApprovalFlowNode firstFlowNode = getFirstFlowNode(ApprovalTypeEnum.IN_STOCK.getCode());
+        applications.setCurrentFlowNodeId(firstFlowNode.getId());
+        oaApprovalApplicationsService.save(applications);
+
+        // 3. 创建待办事项记录
+        createApprovalTodo(applications.getId(), applications.getApplicationCode(), firstFlowNode, dto.getDeptId());
+
+        // 4. 保存资产入库申请明细数据
+        OaApprovalApplicationStorage storage = buildOaApprovalApplicationStorage(dto, applications.getId());
+        save(storage);
+
+        // 5. 保存车辆资产数据
+        saveVehicleAssets(dto.getAssetItems(), applications.getId(), dto.getAssetTypeId(), dto.getStorageTime());
+    }
+
+    /**
+     * 保存通用资产数据
+     */
+    private void saveGeneralAssets(List<OaApprovalApplicationStorageGeneralDTO.GeneralAssetItemDTO> assetItems, Integer applicationId, Integer assetTypeId, LocalDate storageDate) {
+        List<AssetMain> allAssetMains = new ArrayList<>();
+        List<AssetGeneralExt> allGeneralExts = new ArrayList<>();
+        
+        for (OaApprovalApplicationStorageGeneralDTO.GeneralAssetItemDTO item : assetItems) {
+            // 根据数量创建对应数量的资产记录
+            int quantity = item.getQuantity().intValue();
+            for (int i = 0; i < quantity; i++) {
+                AssetMain assetMain = buildAssetMain(item, applicationId, assetTypeId, storageDate);
+                assetMain.setAssetMainType(AssetTypeEnum.GENERAL.getCode());
+                assetMain.setQuantity(BigDecimal.ONE); // 每个资产记录数量为1
+                assetMain.setTotalValue(item.getUnitPrice()); // 总价值等于单价
+                allAssetMains.add(assetMain);
+            }
+        }
+        
+        // 批量保存资产主表数据
+        assetMainService.saveBatch(allAssetMains);
+
+        // 为每个资产主表记录创建对应的扩展信息
+        int assetMainIndex = 0;
+        for (OaApprovalApplicationStorageGeneralDTO.GeneralAssetItemDTO item : assetItems) {
+            int quantity = item.getQuantity().intValue();
+            for (int i = 0; i < quantity; i++) {
+                AssetGeneralExt generalExt = buildAssetGeneralExt(item, allAssetMains.get(assetMainIndex).getId());
+                allGeneralExts.add(generalExt);
+                assetMainIndex++;
+            }
+        }
+        
+        assetGeneralExtService.saveBatch(allGeneralExts);
+    }
+
+    /**
+     * 保存房产资产数据
+     */
+    private void savePropertyAssets(List<OaApprovalApplicationStoragePropertyDTO.PropertyAssetItemDTO> assetItems, Integer applicationId, Integer assetTypeId, LocalDate storageDate) {
+        List<AssetMain> allAssetMains = new ArrayList<>();
+        List<AssetPropertyExt> allPropertyExts = new ArrayList<>();
+        
+        for (OaApprovalApplicationStoragePropertyDTO.PropertyAssetItemDTO item : assetItems) {
+            // 根据数量创建对应数量的资产记录
+            int quantity = item.getQuantity().intValue();
+            for (int i = 0; i < quantity; i++) {
+                AssetMain assetMain = buildAssetMainFromProperty(item, applicationId, assetTypeId, storageDate);
+                assetMain.setAssetMainType(AssetTypeEnum.HOUSE.getCode());
+                assetMain.setQuantity(BigDecimal.ONE); // 每个资产记录数量为1
+                assetMain.setTotalValue(item.getUnitPrice()); // 总价值等于单价
+                allAssetMains.add(assetMain);
+            }
+        }
+        
+        // 批量保存资产主表数据
+        assetMainService.saveBatch(allAssetMains);
+
+        // 为每个资产主表记录创建对应的扩展信息
+        int assetMainIndex = 0;
+        for (OaApprovalApplicationStoragePropertyDTO.PropertyAssetItemDTO item : assetItems) {
+            int quantity = item.getQuantity().intValue();
+            for (int i = 0; i < quantity; i++) {
+                AssetPropertyExt propertyExt = buildAssetPropertyExt(item, allAssetMains.get(assetMainIndex).getId());
+                allPropertyExts.add(propertyExt);
+                assetMainIndex++;
+            }
+        }
+        
+        assetPropertyExtService.saveBatch(allPropertyExts);
+    }
+
+    /**
+     * 保存车辆资产数据
+     */
+    private void saveVehicleAssets(List<OaApprovalApplicationStorageVehicleDTO.VehicleAssetItemDTO> assetItems, Integer applicationId, Integer assetTypeId, LocalDate storageDate) {
+        List<AssetMain> allAssetMains = new ArrayList<>();
+        List<AssetVehicleExt> allVehicleExts = new ArrayList<>();
+        
+        for (OaApprovalApplicationStorageVehicleDTO.VehicleAssetItemDTO item : assetItems) {
+            // 根据数量创建对应数量的资产记录
+            int quantity = item.getQuantity().intValue();
+            for (int i = 0; i < quantity; i++) {
+                AssetMain assetMain = buildAssetMainFromVehicle(item, applicationId, assetTypeId, storageDate);
+                assetMain.setAssetMainType(AssetTypeEnum.VEHICLE.getCode());
+                assetMain.setQuantity(BigDecimal.ONE); // 每个资产记录数量为1
+                assetMain.setTotalValue(item.getUnitPrice()); // 总价值等于单价
+                allAssetMains.add(assetMain);
+            }
+        }
+        
+        // 批量保存资产主表数据
+        assetMainService.saveBatch(allAssetMains);
+
+        // 为每个资产主表记录创建对应的扩展信息
+        int assetMainIndex = 0;
+        for (OaApprovalApplicationStorageVehicleDTO.VehicleAssetItemDTO item : assetItems) {
+            int quantity = item.getQuantity().intValue();
+            for (int i = 0; i < quantity; i++) {
+                AssetVehicleExt vehicleExt = buildAssetVehicleExt(item, allAssetMains.get(assetMainIndex).getId());
+                allVehicleExts.add(vehicleExt);
+                assetMainIndex++;
+            }
+        }
+        
+        assetVehicleExtService.saveBatch(allVehicleExts);
+    }
+
+    /**
+     * 构建通用资产主表数据
+     */
+    private AssetMain buildAssetMain(OaApprovalApplicationStorageGeneralDTO.GeneralAssetItemDTO item, Integer applicationId, Integer assetTypeId, LocalDate storageDate) {
+        AssetMain assetMain = new AssetMain();
+        assetMain.setApprovalApplicationId(applicationId.intValue());
+        assetMain.setAssetOriginalCode(item.getAssetOriginalCode());
+        assetMain.setAssetCode(generateAssetCode(assetTypeId, storageDate)); // 系统生成资产编码
+        assetMain.setAssetName(item.getAssetName());
+        assetMain.setSpecificationModel(item.getSpecificationModel());
+        assetMain.setAssetTypeId(assetTypeId);
+        assetMain.setMeasurementUnit(item.getMeasurementUnit());
+        assetMain.setUnitPrice(item.getUnitPrice());
+        assetMain.setUsefulLife(item.getUsefulLife());
+        assetMain.setOwnershipDeptId(item.getOwnershipDeptId());
+        assetMain.setUserName(item.getUserName());
+        assetMain.setUseDeptId(item.getUseDeptId());
+        assetMain.setWarehouseId(item.getWarehouseId());
+        assetMain.setWarehouseName(item.getWarehouseName());
+        assetMain.setAddress(item.getAddress());
+        assetMain.setAssetStatus(item.getAssetStatus());
+        assetMain.setRemarks(item.getRemarks());
+        assetMain.setAccountingStatus(item.getAccountingStatus());
+        assetMain.setAccountingDate(item.getAccountingDate());
+        assetMain.setAccountingVoucherNo(item.getAccountingVoucherNo());
+        assetMain.setAccountingSubject(item.getAccountingSubject());
+        assetMain.setAccountingAmount(item.getAccountingAmount());
+        assetMain.setDisabled(false);
+        return assetMain;
+    }
+
+    /**
+     * 构建房产资产主表数据
+     */
+    private AssetMain buildAssetMainFromProperty(OaApprovalApplicationStoragePropertyDTO.PropertyAssetItemDTO item, Integer applicationId, Integer assetTypeId, LocalDate storageDate) {
+        AssetMain assetMain = new AssetMain();
+        assetMain.setApprovalApplicationId(applicationId.intValue());
+        assetMain.setAssetOriginalCode(item.getAssetOriginalCode());
+        assetMain.setAssetCode(generateAssetCode(assetTypeId, storageDate));
+        assetMain.setAssetName(item.getAssetName());
+        assetMain.setSpecificationModel(item.getSpecificationModel());
+        assetMain.setAssetTypeId(assetTypeId);
+        assetMain.setMeasurementUnit(item.getMeasurementUnit());
+        assetMain.setUnitPrice(item.getUnitPrice());
+        assetMain.setUsefulLife(item.getUsefulLife());
+        assetMain.setOwnershipDeptId(item.getOwnershipDeptId());
+        assetMain.setUserName(item.getUserName());
+        assetMain.setUseDeptId(item.getUseDeptId());
+        assetMain.setWarehouseId(item.getWarehouseId());
+        assetMain.setWarehouseName(item.getWarehouseName());
+        assetMain.setAddress(item.getAddress());
+        assetMain.setAssetStatus(item.getAssetStatus());
+        assetMain.setRemarks(item.getRemarks());
+        assetMain.setAccountingStatus(item.getAccountingStatus());
+        assetMain.setAccountingDate(item.getAccountingDate());
+        assetMain.setAccountingVoucherNo(item.getAccountingVoucherNo());
+        assetMain.setAccountingSubject(item.getAccountingSubject());
+        assetMain.setAccountingAmount(item.getAccountingAmount());
+        assetMain.setDisabled(false);
+        return assetMain;
+    }
+
+    /**
+     * 构建车辆资产主表数据
+     */
+    private AssetMain buildAssetMainFromVehicle(OaApprovalApplicationStorageVehicleDTO.VehicleAssetItemDTO item, Integer applicationId, Integer assetTypeId, LocalDate storageDate) {
+        AssetMain assetMain = new AssetMain();
+        assetMain.setApprovalApplicationId(applicationId.intValue());
+        assetMain.setAssetOriginalCode(item.getAssetOriginalCode());
+        assetMain.setAssetCode(generateAssetCode(assetTypeId, storageDate));
+        assetMain.setAssetName(item.getAssetName());
+        assetMain.setSpecificationModel(item.getSpecificationModel());
+        assetMain.setAssetTypeId(assetTypeId);
+        assetMain.setMeasurementUnit(item.getMeasurementUnit());
+        assetMain.setUnitPrice(item.getUnitPrice());
+        assetMain.setUsefulLife(item.getUsefulLife());
+        assetMain.setOwnershipDeptId(item.getOwnershipDeptId());
+        assetMain.setUserName(item.getUserName());
+        assetMain.setUseDeptId(item.getUseDeptId());
+        assetMain.setWarehouseId(item.getWarehouseId());
+        assetMain.setWarehouseName(item.getWarehouseName());
+        assetMain.setAddress(item.getAddress());
+        assetMain.setAssetStatus(item.getAssetStatus());
+        assetMain.setRemarks(item.getRemarks());
+        assetMain.setAccountingStatus(item.getAccountingStatus());
+        assetMain.setAccountingDate(item.getAccountingDate());
+        assetMain.setAccountingVoucherNo(item.getAccountingVoucherNo());
+        assetMain.setAccountingSubject(item.getAccountingSubject());
+        assetMain.setAccountingAmount(item.getAccountingAmount());
+        assetMain.setDisabled(false);
+        return assetMain;
+    }
+
+    /**
+     * 构建通用资产扩展数据
+     */
+    private AssetGeneralExt buildAssetGeneralExt(OaApprovalApplicationStorageGeneralDTO.GeneralAssetItemDTO item, Integer assetMainId) {
+        AssetGeneralExt generalExt = new AssetGeneralExt();
+        generalExt.setAssetMainId(assetMainId);
+        generalExt.setSupplierName(item.getSupplierName());
+        generalExt.setPurchaseDate(item.getPurchaseDate());
+        generalExt.setWarrantyPeriod(item.getWarrantyPeriod());
+        generalExt.setWarrantyExpireDate(item.getWarrantyExpireDate());
+        generalExt.setDepreciationMethod(item.getDepreciationMethod());
+        generalExt.setDepreciationRate(item.getDepreciationRate());
+        generalExt.setNetValue(item.getNetValue());
+        generalExt.setMaintenanceCycle(item.getMaintenanceCycle());
+        generalExt.setLastMaintenanceDate(item.getLastMaintenanceDate());
+        generalExt.setNextMaintenanceDate(item.getNextMaintenanceDate());
+        generalExt.setDisabled(false);
+        return generalExt;
+    }
+
+    /**
+     * 构建房产资产扩展数据
+     */
+    private AssetPropertyExt buildAssetPropertyExt(OaApprovalApplicationStoragePropertyDTO.PropertyAssetItemDTO item, Integer assetMainId) {
+        AssetPropertyExt propertyExt = new AssetPropertyExt();
+        propertyExt.setAssetMainId(assetMainId);
+        propertyExt.setRegion(item.getRegion());
+        propertyExt.setDesignPurpose(item.getDesignPurpose());
+        propertyExt.setBuilding(item.getBuilding());
+        propertyExt.setRoomNumber(item.getRoomNumber());
+        propertyExt.setConstructionArea(item.getConstructionArea());
+        propertyExt.setStructureType(item.getStructureType());
+        propertyExt.setCertificateNumber(item.getCertificateNumber());
+        propertyExt.setCompletionDate(item.getCompletionDate());
+        propertyExt.setDetailedLocation(item.getDetailedLocation());
+        propertyExt.setProvincialPlatformValue(item.getProvincialPlatformValue());
+        propertyExt.setResettlementSituation(item.getResettlementSituation());
+        propertyExt.setIsMortgaged(item.getIsMortgaged());
+        propertyExt.setTenantName(item.getTenantName());
+        propertyExt.setRentalAmount(item.getRentalAmount());
+        propertyExt.setLeaseStartDate(item.getLeaseStartDate());
+        propertyExt.setLeaseEndDate(item.getLeaseEndDate());
+        propertyExt.setDisabled(false);
+        return propertyExt;
+    }
+
+    /**
+     * 构建车辆资产扩展数据
+     */
+    private AssetVehicleExt buildAssetVehicleExt(OaApprovalApplicationStorageVehicleDTO.VehicleAssetItemDTO item, Integer assetMainId) {
+        AssetVehicleExt vehicleExt = new AssetVehicleExt();
+        vehicleExt.setAssetMainId(assetMainId);
+        vehicleExt.setLicensePlate(item.getLicensePlate());
+        vehicleExt.setVinCode(item.getVinCode());
+        vehicleExt.setEngineNumber(item.getEngineNumber());
+        vehicleExt.setDisplacement(item.getDisplacement());
+        vehicleExt.setStaffingSituation(item.getStaffingSituation());
+        vehicleExt.setOrigin(item.getOrigin());
+        vehicleExt.setAcquisitionDate(item.getAcquisitionDate());
+        vehicleExt.setPropertyRightForm(item.getPropertyRightForm());
+        vehicleExt.setDisabled(false);
+        return vehicleExt;
+    }
+
+    /**
+     * 获取第一个流程节点
+     */
+    private OaApprovalFlowNode getFirstFlowNode(Integer approvalId) {
+        List<OaApprovalFlowNode> flowNodes = oaApprovalFlowNodeService.lambdaQuery()
+                .eq(OaApprovalFlowNode::getApprovalId, approvalId)
+                .eq(OaApprovalFlowNode::getStatus, 1)
+                .orderByAsc(OaApprovalFlowNode::getSortOrder)
+                .list();
+
+        if (CollectionUtils.isEmpty(flowNodes)) {
+            throw new ServiceException("未找到有效的审批流程配置");
+        }
+
+        return flowNodes.get(0);
+    }
+
+    /**
+     * 创建待办数据
+     */
+    private void createApprovalTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode, Integer deptId) {
+        Integer approvalType = flowNode.getApprovalType();
+        if (approvalType == null) {
+            throw new ServiceException("审批类型不能为空");
+        }
+
+        switch (approvalType) {
+            case 0:
+                createUpperDeptTodo(applicationId, applicationCode, flowNode, deptId);
+                break;
+            case 1:
+                createSpecifiedDeptTodo(applicationId, applicationCode, flowNode);
+                break;
+            case 2:
+                createSpecifiedUserTodo(applicationId, applicationCode, flowNode);
+                break;
+            default:
+                throw new ServiceException("不支持的审批类型: " + approvalType);
+        }
+    }
+
+    /**
+     * 创建上级部门审批待办
+     */
+    private void createUpperDeptTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode, Integer deptId) {
+        if (deptId == null) {
+            throw new ServiceException("未填写申请部门信息");
+        }
+
+        SysDept currentDept = sysDeptService.selectDeptById(Long.valueOf(deptId));
+        if (currentDept == null) {
+            throw new ServiceException("申请部门信息不存在");
+        }
+
+        if (currentDept.getParentId() == null || currentDept.getParentId() == 0) {
+            throw new ServiceException("当前部门没有上级部门");
+        }
+
+        SysDept parentDept = sysDeptService.selectDeptById(currentDept.getParentId());
+        if (parentDept == null) {
+            throw new ServiceException("上级部门信息不存在");
+        }
+
+        List<SysUser> users = sysUserService.selectListByDeptId(parentDept.getDeptId().toString());
+        if (CollUtil.isEmpty(users)) {
+            throw new ServiceException("上级部门下没有找到用户");
+        }
+
+        createTodoItem(applicationId, applicationCode, flowNode, users);
+    }
+
+    /**
+     * 创建指定部门审批待办
+     */
+    private void createSpecifiedDeptTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode) {
+        if (StringUtils.isBlank(flowNode.getApprovalIds())) {
+            throw new ServiceException("操作失败,审批流程配置异常");
+        }
+        
+        List<String> deptIdList = Arrays.stream(flowNode.getApprovalIds().split(",")).collect(Collectors.toList());
+        List<SysUser> users = sysUserService.selectListByDeptIds(deptIdList);
+        if (CollUtil.isEmpty(users)) {
+            throw new ServiceException("指定部门下没有找到用户");
+        }
+
+        createTodoItem(applicationId, applicationCode, flowNode, users);
+    }
+
+    /**
+     * 创建指定人员审批待办
+     */
+    private void createSpecifiedUserTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode) {
+        if (StringUtils.isBlank(flowNode.getApprovalIds())) {
+            throw new ServiceException("操作失败,审批流程配置异常");
+        }
+        
+        List<Integer> userIds = Arrays.stream(flowNode.getApprovalIds().split(","))
+                .map(Integer::valueOf).collect(Collectors.toList());
+        List<SysUser> users = sysUserService.selectListByUserIds(userIds);
+        if (CollUtil.isEmpty(users)) {
+            throw new ServiceException("没有找到指定审批用户");
+        }
+        
+        createTodoItem(applicationId, applicationCode, flowNode, users);
+    }
+
+    /**
+     * 创建待办数据项
+     */
+    private void createTodoItem(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode, List<SysUser> userList) {
+        List<OaApprovalTodo> approvalTodoList = userList.stream().map(item -> {
+            OaApprovalTodo todo = new OaApprovalTodo();
+            todo.setApplicationId(applicationId);
+            todo.setApplicationCode(applicationCode);
+            todo.setFlowNodeId(flowNode.getId());
+            todo.setUserId(item.getUserId().intValue());
+            todo.setUserName(item.getNickName());
+
+            if (item.getDeptId() != null) {
+                todo.setDeptId(Integer.valueOf(item.getDeptId()));
+            }
+
+            todo.setSortOrder(flowNode.getSortOrder());
+            todo.setStatus(0);
+            todo.setCreateTime(LocalDateTime.now());
+            return todo;
+        }).collect(Collectors.toList());
+        
+        oaApprovalTodoService.saveBatch(approvalTodoList);
+    }
+
+    /**
+     * 构建审批申请主表数据
+     */
+    private OaApprovalApplications buildOaApprovalApplications(Object dto) {
+        OaApprovalApplications applications = new OaApprovalApplications();
+        applications.setApprovalId(ApprovalTypeEnum.IN_STOCK.getCode());
+
+        if (dto instanceof OaApprovalApplicationStorageGeneralDTO) {
+            OaApprovalApplicationStorageGeneralDTO generalDTO = (OaApprovalApplicationStorageGeneralDTO) dto;
+            applications.setApplicantUserId(generalDTO.getApplicantUserId());
+            applications.setApplicantName(generalDTO.getApplicantName());
+            applications.setDeptId(generalDTO.getDeptId());
+            applications.setDeptName(generalDTO.getDeptName());
+            applications.setApplicationDate(generalDTO.getApplicationDate());
+            applications.setApplicationReason(generalDTO.getApplicationReason());
+            applications.setAttachmentUrl(generalDTO.getAttachmentUrl());
+        } else if (dto instanceof OaApprovalApplicationStoragePropertyDTO) {
+            OaApprovalApplicationStoragePropertyDTO propertyDTO = (OaApprovalApplicationStoragePropertyDTO) dto;
+            applications.setApplicantUserId(propertyDTO.getApplicantUserId());
+            applications.setApplicantName(propertyDTO.getApplicantName());
+            applications.setDeptId(propertyDTO.getDeptId());
+            applications.setDeptName(propertyDTO.getDeptName());
+            applications.setApplicationDate(propertyDTO.getApplicationDate());
+            applications.setApplicationReason(propertyDTO.getApplicationReason());
+            applications.setAttachmentUrl(propertyDTO.getAttachmentUrl());
+        } else if (dto instanceof OaApprovalApplicationStorageVehicleDTO) {
+            OaApprovalApplicationStorageVehicleDTO vehicleDTO = (OaApprovalApplicationStorageVehicleDTO) dto;
+            applications.setApplicantUserId(vehicleDTO.getApplicantUserId());
+            applications.setApplicantName(vehicleDTO.getApplicantName());
+            applications.setDeptId(vehicleDTO.getDeptId());
+            applications.setDeptName(vehicleDTO.getDeptName());
+            applications.setApplicationDate(vehicleDTO.getApplicationDate());
+            applications.setApplicationReason(vehicleDTO.getApplicationReason());
+            applications.setAttachmentUrl(vehicleDTO.getAttachmentUrl());
+        }
+        
+        applications.setApplicationCode(generateApplicationCode());
+        applications.setDisabled(0);
+        applications.setApprovalStatus(ApprovalStatusEnum.PENDING.getCode());
+        return applications;
+    }
+
+    /**
+     * 构建资产入库申请明细数据
+     */
+    private OaApprovalApplicationStorage buildOaApprovalApplicationStorage(Object dto, Integer applicationId) {
+        OaApprovalApplicationStorage storage = new OaApprovalApplicationStorage();
+        storage.setApprovalApplicationId(applicationId.intValue());
+        
+        if (dto instanceof OaApprovalApplicationStorageGeneralDTO) {
+            OaApprovalApplicationStorageGeneralDTO generalDTO = (OaApprovalApplicationStorageGeneralDTO) dto;
+            storage.setTitle(generalDTO.getTitle());
+            storage.setAssetTypeId(generalDTO.getAssetTypeId());
+            storage.setStorageType(generalDTO.getStorageType());
+            storage.setStorageTime(generalDTO.getStorageTime());
+        } else if (dto instanceof OaApprovalApplicationStoragePropertyDTO) {
+            OaApprovalApplicationStoragePropertyDTO propertyDTO = (OaApprovalApplicationStoragePropertyDTO) dto;
+            storage.setTitle(propertyDTO.getTitle());
+            storage.setAssetTypeId(propertyDTO.getAssetTypeId());
+            storage.setStorageType(propertyDTO.getStorageType());
+            storage.setStorageTime(propertyDTO.getStorageTime());
+        } else if (dto instanceof OaApprovalApplicationStorageVehicleDTO) {
+            OaApprovalApplicationStorageVehicleDTO vehicleDTO = (OaApprovalApplicationStorageVehicleDTO) dto;
+            storage.setTitle(vehicleDTO.getTitle());
+            storage.setAssetTypeId(vehicleDTO.getAssetTypeId());
+            storage.setStorageType(vehicleDTO.getStorageType());
+            storage.setStorageTime(vehicleDTO.getStorageTime());
+        }
+        
+        return storage;
+    }
+
+    /**
+     * 生成申请单号
+     * 格式:RK + 年月日 + 3位序号
+     */
+    private String generateApplicationCode() {
+        String dateStr = LocalDate.now().format(DateTimeFormatter.ofPattern("yyyyMMdd"));
+        String prefix = "RK" + dateStr;
+        
+        Long count = oaApprovalApplicationsService.lambdaQuery()
+                .like(OaApprovalApplications::getApplicationCode, prefix)
+                .ge(OaApprovalApplications::getCreateTime, LocalDate.now().atStartOfDay())
+                .lt(OaApprovalApplications::getCreateTime, LocalDate.now().plusDays(1).atStartOfDay())
+                .count();
+        
+        int sequence = (count != null ? count.intValue() : 0) + 1;
+        String sequenceStr = String.format("%03d", sequence);
+        
+        return prefix + sequenceStr;
+    }
+
+    /**
+     * 生成资产编码
+     * 格式:资产类型一级分类简写+资产类型子类简写+入库日期+【-】+数量顺序编号(4位)
+     * 例如:GDFC20250917-0001
+     */
+    private String generateAssetCode(Integer assetTypeId, LocalDate storageDate) {
+        // 根据资产类型ID获取资产编码前缀
+        String typeCodePrefix = assetTypeService.getAssetCodePrefix(assetTypeId);
+        
+        String dateStr = storageDate.format(DateTimeFormatter.ofPattern("yyyyMMdd"));
+        String prefix = typeCodePrefix + dateStr + "-";
+        
+        // 查询当天该类型资产的数量
+        Long count = assetMainService.lambdaQuery()
+                .like(AssetMain::getAssetCode, prefix)
+                .ge(AssetMain::getCreateTime, storageDate.atStartOfDay())
+                .lt(AssetMain::getCreateTime, storageDate.plusDays(1).atStartOfDay())
+                .count();
+        
+        int sequence = (count != null ? count.intValue() : 0) + 1;
+        String sequenceStr = String.format("%04d", sequence);
+        
+        return prefix + sequenceStr;
+    }
+}
\ No newline at end of file

--
Gitblit v1.7.1