LocationController.java 14.6 KB
package com.huaheng.pc.config.location.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.config.container.domain.Container;
import com.huaheng.pc.config.location.domain.Location;
import com.huaheng.pc.config.location.domain.LocationStatus;
import com.huaheng.pc.config.location.service.LocationService;
import com.huaheng.pc.config.material.domain.Material;
import com.huaheng.pc.config.material.service.MaterialService;
import com.huaheng.pc.config.materialType.service.MaterialTypeService;
import com.huaheng.pc.inventory.inventoryDetail.domain.InventoryDetail;
import com.huaheng.pc.inventory.inventoryDetail.service.InventoryDetailService;
import com.huaheng.pc.inventory.inventoryHeader.domain.InventoryHeader;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiParam;
import io.swagger.models.auth.In;
import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.*;

import javax.annotation.Resource;
import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors;

@Api(tags={"库位操作类"})
@Controller
@RequestMapping("/config/location")
public class LocationController extends BaseController {

    private String prefix = "config/location";
    
    @Resource
    private LocationService locationService;
    @Resource
    private InventoryDetailService inventoryDetailService;
    @Resource
    private MaterialService materialService;

    @RequiresPermissions("config:location:view")
    @GetMapping()
    public String location() {
        return prefix + "/location";
    }

    /**
     * 查询库位列表
     */
    @ApiOperation(value="查看库位列表",
            notes="根据行、列、层、格、库位类型、库区、库位状态、容器编码、库位名称、库位编码、创建时间获取库位的详细信息",
            httpMethod = "POST")
    @RequiresPermissions("config:location:list")
    @Log(title = "配置-库存资料-库位管理", operating = "查看库位列表", action = BusinessType.GRANT)
    @PostMapping("/list")
    @ResponseBody
    public TableDataInfo list(
            @ApiParam(name="location",value="行、列、层、格、库位类型、库区、库位状态、容器编码、库位名称、库位编码") Location location,
            @ApiParam(name = "createdBegin", value = "起止时间") String createdBegin,
            @ApiParam(name = "createdEnd", value = "结束时间") String createdEnd) {
        LambdaQueryWrapper<Location> lambdaQueryWrapper = Wrappers.lambdaQuery();
        PageDomain pageDomain = TableSupport.buildPageRequest();
        Integer pageNum = pageDomain.getPageNum();
        Integer pageSize = pageDomain.getPageSize();
        lambdaQueryWrapper.gt(StringUtils.isNotEmpty(createdBegin), Location::getCreated, createdBegin)
                .lt(StringUtils.isNotEmpty(createdEnd), Location::getCreated, createdEnd)
                .eq(Location::getWarehouseCode,ShiroUtils.getWarehouseCode())
                .eq(StringUtils.isNotEmpty(location.getCode()), Location::getCode, location.getCode())
                .eq(StringUtils.isNotEmpty(location.getName()), Location::getName,location.getName())
                .eq(StringUtils.isNotEmpty(location.getContainerCode()), Location::getContainerCode, location.getContainerCode())
                .eq(StringUtils.isNotNull(location.getSystemCreated()), Location::getStatus, location.getStatus())
                .eq(StringUtils.isNotEmpty(location.getZoneCode()), Location::getZoneCode, location.getZoneCode())
                .eq(StringUtils.isNotNull(location.getIRow()), Location::getIRow, location.getIRow())
                .eq(StringUtils.isNotNull(location.getIColumn()), Location::getIColumn, location.getIColumn())
                .eq(StringUtils.isNotNull(location.getIGrid()), Location::getIGrid, location.getIGrid())
                .eq(StringUtils.isNotNull(location.getILayer()), Location::getILayer, location.getILayer())
                .eq(StringUtils.isNotEmpty(location.getStatus()),Location::getStatus,location.getStatus())
                .eq(StringUtils.isNotEmpty(location.getLocationType()), Location::getLocationType, location.getLocationType())
                .eq(Location::getDeleted,false)
                .orderByDesc(Location::getId);

        if (StringUtils.isNotNull(pageNum) && StringUtils.isNotNull(pageSize)){
            /*使用分页查询*/
            Page<Location> page = new Page<>(pageNum, pageSize);
            IPage<Location> iPage = locationService.page(page, lambdaQueryWrapper);
            return getMpDataTable(iPage.getRecords(), iPage.getTotal());
        } else {
            List<Location> list = locationService.list(lambdaQueryWrapper);
            return getDataTable(list);
        }
    }

