diff --git a/.gitignore b/.gitignore
index b7838ca0..6bb49789 100644
--- a/.gitignore
+++ b/.gitignore
@@ -13,3 +13,5 @@ os_del.cmd
os_del_doc.cmd
.svn
derby.log
+
+.DS_Store
diff --git a/jeecg-boot/.gitignore b/jeecg-boot/.gitignore
index b7838ca0..f287e860 100644
--- a/jeecg-boot/.gitignore
+++ b/jeecg-boot/.gitignore
@@ -13,3 +13,5 @@ os_del.cmd
os_del_doc.cmd
.svn
derby.log
+
+.DS_Store
\ No newline at end of file
diff --git a/jeecg-boot/jeecg-boot-module/jeecg-module-learn/pom.xml b/jeecg-boot/jeecg-boot-module/jeecg-module-learn/pom.xml
new file mode 100644
index 00000000..2bc55493
--- /dev/null
+++ b/jeecg-boot/jeecg-boot-module/jeecg-module-learn/pom.xml
@@ -0,0 +1,21 @@
+
+
+ 4.0.0
+
+ org.jeecgframework.boot
+ jeecg-boot-module
+ 3.8.2
+
+
+ jeecg-module-learn
+
+
+
+ org.jeecgframework.boot
+ jeecg-boot-base-core
+
+
+
+
\ No newline at end of file
diff --git a/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/business/controller/CourseBusinessController.java b/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/business/controller/CourseBusinessController.java
new file mode 100644
index 00000000..564f9882
--- /dev/null
+++ b/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/business/controller/CourseBusinessController.java
@@ -0,0 +1,28 @@
+package org.jeecg.modules.learn.business.controller;
+
+import io.swagger.v3.oas.annotations.Operation;
+import io.swagger.v3.oas.annotations.tags.Tag;
+import lombok.extern.slf4j.Slf4j;
+import org.jeecg.common.api.vo.Result;
+import org.jeecg.common.system.base.controller.JeecgController;
+import org.jeecg.config.shiro.IgnoreAuth;
+import org.jeecg.modules.learn.gen.entity.Course;
+import org.jeecg.modules.learn.gen.service.ICourseService;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RestController;
+
+@Tag(name="课程")
+@RestController
+@RequestMapping("/business/course")
+@Slf4j
+public class CourseBusinessController extends JeecgController {
+
+ @GetMapping("/test")
+ @Operation(summary="测试")
+ @IgnoreAuth
+ public Result test() {
+ return Result.OK("test");
+ }
+
+}
diff --git a/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/gen/controller/CourseController.java b/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/gen/controller/CourseController.java
new file mode 100644
index 00000000..b2e42ca8
--- /dev/null
+++ b/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/gen/controller/CourseController.java
@@ -0,0 +1,187 @@
+package org.jeecg.modules.learn.gen.controller;
+
+import java.util.Arrays;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.stream.Collectors;
+import java.io.IOException;
+import java.io.UnsupportedEncodingException;
+import java.net.URLDecoder;
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.HttpServletResponse;
+import org.jeecg.common.api.vo.Result;
+import org.jeecg.common.system.query.QueryGenerator;
+import org.jeecg.common.system.query.QueryRuleEnum;
+import org.jeecg.common.util.oConvertUtils;
+import org.jeecg.config.shiro.IgnoreAuth;
+import org.jeecg.modules.learn.gen.entity.Course;
+import org.jeecg.modules.learn.gen.service.ICourseService;
+
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import lombok.extern.slf4j.Slf4j;
+
+import org.jeecgframework.poi.excel.ExcelImportUtil;
+import org.jeecgframework.poi.excel.def.NormalExcelConstants;
+import org.jeecgframework.poi.excel.entity.ExportParams;
+import org.jeecgframework.poi.excel.entity.ImportParams;
+import org.jeecgframework.poi.excel.view.JeecgEntityExcelView;
+import org.jeecg.common.system.base.controller.JeecgController;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.*;
+import org.springframework.web.multipart.MultipartFile;
+import org.springframework.web.multipart.MultipartHttpServletRequest;
+import org.springframework.web.servlet.ModelAndView;
+import com.alibaba.fastjson.JSON;
+import io.swagger.v3.oas.annotations.tags.Tag;
+import io.swagger.v3.oas.annotations.Operation;
+import org.jeecg.common.aspect.annotation.AutoLog;
+import org.apache.shiro.authz.annotation.RequiresPermissions;
+ /**
+ * @Description: 课程
+ * @Author: jeecg-boot
+ * @Date: 2025-08-07
+ * @Version: V1.0
+ */
+@Tag(name="课程")
+@RestController
+@RequestMapping("/gen/course")
+@Slf4j
+public class CourseController extends JeecgController {
+ @Autowired
+ private ICourseService courseService;
+
+ /**
+ * 分页列表查询
+ *
+ * @param course
+ * @param pageNo
+ * @param pageSize
+ * @param req
+ * @return
+ */
+ //@AutoLog(value = "课程-分页列表查询")
+ @Operation(summary="课程-分页列表查询")
+ @GetMapping(value = "/list")
+ public Result> queryPageList(Course course,
+ @RequestParam(name="pageNo", defaultValue="1") Integer pageNo,
+ @RequestParam(name="pageSize", defaultValue="10") Integer pageSize,
+ HttpServletRequest req) {
+
+
+ // 自定义查询规则
+ Map customeRuleMap = new HashMap<>();
+ // 自定义多选的查询规则为:LIKE_WITH_OR
+ customeRuleMap.put("categoryId", QueryRuleEnum.LIKE_WITH_OR);
+ QueryWrapper queryWrapper = QueryGenerator.initQueryWrapper(course, req.getParameterMap(),customeRuleMap);
+ Page page = new Page(pageNo, pageSize);
+ IPage pageList = courseService.page(page, queryWrapper);
+ return Result.OK(pageList);
+ }
+
+ /**
+ * 添加
+ *
+ * @param course
+ * @return
+ */
+ @AutoLog(value = "课程-添加")
+ @Operation(summary="课程-添加")
+ @RequiresPermissions("gen:course:add")
+ @PostMapping(value = "/add")
+ public Result add(@RequestBody Course course) {
+ courseService.save(course);
+
+ return Result.OK("添加成功!");
+ }
+
+ /**
+ * 编辑
+ *
+ * @param course
+ * @return
+ */
+ @AutoLog(value = "课程-编辑")
+ @Operation(summary="课程-编辑")
+ @RequiresPermissions("gen:course:edit")
+ @RequestMapping(value = "/edit", method = {RequestMethod.PUT,RequestMethod.POST})
+ public Result edit(@RequestBody Course course) {
+ courseService.updateById(course);
+ return Result.OK("编辑成功!");
+ }
+
+ /**
+ * 通过id删除
+ *
+ * @param id
+ * @return
+ */
+ @AutoLog(value = "课程-通过id删除")
+ @Operation(summary="课程-通过id删除")
+ @RequiresPermissions("gen:course:delete")
+ @DeleteMapping(value = "/delete")
+ public Result delete(@RequestParam(name="id",required=true) String id) {
+ courseService.removeById(id);
+ return Result.OK("删除成功!");
+ }
+
+ /**
+ * 批量删除
+ *
+ * @param ids
+ * @return
+ */
+ @AutoLog(value = "课程-批量删除")
+ @Operation(summary="课程-批量删除")
+ @RequiresPermissions("gen:course:deleteBatch")
+ @DeleteMapping(value = "/deleteBatch")
+ public Result deleteBatch(@RequestParam(name="ids",required=true) String ids) {
+ this.courseService.removeByIds(Arrays.asList(ids.split(",")));
+ return Result.OK("批量删除成功!");
+ }
+
+ /**
+ * 通过id查询
+ *
+ * @param id
+ * @return
+ */
+ //@AutoLog(value = "课程-通过id查询")
+ @Operation(summary="课程-通过id查询")
+ @GetMapping(value = "/queryById")
+ public Result queryById(@RequestParam(name="id",required=true) String id) {
+ Course course = courseService.getById(id);
+ if(course==null) {
+ return Result.error("未找到对应数据");
+ }
+ return Result.OK(course);
+ }
+
+ /**
+ * 导出excel
+ *
+ * @param request
+ * @param course
+ */
+ @RequiresPermissions("gen:course:exportXls")
+ @RequestMapping(value = "/exportXls")
+ public ModelAndView exportXls(HttpServletRequest request, Course course) {
+ return super.exportXls(request, course, Course.class, "课程");
+ }
+
+ /**
+ * 通过excel导入数据
+ *
+ * @param request
+ * @param response
+ * @return
+ */
+ @RequiresPermissions("gen:course:importExcel")
+ @RequestMapping(value = "/importExcel", method = RequestMethod.POST)
+ public Result> importExcel(HttpServletRequest request, HttpServletResponse response) {
+ return super.importExcel(request, response, Course.class);
+ }
+
+}
diff --git a/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/gen/entity/Course.java b/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/gen/entity/Course.java
new file mode 100644
index 00000000..473f0653
--- /dev/null
+++ b/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/gen/entity/Course.java
@@ -0,0 +1,76 @@
+package org.jeecg.modules.learn.gen.entity;
+
+import java.io.Serializable;
+import java.io.UnsupportedEncodingException;
+import java.util.Date;
+import java.math.BigDecimal;
+import com.baomidou.mybatisplus.annotation.IdType;
+import com.baomidou.mybatisplus.annotation.TableId;
+import com.baomidou.mybatisplus.annotation.TableName;
+import com.baomidou.mybatisplus.annotation.TableLogic;
+import org.jeecg.common.constant.ProvinceCityArea;
+import org.jeecg.common.util.SpringContextUtils;
+import lombok.Data;
+import com.fasterxml.jackson.annotation.JsonFormat;
+import org.springframework.format.annotation.DateTimeFormat;
+import org.jeecgframework.poi.excel.annotation.Excel;
+import org.jeecg.common.aspect.annotation.Dict;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.EqualsAndHashCode;
+import lombok.experimental.Accessors;
+
+/**
+ * @Description: 课程
+ * @Author: jeecg-boot
+ * @Date: 2025-08-07
+ * @Version: V1.0
+ */
+@Data
+@TableName("course")
+@Accessors(chain = true)
+@EqualsAndHashCode(callSuper = false)
+@Schema(description="课程")
+public class Course implements Serializable {
+ private static final long serialVersionUID = 1L;
+
+ /**主键*/
+ @TableId(type = IdType.ASSIGN_ID)
+ @Schema(description = "主键")
+ private java.lang.String id;
+ /**创建人*/
+ @Schema(description = "创建人")
+ private java.lang.String createBy;
+ /**创建日期*/
+ @JsonFormat(timezone = "GMT+8",pattern = "yyyy-MM-dd HH:mm:ss")
+ @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss")
+ @Schema(description = "创建日期")
+ private java.util.Date createTime;
+ /**更新人*/
+ @Schema(description = "更新人")
+ private java.lang.String updateBy;
+ /**更新日期*/
+ @JsonFormat(timezone = "GMT+8",pattern = "yyyy-MM-dd HH:mm:ss")
+ @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss")
+ @Schema(description = "更新日期")
+ private java.util.Date updateTime;
+ /**所属部门*/
+ @Schema(description = "所属部门")
+ private java.lang.String sysOrgCode;
+ /**课程名*/
+ @Excel(name = "课程名", width = 15)
+ @Schema(description = "课程名")
+ private java.lang.String name;
+ /**图片*/
+ @Excel(name = "图片", width = 15)
+ @Schema(description = "图片")
+ private java.lang.String cover;
+ /**描述*/
+ @Excel(name = "描述", width = 15)
+ @Schema(description = "描述")
+ private java.lang.String description;
+ /**所属分类*/
+ @Excel(name = "所属分类", width = 15, dictTable = "demo", dicText = "name", dicCode = "id")
+ @Dict(dictTable = "demo", dicText = "name", dicCode = "id")
+ @Schema(description = "所属分类")
+ private java.lang.String categoryId;
+}
diff --git a/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/gen/mapper/CourseMapper.java b/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/gen/mapper/CourseMapper.java
new file mode 100644
index 00000000..11101e30
--- /dev/null
+++ b/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/gen/mapper/CourseMapper.java
@@ -0,0 +1,17 @@
+package org.jeecg.modules.learn.gen.mapper;
+
+import java.util.List;
+
+import org.apache.ibatis.annotations.Param;
+import org.jeecg.modules.learn.gen.entity.Course;
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+
+/**
+ * @Description: 课程
+ * @Author: jeecg-boot
+ * @Date: 2025-08-07
+ * @Version: V1.0
+ */
+public interface CourseMapper extends BaseMapper {
+
+}
diff --git a/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/gen/mapper/xml/CourseMapper.xml b/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/gen/mapper/xml/CourseMapper.xml
new file mode 100644
index 00000000..64c60308
--- /dev/null
+++ b/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/gen/mapper/xml/CourseMapper.xml
@@ -0,0 +1,5 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/gen/service/ICourseService.java b/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/gen/service/ICourseService.java
new file mode 100644
index 00000000..cf7e9b0f
--- /dev/null
+++ b/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/gen/service/ICourseService.java
@@ -0,0 +1,14 @@
+package org.jeecg.modules.learn.gen.service;
+
+import org.jeecg.modules.learn.gen.entity.Course;
+import com.baomidou.mybatisplus.extension.service.IService;
+
+/**
+ * @Description: 课程
+ * @Author: jeecg-boot
+ * @Date: 2025-08-07
+ * @Version: V1.0
+ */
+public interface ICourseService extends IService {
+
+}
diff --git a/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/gen/service/impl/CourseServiceImpl.java b/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/gen/service/impl/CourseServiceImpl.java
new file mode 100644
index 00000000..34c78bea
--- /dev/null
+++ b/jeecg-boot/jeecg-boot-module/jeecg-module-learn/src/main/java/org/jeecg/modules/learn/gen/service/impl/CourseServiceImpl.java
@@ -0,0 +1,19 @@
+package org.jeecg.modules.learn.gen.service.impl;
+
+import org.jeecg.modules.learn.gen.entity.Course;
+import org.jeecg.modules.learn.gen.mapper.CourseMapper;
+import org.jeecg.modules.learn.gen.service.ICourseService;
+import org.springframework.stereotype.Service;
+
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+
+/**
+ * @Description: 课程
+ * @Author: jeecg-boot
+ * @Date: 2025-08-07
+ * @Version: V1.0
+ */
+@Service
+public class CourseServiceImpl extends ServiceImpl implements ICourseService {
+
+}
diff --git a/jeecg-boot/jeecg-boot-module/pom.xml b/jeecg-boot/jeecg-boot-module/pom.xml
index 92562dd6..e712b006 100644
--- a/jeecg-boot/jeecg-boot-module/pom.xml
+++ b/jeecg-boot/jeecg-boot-module/pom.xml
@@ -15,6 +15,7 @@
jeecg-module-demo
jeecg-boot-module-airag
+ jeecg-module-learn
diff --git a/jeecg-boot/jeecg-module-system/jeecg-system-start/pom.xml b/jeecg-boot/jeecg-module-system/jeecg-system-start/pom.xml
index 756902c2..cf8df1ae 100644
--- a/jeecg-boot/jeecg-module-system/jeecg-system-start/pom.xml
+++ b/jeecg-boot/jeecg-module-system/jeecg-system-start/pom.xml
@@ -30,6 +30,13 @@
org.flywaydb
flyway-core
+
+
+
+ org.jeecgframework.boot
+ jeecg-module-learn
+ ${jeecgboot.version}
+
diff --git a/jeecg-boot/jeecg-module-system/jeecg-system-start/src/main/resources/application-dev.yml b/jeecg-boot/jeecg-module-system/jeecg-system-start/src/main/resources/application-dev.yml
index 1b039cd3..7dc1e42b 100644
--- a/jeecg-boot/jeecg-module-system/jeecg-system-start/src/main/resources/application-dev.yml
+++ b/jeecg-boot/jeecg-module-system/jeecg-system-start/src/main/resources/application-dev.yml
@@ -151,9 +151,9 @@ spring:
slow-sql-millis: 5000
datasource:
master:
- url: jdbc:mysql://127.0.0.1:3306/jeecg-boot?characterEncoding=UTF-8&useUnicode=true&useSSL=false&tinyInt1isBit=false&allowPublicKeyRetrieval=true&serverTimezone=Asia/Shanghai
+ url: jdbc:mysql://127.0.0.1:33061/jeecg-boot?characterEncoding=UTF-8&useUnicode=true&useSSL=false&tinyInt1isBit=false&allowPublicKeyRetrieval=true&serverTimezone=Asia/Shanghai
username: root
- password: root
+ password: 123456
driver-class-name: com.mysql.cj.jdbc.Driver
# 多数据源配置
#multi-datasource1:
@@ -214,7 +214,7 @@ jeecg:
#签名拦截接口
signUrls: /sys/dict/getDictItems/*,/sys/dict/loadDict/*,/sys/dict/loadDictOrderByValue/*,/sys/dict/loadDictItem/*,/sys/dict/loadTreeData,/sys/api/queryTableDictItemsByCode,/sys/api/queryFilterTableDictInfo,/sys/api/queryTableDictByKeys,/sys/api/translateDictFromTable,/sys/api/translateDictFromTableByKeys,/sys/sendChangePwdSms,/sys/user/sendChangePhoneSms,/sys/sms,/desform/api/sendVerifyCode
# 本地:local、Minio:minio、阿里云:alioss
- uploadType: local
+ uploadType: minio
# 前端访问地址
domainUrl:
pc: http://localhost:3100
@@ -248,10 +248,10 @@ jeecg:
file-view-domain: http://fileview.jeecg.com
# minio文件上传
minio:
- minio_url: http://minio.jeecg.com
- minio_name: ??
- minio_pass: ??
- bucketName: otatest
+ minio_url: http://127.0.0.1:9000
+ minio_name: minio
+ minio_pass: minio123
+ bucketName: learn
#大屏报表参数设置
jmreport:
#多租户模式,默认值为空(created:按照创建人隔离、tenant:按照租户隔离) (v1.6.2+ 新增)
diff --git a/jeecg-boot/jeecg-module-system/jeecg-system-start/src/main/resources/jeecg/jeecg_config.properties b/jeecg-boot/jeecg-module-system/jeecg-system-start/src/main/resources/jeecg/jeecg_config.properties
index 44618ab8..7dfee0a2 100644
--- a/jeecg-boot/jeecg-module-system/jeecg-system-start/src/main/resources/jeecg/jeecg_config.properties
+++ b/jeecg-boot/jeecg-module-system/jeecg-system-start/src/main/resources/jeecg/jeecg_config.properties
@@ -1,7 +1,7 @@
#code_generate_project_path
project_path=E:\\workspace\\jeecg-boot
#bussi_package[User defined]
-bussi_package=org.jeecg.modules.demo
+bussi_package=org.jeecg.modules.learn
#default code path
diff --git a/jeecgboot-vue3/src/views/learn/Course.api.ts b/jeecgboot-vue3/src/views/learn/Course.api.ts
new file mode 100644
index 00000000..44203624
--- /dev/null
+++ b/jeecgboot-vue3/src/views/learn/Course.api.ts
@@ -0,0 +1,64 @@
+import {defHttp} from '/@/utils/http/axios';
+import { useMessage } from "/@/hooks/web/useMessage";
+
+const { createConfirm } = useMessage();
+
+enum Api {
+ list = '/learn/course/list',
+ save='/learn/course/add',
+ edit='/learn/course/edit',
+ deleteOne = '/learn/course/delete',
+ deleteBatch = '/learn/course/deleteBatch',
+ importExcel = '/learn/course/importExcel',
+ exportXls = '/learn/course/exportXls',
+}
+/**
+ * 导出api
+ * @param params
+ */
+export const getExportUrl = Api.exportXls;
+/**
+ * 导入api
+ */
+export const getImportUrl = Api.importExcel;
+/**
+ * 列表接口
+ * @param params
+ */
+export const list = (params) =>
+ defHttp.get({url: Api.list, params});
+
+/**
+ * 删除单个
+ */
+export const deleteOne = (params,handleSuccess) => {
+ return defHttp.delete({url: Api.deleteOne, params}, {joinParamsToUrl: true}).then(() => {
+ handleSuccess();
+ });
+}
+/**
+ * 批量删除
+ * @param params
+ */
+export const batchDelete = (params, handleSuccess) => {
+ createConfirm({
+ iconType: 'warning',
+ title: '确认删除',
+ content: '是否删除选中数据',
+ okText: '确认',
+ cancelText: '取消',
+ onOk: () => {
+ return defHttp.delete({url: Api.deleteBatch, data: params}, {joinParamsToUrl: true}).then(() => {
+ handleSuccess();
+ });
+ }
+ });
+}
+/**
+ * 保存或者更新
+ * @param params
+ */
+export const saveOrUpdate = (params, isUpdate) => {
+ let url = isUpdate ? Api.edit : Api.save;
+ return defHttp.post({url: url, params});
+}
diff --git a/jeecgboot-vue3/src/views/learn/Course.data.ts b/jeecgboot-vue3/src/views/learn/Course.data.ts
new file mode 100644
index 00000000..931d3953
--- /dev/null
+++ b/jeecgboot-vue3/src/views/learn/Course.data.ts
@@ -0,0 +1,94 @@
+import {BasicColumn} from '/@/components/Table';
+import {FormSchema} from '/@/components/Table';
+import { rules} from '/@/utils/helper/validator';
+import { render } from '/@/utils/common/renderUtils';
+import { getWeekMonthQuarterYear } from '/@/utils';
+//列表数据
+export const columns: BasicColumn[] = [
+ {
+ title: '课程名',
+ align:"center",
+ dataIndex: 'name'
+ },
+ {
+ title: '图片',
+ align:"center",
+ dataIndex: 'cover',
+ customRender:render.renderImage,
+ },
+ {
+ title: '描述',
+ align:"center",
+ dataIndex: 'description',
+ },
+ {
+ title: '所属分类',
+ align:"center",
+ dataIndex: 'categoryId_dictText'
+ },
+];
+//查询数据
+export const searchFormSchema: FormSchema[] = [
+ {
+ label: "所属分类",
+ field: 'categoryId',
+ component: 'JSelectMultiple',
+ componentProps:{
+ dictCode:"demo,name,id"
+ },
+ //colProps: {span: 6},
+ },
+];
+//表单数据
+export const formSchema: FormSchema[] = [
+ {
+ label: '课程名',
+ field: 'name',
+ component: 'Input',
+ },
+ {
+ label: '图片',
+ field: 'cover',
+ component: 'JImageUpload',
+ componentProps:{
+ fileMax: 0
+ },
+ },
+ {
+ label: '描述',
+ field: 'description',
+ component: 'JEditor',
+ },
+ {
+ label: '所属分类',
+ field: 'categoryId',
+ component: 'JDictSelectTag',
+ componentProps:{
+ dictCode:"demo,name,id"
+ },
+ },
+ // TODO 主键隐藏字段,目前写死为ID
+ {
+ label: '',
+ field: 'id',
+ component: 'Input',
+ show: false
+ },
+];
+
+// 高级查询数据
+export const superQuerySchema = {
+ name: {title: '课程名',order: 0,view: 'text', type: 'string',},
+ cover: {title: '图片',order: 1,view: 'image', type: 'string',},
+ description: {title: '描述',order: 2,view: 'umeditor', type: 'string',},
+ categoryId: {title: '所属分类',order: 3,view: 'list', type: 'string',dictTable: "demo", dictCode: 'id', dictText: 'name',},
+};
+
+/**
+* 流程表单调用这个方法获取formSchema
+* @param param
+*/
+export function getBpmFormSchema(_formData): FormSchema[]{
+ // 默认和原始表单保持一致 如果流程中配置了权限数据,这里需要单独处理formSchema
+ return formSchema;
+}
\ No newline at end of file
diff --git a/jeecgboot-vue3/src/views/learn/CourseList.vue b/jeecgboot-vue3/src/views/learn/CourseList.vue
new file mode 100644
index 00000000..1cee094b
--- /dev/null
+++ b/jeecgboot-vue3/src/views/learn/CourseList.vue
@@ -0,0 +1,210 @@
+
+
+
+
+
+
+ 新增
+ 导出
+ 导入
+
+
+
+
+
+
+ 删除
+
+
+
+ 批量操作
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/jeecgboot-vue3/src/views/learn/components/CourseForm.vue b/jeecgboot-vue3/src/views/learn/components/CourseForm.vue
new file mode 100644
index 00000000..22813e05
--- /dev/null
+++ b/jeecgboot-vue3/src/views/learn/components/CourseForm.vue
@@ -0,0 +1,70 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/jeecgboot-vue3/src/views/learn/components/CourseModal.vue b/jeecgboot-vue3/src/views/learn/components/CourseModal.vue
new file mode 100644
index 00000000..7affc85c
--- /dev/null
+++ b/jeecgboot-vue3/src/views/learn/components/CourseModal.vue
@@ -0,0 +1,99 @@
+
+
+
+
+
+
+
+
+
\ No newline at end of file