美文网首页
金蝶云苍穹弹出自定义单据页面案例

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

作者: 涎涎 | 来源:发表于2020-08-15 11:24 被阅读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.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("保存数据失败,请重试或联系管理员~", "数据保存失败");
                }
            }
        }
    }
    

    注册插件

    预览测试

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

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


    分割线

    相关文章

      网友评论

          本文标题:金蝶云苍穹弹出自定义单据页面案例

          本文链接:https://www.haomeiwen.com/subject/pxxadktx.html