GuestInfoController.java 8.4 KB
package com.skua.modules.guest.controller;

import java.util.Arrays;
import java.util.Date;
import java.util.List;

import com.skua.core.api.vo.Result;
import com.skua.core.aspect.annotation.AutoLog;
import com.skua.modules.guest.dto.GuestInfoDTO;
import com.skua.modules.guest.entity.GuestInfo;
import com.skua.modules.guest.service.IGuestInfoService;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.skua.modules.guest.util.DateUtil;
import com.skua.modules.guest.vo.GuestInfoVO;
import com.skua.modules.guest.vo.StatisticsByChartsVO;
import com.skua.modules.guest.vo.StatisticsByTimeVO;
import lombok.extern.slf4j.Slf4j;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.*;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;

/**
 * 来访人员信息
 */
@Slf4j
@Api(tags = "来访人员信息")
@RestController
@RequestMapping("/guest/guestInfo")
public class GuestInfoController {
    @Autowired
    private IGuestInfoService guestInfoService;

    @AutoLog(value = "来访人员信息-分页列表查询")
    @ApiOperation(value = "来访人员信息-分页列表查询", notes = "来访人员信息-分页列表查询")
    @PostMapping(value = "/list")
    public Result<IPage<GuestInfo>> queryPageList(@RequestBody GuestInfoDTO guestInfoDTO) {
        Result<IPage<GuestInfo>> result = new Result<>();
        try {
            QueryWrapper<GuestInfo> queryWrapper = new QueryWrapper<>();
            Date startTime = DateUtil.strToDate(guestInfoDTO.getStartTime() + " 00:00:00", "yyyy-MM-dd HH:mm:ss");
            Date endTime = DateUtil.strToDate(guestInfoDTO.getEndTime() + " 23:59:59", "yyyy-MM-dd HH:mm:ss");
            if (!StringUtils.isEmpty(guestInfoDTO.getGuestName())) {
                queryWrapper.lambda().like(GuestInfo::getGuestName, guestInfoDTO.getGuestName());
            }
            queryWrapper.lambda().ge(GuestInfo::getCreateTime, startTime).le(GuestInfo::getCreateTime, endTime);
            queryWrapper.orderByDesc("create_time");
            Page<GuestInfo> page = new Page<>(guestInfoDTO.getPageNo(), guestInfoDTO.getPageSize());
            IPage<GuestInfo> pageList = guestInfoService.page(page, queryWrapper);
            result.setSuccess(true);
            result.setResult(pageList);
        } catch (Exception e) {
            log.error("查询访客信息失败: {}", e.getMessage());
            result.setCode(500);
            result.setMessage("查询访客信息失败: " + e.getMessage());
        }
        return result;
    }

    /**
     * 添加
     *
     * @param guestInfo
     * @return
     */
    @AutoLog(value = "来访人员信息-添加")
    @ApiOperation(value = "来访人员信息-添加", notes = "来访人员信息-添加")
    @PostMapping(value = "/add")
    public Result<GuestInfo> add(@RequestBody GuestInfo guestInfo) {
        Result<GuestInfo> result = new Result<>();
        try {
            boolean flag = guestInfoService.save(guestInfo);
            if (flag) {
                result.success("添加成功!");
                result.setResult(guestInfo);
            } else {
                result.error500("操作失败");
            }
        } catch (Exception e) {
            log.error(e.getMessage(), e);
            result.error500("操作失败");
        }
        return result;
    }

    /**
     * 编辑
     *
     * @param guestInfo
     * @return
     */
    @AutoLog(value = "来访人员信息-编辑")
    @ApiOperation(value = "来访人员信息-编辑", notes = "来访人员信息-编辑")
    @PutMapping(value = "/edit")
    public Result<GuestInfo> edit(@RequestBody GuestInfo guestInfo) {
        Result<GuestInfo> result = new Result<>();
        GuestInfo guestInfoEntity = guestInfoService.getById(guestInfo.getId());
        if (guestInfoEntity == null) {
            result.error500("未找到对应实体");
        } else {
            boolean ok = guestInfoService.updateById(guestInfo);
            //TODO 返回false说明什么?
            if (ok) {
                result.success("修改成功!");
            }
        }

        return result;
    }

