ITPub博客

首页 > 应用开发 > IT综合 > 使用O2OA二次开发搭建企业办公平台(十七)信息开发篇:信息发布的审批功能

使用O2OA二次开发搭建企业办公平台(十七)信息开发篇:信息发布的审批功能

原创 IT综合 作者:o2oa 时间:2018-12-04 10:57:00 0 删除 编辑

本博客为O2OA系列教程、O2OA使用手册,教程目录和各章节天梯将在连载完后更新。


本章题纲:

1、谁可以进行设计和开发?

2、信息系统设计入口

3、创建信息发布流程和表单

4、给分类配置信息发布流程

本章节以创建通知公告为例,介绍一个使用流程的内容发布的设计过程。主要讲述发布流程的配置。

 

一、谁可以进行设计开发?

       除了xadmin, 拥有如下角色的用户均能进行流程应用的管理和开发:     

人员或者角色

人员或者角色名称

平台

说明

xadmin

系统管理员

所有

所有权限

Manager

系统管理员

所有

所有权限

ProcessPlatformManager

流程平台系统管理员

流程平台

可以在流程应用管理平台中对流程应用进行创建,对流程、表单、视图以及权限进行各类管理操作

 

二、流程管理设计入口

       在系统菜单-设计中心-流程管理平台中定制您的系统。点击系统菜单,找到“设计中心”,点击后打开设计中心。

       

 

       在流程管理平台中,可以为信息应用的创建相应的流程。

 

三、创建信息发布流程和表单

1、创建信息发布流程应用

根据需要在流程应用管理中创建信息发布流程应用:

点击脚本配置,先创建一个用于调用发布信息服务的脚本,以备在流程相关环节中使用:

publishToCMS脚本代码如下:

this.define("getPublishData", function(){
    
    var clone = function (obj) {
        if (null === obj || "object" != typeof obj) return obj;
        
        if ( typeof obj.length==='number'){ //数组
            //print( "array" );
            var copy = [];
            for (var i = 0, len = obj.length; i < len; ++i) {
                copy[i] = clone(obj[i]);
            }
            return copy;
        }else{
            var copy = {};
            for (var attr in obj) { 
                copy[attr] = clone(obj[attr]);
            }
            return copy;
        }
    };
    
    var removeHTMLTag = function(str) {
        str = str.replace(/<\/?[^>]*>/g,''); //去除HTML tag
        str = str.replace(/[ | ]*\n/g,'\n'); //去除行尾空白
        //str = str.replace(/\n[\s| | ]*\r/g,'\n'); //去除多余空行
        str=str.replace(/&nbsp;/ig,'');//去掉&nbsp;
        str=str.replace(/\s/g,''); //将空格去掉
        return str;
    };
  
    
    var document = clone( this.data.cmsDocument ); 
    var data = clone( this.data );
    
    var work = this.workContext.getWork();
    
    data.formProcess = true;
    
    delete document.attachmentList;
    document.subject = data.subject;
    document.title = data.subject;
    
    document.wf_workId = work.id;
    document.wf_jobId = work.job;
    
    document.pictureList = [];
    if( data.imageclipper ){
        document.pictureList.push( data.imageclipper );
    }
    
    document.summary = "";
    if( data.htmleditor ){
        var text = removeHTMLTag( data.htmleditor );
        document.summary = text.substr(0,85);
    }
    
    var attachmentList = this.workContext.getAttachmentList();
    var attachmentIds = [];
    for( var i=0, len=attachmentList.length; i<len; ++i ){
        attachmentIds.push( attachmentList[i].id );
    }
    document.wf_attachmentIds = attachmentIds;
    
    
    var cnArray = ["公司","部门","人员","群组"];
    var keyArray = ["companyValue","departmentValue","personValue","groupValue"];
    var result = [];
    if( typeof data.publishFor  == "object" && data.publishFor!==null){
        for( var key in data.publishFor ){
            var it = data.publishFor[key];
            for( var i=0; i<it.length; i++ ){
                result.push({
                    permission : "阅读",
                    permissionObjectType : cnArray[ keyArray.indexOf(key) ],
                    permissionObjectName : it[i].name
                });
            }
        }
    }
    
    var owners = [];
    if( result.length > 0 ){
        var taskCompletedList = this.workContext.getTaskCompletedList();
        for(var i=0, len=taskCompletedList.length; i<len; ++i){
            var taskCompleted = taskCompletedList[i];
            if(taskCompleted.person){
                owners.push( taskCompleted.person );
            }
        }
        if( owners.length > 0 ){
            for(var i=0, len=owners.length; i<len; ++i){
                result.push({
                    permission : "阅读",
                    permissionObjectType : "人员",
                    permissionObjectName : owners[i]
                });
            }
        }
    }
    document.permissionList = result;
    
    data.processOwnerList = owners;
    document.docData = data;
    
    return document;
}.bind(this));

脚本创建好后,界面如下图所示:

 

2、创建信息发布流程

流程需求:拟稿 -> 审核  -> 自动完成发布。

示例流程图如下:

在流程设置界面,使用两个人工活动环节和服务调用环节来完成流程的设计,流程设计方法请参考教程流程开发篇相关文档,本篇不做过多的赘述。

此处注意,因为需要由流程完成信息内容的发布工作,所在在流程最后需要使用一个服务调用节点,该节点作用是把流程数据转为信息内容使用相关的服务进行发布,最后完成流程数据到通知公告信息的发布功能。

服务调用环节需要如图配置相应的参数:

基本------------------------------------------------

名称:服务调用(或者其他名称,此处可随意填写)

 

调用------------------------------------------------

服务协议:jaxrs

系统内请求:是

服务应用:内容管理

REST地址:document/cipher/publish/content

调用方法:PUT

ContentType:application/json

参数脚本:不需要

消息体脚本:引用publishToCMS

调用脚本内容:

var data = this.getPublishData();
this.body.set(data);

 

3、信息发布流程表单设计

信息发布流程表单实际可以直接COPY信息发布编辑表单内容后,稍作修改即可。

示例表单如下:

 

四、给分类配置信息发布流程

点击“分类配置”下的通知公告,给通知公告配置上信息发布流程,如下图:

 

经过以上步骤,我们完成了一个带流程的内容发布模块的创建,我们可以到“信息平台”模块中测试它。


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31563356/viewspace-2283730/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2018-11-22

  • 博文量
    41
  • 访问量
    25840