package com.zy.crm.manager.controller; 
 | 
  
 | 
import com.alibaba.fastjson.JSONObject; 
 | 
import com.baomidou.mybatisplus.mapper.EntityWrapper; 
 | 
import com.baomidou.mybatisplus.mapper.Wrapper; 
 | 
import com.baomidou.mybatisplus.plugins.Page; 
 | 
import com.core.annotations.ManagerAuth; 
 | 
import com.core.common.BaseRes; 
 | 
import com.core.common.Cools; 
 | 
import com.core.common.DateUtils; 
 | 
import com.core.common.R; 
 | 
import com.core.domain.KeyValueVo; 
 | 
import com.zy.crm.common.web.BaseController; 
 | 
import com.zy.crm.manager.entity.Reimburse; 
 | 
import com.zy.crm.manager.service.ReimburseService; 
 | 
import com.zy.crm.system.entity.User; 
 | 
import org.springframework.beans.factory.annotation.Autowired; 
 | 
import org.springframework.web.bind.annotation.*; 
 | 
  
 | 
import java.util.*; 
 | 
  
 | 
@RestController 
 | 
public class ReimburseController extends BaseController { 
 | 
  
 | 
    @Autowired 
 | 
    private ReimburseService reimburseService; 
 | 
  
 | 
    @RequestMapping(value = "/reimburse/{id}/auth") 
 | 
    @ManagerAuth 
 | 
    public R get(@PathVariable("id") String id) { 
 | 
        return R.ok(reimburseService.selectById(String.valueOf(id))); 
 | 
    } 
 | 
  
 | 
    @RequestMapping(value = "/reimburse/getSheetData/{id}/auth") 
 | 
    @ManagerAuth 
 | 
    public String getSheetData(@PathVariable("id") String id) { 
 | 
        return reimburseService.selectById(String.valueOf(id)).getSheetData(); 
 | 
    } 
 | 
  
 | 
    @RequestMapping(value = "/reimburse/list/auth") 
 | 
    @ManagerAuth 
 | 
    public R list(@RequestParam(defaultValue = "1")Integer curr, 
 | 
                  @RequestParam(defaultValue = "10")Integer limit, 
 | 
                  @RequestParam(required = false)String orderByField, 
 | 
                  @RequestParam(required = false)String orderByType, 
 | 
                  @RequestParam(required = false)String condition, 
 | 
                  @RequestParam Map<String, Object> param){ 
 | 
        EntityWrapper<Reimburse> wrapper = new EntityWrapper<>(); 
 | 
        wrapper.setSqlSelect("id,title,create_time as createTime,filepath,user_id as userId,status,update_time as updateTime"); 
 | 
        excludeTrash(param); 
 | 
        convert(param, wrapper); 
 | 
        allLike(Reimburse.class, param.keySet(), wrapper, condition); 
 | 
        if (!Cools.isEmpty(orderByField)){wrapper.orderBy(humpToLine(orderByField), "asc".equals(orderByType));} 
 | 
        return R.ok(reimburseService.selectPage(new Page<>(curr, limit), wrapper)); 
 | 
    } 
 | 
  
 | 
    private <T> void convert(Map<String, Object> map, EntityWrapper<T> wrapper){ 
 | 
        for (Map.Entry<String, Object> entry : map.entrySet()){ 
 | 
            String val = String.valueOf(entry.getValue()); 
 | 
            if (val.contains(RANGE_TIME_LINK)){ 
 | 
                String[] dates = val.split(RANGE_TIME_LINK); 
 | 
                wrapper.ge(entry.getKey(), DateUtils.convert(dates[0])); 
 | 
                wrapper.le(entry.getKey(), DateUtils.convert(dates[1])); 
 | 
            } else { 
 | 
                wrapper.like(entry.getKey(), val); 
 | 
            } 
 | 
        } 
 | 
    } 
 | 
  
 | 
    @RequestMapping(value = "/reimburse/add/auth") 
 | 
    @ManagerAuth 
 | 
    public R add(@RequestBody Map<String,Object> map) { 
 | 
        User user = getUser(); 
 | 
        if(!user.getRoleCode().equals("boss") && !user.getDeptName().equals("核价组")){ 
 | 
            return R.error("权限不足,禁止新增模板"); 
 | 
        } 
 | 
  
 | 
        Reimburse reimburse = new Reimburse(); 
 | 
        reimburse.setTitle(map.get("title").toString()); 
 | 
        reimburse.setSheetData(map.get("sheetData").toString()); 
 | 
        reimburse.setCreateTime(new Date()); 
 | 
        reimburse.setUpdateTime(new Date()); 
 | 
        reimburse.setUserId(getUserId()); 
 | 
        reimburse.setStatus(1); 
 | 
//        if (!pri.getSheetData().isEmpty()) { 
 | 
//            //保存excel文件 
 | 
//            String filepath = ExcelUtils.saveExcelFile(pri.getTitle(), pri.getSheetData()); 
 | 
//            pri.setFilepath(filepath); 
 | 
//        } 
 | 
        reimburseService.insert(reimburse); 
 | 
        return R.ok(); 
 | 
    } 
 | 
  
