金蝶云苍穹弹出修改自定义单据页面案例

2020-08-13  本文已影响0人  涎涎

前置条件

  1. 新建请假类型基础资料
  1. 新建请假类型基础资料
  1. 新建请假申请单单据
  1. 新建自定义单据单据

编码

请假申请单插件

package kd.bos.plugin.leave.message;

import java.util.HashMap;

import kd.bos.bill.AbstractBillPlugIn;
import kd.bos.bill.BillShowParameter;
import kd.bos.dataentity.utils.StringUtils;
import kd.bos.entity.datamodel.events.PropertyChangedArgs;
import kd.bos.form.CloseCallBack;
import kd.bos.form.ShowType;
import kd.bos.form.StyleCss;
import kd.bos.form.events.ClosedCallBackEvent;

/**
 * <p>Title: </p>
 * <p>
 *    Description:
 *    弹出自定义单据
 *    试验成功
 * </p>
 * <p>Copyright: Copyright (c) 2020</p>
 * @author xx
 * @date 2020年3月21日
 * @version 1.0
 */
public class PopBillAppendParentPlugin extends AbstractBillPlugIn {
    //父页面的请假天数标识
//    private final String KEY_LEAVE_DAYS = "day";
    private final String KEY_LEAVE_DAYS = "leavedays";
    //子页面的标识
//    private final String KEY_APPEND_BILL = "wlzy_forleave_reason";
    private final String KEY_APPEND_BILL = "op_zdybill_test1";
    //父页面的工作交接安排标识
    private final String KEY_WORK_ARRANGE = "leave_workarrangement";
    //父页面的备注信息标识
    private final String KEY_REMARK = "leave_info";
    //子页面的主键标识
    private final String KEY_PKID = "son_pkid";

    /**
     * <p>Title: </p>
     * <p>
     *    Description:
     * 修改字段值之后触发
     * 通知插件字段发生了改变,可以同步调整其他字段值
     * 特别说明:
     * 界面数据初始时,不触发此事件,即在afterCreateNewData事件中,修改字段值,不会触发此事件
     * </p>
     * <p>Copyright: Copyright (c) 2020</p>
     * @author xx
     * @date 2020年3月21日
     * @param param the bare_field_name
     * @param e
     * @see kd.bos.entity.datamodel.events.IDataModelChangeListener#propertyChanged(kd.bos.entity.datamodel.events.PropertyChangedArgs)
     * @version 1.0
     */
    @Override
    public void propertyChanged(PropertyChangedArgs e) {
        super.propertyChanged(e);
        //获取改变字段的编码
        String name = e.getProperty().getName();
        if (StringUtils.equals(KEY_LEAVE_DAYS, name)) {
            //获取改变字段的新值
//            Integer newValue = (Integer) e.getChangeSet()[0].getNewValue();
            Integer newValue = Integer.parseInt(String.valueOf(e.getChangeSet()[0].getNewValue()));
            if (null != newValue && newValue > 3) {
                //创建弹出单据页面对象,并赋值
                BillShowParameter billShowParameter = new BillShowParameter();
                //设置弹出子单据页面的标识
                billShowParameter.setFormId(KEY_APPEND_BILL);
                //设置弹出子单据页面的标题
                billShowParameter.setCaption("您的请假天数大于3天,请填写工作交接安排~");
                //设置弹出子单据页面的打开方式
                billShowParameter.getOpenStyle().setShowType(ShowType.Modal);
                //设置弹出子单据页面的样式,高600宽800
                StyleCss inlineStyleCss = new StyleCss();
                inlineStyleCss.setHeight("600");
                inlineStyleCss.setWidth("800");
                billShowParameter.getOpenStyle().setInlineStyleCss(inlineStyleCss);
                //设置子页面关闭回调对象,回调本插件,标识为常量KEY_LEAVE_DAYS对应的值
                billShowParameter.setCloseCallBack(new CloseCallBack(this, KEY_LEAVE_DAYS));
                //弹窗子页面和父页面绑定
                this.getView().showForm(billShowParameter);
            }
        }
    }

    /**
     * <p>Title: </p>
     * <p>
     *    Description:
     * 子界面关闭时,触发父界面的closedCallBack事件;
     * 父界面的插件,可以在此事件,接收子界面返回的数据。
     * 特别说明:
     * 需要在显示子界面时,调用FormShowParameter参数的setCloseCallBack方法,设置回调属性,才会在子界面关闭时触发此事件:
     * </p>
     * <p>Copyright: Copyright (c) 2020</p>
     * @author xx
     * @date 2020年3月21日
     * @param param the bare_field_name
     * @param closedCallBackEvent
     * @see kd.bos.form.plugin.AbstractFormPlugin#closedCallBack(kd.bos.form.events.ClosedCallBackEvent)
     * @version 1.0
     */
    @Override
    public void closedCallBack(ClosedCallBackEvent closedCallBackEvent) {
        super.closedCallBack(closedCallBackEvent);
        //返回数据不为空并且标识为常量KEY_LEAVE_DAYS对应的值,代表是我们所监控的子页面关闭事件
        if (closedCallBackEvent.getReturnData() != null && StringUtils.equals(KEY_LEAVE_DAYS, closedCallBackEvent.getActionId())) {
            //给父页面相关属性赋值
            HashMap<String, String> returnData = (HashMap<String, String>) closedCallBackEvent.getReturnData();
            this.getModel().setValue(KEY_WORK_ARRANGE, returnData.get(KEY_WORK_ARRANGE));
            this.getModel().setValue(KEY_REMARK, returnData.get(KEY_REMARK));
            this.getModel().setValue(KEY_PKID, returnData.get(KEY_PKID));
        }
    }
}
package kd.bos.plugin.leave.message;

