WarehouseController.java 4.82 KB
package com.huaheng.pc.general.warehouse.controller;

import com.huaheng.common.support.Convert;
import com.huaheng.common.utils.StringUtils;
import com.huaheng.common.utils.security.ShiroUtils;
import com.huaheng.pc.general.warehouse.domain.WarehouseWu;
import com.huaheng.pc.inventory.inventory.domain.Inventory;
import com.huaheng.pc.inventory.inventory.service.IInventoryService;
import com.huaheng.pc.system.dict.service.IDictDataService;
import com.huaheng.pc.system.dict.service.IDictTypeService;
import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import com.huaheng.framework.aspectj.lang.annotation.Log;
import com.huaheng.framework.aspectj.lang.constant.BusinessType;
import com.huaheng.pc.general.warehouse.domain.Warehouse;
import com.huaheng.pc.general.warehouse.service.IWarehouseService;
import com.huaheng.framework.web.controller.BaseController;
import com.huaheng.framework.web.domain.AjaxResult;
import com.huaheng.framework.web.page.TableDataInfo;

import javax.annotation.Resource;
import java.util.List;
import java.util.Map;

/**
 * 仓库 信息操作处理
 * 
 * @author huaheng
 * @date 2018-08-19
 */
@Controller
@RequestMapping("/general/warehouse")
public class WarehouseController extends BaseController
{
    private String prefix = "general/warehouse";
	

	@Autowired
	private IDictDataService dictDataService;
	@Autowired
	private IDictTypeService dictTypeService;
    @Autowired
    private IWarehouseService warehouseService;
    @Resource
    private IInventoryService inventoryService;

	
	@RequiresPermissions("general:warehouse:view")
	@GetMapping()
	public String warehouse()
	{
	    return prefix + "/warehouse";
	}
	
	/**
	 * 查询仓库列表
	 */
	@RequiresPermissions("general:warehouse:list")
	@Log(title = "通用-仓库管理", operating = "查看仓库列表", action = BusinessType.GRANT)
	@PostMapping("/list")
	@ResponseBody
	public TableDataInfo list(Warehouse warehouse)
	{
        warehouse.setDeleted(false);
		startPage();
		List<Warehouse> list = warehouseService.selectListEntityByLike(warehouse) ;
		return getDataTable(list);
	}
	
	/**
	 * 新增仓库
	 */
	@GetMapping("/add")
	public String add()
	{
	    return prefix + "/add";
	}
	
	/**
	 * 新增保存仓库
	 */
	@RequiresPermissions("general:warehouse:add")
	@Log(title = "通用-仓库管理", operating = "新增仓库", action = BusinessType.INSERT)
	@PostMapping("/add")
	@ResponseBody
	public AjaxResult addSave(Warehouse warehouse)
	{
		warehouse.setCreatedBy(ShiroUtils.getLoginName());
		warehouse.setLastUpdatedBy(ShiroUtils.getLoginName());
		return toAjax(warehouseService.insertWarehouseAndDict(warehouse));
	}

	/**
	 * 修改仓库
	 */
	@GetMapping("/edit/{id}")
	public String edit(@PathVariable("id") Integer id, ModelMap mmap)
	{
		Warehouse warehouse = warehouseService.selectEntityById(id);
		mmap.put("warehouse", warehouse);
	    return prefix + "/edit";
	}
	
	/**
	 * 修改保存仓库
	 */
	@RequiresPermissions("general:warehouse:edit")
	@Log(title = "通用-仓库管理", operating = "修改仓库", action = BusinessType.UPDATE)
	@PostMapping("/edit")
	@ResponseBody
	public AjaxResult editSave(Warehouse warehouse)
	{
		warehouse.setLastUpdatedBy(ShiroUtils.getLoginName());
		return toAjax(warehouseService.updateByModel(warehouse));
	}
	
	/**
	 * 删除仓库
	 */
	@RequiresPermissions("general:warehouse:remove")
	@Log(title = "通用-仓库管理", operating = "删除仓库", action = BusinessType.DELETE)
	@PostMapping( "/remove")
	@ResponseBody
	public AjaxResult remove(String ids)
	{
		if (StringUtils.isEmpty(ids))
			return AjaxResult.error("id不能为空");
		for (Integer id : Convert.toIntArray(ids))
		{
			Warehouse warehouse = new Warehouse();
            Inventory inventory = new Inventory();
            inventory.setWarehouseId(id);
            inventory.setCompanyCode(warehouse.getCode());
            Map<String, Object> map = inventoryService.selectFirstMap("id", inventory);
            if (map != null) {
                return AjaxResult.error("仓库编码(" + warehouse.getCode() +")还有库存,不能删除!");
            }
            warehouse.setId(id);
            warehouse.setLastUpdatedBy(ShiroUtils.getLoginName());
            warehouse.setDeleted(true);
			warehouseService.updateByModel(warehouse);
			dictDataService.deleteDictDataByWarehouseId(id);
			dictTypeService.deleteDictTypeByWarehouseId(id);
		}
		return AjaxResult.success("删除成功!");
	}

}