    /**
     * 查询库位列表
     */
    @Log(title = "配置-库存资料-库位管理", operating = "查看库位列表", action = BusinessType.GRANT)
    @PostMapping("/getAllLocation")
    @ResponseBody
    public AjaxResult getAllLocation(String type)  {
        if (StringUtils.isEmpty(type)) {
            return AjaxResult.error("type不能为空");
        }

        return AjaxResult.success(locationService.getAllLocation(type));
    }


    /**
     * 新增库位
     */
    @GetMapping("/add")
    public String add() {
        return prefix + "/add";
    }

    /**
     * 新增保存库位
     */
    @ApiOperation(value="新增库位", notes="新增单个库位", httpMethod = "POST")
    @RequiresPermissions("config:location:add")
    @Log(title = "配置-库存资料-库位管理", operating = "新增库位", action = BusinessType.INSERT)
    @PostMapping("/add")
    @ResponseBody
    public AjaxResult addSave(Location location)  {
        AjaxResult result = locationService.addsave(location);
        return result;
    }


    /**
     * 批量新增库位
     */

    @GetMapping("/addBatch")
    public String addBatch()
    {
        return prefix + "/addBatch";
    }

    /**
     * 批量新增保存库位
     */
    @RequiresPermissions("config:location:addBatch")
    @ApiOperation(value="新增库位", notes="批量新增库位", httpMethod = "POST")
    @Log(title = "配置-库存资料-库位管理", operating = "新增库位", action = BusinessType.INSERT)
    @PostMapping("/addBatchSave")
    @ResponseBody
    public AjaxResult addBatchSave(Location lastLocation)  {
        return toAjax(locationService.insertLocation(lastLocation));
    }

    /**
     * 修改库位
     */
    @GetMapping("/edit/{id}")
    public String edit(@PathVariable("id") Integer id, ModelMap mmap) {
        mmap.put("location", locationService.getById(id));
        return prefix + "/edit";
    }

    /**
     * 修改保存库位
     */
    @RequiresPermissions("config:location:edit")
    @ApiOperation(value="修改库位", notes="批量修改库位", httpMethod = "POST")
    @Log(title = "配置-库存资料-库位管理", operating = "修改库位", action = BusinessType.UPDATE)
    @PostMapping("/edit")
    @ResponseBody
    public AjaxResult editSave(Location location) {
        location.setLastUpdatedBy(ShiroUtils.getLoginName());
        return toAjax(locationService.updateById(location));
    }

    /**
     * 删除库位
     */
    @RequiresPermissions("config:location:remove")
    @Log(title = "配置库存资料-库位管理", operating = "删除库位", action = BusinessType.DELETE)
    @ApiOperation(value="删除库位", notes="批量删除库位", httpMethod = "POST")
    @PostMapping( "/remove")
    @ResponseBody
    public AjaxResult remove(String ids) {
        if (StringUtils.isEmpty(ids)){
            return AjaxResult.error("id不能为空");
        }
        for (Integer id : Convert.toIntArray(ids)) {
            Location location = locationService.getById(id);
            if (StringUtils.isEmpty(location.getContainerCode())) {
                location.setDeleted(true);
                location.setLastUpdatedBy(ShiroUtils.getLoginName());
                locationService.updateById(location);
            }
            else    {
                return AjaxResult.error("库位(" + location.getCode() + ")不是空,或者有容器,不能删除成功!");
            }
        }
        return AjaxResult.success("删除成功!");
    }

