欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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

程序员文章站 2022-05-30 11:59:32
...

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

使用O2OA二次开发搭建企业办公平台(一)平台部署篇:平台下载和部署

使用O2OA二次开发搭建企业办公平台(二)平台部署篇:端口冲突和服务器端口配置

使用O2OA二次开发搭建企业办公平台(三)平台部署篇:使用外部数据库

使用O2OA二次开发搭建企业办公平台(四)平台部署篇:用户密码设置

使用O2OA二次开发搭建企业办公平台(五)平台部署篇:连接O2云使用APP

使用O2OA二次开发搭建企业办公平台(六)平台部署篇:定制自己的APP

使用O2OA二次开发搭建企业办公平台(七)平台部署篇:服务器备份和数据导入导出

使用O2OA二次开发搭建企业办公平台(八)组织管理篇:创建组织和个人信息

使用O2OA二次开发搭建企业办公平台(九)组织管理篇:组织职务的创建和使用

使用O2OA二次开发搭建企业办公平台(十)组织管理篇:组织管理者设定

使用O2OA二次开发搭建企业办公平台(十一)组织管理篇:关于系统角色管理

使用O2OA二次开发搭建企业办公平台(十二)流程开发篇:报销审批流程需求和应用创建

使用O2OA二次开发搭建企业办公平台(十三)流程开发篇:报销审批流程表单开发

使用O2OA二次开发搭建企业办公平台(十四)流程开发篇:使用数据字典进行报销类型配置

使用O2OA二次开发搭建企业办公平台(十五)流程开发篇:创建报销审批流程

使用O2OA二次开发搭建企业办公平台(十六)信息开发篇:信息栏目和分类的创建及权限的设置

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

 

本章题纲:

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

2、信息系统设计入口

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

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

本章节以创建通知公告为例,介绍一个使用流程的内容发布的设计过程。主要讲述发布流程的配置。具体内容发布设计请参考《使用O2OA二次开发搭建企业办公平台(十六)信息开发篇:信息栏目和分类的创建及权限的设置》。

 

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

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

人员或者角色

人员或者角色名称

平台

说明

xadmin

系统管理员

所有

所有权限

Manager

系统管理员

所有

所有权限

ProcessPlatformManager

流程平台系统管理员

流程平台

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

       具体角色管理方法,请见《使用O2OA二次开发搭建企业办公平台(十一)组织管理篇:关于系统角色管理

 

二、流程管理设计入口

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

       使用O2OA二次开发搭建企业办公平台(十七)信息开发篇:信息发布的审批功能
            
    
    博客分类: O2OA二次开发手册企业信息化系统 O2OA企业信息化开源OA协同办公开源平台 

使用O2OA二次开发搭建企业办公平台(十七)信息开发篇:信息发布的审批功能
            
    
    博客分类: O2OA二次开发手册企业信息化系统 O2OA企业信息化开源OA协同办公开源平台 

使用O2OA二次开发搭建企业办公平台(十七)信息开发篇:信息发布的审批功能
            
    
    博客分类: O2OA二次开发手册企业信息化系统 O2OA企业信息化开源OA协同办公开源平台 

 

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

 

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

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

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

使用O2OA二次开发搭建企业办公平台(十七)信息开发篇:信息发布的审批功能
            
    
    博客分类: O2OA二次开发手册企业信息化系统 O2OA企业信息化开源OA协同办公开源平台 

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

使用O2OA二次开发搭建企业办公平台(十七)信息开发篇:信息发布的审批功能
            
    
    博客分类: O2OA二次开发手册企业信息化系统 O2OA企业信息化开源OA协同办公开源平台 

固定脚本代码如下:

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));

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

使用O2OA二次开发搭建企业办公平台(十七)信息开发篇:信息发布的审批功能
            
    
    博客分类: O2OA二次开发手册企业信息化系统 O2OA企业信息化开源OA协同办公开源平台 

 

2、创建信息发布流程

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

示例流程图如下:

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

使用O2OA二次开发搭建企业办公平台(十七)信息开发篇:信息发布的审批功能
            
    
    博客分类: O2OA二次开发手册企业信息化系统 O2OA企业信息化开源OA协同办公开源平台 

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

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

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

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

 

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

服务协议:jaxrs

系统内请求:是

服务应用:内容管理

REST地址:document/cipher/publish/content

调用方法:PUT

ContentType:application/json

参数脚本:不需要

消息体脚本:引用publishToCMS

使用O2OA二次开发搭建企业办公平台(十七)信息开发篇:信息发布的审批功能
            
    
    博客分类: O2OA二次开发手册企业信息化系统 O2OA企业信息化开源OA协同办公开源平台 

调用脚本内容:

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

 

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

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

示例表单如下:

使用O2OA二次开发搭建企业办公平台(十七)信息开发篇:信息发布的审批功能
            
    
    博客分类: O2OA二次开发手册企业信息化系统 O2OA企业信息化开源OA协同办公开源平台 

 

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

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

使用O2OA二次开发搭建企业办公平台(十七)信息开发篇:信息发布的审批功能
            
    
    博客分类: O2OA二次开发手册企业信息化系统 O2OA企业信息化开源OA协同办公开源平台 

 

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

 

使用O2OA二次开发搭建企业办公平台(十七)信息开发篇:信息发布的审批功能
            
    
    博客分类: O2OA二次开发手册企业信息化系统 O2OA企业信息化开源OA协同办公开源平台