package com.ruoyi.web.controller.invest;

import java.util.List;
import javax.servlet.http.HttpServletResponse;

import com.ruoyi.common.enums.FileType;
import com.ruoyi.common.utils.StringUtils;
import com.ruoyi.common.utils.uuid.IdUtils;
import com.ruoyi.invest.domain.TProjectCirculation;
import com.ruoyi.invest.domain.TProjectScoring;
import com.ruoyi.invest.service.ITProjectCirculationService;
import com.ruoyi.tool.domain.TUnifyFile;
import com.ruoyi.tool.service.ITUnifyFileService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.ruoyi.common.annotation.Log;
import com.ruoyi.common.core.controller.BaseController;
import com.ruoyi.common.core.domain.AjaxResult;
import com.ruoyi.common.enums.BusinessType;
import com.ruoyi.invest.domain.TProjectInvestigate;
import com.ruoyi.invest.service.ITProjectInvestigateService;
import com.ruoyi.common.utils.poi.ExcelUtil;
import com.ruoyi.common.core.page.TableDataInfo;

/**
 * 尽调关联Controller
 * 
 * @author zjc
 * @date 2024-03-13
 */
@Api(tags = "尽职背调")
@RestController
@RequestMapping("/invest/investigate")
public class TProjectInvestigateController extends BaseController
{
    @Autowired
    private ITProjectInvestigateService tProjectInvestigateService;

    @Autowired
    private ITProjectCirculationService tProjectCirculationService;

    @Autowired
    private ITUnifyFileService tUnifyFileService;

    /**
     * 查询尽调关联列表
     */
    @ApiOperation("查询尽调关联列表")
    @GetMapping("/list")
    public TableDataInfo list(TProjectInvestigate tProjectInvestigate)
    {
        startPage();
        List<TProjectInvestigate> list = tProjectInvestigateService.selectTProjectInvestigateList(tProjectInvestigate);
        return getDataTable(list);
    }

    /**
     * 导出尽调关联列表
     */
    @ApiOperation("导出尽调关联列表")
    @Log(title = "尽调关联", businessType = BusinessType.EXPORT)
    @PostMapping("/export")
    public void export(HttpServletResponse response, TProjectInvestigate tProjectInvestigate)
    {
        List<TProjectInvestigate> list = tProjectInvestigateService.selectTProjectInvestigateList(tProjectInvestigate);
        ExcelUtil<TProjectInvestigate> util = new ExcelUtil<TProjectInvestigate>(TProjectInvestigate.class);
        util.exportExcel(response, list, "尽调关联数据");
    }

    /**
     * 获取尽调关联详细信息
     */
    @ApiOperation("获取尽调关联详细信息")
    @GetMapping(value = "/{id}")
    public AjaxResult getInfo(@PathVariable("id") String id)
    {
        return success(tProjectInvestigateService.selectTProjectInvestigateById(id));
    }

    /**
     * 新增尽调关联
     */
    @ApiOperation("新增尽调关联")
    @Log(title = "尽调关联", businessType = BusinessType.INSERT)
    @PostMapping
    public AjaxResult add(@RequestBody TProjectInvestigate tProjectInvestigate)
    {
        tProjectInvestigate.setId(IdUtils.fastSimpleUUID());
        // todo 保存附件信息
        List<TUnifyFile> tUnifyFileList = tProjectInvestigate.getListFile();
        if(!tUnifyFileList.isEmpty()){
            for (TUnifyFile tUnifyFile:
                    tUnifyFileList) {
                tUnifyFile.setFileId(tProjectInvestigate.getProjectPoolId());
                tUnifyFile.setFileBusinessId(tProjectInvestigate.getId());//尽调ID
                tUnifyFile.setUploadType(String.valueOf(FileType.INVESTIGATE.ordinal()));//文件类型:尽调
                tUnifyFile.setCreateBy(getNickName());
                tUnifyFileService.insertTUnifyFile(tUnifyFile);
            }
        }

        // todo 增加尽调创建记录
        TProjectCirculation tProjectCirculation = new TProjectCirculation();
        tProjectCirculation.setProjectPoolId(tProjectInvestigate.getProjectPoolId());
        tProjectCirculation.setStageName(tProjectInvestigate.getInvestigateName()+"(尽职背调)");
        tProjectCirculation.setCreateBy(getNickName());
        tProjectCirculationService.insertTProjectCirculation(tProjectCirculation);

        return toAjax(tProjectInvestigateService.insertTProjectInvestigate(tProjectInvestigate));
    }

    /**
     * 修改尽调关联
     */
    @ApiOperation("修改尽调关联")
    @Log(title = "尽调关联", businessType = BusinessType.UPDATE)
    @PutMapping
    public AjaxResult edit(@RequestBody TProjectInvestigate tProjectInvestigate)
    {
        // todo 保存附件信息
        List<TUnifyFile> tUnifyFileList = tProjectInvestigate.getListFile();
        if(!tUnifyFileList.isEmpty()){
            for (TUnifyFile tUnifyFile:
                    tUnifyFileList) {
                if(tUnifyFile.getId() == null){
                    tUnifyFile.setFileId(tProjectInvestigate.getProjectPoolId());
                    tUnifyFile.setFileBusinessId(tProjectInvestigate.getId());//尽调ID
                    tUnifyFile.setUploadType(String.valueOf(FileType.INVESTIGATE.ordinal()));//文件类型:尽调
                    tUnifyFile.setCreateBy(getNickName());
                    tUnifyFileService.insertTUnifyFile(tUnifyFile);
                }
            }
        }
        return toAjax(tProjectInvestigateService.updateTProjectInvestigate(tProjectInvestigate));
    }

    /**
     * 删除尽调关联
     */
    @ApiOperation("删除尽调关联")
    @Log(title = "尽调关联", businessType = BusinessType.DELETE)
	@DeleteMapping("/{ids}")
    public AjaxResult remove(@PathVariable String[] ids)
    {
        return toAjax(tProjectInvestigateService.updateTProjectInvestigateByIds(ids));
    }

    /**
     * 根据项目ID获取尽调
     */
    @ApiOperation("根据项目ID获取尽调数据")
    @GetMapping(value = "/listProjectPoolId")
    public AjaxResult listProjectPoolId(String projectPoolId)
    {
        if (StringUtils.isEmpty(projectPoolId))
        {
            return error("查询尽调数据失败,请提供项目ID!");
        }
        TProjectInvestigate tProjectInvestigate = tProjectInvestigateService.listProjectPoolId(projectPoolId);
        AjaxResult ajax = AjaxResult.success();
        ajax.put("tProjectInvestigate", tProjectInvestigate);
        return ajax;
    }

    /**
     * 修改尽调完成
     */
    @ApiOperation("修改尽调完成")
    @Log(title = "修改尽调完成", businessType = BusinessType.UPDATE)
    @DeleteMapping("/editStatus")
    public AjaxResult editStatus(String id)
    {
        return toAjax(tProjectInvestigateService.editStatus(id));
    }


}