Skip to content

流程审批移动端

流程审批组件用于流程任务的审批,用户可以查阅任务信息和流程操作记录,通过审批组件完成流程表单的录入,并执行各种自定义操作。组件支持定义和执行自定义的流程处理逻辑,确保审批流程的灵活性和高效性。

image

安装方式

bash
yarn add pangea-component-mobile

引用方式

js
import HiFlowApproval from "pangea-component-mobile/hi-m-flow-approval";

API

Props

参数名描述类型默认值
data审批基本信息Data{}
operations操作按钮列表OptionItem[][]
operateRecords流程审批记录OperateRecord[][]
circulateRecords流程传阅记录CirculateRecord[][]
approvalConfig审批组件可配置信息ApprovalConfig{}
openIntl是否开启多语言文案展示Booleanfalse
showAlias多语言文案渲染函数Function-

Events

方法名描述参数
submit审批提交操作回调(通过、驳回、沟通等)(data: FormData)

Slot

插槽名描述参数
header-content流程头部标题区域插槽-
content流程表单内容区域插槽-
flow-diagram流程图区域插槽-

Type

javascript
// 基本信息
interface Data{
  title: string; // 标题
  createTime: string; // 发起时间
  creatorName: string; // 发起人
  creatorDept: string; // 发起人部门
  status: Status; // 状态,
  flowToLabel: string; // 即将流向
  currentResolver: string; // 当前处理人
}
 
// 流程状态
interface Status {
  textColor:string;// 文本颜色
  color: string; // 颜色
  label: string; // 文案
}


// 操作记录
interface OperateRecord{
  dateTime: string, // 操作时间
  nodeName: string, // 节点名称
  operator: string, // 操作人
  operation: string,// 操作
  comments: string, // 意见
  files: Array<FileItem> // 附件列表 
}

// 操作记录文件
interface FileItem {  
  uid: string, // 文件ID
  name: string, // 文件名
  url: string, // 文件URL
}

// 传阅记录
interface CirculateRecord{
  dateTime: string; // 时间
  sponsor: string; // 发起人
  receiver: string; // 传阅对象
  content: string; // 传阅内容
}

// 操作、选项、按钮
interface OptionItem {
  value: string; // 键值
  label: string; // 名称
}


// 审批组件额外配置
interface ApprovalConfig {
  rejectConfig: RejectConfig; // 驳回配置
  uploadConfig: UploadConfig; // 上传配置
  userSelectConfig: UserSelectConfig; // 用户选择配置
  operationConfig:OperationConfig; // 操作栏相关配置
}

// 驳回配置
interface RejectConfig {
  rejectToList?: Array<OptionItem>; // 驳回到节点列表
  rejectStrategyList?: Array<OptionItem>; // 驳回策略列表
}

// 上传配置
interface UploadConfig {
  uploadCallback: Function
}

// 用户选择配置
interface UserSelectConfig {
  api: string; // API
  searchApi: string; // 搜索API
  showRecentData: boolean; // 是否显示最近
  showProcessUser: boolean; // 是否显示流程相关人
  recentApi: string; // 最近API
  recentSaveApi: string; // 保存最近API
  flowUserApi: string; // 流程相关人API
  processInstId: string; // 流程实例ID
}

// 操作栏相关配置
interface OperationConfig {
  commentLength: number; // 处理意见长度
  showCommentWordLimit: boolean; // 是否显示处理意见字数限制
}

interface FormData{  
  operation: string; // 操作类型
  delegate: Array<any>, // 转办人员
  connector: Array<any>, // 沟通人员
  rejectInfo: {
    rejectActivityDefId: string; // 驳回目标活动定义ID
  }
  rejectStrategy: string, // 驳回策略
  comment: string, // 意见
  files: Array<FileItem> // 文件列表
}
 
interface FileItem {
  file:File; // 文件
  fileId:string; // 文件ID
  name:string; // 文件名
}

使用示例

html
<template>
  <van-loading size="24px" vertical v-if="pageLoading" class="page-loading"
    >加载中...</van-loading
  >
  <HiFlowApproval
    v-else
    :data="taskInfo"
    :operateRecords="operateRecords"
    :circulateRecords="circulateRecords"
    :operations="operations"
    :approval-config="approvalConfig"
    :open-intl="true"
    :show-alias="showAlias"
    @submit="submit"
  >
    <template #content>
      流程表单组件
    </template>
    <template #flow-diagram>
      流程图组件
    </template>
  </HiFlowApproval>
</template>

<script lang="ts" setup>
import HiFlowApproval from "pangea-component-mobile/hi-m-flow-approval";
import { ref } from "vue";

const workItemId = ref(1);

// 状态格式化方法
const formatterStatus = function (val) {
  if (val == 1) {
    return {
      color: "grey",
      label: "未启动",
    };
  } else if (val == 2) {
    return {
      color: "blue",
      label: "运行",
    };
  } else if (val == 3) {
    return {
      color: "grey",
      label: "挂起",
    };
  } else if (val == 7) {
    return {
      color: "green",
      label: "完成",
    };
  } else if (val == 8) {
    return {
      color: "red",
      label: "终止",
    };
  }
};

const data = ref({
  creatorName: "测试",
  creatorDept: "集团公司/流程IT与数据管理部/基础架构与云服务管理部",
  createTime: "20240723175644",
  status: formatterStatus(2),
  title: "发起的流程图请审批",
  flowToLabel: "部门长审批:张益达、吴琼",
  currentResolver: "测试",
});
const operations = [
  {
    value: "save-submit",
    label: "同意",
  },
  {
    value: "reject",
    label: "驳回",
  },
  {
    value: "delegate",
    label: "转办",
  },
  {
    value: "connect",
    label: "沟通",
  },
  {
    value: "replyconnect",
    label: "回复",
  },
  {
    value: "cancleconnect",
    label: "撤回沟通",
  },
];
// 审批模板其他配置信息
const approvalConfig = ref({
  rejectConfig: {
    rejectToList: [
      {
        value: "code1",
        label: "驳回到节点1",
      },
    ],
    rejectStrategyList: [
      {
        label: "按顺序流转",
        value: "sequence",
      },
      {
        label: "返回这个节点所有人",
        value: "returnowner",
      },
    ],
  },
  uploadConfig: {
    uploadCallBack: fileUpload,
  },
  userSelectConfig: {
    api: "",
    searchApi: "",
  },
});
// 操作记录
const operateRecords = ref([
  {
    dateTime: "2024-07-25 18:39:45",
    nodeName: "发起",
    operator: "测试",
    operation: "发起",
    comments: "发起流程1",
    files: [
      {
        uid: "930051923594182656",
        name: "config.txt",
        url: "http://pangea-platform.clouddev.hisense.com/oss/files/pangea-test-bucket/flow/pangea/test.txt",
      },
    ],
  },
]);

// 传阅记录
const circulateRecords = ref([
  {
    dateTime: "2024-07-25 18:39:45",
    sponsor: "测试",
    receiver: "测试",
    content: "发起流程1",
  },
]);

// 提交
const submit = function (data) {
  console.log(data);
};

onLoad((params: any) => {
  // 获取页面参数
  workItemId.value = 123456;
});
</script>

<style lang="less" scoped>
.page-loading {
  height: 100vh;
  justify-content: center;
}
</style>