    /**
     * 查询库位列表
     */
    @Log(title = "配置-库存资料-库位管理", operating = "查看库位列表", action = BusinessType.GRANT)
    @PostMapping("/getLocationInfo")
    @ResponseBody
    public AjaxResult getLocationInfo(String type, String row, String line, String layer, String grid)  {
        if (StringUtils.isEmpty(type)) {
            return AjaxResult.error("type不能为空");
        }

        /* 查询库位信息*/
        LambdaQueryWrapper<Location> locationLambdaQueryWrapper = Wrappers.lambdaQuery();
        locationLambdaQueryWrapper.eq(StringUtils.isNotEmpty(row), Location::getIRow, row)
                .eq(StringUtils.isNotEmpty(line), Location::getIColumn, line)
                .eq(StringUtils.isNotEmpty(layer), Location::getILayer, layer)
                .eq(Location::getIGrid, 1) //
                .eq(StringUtils.isNotEmpty(type), Location::getLocationType, type)
                .eq(Location::getWarehouseCode, ShiroUtils.getWarehouseCode())
                .eq(StringUtils.isNotEmpty(type), Location::getZoneCode, type);
        List<Location> locations = locationService.list(locationLambdaQueryWrapper);
        List<Location> locationList = new ArrayList<>();

        /* 查询库存明细*/
        LambdaQueryWrapper<InventoryDetail> inventoryDetailLambda = Wrappers.lambdaQuery();
        inventoryDetailLambda.eq(InventoryDetail::getWarehouseCode, ShiroUtils.getWarehouseCode());
        List<InventoryDetail> inventoryDetailList = inventoryDetailService.list(inventoryDetailLambda);

        for(Location location1 : locations) {
            InventoryDetail inventoryDetail = null;
            String materialName = null;
            for (InventoryDetail inventoryDetail2: inventoryDetailList) {
                if (location1.getCode().equals(inventoryDetail2.getLocationCode())){
                    inventoryDetail = inventoryDetail2;
                }
            }
            List<InventoryDetail> inventoryDetails = inventoryDetailList.stream().filter(inventoryDetail1 ->
                    inventoryDetail1.getLocationCode().equals(location1.getCode())).collect(Collectors.toList());

            int userDef3 = 0;
            String status = location1.getStatus();
            String containerCode = location1.getContainerCode();
            List<String> materialNameList = inventoryDetails.stream().map(InventoryDetail::getMaterialName).collect(Collectors.toList());
            List<String> batchList = inventoryDetails.stream().map(InventoryDetail::getBatch).collect(Collectors.toList());
            List<String> materialCodeList = inventoryDetails.stream().map(InventoryDetail::getMaterialCode).collect(Collectors.toList());
            List<BigDecimal> qtyList = inventoryDetails.stream().map(InventoryDetail::getQty).collect(Collectors.toList());
            if ("empty".equals(status)) {
                if(StringUtils.isEmpty(containerCode)) {
                    userDef3 = LocationStatus.IDLE_EMPTY_LOCATION;
                } else {
                    if(inventoryDetail == null) {
                        userDef3 = LocationStatus.IDLE_EMPTY_CONTAINER;
                    } else {
                        location1.setMaterialName(materialNameList);
                        location1.setMaterialCode(materialCodeList);
                        location1.setBatch(batchList);
                        location1.setQty(qtyList);
                        userDef3 = LocationStatus.IDLE_FULL_CONTAINER;
                    }
                }
            } else if("lock".equals(status)) {
                if(StringUtils.isEmpty(containerCode)) {
                    userDef3 = LocationStatus.LOCK_EMPTY_LOCATION;
                } else {
                    if(inventoryDetail == null) {
                        userDef3 = LocationStatus.LOCK_EMPTY_CONTAINER;
                    } else {
                        location1.setMaterialName(materialNameList);
                        location1.setMaterialCode(materialCodeList);
                        location1.setBatch(batchList);
                        location1.setQty(qtyList);
                        userDef3 = LocationStatus.LOCK_FULL_CONTAINER;
                    }
                }
            }

            if (location1.getDeleted()) {
                if(StringUtils.isEmpty(containerCode)) {
                    userDef3 = LocationStatus.DISABLE_EMPTY_LOCATION;
                } else {
                    if(inventoryDetail == null) {
                        userDef3 = LocationStatus.DISABLE_EMPTY_CONTAINER;
                    } else {
                        location1.setMaterialName(materialNameList);
                        location1.setMaterialCode(materialCodeList);
                        location1.setBatch(batchList);
                        location1.setQty(qtyList);
                        userDef3 = LocationStatus.DISABLE_FULL_CONTAINER;
                    }
                }
            }

            location1.setUserDef3(String.valueOf(userDef3));
            locationList.add(location1);
        }
        return AjaxResult.success(locations);
    }


    @RequiresPermissions("iconfig:location:print")
    @Log(title = "配置-库存资料-库位条码", operating = "库位条码打印", action = BusinessType.OTHER)
    @GetMapping("/print/{ids}")
    public String print(@PathVariable("ids") Integer[] ids, ModelMap mmap)
    {
        List<Location> list = new ArrayList<>();
        for(Integer id:ids){
            if(id != null) {
                Location location = locationService.getById(id);
                list.add(location);
            }
            mmap.put("location", list);
        }
        return prefix + "/print";
    }
}