import java.util.EventObject;
import java.util.HashMap;

import kd.bos.bill.AbstractBillPlugIn;
import kd.bos.bill.BillShowParameter;
import kd.bos.dataentity.utils.StringUtils;
import kd.bos.form.CloseCallBack;
import kd.bos.form.ShowType;
import kd.bos.form.StyleCss;
import kd.bos.form.control.Control;
import kd.bos.form.events.ClosedCallBackEvent;

/**
 * <p>Title: </p>
 * <p>
 *    Description:
 *    试验成功
 * </p>
 * <p>Copyright: Copyright (c) 2020</p>
 * @author xx
 * @date 2020年3月21日
 * see_to_overridden
 * @version 1.0
 */
public class PopBillUpdateParentPlugin extends AbstractBillPlugIn {
    //父页面的工作交接安排标识
    private final String KEY_WORK_ARRANGE = "leave_workarrangement";
    //父页面的备注信息标识
    private final String KEY_REMARK = "leave_info";
    //子页面的标识
//    private final String KEY_APPEND_BILL = "wlzy_forleave_reason";
    private final String KEY_APPEND_BILL = "op_zdybill_test1";
    //父页面的子页面数据主键标识
    private final String KEY_PKID = "son_pkid";

    /**
     * <p>Title: </p>
     * <p>
     *    Description:
     * 用户与界面上的控件进行交互时,即会触发此事件。
     * 建议在此事件,侦听各个控件的插件事件。
     * </p>
     * <p>Copyright: Copyright (c) 2020</p>
     * @author xx
     * @date 2020年3月21日
     * @param param the bare_field_name
     * @param e
     * @see kd.bos.bill.AbstractBillPlugIn#registerListener(java.util.EventObject)
     * @version 1.0
     */
    @Override
    public void registerListener(EventObject e) {
        super.registerListener(e);
        //注册工作交接安排控件的监听
        this.addClickListeners(KEY_WORK_ARRANGE);
    }

    /**
     * <p>Title: </p>
     * <p>
     *    Description:
     * </p>
     * <p>Copyright: Copyright (c) 2020</p>
     * @author xx
     * @date 2020年3月21日
     * @param param the bare_field_name
     * @param evt
     * @see kd.bos.form.plugin.AbstractFormPlugin#click(java.util.EventObject)
     * @version 1.0
     */
    @Override
    public void click(EventObject evt) {
        super.click(evt);
        //获取被点击的控件对象
        Control source = (Control) evt.getSource();
        if (source != null) {
            if (StringUtils.equals(KEY_WORK_ARRANGE, source.getKey())) {
                //当工作交接安排控件被点击的时候,创建弹出表单页面的对象
                BillShowParameter billShowParameter = new BillShowParameter();
                //设置弹出表单页面的标识
                billShowParameter.setFormId(KEY_APPEND_BILL);
                //设置弹出表单页面数据的主键id
                billShowParameter.setPkId(this.getModel().getValue(KEY_PKID));
                //设置弹出表单页面的标题
                billShowParameter.setCaption("您正在修改工作交接安排~");
                //设置弹出表单页面的打开方式
                billShowParameter.getOpenStyle().setShowType(ShowType.Modal);
                //设置弹出表单页面的关闭回调对象,使用本插件,标识为常量KEY_WORK_ARRANGE对应的值
                billShowParameter.setCloseCallBack(new CloseCallBack(this, KEY_WORK_ARRANGE));
                StyleCss styleCss = new StyleCss();
                styleCss.setHeight("600");
                styleCss.setWidth("800");
                //设置弹出表单的样式,宽,高等
                billShowParameter.getOpenStyle().setInlineStyleCss(styleCss);
                //弹出表单和本页面绑定
                this.getView().showForm(billShowParameter);
            }
        }
    }

    /**
     * <p>Title: </p>
     * <p>
     *    Description:
     * </p>
     * <p>Copyright: Copyright (c) 2020</p>
     * @author xx
     * @date 2020年3月21日
     * @param param the bare_field_name
     * @param e
     * @see kd.bos.form.plugin.AbstractFormPlugin#closedCallBack(kd.bos.form.events.ClosedCallBackEvent)
     * @version 1.0
     */
    @Override
    public void closedCallBack(ClosedCallBackEvent e) {
        super.closedCallBack(e);
        if (null != e.getReturnData() && StringUtils.equals(KEY_WORK_ARRANGE, e.getActionId())) {
            //给父页面相关属性赋值
            HashMap<String, String> returnData = (HashMap<String, String>) e.getReturnData();
            this.getModel().setValue(KEY_WORK_ARRANGE, returnData.get(KEY_WORK_ARRANGE));
            this.getModel().setValue(KEY_REMARK, returnData.get(KEY_REMARK));
        }
    }
}

