package com.huaheng.pc.plc.controller; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.huaheng.common.support.Convert; import com.huaheng.common.utils.StringUtils; import com.huaheng.common.utils.security.ShiroUtils; import com.huaheng.framework.aspectj.lang.annotation.Log; import com.huaheng.framework.aspectj.lang.constant.BusinessType; import com.huaheng.framework.web.controller.BaseController; import com.huaheng.framework.web.domain.AjaxResult; import com.huaheng.framework.web.page.PageDomain; import com.huaheng.framework.web.page.TableDataInfo; import com.huaheng.framework.web.page.TableSupport; import com.huaheng.pc.common.JasperPrint.Print; import com.huaheng.pc.plc.domain.PlcEquipment; import com.huaheng.pc.plc.service.EquipmentService; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiParam; import org.apache.shiro.authz.annotation.RequiresPermissions; import org.springframework.stereotype.Controller; import org.springframework.transaction.annotation.Transactional; import org.springframework.ui.ModelMap; import org.springframework.web.bind.annotation.*; import javax.annotation.Resource; import java.util.Arrays; import java.util.Date; import java.util.List; /** * @author:zhouhong * 设备管理 * 202203 */ @Api(tags={"设备管理类"}) @Controller @RequestMapping("/plc/equipment") public class EquipmnetController extends BaseController { @Resource private EquipmentService equipmentService; private String prefix = "plc/equipment"; @Resource private Print print; @RequiresPermissions("plc:equipment:list") @GetMapping() public String tolist() { return prefix + "/equipmentlist"; } /** * 查询列表 */ @ApiOperation(value="查询列表", notes="根据名称查询信息", httpMethod = "POST") @RequiresPermissions("plc:equipment:list") @Log(title = "配置-plc-设备管理", operating = "查看列表", action = BusinessType.GRANT) @PostMapping("/list") @ResponseBody public TableDataInfo list( @ApiParam(name="equipmentName",value="设备名称") String equipmentName, @ApiParam(name = "status", value = "启用状态") String status) { LambdaQueryWrapper<PlcEquipment> lambdaQueryWrapper = Wrappers.lambdaQuery(); PageDomain pageDomain = TableSupport.buildPageRequest(); Integer pageNum = pageDomain.getPageNum(); Integer pageSize = pageDomain.getPageSize(); lambdaQueryWrapper.eq(StringUtils.isNotEmpty(equipmentName), PlcEquipment::getEquipmentName,equipmentName) .eq(StringUtils.isNotEmpty(status), PlcEquipment::getStatus, status) .orderByDesc(PlcEquipment::getId); if (StringUtils.isNotNull(pageNum) && StringUtils.isNotNull(pageSize)){ /*使用分页查询*/ Page<PlcEquipment> page = new Page<>(pageNum, pageSize); IPage<PlcEquipment> iPage = equipmentService.page(page, lambdaQueryWrapper); return getMpDataTable(iPage.getRecords(), iPage.getTotal()); } else { List<PlcEquipment> list = equipmentService.list(lambdaQueryWrapper); return getDataTable(list); } } /** * 新增 */ @GetMapping("/add") public String add(ModelMap mmap) { return prefix + "/add"; } /** * 新增保存 */ @RequiresPermissions("plc:equipment:add") @Log(title = "设备管理", operating = "新增", action = BusinessType.INSERT) @PostMapping("/addSave") @Transactional(rollbackFor = Exception.class) @ResponseBody public AjaxResult addSave(PlcEquipment plcEquipment) { plcEquipment.setCreateBy(ShiroUtils.getName()); plcEquipment.setCreateTime(new Date()); //plcEquipment.seto AjaxResult ajaxResult = toAjax(equipmentService.save(plcEquipment)); return ajaxResult; } /** * 修改 */ @GetMapping("/edit/{id}") public String edit(@PathVariable("id") Integer id, ModelMap mmap) { mmap.put("equipment", equipmentService.getById(id)); return prefix + "/edit"; } /** * 修改保存 */ @RequiresPermissions("plc:equipment:edit") @Log(title = "修改保存", operating = "修改", action = BusinessType.UPDATE) @PostMapping("/edit") @Transactional(rollbackFor = Exception.class) @ResponseBody public AjaxResult editSave(PlcEquipment equipment) { equipment.setUpdateBy(ShiroUtils.getName()); equipment.setUpdateTime(new Date()); AjaxResult ajaxResult = toAjax(equipmentService.updateById(equipment)); return ajaxResult; } @RequiresPermissions("plc:equipment:remove") @Log(title = "删除", operating = "删除", action = BusinessType.DELETE) @PostMapping("/remove") @ResponseBody public AjaxResult remove(String ids) { try { return toAjax(equipmentService.removeByIds(Arrays.asList(Convert.toIntArray(ids)))); } catch (Exception e) { return error(e.getMessage()); } } @Log(title = "修改启用停用状态", operating = "修改状态", action = BusinessType.FORCE) @PostMapping("/updateStatus") @ResponseBody public AjaxResult updateStatus(@RequestParam("ids[]") String[] ids,int status) { LambdaQueryWrapper<PlcEquipment> lambdaQueryWrapper = Wrappers.lambdaQuery(); lambdaQueryWrapper.in(StringUtils.isNotEmpty(ids),PlcEquipment::getId,ids); PlcEquipment plcEquipment=new PlcEquipment(); plcEquipment.setStatus(status); plcEquipment.setUpdateTime(new Date()); plcEquipment.setUpdateBy(ShiroUtils.getName()); equipmentService.update(plcEquipment,lambdaQueryWrapper); return success(); } }