From e26d98c47301e937a2812b607e26e5801dce83fe Mon Sep 17 00:00:00 2001
From: cloudroam <cloudroam>
Date: 星期一, 26 五月 2025 09:54:09 +0800
Subject: [PATCH] add:影视作品信息管理
---
src/main/java/com/mzl/flower/dto/request/filmwork/FilmWorksQueryDTO.java | 24 +++++
src/main/java/com/mzl/flower/service/film/impl/FilmWorksServiceImpl.java | 71 +++++++++++++++++
src/main/resources/mapper/film/FilmWorksMapper.xml | 51 +++++-------
src/main/java/com/mzl/flower/dto/response/filmwork/FilmWorksVO.java | 17 +++-
src/main/java/com/mzl/flower/entity/film/FilmWorks.java | 8 +
src/main/java/com/mzl/flower/mapper/filmwork/FilmWorksMapper.java | 5 +
src/main/java/com/mzl/flower/web/film/FilmWorksController.java | 31 +++++++
src/main/java/com/mzl/flower/service/film/FilmWorksService.java | 9 ++
8 files changed, 177 insertions(+), 39 deletions(-)
diff --git a/src/main/java/com/mzl/flower/dto/request/filmwork/FilmWorksQueryDTO.java b/src/main/java/com/mzl/flower/dto/request/filmwork/FilmWorksQueryDTO.java
index a688f7a..aa5766f 100644
--- a/src/main/java/com/mzl/flower/dto/request/filmwork/FilmWorksQueryDTO.java
+++ b/src/main/java/com/mzl/flower/dto/request/filmwork/FilmWorksQueryDTO.java
@@ -3,8 +3,28 @@
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
+import java.time.LocalDateTime;
+
@Data
public class FilmWorksQueryDTO {
- @ApiModelProperty(value = "会员等级名称")
- private String name;
+ @ApiModelProperty(value = "中文名称")
+ private String nameCn;
+
+ @ApiModelProperty("片场类型(FILMSET_TYPE)")
+ private String type;
+
+ @ApiModelProperty("发布状态(COMMON_PUBLISH_STATUS)")
+ private String status;
+
+ @ApiModelProperty("创建日期(yyyy-mm-dd)")
+ private String createDateBeginStr;
+
+ @ApiModelProperty("创建日期(yyyy-mm-dd)")
+ private String createDateEndStr;
+
+ @ApiModelProperty(value = "创建日期(yyyy-mm-dd)",hidden = true)
+ private LocalDateTime createDateBegin;
+
+ @ApiModelProperty(value = "创建日期(yyyy-mm-dd)", hidden = true)
+ private LocalDateTime createDateEnd;
}
diff --git a/src/main/java/com/mzl/flower/dto/response/filmwork/FilmWorksVO.java b/src/main/java/com/mzl/flower/dto/response/filmwork/FilmWorksVO.java
index 4b8122f..17045ab 100644
--- a/src/main/java/com/mzl/flower/dto/response/filmwork/FilmWorksVO.java
+++ b/src/main/java/com/mzl/flower/dto/response/filmwork/FilmWorksVO.java
@@ -2,11 +2,8 @@
import com.mzl.flower.base.AbstractTransDTO;
import com.mzl.flower.base.annotation.DictTrans;
-import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
-import java.math.BigDecimal;
-import java.time.LocalDateTime;
@Data
public class FilmWorksVO extends AbstractTransDTO {
@@ -25,7 +22,10 @@
/**
* 作品类型
*/
+ @DictTrans(target = "typeStr", codeType = "FILMSET_TYPE")
private String type;
+
+ private String typeStr;
/**
* 上映年份
@@ -70,7 +70,11 @@
/**
* 创建者用户类型
*/
+ @DictTrans(target = "userTypeStr", codeType = "FILMSET_CREATE_TYPE")
private String userType;
+
+
+ private String userTypeStr;
/**
* 置顶权重(越大越靠前)
@@ -78,9 +82,12 @@
private Integer stickyWeight;
/**
- * 状态(0禁用,1启用)
+ * 状态
*/
- private Integer status;
+ @DictTrans(target = "statusStr", codeType = "COMMON_PUBLISH_STATUS")
+ private String status;
+
+ private String statusStr;
/**
* 创建者ID
diff --git a/src/main/java/com/mzl/flower/entity/film/FilmWorks.java b/src/main/java/com/mzl/flower/entity/film/FilmWorks.java
index fdfc034..5cee130 100644
--- a/src/main/java/com/mzl/flower/entity/film/FilmWorks.java
+++ b/src/main/java/com/mzl/flower/entity/film/FilmWorks.java
@@ -1,9 +1,12 @@
package com.mzl.flower.entity.film;
import com.baomidou.mybatisplus.annotation.TableName;
+
+import java.time.LocalDate;
import java.time.LocalDateTime;
import com.mzl.flower.base.BaseAutoEntity;
+import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
/**
@@ -85,7 +88,7 @@
/**
* 状态(0禁用,1启用)
*/
- private Integer status;
+ private String status;
/**
* 创建者ID
@@ -117,5 +120,8 @@
*/
private Integer shareCount;
+ @ApiModelProperty("发布日期")
+ private LocalDate publishDate;
+
}
diff --git a/src/main/java/com/mzl/flower/mapper/filmwork/FilmWorksMapper.java b/src/main/java/com/mzl/flower/mapper/filmwork/FilmWorksMapper.java
index afbcf55..6b03a07 100644
--- a/src/main/java/com/mzl/flower/mapper/filmwork/FilmWorksMapper.java
+++ b/src/main/java/com/mzl/flower/mapper/filmwork/FilmWorksMapper.java
@@ -1,8 +1,11 @@
package com.mzl.flower.mapper.filmwork;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.mzl.flower.dto.request.filmwork.FilmWorksQueryDTO;
import com.mzl.flower.dto.response.filmwork.FilmWorksVO;
import com.mzl.flower.entity.film.FilmWorks;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
import java.util.List;
@@ -20,4 +23,6 @@
@Select("select * from film_works where deleted = '0' and user_type = 'admin'")
List<FilmWorksVO> getFilmWorksAll();
+
+ List<FilmWorksVO> queryPage(@Param("dto") FilmWorksQueryDTO dto, Page page);
}
diff --git a/src/main/java/com/mzl/flower/service/film/FilmWorksService.java b/src/main/java/com/mzl/flower/service/film/FilmWorksService.java
index 5113fa8..fd3c843 100644
--- a/src/main/java/com/mzl/flower/service/film/FilmWorksService.java
+++ b/src/main/java/com/mzl/flower/service/film/FilmWorksService.java
@@ -1,6 +1,7 @@
package com.mzl.flower.service.film;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.mzl.flower.dto.BatchDTO;
import com.mzl.flower.dto.request.filmwork.FilmWorksDTO;
import com.mzl.flower.dto.request.filmwork.FilmWorksQueryDTO;
import com.mzl.flower.dto.response.filmwork.FilmWorksVO;
@@ -27,4 +28,12 @@
Page<FilmWorksVO> queryPage(FilmWorksQueryDTO filmWorksQueryDTO, Page page);
List<FilmWorksVO> getFilmWorksAll();
+
+ void changeStatus(Long id);
+
+ void batchDelete(BatchDTO dto);
+
+ void batchPublish(BatchDTO dto);
+
+ FilmWorksVO detail(Long id);
}
diff --git a/src/main/java/com/mzl/flower/service/film/impl/FilmWorksServiceImpl.java b/src/main/java/com/mzl/flower/service/film/impl/FilmWorksServiceImpl.java
index 10d204b..7548242 100644
--- a/src/main/java/com/mzl/flower/service/film/impl/FilmWorksServiceImpl.java
+++ b/src/main/java/com/mzl/flower/service/film/impl/FilmWorksServiceImpl.java
@@ -1,18 +1,29 @@
package com.mzl.flower.service.film.impl;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.mzl.flower.config.exception.ValidationException;
+import com.mzl.flower.constant.Constants;
+import com.mzl.flower.dto.BatchDTO;
import com.mzl.flower.dto.request.filmwork.FilmWorksDTO;
import com.mzl.flower.dto.request.filmwork.FilmWorksQueryDTO;
+import com.mzl.flower.dto.response.content.BannerDTO;
+import com.mzl.flower.dto.response.content.FilmsetDTO;
import com.mzl.flower.dto.response.filmwork.FilmWorksVO;
+import com.mzl.flower.entity.content.Banner;
+import com.mzl.flower.entity.content.Filmset;
import com.mzl.flower.entity.film.FilmWorks;
import com.mzl.flower.mapper.filmwork.FilmWorksMapper;
import com.mzl.flower.service.film.FilmWorksService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.mzl.flower.utils.DateUtils;
import lombok.RequiredArgsConstructor;
+import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.BeanUtils;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
+import java.time.LocalDate;
import java.util.List;
/**
@@ -36,6 +47,7 @@
FilmWorks filmWorks = new FilmWorks();
BeanUtils.copyProperties(filmWorksDTO, filmWorks);
filmWorks.create();
+ filmWorks.setStatus(Constants.COMMON_PUBLISH_STATUS.unpublished.name());
filmWorksMapper.insert(filmWorks);
}
@@ -46,16 +58,69 @@
@Override
public void deleteFilmWorks(String id) {
-
+ FilmWorks filmWork = filmWorksMapper.selectById(id);
+ if(filmWork==null){
+ throw new ValidationException("找不到id为"+id+"的影视作品");
+ }
+ filmWorksMapper.deleteById(id);
}
@Override
- public Page<FilmWorksVO> queryPage(FilmWorksQueryDTO filmWorksQueryDTO, Page page) {
- return null;
+ public Page<FilmWorksVO> queryPage(FilmWorksQueryDTO dto, Page page) {
+ if(StringUtils.isNotBlank(dto.getCreateDateBeginStr())){
+ dto.setCreateDateBegin(DateUtils.dateToLocalDateTime(dto.getCreateDateBeginStr(),true));
+ }
+ if(StringUtils.isNotBlank(dto.getCreateDateEndStr())){
+ dto.setCreateDateEnd(DateUtils.dateToLocalDateTime(dto.getCreateDateEndStr(),false));
+ }
+ List<FilmWorksVO> list = filmWorksMapper.queryPage(dto,page);
+ page.setRecords(list);
+ return page;
}
@Override
public List<FilmWorksVO> getFilmWorksAll() {
return filmWorksMapper.getFilmWorksAll();
}
+
+ @Override
+ public void changeStatus(Long id) {
+ FilmWorks filmWork = filmWorksMapper.selectById(id);
+ if (filmWork == null) {
+ throw new ValidationException("找不到id为" + id + "的公告");
+ }
+ if (Constants.COMMON_PUBLISH_STATUS.published.name().equals(filmWork.getStatus())) {
+ filmWork.setStatus(Constants.COMMON_PUBLISH_STATUS.unpublished.name());
+ } else {
+ filmWork.setStatus(Constants.COMMON_PUBLISH_STATUS.published.name());
+ filmWork.setPublishDate(LocalDate.now());
+ }
+ filmWorksMapper.updateById(filmWork);
+ }
+
+ @Override
+ public void batchDelete(BatchDTO dto) {
+ filmWorksMapper.deleteBatchIds(dto.getIds());
+ }
+
+ @Override
+ public void batchPublish(BatchDTO dto) {
+ List<FilmWorks> list = filmWorksMapper.selectList(new LambdaQueryWrapper<FilmWorks>().in(FilmWorks::getId, dto.getIds()));
+ for (FilmWorks filmWork : list) {
+ filmWork.setStatus(Constants.COMMON_PUBLISH_STATUS.published.name());
+ filmWork.setPublishDate(LocalDate.now());
+ filmWorksMapper.updateById(filmWork);
+ }
+ }
+
+ @Override
+ public FilmWorksVO detail(Long id) {
+ FilmWorks filmWork = filmWorksMapper.selectById(id);
+ if(filmWork==null){
+ return null;
+ }
+ FilmWorksVO filmWorksVO = new FilmWorksVO();
+ BeanUtils.copyProperties(filmWork,filmWorksVO);
+ return filmWorksVO;
+ }
}
diff --git a/src/main/java/com/mzl/flower/web/film/FilmWorksController.java b/src/main/java/com/mzl/flower/web/film/FilmWorksController.java
index 7eeb3a3..dd1b7b4 100644
--- a/src/main/java/com/mzl/flower/web/film/FilmWorksController.java
+++ b/src/main/java/com/mzl/flower/web/film/FilmWorksController.java
@@ -4,14 +4,17 @@
import com.mzl.flower.base.BaseController;
import com.mzl.flower.base.R;
import com.mzl.flower.base.ReturnDataDTO;
+import com.mzl.flower.dto.BatchDTO;
import com.mzl.flower.dto.request.filmwork.FilmWorksDTO;
import com.mzl.flower.dto.request.filmwork.FilmWorksQueryDTO;
+import com.mzl.flower.dto.response.content.BannerDTO;
import com.mzl.flower.dto.response.filmwork.FilmWorksVO;
import com.mzl.flower.service.film.FilmWorksService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import lombok.RequiredArgsConstructor;
import org.springframework.http.ResponseEntity;
+import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
import javax.validation.constraints.NotNull;
@@ -66,5 +69,33 @@
return returnData(R.SUCCESS.getCode(), null);
}
+ @GetMapping("/filmWorks/changeStatus")
+ @ApiOperation(value = "修改状态", notes = "修改状态")
+ public ResponseEntity<ReturnDataDTO> changeStatus(@NotNull(message = "id不能为空") Long id) {
+ filmWorksService.changeStatus(id);
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+
+ @PostMapping("/filmWorks/delete/batch")
+ @ApiOperation(value = "批量删除", notes = "批量删除")
+ public ResponseEntity<ReturnDataDTO> batchDelete(@Validated @RequestBody BatchDTO dto) {
+ filmWorksService.batchDelete(dto);
+ return returnData(R.SUCCESS.getCode(),null);
+ }
+
+ @PostMapping("/filmWorks/publish/batch")
+ @ApiOperation(value = "批量发布", notes = "批量发布")
+ public ResponseEntity<ReturnDataDTO> batchPublish(@Validated @RequestBody BatchDTO dto) {
+ filmWorksService.batchPublish(dto);
+ return returnData(R.SUCCESS.getCode(), null);
+ }
+
+ @GetMapping("/filmWorks/list/view")
+ @ApiOperation(value = "详情", notes = "详情")
+ public ResponseEntity<ReturnDataDTO<FilmWorksVO>> detail(@NotNull(message = "id不能为空") Long id) {
+ return returnData(R.SUCCESS.getCode(),filmWorksService.detail(id));
+ }
+
}
diff --git a/src/main/resources/mapper/film/FilmWorksMapper.xml b/src/main/resources/mapper/film/FilmWorksMapper.xml
index c9a6ab9..38fe88d 100644
--- a/src/main/resources/mapper/film/FilmWorksMapper.xml
+++ b/src/main/resources/mapper/film/FilmWorksMapper.xml
@@ -2,32 +2,27 @@
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.mzl.flower.mapper.filmwork.FilmWorksMapper">
- <!-- 通用查询映射结果 -->
- <resultMap id="BaseResultMap" type="com.mzl.flower.entity.film.FilmWorks">
- <id column="id" property="id" />
- <result column="create_time" property="createTime" />
- <result column="update_time" property="updateTime" />
- <result column="name_cn" property="nameCn" />
- <result column="name_en" property="nameEn" />
- <result column="type" property="type" />
- <result column="release_year" property="releaseYear" />
- <result column="director" property="director" />
- <result column="producer" property="producer" />
- <result column="actors" property="actors" />
- <result column="keywords" property="keywords" />
- <result column="synopsis" property="synopsis" />
- <result column="cover_url" property="coverUrl" />
- <result column="cover_alt" property="coverAlt" />
- <result column="user_type" property="userType" />
- <result column="sticky_weight" property="stickyWeight" />
- <result column="status" property="status" />
- <result column="deleted" property="deleted" />
- <result column="create_by" property="createBy" />
- <result column="update_by" property="updateBy" />
- <result column="collect_count" property="collectCount" />
- <result column="like_count" property="likeCount" />
- <result column="comment_count" property="commentCount" />
- <result column="share_count" property="shareCount" />
- </resultMap>
-
+ <select id="queryPage" resultType="com.mzl.flower.dto.response.filmwork.FilmWorksVO">
+ select t.* from film_works t where t.deleted= 0
+ <if test="dto.nameCn != null and dto.nameCn != ''">
+ and t.name_cn like concat('%', #{dto.nameCn}, '%')
+ </if>
+ <if test="dto.status != null and dto.status != ''">
+ and t.status = #{dto.status}
+ </if>
+ <if test="dto.type != null and dto.type != ''">
+ and t.type = #{dto.type}
+ </if>
+ <if test="dto.createDateBegin!=null ">
+ <![CDATA[
+ AND t.create_time >= #{dto.createDateBegin}
+ ]]>
+ </if>
+ <if test="dto.createDateEnd!=null ">
+ <![CDATA[
+ AND t.create_time <= #{dto.createDateEnd}
+ ]]>
+ </if>
+ order by t.update_time desc
+ </select>
</mapper>
--
Gitblit v1.9.3