package com.ruoyi.web.controller.project; import java.util.Arrays; import java.util.List; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import lombok.extern.slf4j.Slf4j; 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.annotation.RepeatSubmit; import com.ruoyi.common.core.controller.BaseController; import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.common.enums.BusinessType; import com.ruoyi.project.domain.BaseItemexpense; import com.ruoyi.project.service.IBaseItemexpenseService; import com.ruoyi.common.utils.poi.ExcelUtil; import com.ruoyi.common.core.page.TableDataInfo; /** * 收入费用科目Controller * * @author ruoyi * @date 2022-05-11 */ @Slf4j @Api("收入费用科目") @RestController @RequestMapping("/project/itemexpense") public class BaseItemexpenseController extends BaseController { @Autowired private IBaseItemexpenseService baseItemexpenseService; /** * 查询收入费用科目列表 */ @ApiOperation("查询收入费用科目列表") @GetMapping("/list") public TableDataInfo list(BaseItemexpense baseItemexpense) { log.info("查询收入费用科目列表{}:" , baseItemexpense); startPage(); List list = baseItemexpenseService.queryList(baseItemexpense); return getDataTable(list); } /** * 导出收入费用科目列表 */ @ApiOperation("导出收入费用科目列表") @Log(title = "收入费用科目", businessType = BusinessType.EXPORT) @GetMapping("/export") public AjaxResult export(BaseItemexpense baseItemexpense) { log.info("导出收入费用科目列表{}:" , baseItemexpense); List list = baseItemexpenseService.queryList(baseItemexpense); ExcelUtil util = new ExcelUtil(BaseItemexpense.class); return util.exportExcel(list, "收入费用科目数据"); } /** * 获取收入费用科目详细信息 */ @ApiOperation("获取收入费用科目详细信息") @GetMapping(value = "/{id}") public AjaxResult getInfo(@PathVariable("id") Long id) { log.info("获取收入费用科目详细信息{}:" , id); return AjaxResult.success(baseItemexpenseService.getById(id)); } /** * 新增收入费用科目 */ @ApiOperation("新增收入费用科目") @Log(title = "收入费用科目", businessType = BusinessType.INSERT) @PostMapping @RepeatSubmit public AjaxResult add(@RequestBody BaseItemexpense baseItemexpense) { log.info("新增收入费用科目{}:" , baseItemexpense); return toAjax(baseItemexpenseService.save(baseItemexpense)); } /** * 修改收入费用科目 */ @ApiOperation("修改收入费用科目") @Log(title = "收入费用科目", businessType = BusinessType.UPDATE) @PostMapping("/edit") @RepeatSubmit public AjaxResult edit(@RequestBody BaseItemexpense baseItemexpense) { log.info("修改收入费用科目{}:" , baseItemexpense); return toAjax(baseItemexpenseService.updateById(baseItemexpense)); } /** * 删除收入费用科目 */ @ApiOperation("删除收入费用科目") @Log(title = "收入费用科目", businessType = BusinessType.DELETE) @GetMapping("/remove/{ids}") public AjaxResult remove(@PathVariable Long[] ids) { log.info("删除收入费用科目{}:" , ids); return toAjax(baseItemexpenseService.removeByIds(Arrays.asList(ids))); } /** * 通过项目id获取收入费用科目详细信息 */ @ApiOperation("通过项目id获取收入费用科目详细信息") @GetMapping(value = "/getDetailsByItemId/{itemid}") public AjaxResult getDetailsByItemId(@PathVariable("itemid") Long itemid) { log.info("通过项目id获取收入费用科目详细信息{}:" , itemid); return AjaxResult.success(baseItemexpenseService.getDetailsByItemId(itemid)); } }