O2OA开源免费开发平台:在O2门户页面中使用React(三)

news/2024/7/20 22:20:27 标签: java, github, android, ios

  在前面的章节中,我们介绍了两种在O2OA中使用React开发应用的方式,已经可以满足绝大多数的情况了。如果您考虑完全脱离O2的web服务器,自己搭建web服务器,那就请阅读本章。

  我们还是使用React的Create React App工具,创建React应用,然后将O2OA集成到应用中,并实现以下功能:列示当前用户的前20条待办,点击标题打开待办;通过点击按钮启动流程和打开主页。

版本要求

本文适用于如下版本:

  • O2OA版本要求:5.1及以上版本;
  • React版本:本文撰写时,react版本是16.13.1。(更低的版本未经验证)


前提

  • 开发端安装了Node.js,Node >= 8.10, npm >= 5.6
  • 有一台O2服务器(并不需要启动webServer,但其他服务需要正常启动)
  • 使用合适的开发工具:WebStorm、VSCode、Atom等(本例使用WebStorm)

 

创建React应用

您可以使用WebStorm创建一个新的React App,如下图:

image.png

或者创建一个空项目,然后使用以下命令创建React应用:

npx create-react-app my-app
cd my-app

 

创建后目录结构如下:

image.png

添加O2平台web脚本

  将O2服务器的webServer下的所有文件夹拷贝到public目录:image.png

在public/index.html的head中添加O2脚本引入:

<script src="../o2_core/bundle.js"></script>

 

修改public/x_desktop/res/config/config.json文件:

{
    "center": [
    {
      "port": "20030",      //O2服务器中心服务器端口
      "host": "develop.o2oa.net"    //O2服务器中心服务器Host
    }
  ],
  "applicationServer": {
    "host": "develop.o2oa.net"  //O2应用服务器Host
  },
  "initManagerChanged": true,
  "initManagerName": "",
    ...
}

此文件主要修改两部分内容:

1、center部分,修改为要访问的O2中心服务器地址和端口;

2、applicationServer部分,修改为要访问的O2应用服务器地址,如果没有applicationServer,就添加一个。集群环境下,可配置应用服务器负载地址;

 

为了方便后续引入,我们在src下创建一个o2.js,添加以下代码:

let o2 = window.o2;
let layout = window.layout;
export {o2, layout};

 

自此以后,所有的过程都和第二章基本一样了。

 

修改inde.js

修改src/index.js文件如下:

import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
//获取O2全局对象
import {o2, layout} from './o2';

//在O2平台脚本载入完成后执行
layout.addReady(function(){
    layout.app = true;
    //通过平台服务,获取当前用户的前20条待办(可通过http://your-server:20030/x_program_center/jest/list.html查询平台接口服务)
    o2.Actions.load("x_processplatform_assemble_surface").TaskAction.V2ListPaging(1,20, {}, function(json){
        //React渲染App组件
        ReactDOM.render(
            <React.StrictMode>
                <App value={json.count} data={json.data}></App>
            </React.StrictMode>,
            document.getElementById('root')
        );
    });
});

layout.addReady 方法会在O2载入完成后执行回调方法。

o2.Actions.load 方法可以调用平台的Restful服务。

 

修改App组件

先修改src/App.css样式文件,拷贝以下代码:

.App {
  padding: 20px;
  margin: 20px;
}
.App-header {
  padding: 5px 10px;
  background: #0f81cc;
  font-size: 18px;
  color: #ffffff;
}

.o2-tasklist {
  padding: 10px;
  background: #f3f3f3;
  font-size: 18px;
}
.o2-task {
  line-height: 30px;
  height: 30px;
  cursor: pointer;
}
.o2-button {
  padding: 10px 20px;
  text-align: center;
  background: #0f81cc;
  margin-top: 10px;
  color: #ffffff;
  font-size: 18px;
  float: left;
  margin-right: 20px;
  cursor: pointer;
}

修改src/App.js文件如下:

import React from 'react';
import './App.css';
//获取O2全局对象
import {o2, layout} from './o2';

function App(props) {
    function openHomepage(){
            //通过O2全局对象layout的openApplication方法打开主页"Homepage"
        layout.openApplication(null,"Homepage")
    }
    function openTask(id){
        //通过O2全局对象layout的openApplication方法打开待办
        layout.openApplication(null,"process.Work", {"workId": id});
    }
    function startProcess(){
        //通过o2.env对象启动流程
        //o2.env对象即是在O2门户页面的脚本中的this指向,可以使用其方法。
        //请将“application-name”和“process-name”修改为您的流程应用名称和流程名
        o2.env.page.startProcess("application-name", "process-name");
    }

    function listTask(){
        let list = [];
        props.data.each(function(d){
            list.push(<div className="o2-task" onClick={()=>{openTask(d.work)}}>{d.title || "无标题"}</div>);
        });
        return list;
    }

    return (
        <div className="App">
            <header className="App-header">
                <p>
                    您有{props.value}个待办
                </p>
            </header>
            <div className="o2-tasklist">
                {listTask()}
            </div>
            <div className="o2-button" onClick={startProcess}>点击此处启动流程</div>
            <div className="o2-button" onClick={openHomepage}>点击此处打开O2首页</div>
        </div>
    );
}

