package com.java110.@@shareName@@.listener.@@templateCode@@;

import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.java110.utils.constant.BusinessTypeConstant;
import com.java110.utils.constant.ResponseConstant;
import com.java110.utils.constant.StatusConstant;
import com.java110.utils.exception.ListenerExecuteException;
import com.java110.utils.util.Assert;
import com.java110.core.annotation.Java110Listener;
import com.java110.core.context.DataFlowContext;
import com.java110.entity.center.Business;
import com.java110.@@shareName@@.dao.IStoreServiceDao;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.transaction.annotation.Transactional;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * 修改商户信息 侦听
 *
 * 处理节点
 * 1、businessStore:{} 商户基本信息节点
 * 2、businessStoreAttr:[{}] 商户属性信息节点
 * 3、businessStorePhoto:[{}] 商户照片信息节点
 * 4、businessStoreCerdentials:[{}] 商户证件信息节点
 * 协议地址 ：https://github.com/java110/MicroCommunity/wiki/%E4%BF%AE%E6%94%B9%E5%95%86%E6%88%B7%E4%BF%A1%E6%81%AF-%E5%8D%8F%E8%AE%AE
 * Created by wuxw on 2018/5/18.
 */
@Java110Listener("updateStoreInfoListener")
@Transactional
public class UpdateStoreInfoListener extends AbstractStoreBusinessServiceDataFlowListener {

    private static Logger logger = LoggerFactory.getLogger(UpdateStoreInfoListener.class);
    @Autowired
    private IStoreServiceDao storeServiceDaoImpl;

    @Override
    public int getOrder() {
        return 2;
    }

    @Override
    public String getBusinessTypeCd() {
        return BusinessTypeConstant.BUSINESS_TYPE_UPDATE_STORE_INFO;
    }

    /**
     * business过程
     * @param dataFlowContext 上下文对象
     * @param business 业务对象
     */
    @Override
    protected void doSaveBusiness(DataFlowContext dataFlowContext, Business business) {

        JSONObject data = business.getDatas();

        Assert.notEmpty(data,"没有datas 节点，或没有子节点需要处理");


            //处理 businessStore 节点
            if(data.containsKey(StorePo.class.getSimpleName())){
                Object _obj = data.get(StorePo.class.getSimpleName());
                JSONArray businessStores = null;
                if(_obj instanceof JSONObject){
                    businessStores = new JSONArray();
                    businessStores.add(_obj);
                }else {
                    businessStores = (JSONArray)_obj;
                }
                //JSONObject businessStore = data.getJSONObject(StorePo.class.getSimpleName());
                for (int _storeIndex = 0; _storeIndex < businessStores.size();_storeIndex++) {
                    JSONObject businessStore = businessStores.getJSONObject(_storeIndex);
                    doBusinessStore(business, businessStore);
                    if(_obj instanceof JSONObject) {
                        dataFlowContext.addParamOut("storeId", businessStore.getString("storeId"));
                    }
                }
            }
    }


    /**
     * business to instance 过程
     * @param dataFlowContext 数据对象
     * @param business 当前业务对象
     */
    @Override
    protected void doBusinessToInstance(DataFlowContext dataFlowContext, Business business) {

        JSONObject data = business.getDatas();

        Map info = new HashMap();
        info.put("bId",business.getbId());
        info.put("operate",StatusConstant.OPERATE_ADD);

        //商户信息
        List<Map> businessStoreInfos = storeServiceDaoImpl.getBusinessStoreInfo(info);
        if( businessStoreInfos != null && businessStoreInfos.size() >0) {
            for (int _storeIndex = 0; _storeIndex < businessStoreInfos.size();_storeIndex++) {
                Map businessStoreInfo = businessStoreInfos.get(_storeIndex);
                flushBusinessStoreInfo(businessStoreInfo,StatusConstant.STATUS_CD_VALID);
                storeServiceDaoImpl.updateStoreInfoInstance(businessStoreInfo);
                if(businessStoreInfo.size() == 1) {
                    dataFlowContext.addParamOut("storeId", businessStoreInfo.get("store_id"));
                }
            }
        }

    }

    /**
     * 撤单
     * @param dataFlowContext 数据对象
     * @param business 当前业务对象
     */
    @Override
    protected void doRecover(DataFlowContext dataFlowContext, Business business) {

        String bId = business.getbId();
        //Assert.hasLength(bId,"请求报文中没有包含 bId");
        Map info = new HashMap();
        info.put("bId",bId);
        info.put("statusCd",StatusConstant.STATUS_CD_VALID);
        Map delInfo = new HashMap();
        delInfo.put("bId",business.getbId());
        delInfo.put("operate",StatusConstant.OPERATE_DEL);
        //商户信息
        List<Map> storeInfo = storeServiceDaoImpl.getStoreInfo(info);
        if(storeInfo != null && storeInfo.size() > 0){

            //商户信息
            List<Map> businessStoreInfos = storeServiceDaoImpl.getBusinessStoreInfo(delInfo);
            //除非程序出错了，这里不会为空
            if(businessStoreInfos == null || businessStoreInfos.size() == 0){
                throw new ListenerExecuteException(ResponseConstant.RESULT_CODE_INNER_ERROR,"撤单失败（store），程序内部异常,请检查！ "+delInfo);
            }
            for (int _storeIndex = 0; _storeIndex < businessStoreInfos.size();_storeIndex++) {
                Map businessStoreInfo = businessStoreInfos.get(_storeIndex);
                flushBusinessStoreInfo(businessStoreInfo,StatusConstant.STATUS_CD_VALID);
                storeServiceDaoImpl.updateStoreInfoInstance(businessStoreInfo);
            }
        }

    }



    /**
     * 处理 businessStore 节点
     * @param business 总的数据节点
     * @param businessStore 商户节点
     */
    private void doBusinessStore(Business business,JSONObject businessStore){

        Assert.jsonObjectHaveKey(businessStore,"storeId","businessStore 节点下没有包含 storeId 节点");

        if(businessStore.getString("storeId").startsWith("-")){
            throw new ListenerExecuteException(ResponseConstant.RESULT_PARAM_ERROR,"storeId 错误，不能自动生成（必须已经存在的storeId）"+businessStore);
        }
        //自动保存DEL
        autoSaveDelBusinessStore(business,businessStore);

        businessStore.put("bId",business.getbId());
        businessStore.put("operate", StatusConstant.OPERATE_ADD);
        //保存商户信息
        storeServiceDaoImpl.saveBusinessStoreInfo(businessStore);

    }



    @Override
    public IStoreServiceDao getStoreServiceDaoImpl() {
        return storeServiceDaoImpl;
    }

    public void setStoreServiceDaoImpl(IStoreServiceDao storeServiceDaoImpl) {
        this.storeServiceDaoImpl = storeServiceDaoImpl;
    }



}