自定义单据插件

package kd.bos.plugin.leave.message;

import java.util.EventObject;
import java.util.HashMap;

import kd.bos.bill.AbstractBillPlugIn;
import kd.bos.dataentity.utils.StringUtils;
import kd.bos.entity.datamodel.IDataModel;
import kd.bos.form.events.AfterDoOperationEventArgs;

/**
 * <p>Title: </p>
 * <p>
 *    Description:
 *    试验成功
 * </p>
 * <p>Copyright: Copyright (c) 2020</p>
 * @author xx
 * @date 2020年3月21日
 * @version 1.0
 */
public class PopBillAppendPlugin extends AbstractBillPlugIn {
    //子页面的申请人标识
    private final String KEY_CREATOR = "person"; 
    //子页面的请假天数标识
//    private final String KEY_LEAVE_DAYS = "day";
    private final String KEY_LEAVE_DAYS = "leavedays";
    //子页面的工作交接安排标识
    private final String KEY_WORK_ARRANGE = "leave_workarrangement";
    //子页面的备注信息标识
    private final String KEY_REMARK = "leave_info";
    //子页面的主键标识
    private final String KEY_PKID = "son_pkid";
    //页面保存操作
    private final String KEY_SAVE_OPERATION = "save";

    /**
     * <p>Title: </p>
     * <p>
     *    Description:
     * 界面初始化或刷新,新建表单数据包成功,并给字段填写了默认值之后,触发此事件。
     * 插件可以在此事件,重设字段的默认值。
     * 部分字段的默认值难以通过设计器配置出来,如需要计算的值、根据系统参数选项决定的值,必须写插件实现。
     * </p>
     * <p>Copyright: Copyright (c) 2020</p>
     * @author xx
     * @date 2020年3月21日
     * @param param the bare_field_name
     * @param e
     * @see kd.bos.entity.datamodel.events.IDataModelListener#afterCreateNewData(java.util.EventObject)
     * @version 1.0
     */
    @Override
    public void afterCreateNewData(EventObject e) {
        super.afterCreateNewData(e);
        //获取父页面的数据模型
        IDataModel parentModel = this.getView().getParentView().getModel();
        //给子页面相关属性赋值
        this.getModel().setValue(KEY_CREATOR, parentModel.getValue(KEY_CREATOR));
        this.getModel().setValue(KEY_LEAVE_DAYS, parentModel.getValue(KEY_LEAVE_DAYS));
        this.getModel().setValue(KEY_WORK_ARRANGE, parentModel.getValue(KEY_WORK_ARRANGE));
        this.getModel().setValue(KEY_REMARK, parentModel.getValue(KEY_REMARK));
    }

    /**
     * <p>Title: </p>
     * <p>
     *    Description:
     * 用户点击按钮、菜单,执行完绑定的操作后,不论成功与否,均会触发此事件;
     * 插件可以在此事件,根据操作结果控制界面。
     * 特别说明:
     * 这个事件,是在表单界面层执行的,没有事务保护。
     * 不允许在此事件同步修改数据库数据,以免同步失败导致数据不一致。
     * <p>
     * 这里使用了监控save操作,也可以监控按钮点击事件或者工具栏按钮点击事件
     * </p>
     * <p>Copyright: Copyright (c) 2020</p>
     * @author xx
     * @date 2020年3月21日
     * @param param the bare_field_name
     * @param e
     * @see kd.bos.form.plugin.AbstractFormPlugin#afterDoOperation(kd.bos.form.events.AfterDoOperationEventArgs)
     * @version 1.0
     */
    @Override
    public void afterDoOperation(AfterDoOperationEventArgs e) {
        super.afterDoOperation(e);
        System.out.println(e.getOperateKey());
        
        //如果执行了save操作
        if (StringUtils.equals(KEY_SAVE_OPERATION, e.getOperateKey())) {
            //并且save操作的结果是success
            if (e.getOperationResult().isSuccess()) {
                //那么就组装子页面数据返回给父页面,最后关闭子页面
                HashMap<String, String> map = new HashMap<>();
                map.put(KEY_WORK_ARRANGE, String.valueOf(this.getModel().getValue(KEY_WORK_ARRANGE)));
                map.put(KEY_REMARK, String.valueOf(this.getModel().getValue(KEY_REMARK)));
                map.put(KEY_PKID, String.valueOf(this.getModel().getDataEntity().getPkValue()));
                this.getView().returnDataToParent(map);
                this.getView().close();
            } else {
                //如果save操作失败则弹窗提示
                this.getView().showErrMessage("保存数据失败,请重试或联系管理员~", "数据保存失败");
            }
        }
    }
}

注册插件

测试

重启服务后预览测试,如下图所示测试成功

以上就是我关于 金蝶云苍穹弹出修改自定义单据页面案例 知识点整理与总结的全部内容,希望对你有帮助。。。。。。。


分割线

上一篇下一篇

猜你喜欢

热点阅读