package com.product.contract.controller;

import com.product.common.lang.StringUtils;
import com.product.contract.config.CmnConst;
import com.product.contract.config.SystemCode;
import com.product.contract.service.ContractInvoiceService;
import com.product.contract.service.ide.IContractInvoiceService;
import com.product.core.config.CoreConst;
import com.product.core.controller.support.AbstractBaseController;
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.spring.context.SpringMVCContextHolder;
import com.product.module.sys.version.ApiVersion;
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 javax.servlet.http.HttpServletRequest;

/**
 * Copyright LX
 * @Title: ContractInvoiceController
 * @Project: product-server
 * @date: 2021-06-29 11:23
 * @author: ZhouJie
 * @Description: 鍚堝悓寮€绁�
 */
@RequestMapping("/api/contract")
@RestController
public class ContractInvoiceController extends AbstractBaseController {

    @Autowired
    public ContractInvoiceService contractInvoiceService;

    /**
     * 鍚堝悓寮€绁ㄤ俊鎭繚瀛�
     * @param request
     * @return
     */
    @RequestMapping(value = "/save-invoice/{version}", method = RequestMethod.POST)
    @ApiVersion(1)
    public String saveContractInvoice(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.LX_PROJECT_CONTRACT_INVOICE.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());
            }
            IContractInvoiceService service = (IContractInvoiceService) getProxyInstance(contractInvoiceService);
            String uuid = service.saveContractInvoice(fse);
            if (!StringUtils.isEmpty(uuid)) {
                return OK_Add(uuid);
            }
            SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_SAVE_CONTRACT_INVOICE_FAIL.getValue(), SystemCode.SYSTEM_SAVE_CONTRACT_INVOICE_FAIL.getText());
            return error(SystemCode.SYSTEM_SAVE_CONTRACT_INVOICE_FAIL.getValue(), SystemCode.SYSTEM_SAVE_CONTRACT_INVOICE_FAIL.getText());
        }catch(BaseException e) {
            SpringMVCContextHolder.getSystemLogger().error(e);
            return this.error(e);
        }catch (Exception e) {
            SpringMVCContextHolder.getSystemLogger().error(e);
            return this.error(SystemCode.SYSTEM_SAVE_CONTRACT_INVOICE_FAIL.getValue(), SystemCode.SYSTEM_SAVE_CONTRACT_INVOICE_FAIL.getText());
        }
    }

    /**
     * 鍚堝悓寮€绁ㄤ俊鎭垹闄�
     * @param request
     * @return
     */
    @RequestMapping(value = "/delete-invoice/{version}", method = RequestMethod.POST)
    @ApiVersion(1)
    public String deleteContractInvoice(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.LX_PROJECT_CONTRACT_INVOICE.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 (com.alibaba.druid.util.StringUtils.isEmpty(fse.getString(CmnConst.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());
            }
            IContractInvoiceService service = (IContractInvoiceService) getProxyInstance(contractInvoiceService);
            boolean success = service.deleteContractInvoice(fse);
            if(success) {
                return OK();
            }
            SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_DELETE_CONTRACT_INVOICE_FAIL.getValue(),SystemCode.SYSTEM_DELETE_CONTRACT_INVOICE_FAIL.getText());
            return error(SystemCode.SYSTEM_DELETE_CONTRACT_INVOICE_FAIL.getValue(),SystemCode.SYSTEM_DELETE_CONTRACT_INVOICE_FAIL.getText());
        }catch(BaseException e) {
            SpringMVCContextHolder.getSystemLogger().error(e);
            return this.error(e);
        }catch (Exception e) {
            SpringMVCContextHolder.getSystemLogger().error(e);
            return this.error(SystemCode.SYSTEM_DELETE_CONTRACT_INVOICE_FAIL.getValue(), SystemCode.SYSTEM_DELETE_CONTRACT_INVOICE_FAIL.getText());
        }
    }

    /**
     * 鍚堝悓寮€绁ㄥ垪琛�
     * @param request
     * @return
     */
    @RequestMapping(value = "/list-invoice/{version}", method = RequestMethod.POST)
    @ApiVersion(1)
    public String listContractInvoice(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.LX_PROJECT_CONTRACT_INVOICE.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 (fse.getString(CmnConst.PAGESIZE) == null || fse.getString(CmnConst.CPAGE) == null) {
                return this.error(SystemCode.SYSTEM_CPAGES_NOT_NULL.getValue(),
                        SystemCode.SYSTEM_CPAGES_NOT_NULL.getText());
            }
            DataTableEntity dt = contractInvoiceService.listContractInvoice(fse);
            return OK_List(dt);
        } catch (BaseException e) {
            e.printStackTrace();
            SpringMVCContextHolder.getSystemLogger().error(e);
            return this.error(e);
        } catch (Exception e) {
            e.printStackTrace();
            SpringMVCContextHolder.getSystemLogger().error(e);
            return this.error(SystemCode.SYSTEM_LIST_CONTRACT_INVOICE_FAIL.getValue(),
                    SystemCode.SYSTEM_LIST_CONTRACT_INVOICE_FAIL.getText());
        }
    }

    /**
     * 鍚堝悓寮€绁ㄨ鎯�
     * @param request
     * @return
     */
    @RequestMapping(value = "/find-invoice/{version}", method = RequestMethod.POST)
    @ApiVersion(1)
    public String findContractInvoice(HttpServletRequest request){
        try {
            // 鑾峰彇鍙傛暟find-invoice
            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.LX_PROJECT_CONTRACT_INVOICE.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 (com.alibaba.druid.util.StringUtils.isEmpty(fse.getString(CmnConst.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());
            }
            FieldSetEntity fs = contractInvoiceService.findContractInvoice(fse);
            return OK_List(fs);
        } catch (BaseException e) {
            e.printStackTrace();
            SpringMVCContextHolder.getSystemLogger().error(e);
            return this.error(e);
        } catch (Exception e) {
            e.printStackTrace();
            SpringMVCContextHolder.getSystemLogger().error(e);
            return this.error(SystemCode.SYSTEM_FIND_CONTRACT_INVOICE_FAIL.getValue(),
                    SystemCode.SYSTEM_FIND_CONTRACT_INVOICE_FAIL.getText());
        }
    }

    /**
     * 鏍规嵁寮€绁ㄥ彿鑾峰彇鍙戠エ閲戦
     * @param request
     * @return
     */
    @RequestMapping(value = "/get-invoiceamount/{version}", method = RequestMethod.POST)
    @ApiVersion(1)
    public String getInvoiceAmountByTerms(HttpServletRequest request){
        try {
            // 鑾峰彇鍙傛暟find-invoice
            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.LX_PROJECT_CONTRACT_INVOICE.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 (com.alibaba.druid.util.StringUtils.isEmpty(fse.getString(CmnConst.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());
//            }
            FieldSetEntity fs = contractInvoiceService.getInvoiceAmountByTerms(fse);
            return OK_List(fs);
        } catch (BaseException e) {
            e.printStackTrace();
            SpringMVCContextHolder.getSystemLogger().error(e);
            return this.error(e);
        } catch (Exception e) {
            e.printStackTrace();
            SpringMVCContextHolder.getSystemLogger().error(e);
            return this.error(SystemCode.SYSTEM_GET_INVOICE_AMOUNT_FAIL.getValue(),
                    SystemCode.SYSTEM_GET_INVOICE_AMOUNT_FAIL.getText());
        }
    }



}