 | 
    @RequestMapping(value = "/reimburse/update/auth") 
 | 
    @ManagerAuth 
 | 
    public R update(@RequestBody Map<String,Object> map){ 
 | 
        User user = getUser(); 
 | 
        if(!user.getRoleCode().equals("boss") && !user.getDeptName().equals("核价组")){ 
 | 
            return R.error("权限不足,禁止更新模板"); 
 | 
        } 
 | 
  
 | 
        Reimburse reimburse = reimburseService.selectById(Long.parseLong(map.get("id").toString())); 
 | 
        reimburse.setTitle(map.get("title").toString()); 
 | 
        reimburse.setSheetData(map.get("sheetData").toString()); 
 | 
        reimburse.setUpdateTime(new Date()); 
 | 
        reimburseService.updateById(reimburse); 
 | 
        return R.ok(); 
 | 
    } 
 | 
  
 | 
    @RequestMapping(value = "/reimburse/updateStatus/auth") 
 | 
    @ManagerAuth 
 | 
    public R update(Long id,Integer status){ 
 | 
        User user = getUser(); 
 | 
        if(!user.getRoleCode().equals("boss") && !user.getDeptName().equals("核价组")){ 
 | 
            return R.error("权限不足,禁止更新模板"); 
 | 
        } 
 | 
  
 | 
        Reimburse reimburse = reimburseService.selectById(id); 
 | 
        reimburse.setStatus(status); 
 | 
        reimburse.setUpdateTime(new Date()); 
 | 
        reimburseService.updateById(reimburse); 
 | 
        return R.ok(); 
 | 
    } 
 | 
  
 | 
    @RequestMapping(value = "/reimburse/delete/auth") 
 | 
    @ManagerAuth 
 | 
    public R delete(Long[] ids){ 
 | 
        User user = getUser(); 
 | 
        if(!user.getRoleCode().equals("boss") && !user.getDeptName().equals("核价组")){ 
 | 
            return R.error("权限不足,禁止删除模板"); 
 | 
        } 
 | 
  
 | 
        if (Cools.isEmpty(ids)){ 
 | 
            return R.error(); 
 | 
        } 
 | 
        reimburseService.deleteBatchIds(Arrays.asList(ids)); 
 | 
        return R.ok(); 
 | 
    } 
 | 
  
 | 
    @RequestMapping(value = "/reimburse/export/auth") 
 | 
    @ManagerAuth 
 | 
    public R export(@RequestBody JSONObject param){ 
 | 
        EntityWrapper<Reimburse> wrapper = new EntityWrapper<>(); 
 | 
        List<String> fields = JSONObject.parseArray(param.getJSONArray("fields").toJSONString(), String.class); 
 | 
        Map<String, Object> map = excludeTrash(param.getJSONObject("pri")); 
 | 
        convert(map, wrapper); 
 | 
        List<Reimburse> list = reimburseService.selectList(wrapper); 
 | 
        return R.ok(exportSupport(list, fields)); 
 | 
    } 
 | 
  
 | 
    @RequestMapping(value = "/reimburseQuery/auth") 
 | 
    @ManagerAuth 
 | 
    public R query(String condition) { 
 | 
        EntityWrapper<Reimburse> wrapper = new EntityWrapper<>(); 
 | 
        wrapper.like("id", condition); 
 | 
        Page<Reimburse> page = reimburseService.selectPage(new Page<>(0, 10), wrapper); 
 | 
        List<Map<String, Object>> result = new ArrayList<>(); 
 | 
        for (Reimburse pri : page.getRecords()){ 
 | 
            Map<String, Object> map = new HashMap<>(); 
 | 
            map.put("id", pri.getId()); 
 | 
            map.put("value", pri.getTitle()); 
 | 
            result.add(map); 
 | 
        } 
 | 
        return R.ok(result); 
 | 
    } 
 | 
  
 | 
    @RequestMapping(value = "/reimburse/check/column/auth") 
 | 
    @ManagerAuth 
 | 
    public R query(@RequestBody JSONObject param) { 
 | 
        Wrapper<Reimburse> wrapper = new EntityWrapper<Reimburse>().eq(humpToLine(String.valueOf(param.get("key"))), param.get("val")); 
 | 
        if (null != reimburseService.selectOne(wrapper)){ 
 | 
            return R.parse(BaseRes.REPEAT).add(getComment(Reimburse.class, String.valueOf(param.get("key")))); 
 | 
        } 
 | 
        return R.ok(); 
 | 
    } 
 | 
  
 | 
    @RequestMapping("/reimburse/all/get/kv") 
 | 
    @ManagerAuth 
 | 
    public R getDataKV(@RequestParam(required = false) String condition) { 
 | 
        List<KeyValueVo> vos = new ArrayList<>(); 
 | 
        Wrapper<Reimburse> wrapper = new EntityWrapper<Reimburse>().andNew().like("id", condition).orderBy("create_time", false); 
 | 
        reimburseService.selectPage(new Page<>(1, 30), wrapper).getRecords().forEach(item -> vos.add(new KeyValueVo(String.valueOf(item.getId()), item.getId()))); 
 | 
        return R.ok().add(vos); 
 | 
    } 
 | 
  
 | 
} 
 |