package com.product.org.admin.controller;

import java.util.Date;

import javax.servlet.http.HttpServletRequest;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

import com.product.core.config.CoreConst;
import com.product.core.controller.support.AbstractBaseController;
import com.product.core.dao.BaseDao;
import com.product.core.entity.DataTableEntity;
import com.product.core.entity.FieldSetEntity;
import com.product.core.entity.RequestParameterEntity;
import com.product.core.exception.BaseException;
import com.product.core.permission.PermissionService;
import com.product.core.spring.context.SpringMVCContextHolder;
import com.product.core.util.JsonUtil;
import com.product.module.sys.config.SystemErrorCode;
import com.product.module.sys.version.ApiVersion;
import com.product.org.admin.config.SystemCode;
import com.product.org.admin.service.DeptChangeService;
import com.product.org.admin.config.CmnCode;
import com.product.org.admin.config.CmnConst;
import com.product.common.lang.StringUtils;

/**
 * 
* Copyright  LX-BASE
* @Title: LX-BASE-
* @Project: DeptChangeController
* @Date:  2020-06-09 14:32   
* @Author: 鏉滄椽娉�
* @Description:閮ㄩ棬鍙樻洿
 */
@RestController
@RequestMapping("/api/dept")
public class DeptChangeController extends AbstractBaseController{
	
	@Autowired
	public BaseDao baseDao;
	
	@Autowired
	private DeptChangeService deptChangeService;
	
	@Autowired
	PermissionService permissionService;
	