export default App;

  上述代码创建了一个React组件,列示了待办列表,并创建两个div,点击后分别启动指定的流程,打开主页。

  

  App.js中,我们使用了o2.env对象,这个对象和在门户页面脚本中的this指向一致,可以调用除了与门户页面组件相关方法以外的各种方法,如:o2.env.page.openWork、o2.env.inculde、o2.env.confirm、o2.env.page.startProcess等,详细内容可以参考API文档。

 

编译并运行

  我们完成了上述开发工作,就可以编译并运行我们的应用了。使用以下命令来查看结果:

npm run start

  运行后,会启动一个web服务器,默认端口3000,并自动打开浏览器,访问http://locahost:3000,就可以看到和第二章一样的效果了。

  如果您未登录到服务器,会出现登录页面,登录后就可以看到登录人的待办列表,并可以启动流程了。image.png

  登录后:

image.png

您可以接着修改代码,每次修改保存后,React会自动编译,并刷新浏览器,及时看到修改效果。

 

开发完成后,可使用命令:

npm run build

React会在将所有的代码编译到build目录下,你就可以将build中的内容部署到任意的web服务器了。


总结

  O2OA和React的集成还是非常方便的,对于熟悉React的用户,可以通过更多更灵活的工具来进行集成开发,更多有关React的内容请参考React官网教程。

  对于VUE和Angular和O2OA的集成,我们将在后面的章节为大家介绍。


http://www.niftyadmin.cn/n/953365.html

相关文章

O2OA开源免费开发平台:启用Eruda进行移动端调试

O2OA平台启用Eruda进行移动端调试 Eruda 是一个专为前端移动端、移动端设计的调试面板&#xff0c;类似Chrome DevTools 的迷你版&#xff08;没有chrome强大 这个是可以肯定的&#xff09;&#xff0c;其主要功能包括&#xff1a;捕获 console 日志、检查元素状态、显示性能指…

O2OA开源免费办公平台——F2移动端图表

F2 是一个专注于移动&#xff0c;开箱即用的可视化解决方案&#xff0c;完美支持 H5 环境同时兼容多种环境&#xff08;Node, 小程序&#xff0c;Weex&#xff09;&#xff0c;完备的图形语法理论&#xff0c;满足你的各种可视化需求&#xff0c;专业的移动设计指引为你带来最佳…

开源免费O2OA办公:如何搭建流媒体服务器(rtmp+ffmgp)

1. 安装nginx 下载 nginx 1.7.11.3 Gryphon 下载链接: nginx-win.ecsds.eu/download/ng… 解压到 D:\ffmpgtest\nginx目录 2. 下载 nginx-rtmp-module 下载链接&#xff1a;github.com/arut/nginx-… 解压后到nginx目录下 配置文件 conf\nginx-win.conf 内容如下&#xff1…

O2OA开源免费办公平台:在PAAS平台上部署O2OA开发平台

一、镜像制作 1、将安装介质o2server-5.0.3-linux.zip上传至镜像制作服务器上。(上传目录为/paas/xxhpaas/moka/o2oa) 2、使用unzip命令解压安装包&#xff0c;参考命令&#xff1a;unzip o2server-5.0.3-linux.zip 3、制作DockerFile文件&#xff0c;文件内容如下&#xff…

一套开源免费的办公OA软件,会有什么样的线上办公功能?

1.手机随时随地办公 使用办公OA软件后&#xff0c;手机就是一个线上的移动应用库&#xff0c;除了最基础的移动打卡、日程安排、在线沟通这几个基本功能&#xff0c;还有任务分配、合同签署、在线会议、工作管理、论坛、邮件等功能等许多的办公应用&#xff0c;都是开箱即得。…

如何使用华为弹性云服务器部署O2OA V5?

使用华为云合作伙伴O2OA的邀请注册或者关联华为云账号后购买主机会更加优惠哦。 点击此处即可跳转华为云 购买ECS主机 登录华为云控制台 选择服务提供区域和主机 选择操作系统镜像和磁盘 网络配置 高级配置 确认配置 系统正在生成订单 支付订单后即完成ECS创建 查看服务器信息…

从OA系统到开源免费的OA系统,你需要了解什么?

一、OA系统是什么&#xff1f; 办公自动化&#xff08;Office Automation&#xff0c;简称OA&#xff09;&#xff0c;是将计算机、通信等现代化技术运用到传统办公方式&#xff0c;进而形成的一种新型办公方式。 利用现代化设备和信息化技术实现办公的自动化&#xff0c;代替…

一套政务OA系统,助力高效线上办公

因为工作流程复杂&#xff0c;人民群众需求多样&#xff0c;政务工作中&#xff0c;政府工作人员虽然看似“轻松”&#xff0c;实际上堆积如山的加班和会议常常将工作进度拖垮&#xff0c;工作效率也常常为人诟病。 公文收文、公文发文、流转审批、任务管理、督查督办、会议管…