新增待办信息
This commit is contained in:
@@ -0,0 +1,35 @@
|
|||||||
|
package com.jeesite.modules.app.dao.file;
|
||||||
|
|
||||||
|
|
||||||
|
import com.jeesite.modules.biz.entity.BizFolders;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
public class FolderItem implements Serializable {
|
||||||
|
|
||||||
|
|
||||||
|
private String id;
|
||||||
|
private String name;
|
||||||
|
private Boolean expanded;
|
||||||
|
|
||||||
|
private String type;
|
||||||
|
|
||||||
|
List<BizFolders> children = new ArrayList<>();
|
||||||
|
|
||||||
|
public FolderItem() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public FolderItem(String id, String name, Boolean expanded, String type, List<BizFolders> children) {
|
||||||
|
this.id = id;
|
||||||
|
this.name = name;
|
||||||
|
this.expanded = expanded;
|
||||||
|
this.type = type;
|
||||||
|
this.children = children;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
@@ -58,7 +58,7 @@ public class BizMyfiles extends DataEntity<BizMyfiles> implements Serializable {
|
|||||||
private String fileName; // 原始名称
|
private String fileName; // 原始名称
|
||||||
private String filePath; // 存储路径
|
private String filePath; // 存储路径
|
||||||
private String fileHash; // 文件MD5
|
private String fileHash; // 文件MD5
|
||||||
private Long fileSize; // 文件大小
|
private String fileSize; // 文件大小
|
||||||
private String fileExt; // 文件扩展名
|
private String fileExt; // 文件扩展名
|
||||||
private String mimeType; // 文件类型
|
private String mimeType; // 文件类型
|
||||||
private String folderId; // 文件夹标识
|
private String folderId; // 文件夹标识
|
||||||
|
|||||||
@@ -1,6 +1,9 @@
|
|||||||
package com.jeesite.modules.biz.web;
|
package com.jeesite.modules.biz.web;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import com.jeesite.modules.app.dao.file.FolderItem;
|
||||||
import jakarta.servlet.http.HttpServletRequest;
|
import jakarta.servlet.http.HttpServletRequest;
|
||||||
import jakarta.servlet.http.HttpServletResponse;
|
import jakarta.servlet.http.HttpServletResponse;
|
||||||
|
|
||||||
@@ -26,6 +29,7 @@ import com.jeesite.modules.biz.service.BizFoldersService;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* 文件夹信息Controller
|
* 文件夹信息Controller
|
||||||
|
*
|
||||||
* @author gaoxq
|
* @author gaoxq
|
||||||
* @version 2025-12-18
|
* @version 2025-12-18
|
||||||
*/
|
*/
|
||||||
@@ -33,106 +37,122 @@ import com.jeesite.modules.biz.service.BizFoldersService;
|
|||||||
@RequestMapping(value = "${adminPath}/biz/folders")
|
@RequestMapping(value = "${adminPath}/biz/folders")
|
||||||
public class BizFoldersController extends BaseController {
|
public class BizFoldersController extends BaseController {
|
||||||
|
|
||||||
private final BizFoldersService bizFoldersService;
|
private final BizFoldersService bizFoldersService;
|
||||||
|
|
||||||
public BizFoldersController(BizFoldersService bizFoldersService) {
|
public BizFoldersController(BizFoldersService bizFoldersService) {
|
||||||
this.bizFoldersService = bizFoldersService;
|
this.bizFoldersService = bizFoldersService;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 获取数据
|
|
||||||
*/
|
|
||||||
@ModelAttribute
|
|
||||||
public BizFolders get(String folderId, boolean isNewRecord) {
|
|
||||||
return bizFoldersService.get(folderId, isNewRecord);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 查询列表
|
|
||||||
*/
|
|
||||||
@RequestMapping(value = {"list", ""})
|
|
||||||
public String list(BizFolders bizFolders, Model model) {
|
|
||||||
model.addAttribute("bizFolders", bizFolders);
|
|
||||||
return "modules/biz/bizFoldersList";
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 查询列表数据
|
|
||||||
*/
|
|
||||||
@RequestMapping(value = "listData")
|
|
||||||
@ResponseBody
|
|
||||||
public Page<BizFolders> listData(BizFolders bizFolders, HttpServletRequest request, HttpServletResponse response) {
|
|
||||||
bizFolders.setPage(new Page<>(request, response));
|
|
||||||
Page<BizFolders> page = bizFoldersService.findPage(bizFolders);
|
|
||||||
return page;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 查看编辑表单
|
* 获取数据
|
||||||
*/
|
*/
|
||||||
@RequestMapping(value = "form")
|
@ModelAttribute
|
||||||
public String form(BizFolders bizFolders, Model model) {
|
public BizFolders get(String folderId, boolean isNewRecord) {
|
||||||
model.addAttribute("bizFolders", bizFolders);
|
return bizFoldersService.get(folderId, isNewRecord);
|
||||||
return "modules/biz/bizFoldersForm";
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 保存数据
|
* 查询列表
|
||||||
*/
|
*/
|
||||||
@PostMapping(value = "save")
|
@RequestMapping(value = {"list", ""})
|
||||||
@ResponseBody
|
public String list(BizFolders bizFolders, Model model) {
|
||||||
public String save(@Validated BizFolders bizFolders) {
|
model.addAttribute("bizFolders", bizFolders);
|
||||||
bizFoldersService.save(bizFolders);
|
return "modules/biz/bizFoldersList";
|
||||||
return renderResult(Global.TRUE, text("保存文件夹信息成功!"));
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 导出数据
|
* 查询列表数据
|
||||||
*/
|
*/
|
||||||
@RequestMapping(value = "exportData")
|
@RequestMapping(value = "listData")
|
||||||
public void exportData(BizFolders bizFolders, HttpServletResponse response) {
|
@ResponseBody
|
||||||
List<BizFolders> list = bizFoldersService.findList(bizFolders);
|
public Page<BizFolders> listData(BizFolders bizFolders, HttpServletRequest request, HttpServletResponse response) {
|
||||||
String fileName = "文件夹信息" + DateUtils.getDate("yyyyMMddHHmmss") + ".xlsx";
|
bizFolders.setPage(new Page<>(request, response));
|
||||||
try(ExcelExport ee = new ExcelExport("文件夹信息", BizFolders.class)){
|
Page<BizFolders> page = bizFoldersService.findPage(bizFolders);
|
||||||
ee.setDataList(list).write(response, fileName);
|
return page;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 下载模板
|
* 查看编辑表单
|
||||||
*/
|
*/
|
||||||
@RequestMapping(value = "importTemplate")
|
@RequestMapping(value = "form")
|
||||||
public void importTemplate(HttpServletResponse response) {
|
public String form(BizFolders bizFolders, Model model) {
|
||||||
BizFolders bizFolders = new BizFolders();
|
model.addAttribute("bizFolders", bizFolders);
|
||||||
List<BizFolders> list = ListUtils.newArrayList(bizFolders);
|
return "modules/biz/bizFoldersForm";
|
||||||
String fileName = "文件夹信息模板.xlsx";
|
}
|
||||||
try(ExcelExport ee = new ExcelExport("文件夹信息", BizFolders.class, Type.IMPORT)){
|
|
||||||
ee.setDataList(list).write(response, fileName);
|
/**
|
||||||
}
|
* 保存数据
|
||||||
}
|
*/
|
||||||
|
@PostMapping(value = "save")
|
||||||
|
@ResponseBody
|
||||||
|
public String save(@Validated BizFolders bizFolders) {
|
||||||
|
bizFoldersService.save(bizFolders);
|
||||||
|
return renderResult(Global.TRUE, text("保存文件夹信息成功!"));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 导出数据
|
||||||
|
*/
|
||||||
|
@RequestMapping(value = "exportData")
|
||||||
|
public void exportData(BizFolders bizFolders, HttpServletResponse response) {
|
||||||
|
List<BizFolders> list = bizFoldersService.findList(bizFolders);
|
||||||
|
String fileName = "文件夹信息" + DateUtils.getDate("yyyyMMddHHmmss") + ".xlsx";
|
||||||
|
try (ExcelExport ee = new ExcelExport("文件夹信息", BizFolders.class)) {
|
||||||
|
ee.setDataList(list).write(response, fileName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 下载模板
|
||||||
|
*/
|
||||||
|
@RequestMapping(value = "importTemplate")
|
||||||
|
public void importTemplate(HttpServletResponse response) {
|
||||||
|
BizFolders bizFolders = new BizFolders();
|
||||||
|
List<BizFolders> list = ListUtils.newArrayList(bizFolders);
|
||||||
|
String fileName = "文件夹信息模板.xlsx";
|
||||||
|
try (ExcelExport ee = new ExcelExport("文件夹信息", BizFolders.class, Type.IMPORT)) {
|
||||||
|
ee.setDataList(list).write(response, fileName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 导入数据
|
||||||
|
*/
|
||||||
|
@ResponseBody
|
||||||
|
@PostMapping(value = "importData")
|
||||||
|
public String importData(MultipartFile file) {
|
||||||
|
try {
|
||||||
|
String message = bizFoldersService.importData(file);
|
||||||
|
return renderResult(Global.TRUE, "posfull:" + message);
|
||||||
|
} catch (Exception ex) {
|
||||||
|
return renderResult(Global.FALSE, "posfull:" + ex.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 删除数据
|
||||||
|
*/
|
||||||
|
@RequestMapping(value = "delete")
|
||||||
|
@ResponseBody
|
||||||
|
public String delete(BizFolders bizFolders) {
|
||||||
|
bizFoldersService.delete(bizFolders);
|
||||||
|
return renderResult(Global.TRUE, text("删除文件夹信息成功!"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@RequestMapping(value = "foldersAll")
|
||||||
|
@ResponseBody
|
||||||
|
public List<FolderItem> foldersAll(BizFolders bizFolders) {
|
||||||
|
List<FolderItem> folderItems = new ArrayList<>();
|
||||||
|
List<BizFolders> foldersList = bizFoldersService.findList(bizFolders);
|
||||||
|
for (BizFolders folder : foldersList) {
|
||||||
|
if (folder.getParentId().equals("0")) {
|
||||||
|
BizFolders childFolder = new BizFolders();
|
||||||
|
childFolder.setParentId(folder.getFolderId());
|
||||||
|
List<BizFolders> childFolders = bizFoldersService.findList(childFolder);
|
||||||
|
folderItems.add(new FolderItem(folder.getFolderId(), folder.getFolderName(), false, "folder", childFolders));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return folderItems;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 导入数据
|
|
||||||
*/
|
|
||||||
@ResponseBody
|
|
||||||
@PostMapping(value = "importData")
|
|
||||||
public String importData(MultipartFile file) {
|
|
||||||
try {
|
|
||||||
String message = bizFoldersService.importData(file);
|
|
||||||
return renderResult(Global.TRUE, "posfull:"+message);
|
|
||||||
} catch (Exception ex) {
|
|
||||||
return renderResult(Global.FALSE, "posfull:"+ex.getMessage());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 删除数据
|
|
||||||
*/
|
|
||||||
@RequestMapping(value = "delete")
|
|
||||||
@ResponseBody
|
|
||||||
public String delete(BizFolders bizFolders) {
|
|
||||||
bizFoldersService.delete(bizFolders);
|
|
||||||
return renderResult(Global.TRUE, text("删除文件夹信息成功!"));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -1,6 +1,8 @@
|
|||||||
package com.jeesite.modules.biz.web;
|
package com.jeesite.modules.biz.web;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import com.jeesite.modules.file.utils.FileUploadUtils;
|
||||||
import jakarta.servlet.http.HttpServletRequest;
|
import jakarta.servlet.http.HttpServletRequest;
|
||||||
import jakarta.servlet.http.HttpServletResponse;
|
import jakarta.servlet.http.HttpServletResponse;
|
||||||
|
|
||||||
@@ -26,6 +28,7 @@ import com.jeesite.modules.biz.service.BizMyfilesService;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* 文件信息Controller
|
* 文件信息Controller
|
||||||
|
*
|
||||||
* @author gaoxq
|
* @author gaoxq
|
||||||
* @version 2025-12-18
|
* @version 2025-12-18
|
||||||
*/
|
*/
|
||||||
@@ -33,106 +36,113 @@ import com.jeesite.modules.biz.service.BizMyfilesService;
|
|||||||
@RequestMapping(value = "${adminPath}/biz/myfiles")
|
@RequestMapping(value = "${adminPath}/biz/myfiles")
|
||||||
public class BizMyfilesController extends BaseController {
|
public class BizMyfilesController extends BaseController {
|
||||||
|
|
||||||
private final BizMyfilesService bizMyfilesService;
|
private final BizMyfilesService bizMyfilesService;
|
||||||
|
|
||||||
public BizMyfilesController(BizMyfilesService bizMyfilesService) {
|
public BizMyfilesController(BizMyfilesService bizMyfilesService) {
|
||||||
this.bizMyfilesService = bizMyfilesService;
|
this.bizMyfilesService = bizMyfilesService;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 获取数据
|
|
||||||
*/
|
|
||||||
@ModelAttribute
|
|
||||||
public BizMyfiles get(Long tid, boolean isNewRecord) {
|
|
||||||
return bizMyfilesService.get(tid, isNewRecord);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 查询列表
|
|
||||||
*/
|
|
||||||
@RequestMapping(value = {"list", ""})
|
|
||||||
public String list(BizMyfiles bizMyfiles, Model model) {
|
|
||||||
model.addAttribute("bizMyfiles", bizMyfiles);
|
|
||||||
return "modules/biz/bizMyfilesList";
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 查询列表数据
|
|
||||||
*/
|
|
||||||
@RequestMapping(value = "listData")
|
|
||||||
@ResponseBody
|
|
||||||
public Page<BizMyfiles> listData(BizMyfiles bizMyfiles, HttpServletRequest request, HttpServletResponse response) {
|
|
||||||
bizMyfiles.setPage(new Page<>(request, response));
|
|
||||||
Page<BizMyfiles> page = bizMyfilesService.findPage(bizMyfiles);
|
|
||||||
return page;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 查看编辑表单
|
* 获取数据
|
||||||
*/
|
*/
|
||||||
@RequestMapping(value = "form")
|
@ModelAttribute
|
||||||
public String form(BizMyfiles bizMyfiles, Model model) {
|
public BizMyfiles get(Long tid, boolean isNewRecord) {
|
||||||
model.addAttribute("bizMyfiles", bizMyfiles);
|
return bizMyfilesService.get(tid, isNewRecord);
|
||||||
return "modules/biz/bizMyfilesForm";
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 保存数据
|
* 查询列表
|
||||||
*/
|
*/
|
||||||
@PostMapping(value = "save")
|
@RequestMapping(value = {"list", ""})
|
||||||
@ResponseBody
|
public String list(BizMyfiles bizMyfiles, Model model) {
|
||||||
public String save(@Validated BizMyfiles bizMyfiles) {
|
model.addAttribute("bizMyfiles", bizMyfiles);
|
||||||
bizMyfilesService.save(bizMyfiles);
|
return "modules/biz/bizMyfilesList";
|
||||||
return renderResult(Global.TRUE, text("保存文件信息成功!"));
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 导出数据
|
* 查询列表数据
|
||||||
*/
|
*/
|
||||||
@RequestMapping(value = "exportData")
|
@RequestMapping(value = "listData")
|
||||||
public void exportData(BizMyfiles bizMyfiles, HttpServletResponse response) {
|
@ResponseBody
|
||||||
List<BizMyfiles> list = bizMyfilesService.findList(bizMyfiles);
|
public Page<BizMyfiles> listData(BizMyfiles bizMyfiles, HttpServletRequest request, HttpServletResponse response) {
|
||||||
String fileName = "文件信息" + DateUtils.getDate("yyyyMMddHHmmss") + ".xlsx";
|
bizMyfiles.setPage(new Page<>(request, response));
|
||||||
try(ExcelExport ee = new ExcelExport("文件信息", BizMyfiles.class)){
|
Page<BizMyfiles> page = bizMyfilesService.findPage(bizMyfiles);
|
||||||
ee.setDataList(list).write(response, fileName);
|
return page;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 下载模板
|
* 查看编辑表单
|
||||||
*/
|
*/
|
||||||
@RequestMapping(value = "importTemplate")
|
@RequestMapping(value = "form")
|
||||||
public void importTemplate(HttpServletResponse response) {
|
public String form(BizMyfiles bizMyfiles, Model model) {
|
||||||
BizMyfiles bizMyfiles = new BizMyfiles();
|
model.addAttribute("bizMyfiles", bizMyfiles);
|
||||||
List<BizMyfiles> list = ListUtils.newArrayList(bizMyfiles);
|
return "modules/biz/bizMyfilesForm";
|
||||||
String fileName = "文件信息模板.xlsx";
|
}
|
||||||
try(ExcelExport ee = new ExcelExport("文件信息", BizMyfiles.class, Type.IMPORT)){
|
|
||||||
ee.setDataList(list).write(response, fileName);
|
/**
|
||||||
}
|
* 保存数据
|
||||||
}
|
*/
|
||||||
|
@PostMapping(value = "save")
|
||||||
|
@ResponseBody
|
||||||
|
public String save(@Validated BizMyfiles bizMyfiles) {
|
||||||
|
// bizMyfilesService.save(bizMyfiles);
|
||||||
|
FileUploadUtils.saveFileUpload(bizMyfiles, bizMyfiles.getId(), "bizMyfiles_file");
|
||||||
|
return renderResult(Global.TRUE, text("保存文件信息成功!"));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 导出数据
|
||||||
|
*/
|
||||||
|
@RequestMapping(value = "exportData")
|
||||||
|
public void exportData(BizMyfiles bizMyfiles, HttpServletResponse response) {
|
||||||
|
List<BizMyfiles> list = bizMyfilesService.findList(bizMyfiles);
|
||||||
|
String fileName = "文件信息" + DateUtils.getDate("yyyyMMddHHmmss") + ".xlsx";
|
||||||
|
try (ExcelExport ee = new ExcelExport("文件信息", BizMyfiles.class)) {
|
||||||
|
ee.setDataList(list).write(response, fileName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 下载模板
|
||||||
|
*/
|
||||||
|
@RequestMapping(value = "importTemplate")
|
||||||
|
public void importTemplate(HttpServletResponse response) {
|
||||||
|
BizMyfiles bizMyfiles = new BizMyfiles();
|
||||||
|
List<BizMyfiles> list = ListUtils.newArrayList(bizMyfiles);
|
||||||
|
String fileName = "文件信息模板.xlsx";
|
||||||
|
try (ExcelExport ee = new ExcelExport("文件信息", BizMyfiles.class, Type.IMPORT)) {
|
||||||
|
ee.setDataList(list).write(response, fileName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 导入数据
|
||||||
|
*/
|
||||||
|
@ResponseBody
|
||||||
|
@PostMapping(value = "importData")
|
||||||
|
public String importData(MultipartFile file) {
|
||||||
|
try {
|
||||||
|
String message = bizMyfilesService.importData(file);
|
||||||
|
return renderResult(Global.TRUE, "posfull:" + message);
|
||||||
|
} catch (Exception ex) {
|
||||||
|
return renderResult(Global.FALSE, "posfull:" + ex.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 删除数据
|
||||||
|
*/
|
||||||
|
@RequestMapping(value = "delete")
|
||||||
|
@ResponseBody
|
||||||
|
public String delete(BizMyfiles bizMyfiles) {
|
||||||
|
bizMyfilesService.delete(bizMyfiles);
|
||||||
|
return renderResult(Global.TRUE, text("删除文件信息成功!"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@RequestMapping(value = "listAll")
|
||||||
|
@ResponseBody
|
||||||
|
public List<BizMyfiles> listAll(BizMyfiles bizMyfiles) {
|
||||||
|
return bizMyfilesService.findList(bizMyfiles);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 导入数据
|
|
||||||
*/
|
|
||||||
@ResponseBody
|
|
||||||
@PostMapping(value = "importData")
|
|
||||||
public String importData(MultipartFile file) {
|
|
||||||
try {
|
|
||||||
String message = bizMyfilesService.importData(file);
|
|
||||||
return renderResult(Global.TRUE, "posfull:"+message);
|
|
||||||
} catch (Exception ex) {
|
|
||||||
return renderResult(Global.FALSE, "posfull:"+ex.getMessage());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 删除数据
|
|
||||||
*/
|
|
||||||
@RequestMapping(value = "delete")
|
|
||||||
@ResponseBody
|
|
||||||
public String delete(BizMyfiles bizMyfiles) {
|
|
||||||
bizMyfilesService.delete(bizMyfiles);
|
|
||||||
return renderResult(Global.TRUE, text("删除文件信息成功!"));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -57,7 +57,7 @@ jdbc:
|
|||||||
# Mysql 数据库配置
|
# Mysql 数据库配置
|
||||||
type: mysql
|
type: mysql
|
||||||
driver: com.mysql.cj.jdbc.Driver
|
driver: com.mysql.cj.jdbc.Driver
|
||||||
url: jdbc:mysql://crontab.club:33069/worker?useSSL=false&allowPublicKeyRetrieval=true&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=CONVERT_TO_NULL&serverTimezone=Asia/Shanghai&nullCatalogMeansCurrent=true
|
url: jdbc:mysql://192.168.31.189:33069/worker?useSSL=false&allowPublicKeyRetrieval=true&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=CONVERT_TO_NULL&serverTimezone=Asia/Shanghai&nullCatalogMeansCurrent=true
|
||||||
username: dream
|
username: dream
|
||||||
password: info_dream
|
password: info_dream
|
||||||
testSql: SELECT 1
|
testSql: SELECT 1
|
||||||
|
|||||||
@@ -24,8 +24,22 @@ export interface BizFolders extends BasicModel<BizFolders> {
|
|||||||
description?: string; // 文件夹描述
|
description?: string; // 文件夹描述
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export interface FolderItem {
|
||||||
|
id: string;
|
||||||
|
name: string;
|
||||||
|
expanded: boolean;
|
||||||
|
children: Array<{
|
||||||
|
folderId: string;
|
||||||
|
folderName: string;
|
||||||
|
type: 'folder' | 'file';
|
||||||
|
}>;
|
||||||
|
}
|
||||||
|
|
||||||
export const bizFoldersList = (params?: BizFolders | any) =>
|
export const bizFoldersList = (params?: BizFolders | any) =>
|
||||||
defHttp.get<BizFolders>({ url: adminPath + '/biz/folders/list', params });
|
defHttp.get<BizFolders>({ url: adminPath + '/biz/folders/list', params });
|
||||||
|
|
||||||
|
export const bizFolderItemAll = (params?: BizFolders | any) =>
|
||||||
|
defHttp.get<FolderItem[]>({ url: adminPath + '/biz/folders/foldersAll', params });
|
||||||
|
|
||||||
export const bizFoldersListData = (params?: BizFolders | any) =>
|
export const bizFoldersListData = (params?: BizFolders | any) =>
|
||||||
defHttp.post<Page<BizFolders>>({ url: adminPath + '/biz/folders/listData', params });
|
defHttp.post<Page<BizFolders>>({ url: adminPath + '/biz/folders/listData', params });
|
||||||
|
|||||||
@@ -33,6 +33,9 @@ export interface BizMyfiles extends BasicModel<BizMyfiles> {
|
|||||||
export const bizMyfilesList = (params?: BizMyfiles | any) =>
|
export const bizMyfilesList = (params?: BizMyfiles | any) =>
|
||||||
defHttp.get<BizMyfiles>({ url: adminPath + '/biz/myfiles/list', params });
|
defHttp.get<BizMyfiles>({ url: adminPath + '/biz/myfiles/list', params });
|
||||||
|
|
||||||
|
export const bizMyfilesListAll = (params?: BizMyfiles | any) =>
|
||||||
|
defHttp.get<BizMyfiles[]>({ url: adminPath + '/biz/myfiles/listAll', params });
|
||||||
|
|
||||||
export const bizMyfilesListData = (params?: BizMyfiles | any) =>
|
export const bizMyfilesListData = (params?: BizMyfiles | any) =>
|
||||||
defHttp.post<Page<BizMyfiles>>({ url: adminPath + '/biz/myfiles/listData', params });
|
defHttp.post<Page<BizMyfiles>>({ url: adminPath + '/biz/myfiles/listData', params });
|
||||||
|
|
||||||
|
|||||||
@@ -64,7 +64,7 @@
|
|||||||
maxlength: 64,
|
maxlength: 64,
|
||||||
},
|
},
|
||||||
required: true,
|
required: true,
|
||||||
dynamicDisabled: true,
|
dynamicDisabled: true,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: t('通知人员'),
|
label: t('通知人员'),
|
||||||
|
|||||||
@@ -3,36 +3,114 @@
|
|||||||
v-bind="$attrs"
|
v-bind="$attrs"
|
||||||
@register="register"
|
@register="register"
|
||||||
title="上传文件"
|
title="上传文件"
|
||||||
width="40%"
|
width="60%"
|
||||||
@cancel="handleCancel"
|
@cancel="handleCancel"
|
||||||
|
@ok="handleSubmit"
|
||||||
>
|
>
|
||||||
|
<BasicForm @register="registerForm" />
|
||||||
</BasicModal>
|
</BasicModal>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import { defineComponent, ref, onMounted, onUnmounted } from 'vue';
|
import { defineComponent, ref, computed, onMounted, onUnmounted } from 'vue';
|
||||||
|
import { useI18n } from '@jeesite/core/hooks/web/useI18n';
|
||||||
|
import { BasicForm, FormSchema, useForm } from '@jeesite/core/components/Form';
|
||||||
import { useMessage } from '@jeesite/core/hooks/web/useMessage';
|
import { useMessage } from '@jeesite/core/hooks/web/useMessage';
|
||||||
import { BasicModal, useModalInner } from '@jeesite/core/components/Modal';
|
import { BasicModal, useModalInner } from '@jeesite/core/components/Modal';
|
||||||
|
import { BizMyfiles, bizMyfilesSave, bizMyfilesForm } from '@jeesite/biz/api/biz/myfiles';
|
||||||
|
|
||||||
export default defineComponent({
|
export default defineComponent({
|
||||||
components: { BasicModal },
|
components: { BasicModal, BasicForm },
|
||||||
emits: ['modalClose'],
|
emits: ['modalClose'],
|
||||||
setup(props, { emit }) {
|
setup(props, { emit }) {
|
||||||
const { createMessage } = useMessage();
|
const { showMessage } = useMessage();
|
||||||
// 模态框注册
|
const { t } = useI18n('biz.myfiles');
|
||||||
const [register, { closeModal }] = useModalInner(async (data: any) => {
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
const handleCancel = () => {
|
const record = ref<BizMyfiles>({} as BizMyfiles);
|
||||||
emit('modalClose');
|
|
||||||
|
const inputFormSchemas: FormSchema<BizMyfiles>[] = [
|
||||||
|
{
|
||||||
|
label: t('文件夹标识'),
|
||||||
|
field: 'folderId',
|
||||||
|
component: 'Input',
|
||||||
|
componentProps: {
|
||||||
|
maxlength: 52,
|
||||||
|
},
|
||||||
|
required: true,
|
||||||
|
dynamicDisabled: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: t('文件夹名称'),
|
||||||
|
field: 'folderName',
|
||||||
|
component: 'Input',
|
||||||
|
componentProps: {
|
||||||
|
maxlength: 52,
|
||||||
|
},
|
||||||
|
required: true,
|
||||||
|
dynamicDisabled: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: t('附件上传'),
|
||||||
|
field: 'dataMap',
|
||||||
|
component: 'Upload',
|
||||||
|
componentProps: {
|
||||||
|
loadTime: computed(() => record.value.__t),
|
||||||
|
bizKey: computed(() => record.value.id),
|
||||||
|
bizType: 'bizMyfiles_file',
|
||||||
|
uploadType: 'all',
|
||||||
|
},
|
||||||
|
colProps: { md: 24, lg: 24 },
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
|
// 表单注册核心逻辑
|
||||||
|
const [registerForm, { resetFields, setFieldsValue, validate }] = useForm<BizMyfiles>({
|
||||||
|
labelWidth: 120,
|
||||||
|
schemas: inputFormSchemas,
|
||||||
|
baseColProps: { md: 24, lg: 12 },
|
||||||
|
});
|
||||||
|
|
||||||
|
const { createMessage } = useMessage();
|
||||||
|
|
||||||
|
const [register, { closeModal }] = useModalInner(async (data: any) => {
|
||||||
|
const dddd = {
|
||||||
|
... data
|
||||||
|
}
|
||||||
|
console.log(dddd)
|
||||||
|
resetFields();
|
||||||
|
if (data) {
|
||||||
|
setFieldsValue({ ...data });
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
async function handleSubmit() {
|
||||||
|
try {
|
||||||
|
const data = await validate();
|
||||||
|
const params: any = {
|
||||||
|
isNewRecord: true,
|
||||||
|
};
|
||||||
|
const res = await bizMyfilesSave(params, data);
|
||||||
|
showMessage(res.message);
|
||||||
|
handleCancel(data);
|
||||||
|
} catch (error: any) {
|
||||||
|
console.error('上传文件保存失败:', error);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 取消按钮逻辑
|
||||||
|
const handleCancel = (data: any) => {
|
||||||
|
resetFields(); // 取消时重置表单
|
||||||
|
emit('modalClose',data);
|
||||||
|
closeModal(); // 关闭模态框
|
||||||
};
|
};
|
||||||
|
|
||||||
return {
|
return {
|
||||||
register,
|
register,
|
||||||
closeModal,
|
closeModal,
|
||||||
handleCancel,
|
handleCancel,
|
||||||
|
registerForm,
|
||||||
|
inputFormSchemas,
|
||||||
|
handleSubmit
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -6,15 +6,15 @@
|
|||||||
v-model:value="folderSearchText"
|
v-model:value="folderSearchText"
|
||||||
placeholder="文件夹搜索框"
|
placeholder="文件夹搜索框"
|
||||||
class="folder-search-input"
|
class="folder-search-input"
|
||||||
|
allow-clear
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<div class="tree-scroll-container">
|
<div class="tree-scroll-container">
|
||||||
<div class="tree-container">
|
<div class="tree-container">
|
||||||
<!-- 顶级文件夹节点 -->
|
|
||||||
<div
|
<div
|
||||||
class="tree-node folder-node"
|
class="tree-node folder-node"
|
||||||
v-for="(folder, index) in folderList"
|
v-for="(folder, index) in filteredFolderList"
|
||||||
:key="index"
|
:key="folder.id || index"
|
||||||
@click="toggleFolder(folder)"
|
@click="toggleFolder(folder)"
|
||||||
@dblclick="doubleClickFolder(folder)"
|
@dblclick="doubleClickFolder(folder)"
|
||||||
:class="{ active: folder.expanded }"
|
:class="{ active: folder.expanded }"
|
||||||
@@ -36,41 +36,44 @@
|
|||||||
style="margin-right: 4px;"
|
style="margin-right: 4px;"
|
||||||
/>
|
/>
|
||||||
</span>
|
</span>
|
||||||
<!-- 子节点容器:移除多余的 tree-toggle 元素 -->
|
<!-- 子节点容器:自动展开匹配子项的父级 -->
|
||||||
<div class="tree-children" v-if="folder.expanded">
|
<div class="tree-children" v-if="folder.expanded">
|
||||||
<div
|
<div
|
||||||
class="tree-node file-node"
|
class="tree-node file-node"
|
||||||
v-for="(child, idx) in folder.children"
|
v-for="(child, idx) in filterChildren(folder.children, folderSearchText)"
|
||||||
:key="idx"
|
:key="child.id || idx"
|
||||||
@click.stop="handleChildClick(child)"
|
@click.stop="handleChildClick(child)"
|
||||||
>
|
>
|
||||||
<span class="file-icon">
|
<span class="file-icon">
|
||||||
<Icon
|
<Icon
|
||||||
:icon="child.type === 'folder'
|
icon="simple-line-icons:folder"
|
||||||
? 'simple-line-icons:folder'
|
|
||||||
: 'ant-design:file-outlined'"
|
|
||||||
class="icon-size"
|
class="icon-size"
|
||||||
/>
|
/>
|
||||||
</span>
|
</span>
|
||||||
<span class="file-name">{{ child.name }}</span>
|
<span class="file-name">{{ child.folderName }}</span>
|
||||||
<!-- 移除:<span class="tree-toggle empty"></span> -->
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<!-- 无匹配结果提示 -->
|
||||||
|
<div v-if="folderSearchText && filteredFolderList.length === 0" class="no-result">
|
||||||
|
<span>未找到匹配的文件夹</span>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="main-content">
|
<div class="main-content">
|
||||||
<div class="header-bar">
|
<div class="header-bar">
|
||||||
<a-input
|
<a-input-search
|
||||||
v-model:value="fileSearchText"
|
v-model:value="fileSearchText"
|
||||||
placeholder="文件搜索框"
|
placeholder="文件搜索框"
|
||||||
class="file-search-input"
|
class="file-search-input"
|
||||||
|
enter-button
|
||||||
|
@search="onSearch"
|
||||||
/>
|
/>
|
||||||
<div class="header-btn-group">
|
<div class="header-btn-group">
|
||||||
<a-button type="default" class="header-btn" @click="openfolderModal(true, item)"><Icon icon="ant-design:folder-add-outlined" />新建文件夹</a-button>
|
<a-button type="default" class="header-btn" @click="openfolderModal(true, ParamsFolders)"><Icon icon="ant-design:folder-add-outlined" />新建文件夹</a-button>
|
||||||
<a-button type="primary" class="header-btn" @click="openUploadModal(true, item)"><Icon icon="ant-design:cloud-upload-outlined" />上传文件</a-button>
|
<a-button type="primary" class="header-btn" @click="openUploadModal(true, ParamsFolders)" :disabled="UploadFile"><Icon icon="ant-design:cloud-upload-outlined" />上传文件</a-button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@@ -86,9 +89,9 @@
|
|||||||
<div class="file-card-header">
|
<div class="file-card-header">
|
||||||
<div class="file-name-wrap">
|
<div class="file-name-wrap">
|
||||||
<span class="file-card-icon">📄</span>
|
<span class="file-card-icon">📄</span>
|
||||||
<span class="file-card-name" :title="file.name">{{ file.name }}</span>
|
<span class="file-card-name" :title="file.fileName">{{ file.fileName }}</span>
|
||||||
</div>
|
</div>
|
||||||
<span class="file-card-size">{{ file.size }}</span>
|
<span class="file-card-size">{{ file.fileSize }}</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="card-divider"></div>
|
<div class="card-divider"></div>
|
||||||
<div class="file-card-actions">
|
<div class="file-card-actions">
|
||||||
@@ -107,7 +110,7 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { ref } from 'vue';
|
import { ref, onMounted, computed, watch } from 'vue';
|
||||||
import { message } from 'ant-design-vue';
|
import { message } from 'ant-design-vue';
|
||||||
import { Input, Card } from 'ant-design-vue';
|
import { Input, Card } from 'ant-design-vue';
|
||||||
import { Icon } from '@jeesite/core/components/Icon';
|
import { Icon } from '@jeesite/core/components/Icon';
|
||||||
@@ -115,118 +118,179 @@ import { useModal } from '@jeesite/core/components/Modal';
|
|||||||
import UploadModal from './components/upload.vue';
|
import UploadModal from './components/upload.vue';
|
||||||
import FolderModal from './components/folder.vue';
|
import FolderModal from './components/folder.vue';
|
||||||
|
|
||||||
const item = ref();
|
import { FolderItem, bizFolderItemAll } from '@jeesite/biz/api/biz/folders';
|
||||||
|
import { BizMyfiles, bizMyfilesListAll } from '@jeesite/biz/api/biz/myfiles';
|
||||||
|
|
||||||
const [uploadregister, { openModal: openUploadModal }] = useModal();
|
const [uploadregister, { openModal: openUploadModal }] = useModal();
|
||||||
const [folderregister, { openModal: openfolderModal }] = useModal();
|
const [folderregister, { openModal: openfolderModal }] = useModal();
|
||||||
|
|
||||||
// 定义类型接口
|
interface ChildFolder {
|
||||||
interface FolderItem {
|
id?: number | string;
|
||||||
name: string;
|
folderName: string;
|
||||||
expanded: boolean;
|
type: 'folder' | 'file';
|
||||||
children: Array<{
|
children?: ChildFolder[]; // 支持多级子文件夹
|
||||||
name: string;
|
|
||||||
type: 'folder' | 'file';
|
|
||||||
}>;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface FileItem {
|
|
||||||
name: string;
|
|
||||||
size: string;
|
|
||||||
time: string;
|
|
||||||
path: string;
|
|
||||||
creator: string;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let UploadFile = true;
|
||||||
|
const ParamsFolders = ref();
|
||||||
const folderSearchText = ref<string>('');
|
const folderSearchText = ref<string>('');
|
||||||
const fileSearchText = ref<string>('');
|
const fileSearchText = ref<string>('');
|
||||||
|
const folderList = ref<FolderItem[]>([]);
|
||||||
|
const fileList = ref<BizMyfiles[]>([]);
|
||||||
|
|
||||||
const folderList = ref<FolderItem[]>([
|
const bindParentReferences = (folders: FolderItem[], _parent: FolderItem | null = null) => {
|
||||||
{
|
folders.forEach(folder => {
|
||||||
name: '项目文档',
|
if (folder.children && folder.children.length) {
|
||||||
expanded: false,
|
bindParentReferences(folder.children as unknown as FolderItem[], folder);
|
||||||
children: [
|
}
|
||||||
{ name: '需求文档', type: 'folder' },
|
|
||||||
{ name: '设计稿', type: 'folder' },
|
|
||||||
{ name: '开发规范.docx', type: 'file' },
|
|
||||||
{ name: '接口文档.pdf', type: 'file' }
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: '日常办公',
|
|
||||||
expanded: false,
|
|
||||||
children: [
|
|
||||||
{ name: '周报汇总', type: 'folder' },
|
|
||||||
{ name: '会议纪要.docx', type: 'file' },
|
|
||||||
{ name: '考勤表.xlsx', type: 'file' }
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: '第三季度',
|
|
||||||
expanded: false,
|
|
||||||
children: [
|
|
||||||
{ name: '业绩分析.pptx', type: 'file' },
|
|
||||||
{ name: '预算规划.xlsx', type: 'file' },
|
|
||||||
{ name: '工作总结.docx', type: 'file' }
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: '临时文件',
|
|
||||||
expanded: false,
|
|
||||||
children: [
|
|
||||||
{ name: '草稿.txt', type: 'file' },
|
|
||||||
{ name: '截图.png', type: 'file' }
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]);
|
|
||||||
|
|
||||||
const fileList = ref<FileItem[]>([]);
|
|
||||||
const paths = ['项目文档/需求文档', '日常办公/周报汇总', '第三季度', '临时文件', '项目文档/设计稿'];
|
|
||||||
const creators = ['张三', '李四', '王五', '赵六', '钱七'];
|
|
||||||
|
|
||||||
// 初始化文件列表数据
|
|
||||||
for (let i = 0; i < 50; i++) {
|
|
||||||
const randomPath = paths[Math.floor(Math.random() * paths.length)];
|
|
||||||
const randomCreator = creators[Math.floor(Math.random() * creators.length)];
|
|
||||||
|
|
||||||
fileList.value.push({
|
|
||||||
name: `第三季度开始就大家思考爱睡觉的${i + 1}.docx`,
|
|
||||||
size: `${Math.floor(Math.random() * 100) + 50}kb`,
|
|
||||||
time: '2025-12-17 20:53',
|
|
||||||
path: randomPath,
|
|
||||||
creator: randomCreator
|
|
||||||
});
|
});
|
||||||
}
|
};
|
||||||
|
|
||||||
// 顶级文件夹切换逻辑:仅处理顶级文件夹的展开/关闭
|
// 递归展开所有父级文件夹
|
||||||
const toggleFolder = (targetFolder: FolderItem) => {
|
const expandAllParents = (node: FolderItem | ChildFolder) => {
|
||||||
if (targetFolder.expanded) {
|
let currentNode: any = node;
|
||||||
// 关闭当前顶级文件夹
|
while (currentNode.parent) {
|
||||||
targetFolder.expanded = false;
|
currentNode.parent.expanded = true;
|
||||||
} else {
|
currentNode = currentNode.parent;
|
||||||
// 先关闭所有顶级文件夹,再展开当前
|
}
|
||||||
folderList.value.forEach(folder => {
|
};
|
||||||
|
|
||||||
|
// 搜索匹配并展开父级
|
||||||
|
const searchAndExpandParents = (keyword: string) => {
|
||||||
|
if (!keyword.trim()) return;
|
||||||
|
|
||||||
|
const traverseFolders = (folders: FolderItem[]) => {
|
||||||
|
folders.forEach(folder => {
|
||||||
|
// 检查当前文件夹是否匹配
|
||||||
|
const currentMatch = folder.name.toLowerCase().includes(keyword.toLowerCase());
|
||||||
|
if (currentMatch) expandAllParents(folder);
|
||||||
|
// 递归检查子文件夹
|
||||||
|
if (folder.children && folder.children.length) {
|
||||||
|
folder.children.forEach(child => {
|
||||||
|
const childMatch = child.folderName.toLowerCase().includes(keyword.toLowerCase());
|
||||||
|
if (childMatch) {
|
||||||
|
folder.expanded = true; // 展开当前父级
|
||||||
|
expandAllParents(folder); // 展开所有祖先
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
traverseFolders(folderList.value);
|
||||||
|
};
|
||||||
|
|
||||||
|
const filteredFolderList = computed(() => {
|
||||||
|
const keyword = folderSearchText.value.toLowerCase().trim();
|
||||||
|
if (!keyword) return folderList.value;
|
||||||
|
const filterFolders = (folders: FolderItem[]): FolderItem[] => {
|
||||||
|
return folders.filter(folder => {
|
||||||
|
const currentMatch = folder.name.toLowerCase().includes(keyword);
|
||||||
|
let childrenMatch = false;
|
||||||
|
if (folder.children && folder.children.length) {
|
||||||
|
childrenMatch = folder.children.some(child =>
|
||||||
|
child.folderName.toLowerCase().includes(keyword)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
return currentMatch || childrenMatch;
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
return filterFolders(folderList.value);
|
||||||
|
});
|
||||||
|
|
||||||
|
// 过滤子文件夹
|
||||||
|
const filterChildren = (children: ChildFolder[] = [], keyword: string) => {
|
||||||
|
if (!keyword.trim()) return children;
|
||||||
|
return children.filter(child =>
|
||||||
|
child.folderName.toLowerCase().includes(keyword.toLowerCase().trim())
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
// 监听搜索框变化,触发搜索和展开
|
||||||
|
watch(folderSearchText, (newVal) => {
|
||||||
|
// 清空搜索时重置展开状态
|
||||||
|
if (!newVal.trim()) {
|
||||||
|
folderList.value.forEach(folder => folder.expanded = false);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
searchAndExpandParents(newVal);
|
||||||
|
});
|
||||||
|
|
||||||
|
const getDataList = async () => {
|
||||||
|
try {
|
||||||
|
const result = await bizFolderItemAll();
|
||||||
|
const folders = (result || []) as FolderItem[];
|
||||||
|
folders.forEach(folder => {
|
||||||
folder.expanded = false;
|
folder.expanded = false;
|
||||||
});
|
});
|
||||||
|
bindParentReferences(folders); // 绑定父级引用
|
||||||
|
folderList.value = folders;
|
||||||
|
getFileList({});
|
||||||
|
} catch (error) {
|
||||||
|
console.error('获取文件夹信息失败:', error);
|
||||||
|
folderList.value = [];
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const getFileList = async (params: {}) => {
|
||||||
|
try {
|
||||||
|
const result = await bizMyfilesListAll(params);
|
||||||
|
fileList.value = result || [];
|
||||||
|
} catch (error) {
|
||||||
|
console.error('获取文件信息失败:', error);
|
||||||
|
fileList.value = [];
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
const onSearch = (searchValue: string) => {
|
||||||
|
const params = {
|
||||||
|
fileName: searchValue,
|
||||||
|
}
|
||||||
|
getFileList(params);
|
||||||
|
};
|
||||||
|
|
||||||
|
const toggleFolder = async (targetFolder: FolderItem) => {
|
||||||
|
if (targetFolder.expanded) {
|
||||||
|
targetFolder.expanded = false;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
if ('loading' in targetFolder) targetFolder.loading = true;
|
||||||
|
folderList.value.forEach(folder => {
|
||||||
|
if (folder !== targetFolder) folder.expanded = false;
|
||||||
|
});
|
||||||
targetFolder.expanded = true;
|
targetFolder.expanded = true;
|
||||||
|
} catch (error) {
|
||||||
|
console.error('加载文件夹数据失败:', error);
|
||||||
|
targetFolder.expanded = false;
|
||||||
|
} finally {
|
||||||
|
if ('loading' in targetFolder) targetFolder.loading = false;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// 子节点点击处理函数
|
const handleChildClick = (child: ChildFolder) => {
|
||||||
const handleChildClick = (child: { name: string; type: 'folder' | 'file' }) => {
|
UploadFile = false;
|
||||||
// 可以根据子节点类型添加自定义逻辑
|
ParamsFolders.value = child;
|
||||||
if (child.type === 'folder') {
|
const params = {
|
||||||
message.info(`点击了子文件夹:${child.name}`);
|
folderId: child.id,
|
||||||
// 如需展开子文件夹,可在这里扩展逻辑
|
|
||||||
} else {
|
|
||||||
message.info(`点击了文件:${child.name}`);
|
|
||||||
// 比如打开文件预览、加载文件详情等
|
|
||||||
}
|
}
|
||||||
|
getFileList(params);
|
||||||
};
|
};
|
||||||
|
|
||||||
// 双击顶级文件夹逻辑
|
|
||||||
const doubleClickFolder = (targetFolder: FolderItem) => {
|
const doubleClickFolder = (targetFolder: FolderItem) => {
|
||||||
message.info(`正在打开「${targetFolder.name}」文件夹`);
|
message.info(`正在打开「${targetFolder.name}」文件夹`);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// 监听搜索文本变化,触发展开
|
||||||
|
watch(folderSearchText, () => {
|
||||||
|
if (folderSearchText.value.trim()) searchAndExpandParents(folderSearchText.value);
|
||||||
|
});
|
||||||
|
|
||||||
|
onMounted(() => {
|
||||||
|
getDataList();
|
||||||
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style scoped>
|
<style scoped>
|
||||||
@@ -265,6 +329,14 @@ const doubleClickFolder = (targetFolder: FolderItem) => {
|
|||||||
border-radius: 4px;
|
border-radius: 4px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* 无匹配结果样式 */
|
||||||
|
.no-result {
|
||||||
|
padding: 16px;
|
||||||
|
text-align: center;
|
||||||
|
color: #668799;
|
||||||
|
font-size: 13px;
|
||||||
|
}
|
||||||
|
|
||||||
/* 优化 tree-scroll-container 样式 */
|
/* 优化 tree-scroll-container 样式 */
|
||||||
.tree-scroll-container {
|
.tree-scroll-container {
|
||||||
flex: 1;
|
flex: 1;
|
||||||
@@ -289,7 +361,6 @@ const doubleClickFolder = (targetFolder: FolderItem) => {
|
|||||||
border: 2px solid #f0f8ff;
|
border: 2px solid #f0f8ff;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 优化滚动容器的交互体验 */
|
|
||||||
.tree-scroll-container:hover::-webkit-scrollbar-thumb {
|
.tree-scroll-container:hover::-webkit-scrollbar-thumb {
|
||||||
background-color: #91c8ee;
|
background-color: #91c8ee;
|
||||||
}
|
}
|
||||||
@@ -312,13 +383,11 @@ const doubleClickFolder = (targetFolder: FolderItem) => {
|
|||||||
transition: background-color 0.2s ease;
|
transition: background-color 0.2s ease;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 优化文件夹节点激活状态 */
|
|
||||||
.folder-node.active,
|
.folder-node.active,
|
||||||
.folder-node:hover {
|
.folder-node:hover {
|
||||||
background: #e8f4f8;
|
background: #e8f4f8;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 展开状态的文件夹额外样式 */
|
|
||||||
.folder-node.active {
|
.folder-node.active {
|
||||||
background-color: #f5fafe;
|
background-color: #f5fafe;
|
||||||
border-left: 3px solid #1890ff;
|
border-left: 3px solid #1890ff;
|
||||||
@@ -328,8 +397,8 @@ const doubleClickFolder = (targetFolder: FolderItem) => {
|
|||||||
.folder-info {
|
.folder-info {
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
flex: 1;
|
flex: 1;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
.folder-node:last-child {
|
.folder-node:last-child {
|
||||||
@@ -345,7 +414,6 @@ const doubleClickFolder = (targetFolder: FolderItem) => {
|
|||||||
margin: 2px 0;
|
margin: 2px 0;
|
||||||
border-bottom: 1px dashed #e8f4f8;
|
border-bottom: 1px dashed #e8f4f8;
|
||||||
transition: background-color 0.2s ease;
|
transition: background-color 0.2s ease;
|
||||||
/* 移除 justify-content: space-between,避免内容分散 */
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.file-node:last-child {
|
.file-node:last-child {
|
||||||
@@ -369,13 +437,6 @@ const doubleClickFolder = (targetFolder: FolderItem) => {
|
|||||||
transition: transform 0.2s ease;
|
transition: transform 0.2s ease;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 优化箭头图标旋转效果 */
|
|
||||||
.tree-toggle .icon {
|
|
||||||
transition: transform 0.2s ease;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* 移除无用的 empty 类样式 */
|
|
||||||
|
|
||||||
.folder-icon, .file-icon {
|
.folder-icon, .file-icon {
|
||||||
margin: 0 6px;
|
margin: 0 6px;
|
||||||
font-size: 14px;
|
font-size: 14px;
|
||||||
@@ -384,7 +445,6 @@ const doubleClickFolder = (targetFolder: FolderItem) => {
|
|||||||
transition: color 0.2s ease;
|
transition: color 0.2s ease;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 展开文件夹图标颜色加深 */
|
|
||||||
.folder-node.active .folder-icon,
|
.folder-node.active .folder-icon,
|
||||||
.folder-node:hover .folder-icon {
|
.folder-node:hover .folder-icon {
|
||||||
color: #096dd9;
|
color: #096dd9;
|
||||||
@@ -400,7 +460,6 @@ const doubleClickFolder = (targetFolder: FolderItem) => {
|
|||||||
white-space: nowrap;
|
white-space: nowrap;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
text-overflow: ellipsis;
|
text-overflow: ellipsis;
|
||||||
/* 子文件名占满剩余空间 */
|
|
||||||
flex: 1;
|
flex: 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -412,7 +471,6 @@ const doubleClickFolder = (targetFolder: FolderItem) => {
|
|||||||
animation: fadeIn 0.2s ease;
|
animation: fadeIn 0.2s ease;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 子项展开动画 */
|
|
||||||
@keyframes fadeIn {
|
@keyframes fadeIn {
|
||||||
from {
|
from {
|
||||||
opacity: 0;
|
opacity: 0;
|
||||||
@@ -447,7 +505,6 @@ const doubleClickFolder = (targetFolder: FolderItem) => {
|
|||||||
.file-search-input {
|
.file-search-input {
|
||||||
flex: 1;
|
flex: 1;
|
||||||
min-width: 0;
|
min-width: 0;
|
||||||
border: 1px solid #b3d9f2;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.header-btn-group {
|
.header-btn-group {
|
||||||
@@ -493,25 +550,23 @@ const doubleClickFolder = (targetFolder: FolderItem) => {
|
|||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 核心修复:文件卡片样式 */
|
|
||||||
.file-card {
|
.file-card {
|
||||||
background: #e8f4f8;
|
background: #e8f4f8;
|
||||||
border: 1px solid #b3d9f2;
|
border: 1px solid #b3d9f2;
|
||||||
border-radius: 8px;
|
border-radius: 8px;
|
||||||
transition: all 0.2s ease;
|
transition: all 0.2s ease;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
height: 100px; /* 卡片总高度 */
|
height: 100px;
|
||||||
padding: 0; /* 重置卡片默认padding */
|
padding: 0;
|
||||||
overflow: hidden; /* 防止内容溢出 */
|
overflow: hidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 卡片内部容器 - 控制所有内容的间距和布局 */
|
|
||||||
.card-inner-content {
|
.card-inner-content {
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
height: 100%;
|
height: 100%;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
padding: 0 4px; /* 左右内边距,上下通过内部元素控制 */
|
padding: 0 4px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.file-card:hover {
|
.file-card:hover {
|
||||||
@@ -519,13 +574,12 @@ const doubleClickFolder = (targetFolder: FolderItem) => {
|
|||||||
transform: translateY(-2px);
|
transform: translateY(-2px);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 文件名区域 - 精准距顶部2px */
|
|
||||||
.file-card-header {
|
.file-card-header {
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
justify-content: space-between;
|
justify-content: space-between;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
padding-top: 2px; /* 顶部2px间距 */
|
padding-top: 2px;
|
||||||
padding-bottom: 4px;
|
padding-bottom: 4px;
|
||||||
flex-shrink: 0;
|
flex-shrink: 0;
|
||||||
}
|
}
|
||||||
@@ -563,23 +617,21 @@ const doubleClickFolder = (targetFolder: FolderItem) => {
|
|||||||
white-space: nowrap;
|
white-space: nowrap;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 分割线样式 */
|
|
||||||
.card-divider {
|
.card-divider {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
height: 1px;
|
height: 1px;
|
||||||
background-color: #b3d9f2;
|
background-color: #b3d9f2;
|
||||||
opacity: 0.5;
|
opacity: 0.5;
|
||||||
margin: 0 0 4px 0; /* 仅底部留间距 */
|
margin: 0 0 4px 0;
|
||||||
flex-shrink: 0;
|
flex-shrink: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 按钮区域 - 在分割线下,距底部2px,完全在卡片内 */
|
|
||||||
.file-card-actions {
|
.file-card-actions {
|
||||||
display: flex;
|
display: flex;
|
||||||
gap: 4px;
|
gap: 4px;
|
||||||
margin-top: auto; /* 自动填充剩余空间,靠底 */
|
margin-top: auto;
|
||||||
margin-bottom: 2px; /* 距底部2px */
|
margin-bottom: 2px;
|
||||||
justify-content: flex-end; /* 靠右对齐 */
|
justify-content: flex-end;
|
||||||
flex-shrink: 0;
|
flex-shrink: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -591,7 +643,7 @@ const doubleClickFolder = (targetFolder: FolderItem) => {
|
|||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
gap: 4px;
|
gap: 4px;
|
||||||
line-height: 1; /* 重置按钮行高,避免超出 */
|
line-height: 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
:deep(.file-card-actions .ant-btn-dangerous) {
|
:deep(.file-card-actions .ant-btn-dangerous) {
|
||||||
@@ -606,7 +658,6 @@ const doubleClickFolder = (targetFolder: FolderItem) => {
|
|||||||
max-width: 200px;
|
max-width: 200px;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 响应式调整 */
|
|
||||||
@media (max-width: 1400px) {
|
@media (max-width: 1400px) {
|
||||||
.file-list {
|
.file-list {
|
||||||
grid-template-columns: repeat(3, 1fr);
|
grid-template-columns: repeat(3, 1fr);
|
||||||
@@ -636,4 +687,4 @@ const doubleClickFolder = (targetFolder: FolderItem) => {
|
|||||||
* {
|
* {
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
Reference in New Issue
Block a user