    /**
     * 通过id删除
     *
     * @param id
     * @return
     */
    @AutoLog(value = "来访人员信息-通过id删除")
    @ApiOperation(value = "来访人员信息-通过id删除", notes = "来访人员信息-通过id删除")
    @DeleteMapping(value = "/delete")
    public Result<?> delete(@RequestParam(name = "id", required = true) String id) {
        try {
            guestInfoService.removeById(id);
        } catch (Exception e) {
            log.error("删除失败: {}", e.getMessage());
            return Result.error("删除失败!");
        }
        return Result.ok("删除成功!");
    }

    /**
     * 批量删除
     *
     * @param ids
     * @return
     */
    @AutoLog(value = "来访人员信息-批量删除")
    @ApiOperation(value = "来访人员信息-批量删除", notes = "来访人员信息-批量删除")
    @DeleteMapping(value = "/deleteBatch")
    public Result<GuestInfo> deleteBatch(@RequestParam(name = "ids", required = true) String ids) {
        Result<GuestInfo> result = new Result<>();
        if (ids == null || "".equals(ids.trim())) {
            result.error500("参数不识别!");
        } else {
            this.guestInfoService.removeByIds(Arrays.asList(ids.split(",")));
            result.success("删除成功!");
        }
        return result;
    }

    /**
     * 通过id查询
     *
     * @param id
     * @return
     */
    @AutoLog(value = "来访人员信息-通过id查询")
    @ApiOperation(value = "来访人员信息-通过id查询", notes = "来访人员信息-通过id查询")
    @GetMapping(value = "/queryById")
    public Result<GuestInfo> queryById(@RequestParam(name = "id", required = true) String id) {
        Result<GuestInfo> result = new Result<>();
        GuestInfo guestInfo = guestInfoService.getById(id);
        if (guestInfo == null) {
            result.error500("未找到对应实体");
        } else {
            result.setResult(guestInfo);
            result.setSuccess(true);
        }
        return result;
    }

    /**
     * 通过手机号查询
     *
     * @param mobilePhone
     * @return
     */
    @AutoLog(value = "来访人员信息-通过mobilePhone查询")
    @ApiOperation(value = "来访人员信息-通过mobilePhone查询", notes = "来访人员信息-通过mobilePhone查询")
    @GetMapping(value = "/queryByPhone")
    public Result<GuestInfo> queryByPhone(@RequestParam(name = "mobilePhone") String mobilePhone) {
        Result<GuestInfo> result = new Result<>();
        QueryWrapper<GuestInfo> queryWrapper = new QueryWrapper<>();
        queryWrapper.lambda().eq(GuestInfo::getMobilePhone, mobilePhone);
        queryWrapper.orderByDesc("create_time");
        List<GuestInfo> guestInfoList = guestInfoService.list(queryWrapper);
        if (guestInfoList == null || guestInfoList.isEmpty()) {
            result.setResult(null);
            result.setSuccess(true);
        } else {
            result.setResult(guestInfoList.get(0));
            result.setSuccess(true);
        }
        return result;
    }

    @AutoLog(value = "来访人员信息-统计历史信息")
    @ApiOperation(value = "来访人员信息-统计历史信息", notes = "来访人员信息-统计历史信息")
    @GetMapping(value = "/statistics")
    public Result<GuestInfoVO> statisticsGuestInfoCtrl() {
        Result<GuestInfoVO> result = new Result<>();
        GuestInfoVO guestInfoVO = new GuestInfoVO();
        try {
            // 统计 今日、本周、本月、累计
            StatisticsByTimeVO statisticsByTimeVO = guestInfoService.statisticsByTime();
            guestInfoVO.setStatisticsByTimeVO(statisticsByTimeVO);
            // echarts 本周、本月、全年
            StatisticsByChartsVO statisticsByChartsVO = guestInfoService.statisticsByCharts();
            guestInfoVO.setStatisticsByChartsVO(statisticsByChartsVO);
            result.setResult(guestInfoVO);
        } catch (Exception e) {
            log.error("统计来访人员信息异常: {}", e.getMessage());
            result.error500("统计来访人员信息异常: " + e.getMessage());
        }
        return result;
    }


}