	/**
	 * 	閮ㄩ棬鍙樻洿鍒楄〃
	 * @param request
	 * @return
	 */
	@RequestMapping(value = "/list-change/{version}", method = RequestMethod.POST)
	@ApiVersion(1)
	public String listDeptChange(HttpServletRequest request) {
		try {
			//鑾峰彇鍙傛暟
			FieldSetEntity fse=null;
			Object bean=request.getAttribute(CoreConst.API_POST_REQUEST_DATA);
			if(bean != null){
	            RequestParameterEntity reqp=(RequestParameterEntity)bean;
	            fse = reqp.getFormData();
	        }
	        //鍒ゆ柇鍙傛暟鏄惁涓虹┖
			if(bean == null || fse == null) {
				SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_FORM_NODATA.getValue(), SystemCode.SYSTEM_FORM_NODATA.getText());
				return this.error(SystemCode.SYSTEM_FORM_NODATA.getValue(), SystemCode.SYSTEM_FORM_NODATA.getText());
			}
			//鍒ゆ柇琛ㄥ悕鏄惁姝e父
			if (!CmnConst.PRODUCT_SYS_ORG_LEVELS_CHANGE.equals(fse.getTableName())) {
				SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_TABLE_NODATA.getValue(), SystemCode.SYSTEM_TABLE_NODATA.getText());
				return this.error(SystemCode.SYSTEM_TABLE_NODATA.getValue(), SystemCode.SYSTEM_TABLE_NODATA.getText());
			}
			// 鍒ゆ柇鍒嗛〉鍙傛暟鏄惁姝e父
			if (StringUtils.isEmpty(fse.getString(CmnConst.PAGESIZE))|| StringUtils.isEmpty(fse.getString(CmnConst.CPAGE))) {
				SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_FORM_COUNT.getValue(), SystemCode.SYSTEM_FORM_COUNT.getText());
				return this.error(SystemCode.SYSTEM_FORM_COUNT.getValue(), SystemCode.SYSTEM_FORM_COUNT.getText());
			}
			DataTableEntity dt = deptChangeService.listDeptChange(fse);
			baseDao.loadPromptData(dt);
			return OK_List(dt );
		} catch (BaseException e) {
			SpringMVCContextHolder.getSystemLogger().error(e);
			return this.error(e.getCode(), e.getMessageInfo());
		} catch (Exception e) {
			e.printStackTrace();
			SpringMVCContextHolder.getSystemLogger().error(e);
			return error(CmnCode.DEPT_CHANGE_ERROR.getValue(), CmnCode.DEPT_CHANGE_ERROR.getText()+e.getMessage());
		}
	}
	
	/**
	 * 	閮ㄩ棬鍙樻洿璇︽儏
	 * @param request
	 * @return
	 */
	@RequestMapping(value = "/find-change/{version}", method = RequestMethod.POST)
	@ApiVersion(1)
	public String findDeptChange(HttpServletRequest request) {
		try {
			//鑾峰彇鍙傛暟
			FieldSetEntity fse=null;
			Object bean=request.getAttribute(CoreConst.API_POST_REQUEST_DATA);
			if(bean != null)	{
				RequestParameterEntity reqp=(RequestParameterEntity)bean;
				fse = reqp.getFormData();
			}
			//鍒ゆ柇鍙傛暟鏄惁涓虹┖
			if(bean == null || fse == null) {
				SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_FORM_NODATA.getValue(), SystemCode.SYSTEM_FORM_NODATA.getText());
				return this.error(SystemCode.SYSTEM_FORM_NODATA.getValue(), SystemCode.SYSTEM_FORM_NODATA.getText());
			}
			//鍒ゆ柇琛ㄥ悕鏄惁姝e父
			if (!CmnConst.PRODUCT_SYS_ORG_LEVELS_CHANGE.equals(fse.getTableName())) {
				SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_TABLE_NODATA.getValue(), SystemCode.SYSTEM_TABLE_NODATA.getText());
				return this.error(SystemCode.SYSTEM_TABLE_NODATA.getValue(), SystemCode.SYSTEM_TABLE_NODATA.getText());
			}
			//鍒ゆ柇uuid鏄惁涓虹┖
			if (StringUtils.isEmpty(fse.getString("uuid"))) {
				SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_FORM_COUNT.getValue(), SystemCode.SYSTEM_FORM_COUNT.getText());
				return this.error(SystemCode.SYSTEM_FORM_COUNT.getValue(), SystemCode.SYSTEM_FORM_COUNT.getText());
			}
			 //鏁版嵁鎿嶄綔鐨勬潈闄愰獙璇�
			if(!permissionService.validDataPermission(fse,CoreConst.DATA_PERMISSION_VALID_TYPE_ORG)) {
				SpringMVCContextHolder.getSystemLogger().error(SystemErrorCode.SYSTEM_NOT_OPER_PERMISSION.getValue(),
						SystemErrorCode.SYSTEM_NOT_OPER_PERMISSION.getText());
				return this.error(SystemErrorCode.SYSTEM_NOT_OPER_PERMISSION.getValue(), SystemErrorCode.SYSTEM_NOT_OPER_PERMISSION.getText());
			}
			FieldSetEntity fs = deptChangeService.findDeptChange(fse.getString("uuid"));
			return fs!=null?JsonUtil.pareseFieldSetEntityToJson(fs):error(SystemCode.SYSTEM_DEPT_CAHNGE_FIND_FAIL.getValue(),SystemCode.SYSTEM_DEPT_CAHNGE_FIND_FAIL.getText());
		} catch (BaseException e) {
			SpringMVCContextHolder.getSystemLogger().error(e);
			return this.error(e.getCode(), e.getMessageInfo());
		} catch (Exception e) {
			e.printStackTrace();
			SpringMVCContextHolder.getSystemLogger().error(e);
			return error(CmnCode.DEPT_CHANGE_ERROR.getValue(), CmnCode.DEPT_CHANGE_ERROR.getText()+e.getMessage());
		}
	}
	
	/**
	 * 	閮ㄩ棬鍙樻洿鏂板
	 * @param request
	 * @return
	 */
	@RequestMapping(value = "/add-change/{version}", method = RequestMethod.POST)
	@ApiVersion(1)
	public String addDeptChange(HttpServletRequest request) {
		try {
			//鑾峰彇鍙傛暟
			FieldSetEntity fse=null;
			Object bean=request.getAttribute(CoreConst.API_POST_REQUEST_DATA);
			if(bean != null)	{
			    RequestParameterEntity reqp=(RequestParameterEntity)bean;
			    fse = reqp.getFormData();
			}
			//鍒ゆ柇鍙傛暟鏄惁涓虹┖
			if(bean == null || fse == null) {
				SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_FORM_NODATA.getValue(), SystemCode.SYSTEM_FORM_NODATA.getText());
				return this.error(SystemCode.SYSTEM_FORM_NODATA.getValue(), SystemCode.SYSTEM_FORM_NODATA.getText());
			}
			//鍒ゆ柇琛ㄥ悕鏄惁涓虹┖
			if (!CmnConst.PRODUCT_SYS_ORG_LEVELS_CHANGE.equals(fse.getTableName())) {
				SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_TABLE_NODATA.getValue(), SystemCode.SYSTEM_TABLE_NODATA.getText());
				return this.error(SystemCode.SYSTEM_TABLE_NODATA.getValue(), SystemCode.SYSTEM_TABLE_NODATA.getText());
			}
			//鍒ゆ柇鍘熼儴闂╜鍙樻洿绫诲瀷`琛ㄥ悕鏄惁涓虹┖
			if (StringUtils.isEmpty(fse.getString(CmnConst.ORIGIN_DEPT_UUID)) || StringUtils.isEmpty(fse.getString("change_status_uuid"))) {
				SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_FORM_COUNT.getValue(), SystemCode.SYSTEM_FORM_COUNT.getText());
				return this.error(SystemCode.SYSTEM_FORM_COUNT.getValue(), SystemCode.SYSTEM_FORM_COUNT.getText());
			}
			
			return OK_Add(deptChangeService.deptChangeAdd(fse));
		} catch (BaseException e) {
			SpringMVCContextHolder.getSystemLogger().error(e);
			return this.error(e.getCode(), e.getMessageInfo());
		} catch (Exception e) {
			e.printStackTrace();
			SpringMVCContextHolder.getSystemLogger().error(e);
			return error(CmnCode.DEPT_CHANGE_ERROR.getValue(), CmnCode.DEPT_CHANGE_ERROR.getText()+e.getMessage());
		}
	}
}