@ -0,0 +1,43 @@ |
|||
// 文章/评论管理api
|
|||
import service from '@/utils/request' |
|||
|
|||
// @Tags api
|
|||
// @Summary 查询文档评论 分页
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const getdiscussfilemsg = (data) => { |
|||
return service({ |
|||
url: '/archive/getdiscussfilemsg', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 文章 分页
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const archivefilelist = (data) => { |
|||
return service({ |
|||
url: '/archive/archivefilelist', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
|
|||
|
|||
@ -0,0 +1,460 @@ |
|||
// 数据提报
|
|||
import service from '@/utils/request' |
|||
|
|||
// @Tags api
|
|||
// @Summary 查询考核类别 分页
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const dutyclasslist = (data) => { |
|||
return service({ |
|||
url: '/duty/dutyclasslist', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 添加考核类别 分页
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const adddutyclass = (data) => { |
|||
return service({ |
|||
url: '/duty/adddutyclass', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 查询考核类别详情 分页
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const getdutyclassinfo = (data) => { |
|||
return service({ |
|||
url: '/duty/getdutyclassinfo', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 编辑考核类别内容
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const eitedutyclassinfo = (data) => { |
|||
return service({ |
|||
url: '/duty/eitedutyclassinfo', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 删除或改变考核类别状态
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const statedutyclass = (data) => { |
|||
return service({ |
|||
url: '/duty/statedutyclass', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 考核项目列表
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const assessList = (data) => { |
|||
return service({ |
|||
url: '/duty/assessList', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 添加考核项目
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const addassessinfo = (data) => { |
|||
return service({ |
|||
url: '/duty/addassessinfo', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 获取考核项目详情
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const getassessinfo = (data) => { |
|||
return service({ |
|||
url: '/duty/getassessinfo', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 修改考核项目内容
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const eiteassessinfo = (data) => { |
|||
return service({ |
|||
url: '/duty/eiteassessinfo', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 删除或变更考核项目状态
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const eiteassessstate = (data) => { |
|||
return service({ |
|||
url: '/duty/eiteassessstate', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 具体职责列表
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const dutylist = (data) => { |
|||
return service({ |
|||
url: '/duty/dutylist', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 添加具体职责
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const adddutyinfo = (data) => { |
|||
return service({ |
|||
url: '/duty/adddutyinfo', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 获取具体职责详情
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const getdutyinfo = (data) => { |
|||
return service({ |
|||
url: '/duty/getdutyinfo', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 编辑职责详情
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const eitedutyinfo = (data) => { |
|||
return service({ |
|||
url: '/duty/eitedutyinfo', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 修改状态或删除具体职责
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const eitedutystate = (data) => { |
|||
return service({ |
|||
url: '/duty/eitedutystate', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 获取集团详情
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const grouplist = (data) => { |
|||
return service({ |
|||
url: '/group/grouplist', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 获取员工列表
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const stafflist = (data) => { |
|||
return service({ |
|||
url: '/staff/stafflist', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 部门考核项目列表
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const specdutylist = (data) => { |
|||
return service({ |
|||
url: '/duty/specdutylist', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 添加部门考核项目
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const addspecdutyinfo = (data) => { |
|||
return service({ |
|||
url: '/duty/addspecdutyinfo', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 获取部门考核项目详情
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const getspecdutyinfo = (data) => { |
|||
return service({ |
|||
url: '/duty/getspecdutyinfo', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 编辑部门考核项目详情
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const eitespecdutyinfo = (data) => { |
|||
return service({ |
|||
url: '/duty/eitespecdutyinfo', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 修改状态或删除具体部门考核项目
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const eitespecdutystate = (data) => { |
|||
return service({ |
|||
url: '/duty/eitespecdutystate', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 添加部门考核项目详情(副本)
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const adddepartdutyinfo = (data) => { |
|||
return service({ |
|||
url: '/duty/adddepartdutyinfo', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 修改具体部门考核项目详情(副本)
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const eitedepartdutyinfo = (data) => { |
|||
return service({ |
|||
url: '/duty/eitedepartdutyinfo', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
|
|||
@ -0,0 +1,156 @@ |
|||
// 健康上报api
|
|||
import service from '@/utils/request' |
|||
|
|||
// @Tags api
|
|||
// @Summary 获取文档栏目分类 不分页
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const archivetypelist = (data) => { |
|||
return service({ |
|||
url: 'archive/archivetypelist', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 新建栏目
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const addarchivetype = (data) => { |
|||
return service({ |
|||
url: '/archive/addarchivetype', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 获取单个栏目详细信息
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const getarchiveinfo = (data) => { |
|||
return service({ |
|||
url: '/archive/getarchiveinfo', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 改变栏目状态
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const eitearchivestate = (data) => { |
|||
return service({ |
|||
url: '/archive/eitearchivestate', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 修改栏目信息
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const eitearchiveinfo = (data) => { |
|||
return service({ |
|||
url: '/archive/eitearchiveinfo', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 添加被通知人信息
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const addnoticeuser = (data) => { |
|||
return service({ |
|||
url: '/wechathealth/addnoticeuser', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 修改被通知人信息
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const eitenoticeuser = (data) => { |
|||
return service({ |
|||
url: '/wechathealth/eitenoticeuser', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
// @Tags api
|
|||
// @Summary 删除被通知人信息
|
|||
// @Security ApiKeyAuth
|
|||
// @accept application/json
|
|||
// @Produce application/json
|
|||
// @Param data body modelInterface.PageInfo true "分页获取用户列表"
|
|||
// @Success 200 {string} json "{"success":true,"data":{},"msg":"获取成功"}"
|
|||
// @Router /api/getApiList [post]
|
|||
// {
|
|||
// page int
|
|||
// pageSize int
|
|||
// }
|
|||
export const delnoticeuser = (data) => { |
|||
return service({ |
|||
url: '/wechathealth/delnoticeuser', |
|||
method: 'post', |
|||
data |
|||
}) |
|||
} |
|||
|
|||
@ -0,0 +1,202 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<bpmn:definitions xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:bpmn="http://www.omg.org/spec/BPMN/20100524/MODEL" xmlns:bpmndi="http://www.omg.org/spec/BPMN/20100524/DI" xmlns:dc="http://www.omg.org/spec/DD/20100524/DC" xmlns:camunda="http://camunda.org/schema/1.0/bpmn" xmlns:di="http://www.omg.org/spec/DD/20100524/DI" id="Definitions_1" targetNamespace="http://bpmn.io/schema/bpmn"> |
|||
<bpmn:process id="test" name="test" isExecutable="true"> |
|||
<bpmn:startEvent id="StartEvent_1"> |
|||
<bpmn:outgoing>SequenceFlow_07f1sez</bpmn:outgoing> |
|||
</bpmn:startEvent> |
|||
<bpmn:exclusiveGateway id="ExclusiveGateway_0io7r1h" name="删选会员"> |
|||
<bpmn:incoming>SequenceFlow_07f1sez</bpmn:incoming> |
|||
<bpmn:outgoing>SequenceFlow_15ow6gv</bpmn:outgoing> |
|||
<bpmn:outgoing>SequenceFlow_0d1io4v</bpmn:outgoing> |
|||
<bpmn:outgoing>SequenceFlow_1rcakng</bpmn:outgoing> |
|||
</bpmn:exclusiveGateway> |
|||
<bpmn:sequenceFlow id="SequenceFlow_07f1sez" sourceRef="StartEvent_1" targetRef="ExclusiveGateway_0io7r1h" /> |
|||
<bpmn:sequenceFlow id="SequenceFlow_15ow6gv" name="yes" sourceRef="ExclusiveGateway_0io7r1h" targetRef="ExclusiveGateway_17g4cww"> |
|||
<bpmn:conditionExpression xsi:type="bpmn:tFormalExpression">isTrue</bpmn:conditionExpression> |
|||
</bpmn:sequenceFlow> |
|||
<bpmn:serviceTask id="ServiceTask_tagDelegate_0bjokq0" name="添加标签" camunda:delegateExpression="addtag"> |
|||
<bpmn:extensionElements> |
|||
<camunda:properties> |
|||
<camunda:property name="tagnames" value="老人" /> |
|||
<camunda:property name="tagnames1" value="老人1" /> |
|||
</camunda:properties> |
|||
</bpmn:extensionElements> |
|||
<bpmn:incoming>SequenceFlow_0y1iisj</bpmn:incoming> |
|||
<bpmn:outgoing>SequenceFlow_1gwuen1</bpmn:outgoing> |
|||
</bpmn:serviceTask> |
|||
<bpmn:endEvent id="EndEvent_0nqbnar" name="结束"> |
|||
<bpmn:incoming>SequenceFlow_1gwuen1</bpmn:incoming> |
|||
<bpmn:incoming>SequenceFlow_0dissda</bpmn:incoming> |
|||
</bpmn:endEvent> |
|||
<bpmn:exclusiveGateway id="ExclusiveGateway_17g4cww" name="筛选未发券会员"> |
|||
<bpmn:incoming>SequenceFlow_15ow6gv</bpmn:incoming> |
|||
<bpmn:outgoing>SequenceFlow_0jo6785</bpmn:outgoing> |
|||
<bpmn:outgoing>SequenceFlow_0dissda</bpmn:outgoing> |
|||
</bpmn:exclusiveGateway> |
|||
<bpmn:sequenceFlow id="SequenceFlow_0jo6785" name="yes" sourceRef="ExclusiveGateway_17g4cww" targetRef="ServiceTask_appPushDelegate_0wulpvm"> |
|||
<bpmn:conditionExpression xsi:type="bpmn:tFormalExpression">sendapp</bpmn:conditionExpression> |
|||
</bpmn:sequenceFlow> |
|||
<bpmn:serviceTask id="ServiceTask_appPushDelegate_0wulpvm" name="发送指定优惠券" camunda:expression="apppush" camunda:resultVariable="app"> |
|||
<bpmn:extensionElements> |
|||
<camunda:properties> |
|||
<camunda:property name="tagNames" value="test" /> |
|||
</camunda:properties> |
|||
</bpmn:extensionElements> |
|||
<bpmn:incoming>SequenceFlow_0jo6785</bpmn:incoming> |
|||
<bpmn:outgoing>SequenceFlow_0y1iisj</bpmn:outgoing> |
|||
</bpmn:serviceTask> |
|||
<bpmn:sequenceFlow id="SequenceFlow_0y1iisj" sourceRef="ServiceTask_appPushDelegate_0wulpvm" targetRef="ServiceTask_tagDelegate_0bjokq0" /> |
|||
<bpmn:sequenceFlow id="SequenceFlow_1gwuen1" sourceRef="ServiceTask_tagDelegate_0bjokq0" targetRef="EndEvent_0nqbnar" /> |
|||
<bpmn:exclusiveGateway id="ExclusiveGateway_19yj3fu" name="筛选发短信的会员"> |
|||
<bpmn:incoming>SequenceFlow_0d1io4v</bpmn:incoming> |
|||
<bpmn:outgoing>SequenceFlow_0yptzdv</bpmn:outgoing> |
|||
<bpmn:outgoing>SequenceFlow_17zsv75</bpmn:outgoing> |
|||
</bpmn:exclusiveGateway> |
|||
<bpmn:sequenceFlow id="SequenceFlow_0d1io4v" name="yes" sourceRef="ExclusiveGateway_0io7r1h" targetRef="ExclusiveGateway_19yj3fu"> |
|||
<bpmn:conditionExpression xsi:type="bpmn:tFormalExpression">isSend</bpmn:conditionExpression> |
|||
</bpmn:sequenceFlow> |
|||
<bpmn:serviceTask id="ServiceTask_unTagDelegate_1n4e6i4" name="移除指定标签" camunda:expression="UNtag" camunda:resultVariable="UNtag"> |
|||
<bpmn:extensionElements> |
|||
<camunda:properties> |
|||
<camunda:property name="remove" value="true" /> |
|||
</camunda:properties> |
|||
</bpmn:extensionElements> |
|||
<bpmn:incoming>SequenceFlow_1rcakng</bpmn:incoming> |
|||
<bpmn:outgoing>SequenceFlow_0w7hugc</bpmn:outgoing> |
|||
</bpmn:serviceTask> |
|||
<bpmn:sequenceFlow id="SequenceFlow_1rcakng" sourceRef="ExclusiveGateway_0io7r1h" targetRef="ServiceTask_unTagDelegate_1n4e6i4" /> |
|||
<bpmn:endEvent id="EndEvent_116t3md"> |
|||
<bpmn:incoming>SequenceFlow_0w7hugc</bpmn:incoming> |
|||
</bpmn:endEvent> |
|||
<bpmn:sequenceFlow id="SequenceFlow_0w7hugc" sourceRef="ServiceTask_unTagDelegate_1n4e6i4" targetRef="EndEvent_116t3md" /> |
|||
<bpmn:serviceTask id="ServiceTask_shortMessageDelegate_03kenwi" name="f发送指定短信" camunda:delegateExpression="senmessage"> |
|||
<bpmn:incoming>SequenceFlow_0yptzdv</bpmn:incoming> |
|||
<bpmn:outgoing>SequenceFlow_02m7s7p</bpmn:outgoing> |
|||
</bpmn:serviceTask> |
|||
<bpmn:sequenceFlow id="SequenceFlow_0yptzdv" name="yes" sourceRef="ExclusiveGateway_19yj3fu" targetRef="ServiceTask_shortMessageDelegate_03kenwi"> |
|||
<bpmn:conditionExpression xsi:type="bpmn:tFormalExpression">senmessage</bpmn:conditionExpression> |
|||
</bpmn:sequenceFlow> |
|||
<bpmn:endEvent id="EndEvent_0f4cb85"> |
|||
<bpmn:incoming>SequenceFlow_02m7s7p</bpmn:incoming> |
|||
<bpmn:incoming>SequenceFlow_17zsv75</bpmn:incoming> |
|||
</bpmn:endEvent> |
|||
<bpmn:sequenceFlow id="SequenceFlow_02m7s7p" sourceRef="ServiceTask_shortMessageDelegate_03kenwi" targetRef="EndEvent_0f4cb85" /> |
|||
<bpmn:sequenceFlow id="SequenceFlow_17zsv75" sourceRef="ExclusiveGateway_19yj3fu" targetRef="EndEvent_0f4cb85" /> |
|||
<bpmn:sequenceFlow id="SequenceFlow_0dissda" sourceRef="ExclusiveGateway_17g4cww" targetRef="EndEvent_0nqbnar" /> |
|||
</bpmn:process> |
|||
<bpmndi:BPMNDiagram id="BPMNDiagram_1"> |
|||
<bpmndi:BPMNPlane id="BPMNPlane_1" bpmnElement="test"> |
|||
<bpmndi:BPMNShape id="_BPMNShape_StartEvent_2" bpmnElement="StartEvent_1"> |
|||
<dc:Bounds x="102" y="242" width="36" height="36" /> |
|||
</bpmndi:BPMNShape> |
|||
<bpmndi:BPMNShape id="ExclusiveGateway_0io7r1h_di" bpmnElement="ExclusiveGateway_0io7r1h" isMarkerVisible="true"> |
|||
<dc:Bounds x="255" y="235" width="50" height="50" /> |
|||
<bpmndi:BPMNLabel> |
|||
<dc:Bounds x="258" y="295" width="44" height="14" /> |
|||
</bpmndi:BPMNLabel> |
|||
</bpmndi:BPMNShape> |
|||
<bpmndi:BPMNEdge id="SequenceFlow_07f1sez_di" bpmnElement="SequenceFlow_07f1sez"> |
|||
<di:waypoint x="138" y="260" /> |
|||
<di:waypoint x="255" y="260" /> |
|||
</bpmndi:BPMNEdge> |
|||
<bpmndi:BPMNEdge id="SequenceFlow_15ow6gv_di" bpmnElement="SequenceFlow_15ow6gv"> |
|||
<di:waypoint x="280" y="235" /> |
|||
<di:waypoint x="280" y="120" /> |
|||
<di:waypoint x="335" y="120" /> |
|||
<bpmndi:BPMNLabel> |
|||
<dc:Bounds x="287" y="175" width="17" height="14" /> |
|||
</bpmndi:BPMNLabel> |
|||
</bpmndi:BPMNEdge> |
|||
<bpmndi:BPMNShape id="ServiceTask_tagDelegate_0bjokq0_di" bpmnElement="ServiceTask_tagDelegate_0bjokq0"> |
|||
<dc:Bounds x="660" y="80" width="80" height="80" /> |
|||
</bpmndi:BPMNShape> |
|||
<bpmndi:BPMNShape id="EndEvent_0nqbnar_di" bpmnElement="EndEvent_0nqbnar"> |
|||
<dc:Bounds x="882" y="102" width="36" height="36" /> |
|||
<bpmndi:BPMNLabel> |
|||
<dc:Bounds x="889" y="145" width="22" height="14" /> |
|||
</bpmndi:BPMNLabel> |
|||
</bpmndi:BPMNShape> |
|||
<bpmndi:BPMNShape id="ExclusiveGateway_17g4cww_di" bpmnElement="ExclusiveGateway_17g4cww" isMarkerVisible="true"> |
|||
<dc:Bounds x="335" y="95" width="50" height="50" /> |
|||
<bpmndi:BPMNLabel> |
|||
<dc:Bounds x="324" y="152" width="77" height="14" /> |
|||
</bpmndi:BPMNLabel> |
|||
</bpmndi:BPMNShape> |
|||
<bpmndi:BPMNEdge id="SequenceFlow_0jo6785_di" bpmnElement="SequenceFlow_0jo6785"> |
|||
<di:waypoint x="385" y="120" /> |
|||
<di:waypoint x="510" y="120" /> |
|||
<bpmndi:BPMNLabel> |
|||
<dc:Bounds x="439" y="102" width="17" height="14" /> |
|||
</bpmndi:BPMNLabel> |
|||
</bpmndi:BPMNEdge> |
|||
<bpmndi:BPMNShape id="ServiceTask_appPushDelegate_0wulpvm_di" bpmnElement="ServiceTask_appPushDelegate_0wulpvm"> |
|||
<dc:Bounds x="510" y="80" width="80" height="80" /> |
|||
</bpmndi:BPMNShape> |
|||
<bpmndi:BPMNEdge id="SequenceFlow_0y1iisj_di" bpmnElement="SequenceFlow_0y1iisj"> |
|||
<di:waypoint x="590" y="120" /> |
|||
<di:waypoint x="660" y="120" /> |
|||
</bpmndi:BPMNEdge> |
|||
<bpmndi:BPMNEdge id="SequenceFlow_1gwuen1_di" bpmnElement="SequenceFlow_1gwuen1"> |
|||
<di:waypoint x="740" y="120" /> |
|||
<di:waypoint x="882" y="120" /> |
|||
</bpmndi:BPMNEdge> |
|||
<bpmndi:BPMNShape id="ExclusiveGateway_19yj3fu_di" bpmnElement="ExclusiveGateway_19yj3fu" isMarkerVisible="true"> |
|||
<dc:Bounds x="405" y="235" width="50" height="50" /> |
|||
<bpmndi:BPMNLabel> |
|||
<dc:Bounds x="386" y="211" width="88" height="14" /> |
|||
</bpmndi:BPMNLabel> |
|||
</bpmndi:BPMNShape> |
|||
<bpmndi:BPMNEdge id="SequenceFlow_0d1io4v_di" bpmnElement="SequenceFlow_0d1io4v"> |
|||
<di:waypoint x="305" y="260" /> |
|||
<di:waypoint x="405" y="260" /> |
|||
<bpmndi:BPMNLabel> |
|||
<dc:Bounds x="347" y="242" width="17" height="14" /> |
|||
</bpmndi:BPMNLabel> |
|||
</bpmndi:BPMNEdge> |
|||
<bpmndi:BPMNShape id="ServiceTask_unTagDelegate_1n4e6i4_di" bpmnElement="ServiceTask_unTagDelegate_1n4e6i4"> |
|||
<dc:Bounds x="340" y="370" width="80" height="80" /> |
|||
</bpmndi:BPMNShape> |
|||
<bpmndi:BPMNEdge id="SequenceFlow_1rcakng_di" bpmnElement="SequenceFlow_1rcakng"> |
|||
<di:waypoint x="280" y="285" /> |
|||
<di:waypoint x="280" y="410" /> |
|||
<di:waypoint x="340" y="410" /> |
|||
</bpmndi:BPMNEdge> |
|||
<bpmndi:BPMNShape id="EndEvent_116t3md_di" bpmnElement="EndEvent_116t3md"> |
|||
<dc:Bounds x="462" y="392" width="36" height="36" /> |
|||
</bpmndi:BPMNShape> |
|||
<bpmndi:BPMNEdge id="SequenceFlow_0w7hugc_di" bpmnElement="SequenceFlow_0w7hugc"> |
|||
<di:waypoint x="420" y="410" /> |
|||
<di:waypoint x="462" y="410" /> |
|||
</bpmndi:BPMNEdge> |
|||
<bpmndi:BPMNShape id="ServiceTask_shortMessageDelegate_03kenwi_di" bpmnElement="ServiceTask_shortMessageDelegate_03kenwi"> |
|||
<dc:Bounds x="540" y="230" width="80" height="80" /> |
|||
</bpmndi:BPMNShape> |
|||
<bpmndi:BPMNEdge id="SequenceFlow_0yptzdv_di" bpmnElement="SequenceFlow_0yptzdv"> |
|||
<di:waypoint x="455" y="260" /> |
|||
<di:waypoint x="540" y="260" /> |
|||
<bpmndi:BPMNLabel> |
|||
<dc:Bounds x="489" y="242" width="17" height="14" /> |
|||
</bpmndi:BPMNLabel> |
|||
</bpmndi:BPMNEdge> |
|||
<bpmndi:BPMNShape id="EndEvent_0f4cb85_di" bpmnElement="EndEvent_0f4cb85"> |
|||
<dc:Bounds x="712" y="252" width="36" height="36" /> |
|||
</bpmndi:BPMNShape> |
|||
<bpmndi:BPMNEdge id="SequenceFlow_02m7s7p_di" bpmnElement="SequenceFlow_02m7s7p"> |
|||
<di:waypoint x="620" y="270" /> |
|||
<di:waypoint x="712" y="270" /> |
|||
</bpmndi:BPMNEdge> |
|||
<bpmndi:BPMNEdge id="SequenceFlow_17zsv75_di" bpmnElement="SequenceFlow_17zsv75"> |
|||
<di:waypoint x="430" y="285" /> |
|||
<di:waypoint x="430" y="360" /> |
|||
<di:waypoint x="730" y="360" /> |
|||
<di:waypoint x="730" y="288" /> |
|||
</bpmndi:BPMNEdge> |
|||
<bpmndi:BPMNEdge id="SequenceFlow_0dissda_di" bpmnElement="SequenceFlow_0dissda"> |
|||
<di:waypoint x="360" y="95" /> |
|||
<di:waypoint x="360" y="-10" /> |
|||
<di:waypoint x="900" y="-10" /> |
|||
<di:waypoint x="900" y="102" /> |
|||
</bpmndi:BPMNEdge> |
|||
</bpmndi:BPMNPlane> |
|||
</bpmndi:BPMNDiagram> |
|||
</bpmn:definitions> |
|||
@ -0,0 +1,36 @@ |
|||
body{ |
|||
margin: 0; |
|||
padding: 0; |
|||
} |
|||
|
|||
/*路由切换动画*/ |
|||
.router-fade-enter-active { |
|||
transition: all 0.3s cubic-bezier(0.6, 0.5, 0.3, 0.1); |
|||
} |
|||
|
|||
.router-fade-leave-active { |
|||
transition: all 0.3s cubic-bezier(0.5, 0.5, 0.5, 0.5); |
|||
} |
|||
|
|||
.router-fade-enter { |
|||
transform: translateX(-10px); |
|||
opacity: 0; |
|||
} |
|||
|
|||
.router-fade-leave-to { |
|||
transform: translateX(50px); |
|||
opacity: 0; |
|||
} |
|||
|
|||
.fl { |
|||
float: left; |
|||
} |
|||
.fr { |
|||
float: right; |
|||
} |
|||
.tl{ |
|||
text-align: left; |
|||
} |
|||
.tr{ |
|||
text-align: right; |
|||
} |
|||
@ -0,0 +1,16 @@ |
|||
<template> |
|||
<!-- 复杂穿梭框(用于选择人员) --> |
|||
<div> |
|||
|
|||
</div> |
|||
</template> |
|||
|
|||
<script> |
|||
export default { |
|||
|
|||
} |
|||
</script> |
|||
|
|||
<style lang="scss" scoped> |
|||
|
|||
</style> |
|||
@ -0,0 +1,137 @@ |
|||
<template> |
|||
<!-- 具体职责选择框 --> |
|||
<div> |
|||
<div> |
|||
<el-button size="small" @click="showDialog()">选择具体职责</el-button> |
|||
</div> |
|||
|
|||
<el-dialog title="提示" v-model="dialogVisible" width="60%" :before-close="handleClose"> |
|||
<div class="gva-search-box"> |
|||
<el-form ref="searchForm" :inline="true" :model="searchInfo"> |
|||
<el-form-item label="所属考核项目"> |
|||
<span> |
|||
<el-tag v-if="childInfo.title!=''">{{childInfo.title}}</el-tag> |
|||
<projectDialog @checkedInfo="getCheckedInfo"></projectDialog> |
|||
</span> |
|||
|
|||
</el-form-item> |
|||
<el-form-item label="考核项目名称"> |
|||
<el-input |
|||
placeholder="请输入名称" |
|||
v-model="dutySearchInfo.title" |
|||
clearable> |
|||
</el-input> |
|||
</el-form-item> |
|||
<el-form-item> |
|||
<el-button size="mini" type="primary" icon="el-icon-search" @click="onSubmit">查询</el-button> |
|||
<el-button size="mini" icon="el-icon-refresh" @click="onReset">重置</el-button> |
|||
</el-form-item> |
|||
</el-form> |
|||
</div> |
|||
<div class="gva-table-box"> |
|||
<el-table :data="dutyList" @sort-change="sortChange" @selection-change="handleSelectionChange"> |
|||
<el-table-column align="left" label="所属考核项目" prop="parentTitle"/> |
|||
<el-table-column align="left" label="具体职责名称" prop="title"/> |
|||
<el-table-column align="left" label="考核部门" prop="dumpTitle"/> |
|||
<el-table-column align="left" label="考核人" prop="username"/> |
|||
<el-table-column align="left" fixed="right" label="操作" width="200"> |
|||
<template #default="scope"> |
|||
<el-button type="primary" round @click="checked(scope.row)">选中</el-button> |
|||
</template> |
|||
</el-table-column> |
|||
</el-table> |
|||
<div class="gva-pagination"> |
|||
<el-pagination |
|||
:current-page="dutySearchInfo.page" |
|||
:page-size="dutySearchInfo.pageSize" |
|||
:page-sizes="[10, 30, 50, 100]" |
|||
:total="total" |
|||
layout="total, sizes, prev, pager, next, jumper" |
|||
@current-change="handleCurrentChange" |
|||
@size-change="handleSizeChange" |
|||
/> |
|||
</div> |
|||
|
|||
</div> |
|||
</el-dialog> |
|||
|
|||
</div> |
|||
</template> |
|||
|
|||
<script> |
|||
import { |
|||
dutylist, |
|||
} from '@/api/dataEntry' |
|||
import projectDialog from '@/components/projectDialog/index.vue' |
|||
export default { |
|||
components: { |
|||
projectDialog |
|||
}, |
|||
data() { |
|||
return { |
|||
|
|||
childInfo:{ |
|||
title:'', |
|||
}, |
|||
total:'', |
|||
searchList:{ |
|||
page:1, |
|||
pagesize:10000, |
|||
}, |
|||
dutyclasslist:{}, |
|||
dutySearchInfo:{ |
|||
page: 1, |
|||
pageSize: 10, |
|||
state:1, |
|||
}, |
|||
dialogVisible: false, |
|||
dutyList:null, |
|||
} |
|||
}, |
|||
created () { |
|||
this.getdutyList(); |
|||
}, |
|||
methods: { |
|||
// 获取选中组件值 |
|||
getCheckedInfo(data){ |
|||
this.childInfo=data |
|||
}, |
|||
// 条件搜索前端看此方法 |
|||
onSubmit() { |
|||
this.dutySearchInfo.page = 1 |
|||
this.dutySearchInfo.pageSize = 10 |
|||
this.dutySearchInfo.parentId=this.childInfo.outId |
|||
this.getdutyList() |
|||
}, |
|||
// pagesize改变 |
|||
handleSizeChange(val) { |
|||
this.dutySearchInfo.pageSize=val |
|||
}, |
|||
// 页码改变 |
|||
handleCurrentChange(val) { |
|||
this.dutySearchInfo.page=val |
|||
}, |
|||
// 点击按钮事件 |
|||
showDialog(){ |
|||
this.dialogVisible=true; |
|||
}, |
|||
// 获取具体职责列表 |
|||
async getdutyList(){ |
|||
const res = await dutylist(this.dutySearchInfo) |
|||
this.dutyList=res.data.list; |
|||
this.dutySearchInfo.page=res.data.page; |
|||
this.dutySearchInfo.pageSize=res.data.pageSize; |
|||
this.total=res.data.total; |
|||
}, |
|||
// 选中 |
|||
checked(row){ |
|||
this.$emit('checkedInfo',row) |
|||
this.dialogVisible=false |
|||
}, |
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style lang="scss" scoped> |
|||
|
|||
</style> |
|||
@ -0,0 +1,149 @@ |
|||
<template> |
|||
<div> |
|||
<div> |
|||
<el-button size="small" @click="showDialog()">选择考核项目</el-button> |
|||
</div> |
|||
|
|||
<el-dialog title="提示" v-model="dialogVisible" width="60%" :before-close="handleClose"> |
|||
<div class="gva-search-box"> |
|||
<el-form ref="searchForm" :inline="true" :model="searchInfo"> |
|||
<el-form-item label="考核项目名称"> |
|||
<el-input |
|||
placeholder="请输入名称" |
|||
v-model="projectSearchInfo.title" |
|||
clearable> |
|||
</el-input> |
|||
</el-form-item> |
|||
<!-- <el-form-item label="考核项目状态"> |
|||
<el-select v-model="projectSearchInfo.state" clearable placeholder="请选择状态"> |
|||
<el-option :value=1 label="正常">正常</el-option> |
|||
<el-option :value=2 label="禁止">禁止</el-option> |
|||
</el-select> |
|||
</el-form-item> --> |
|||
<el-form-item label="所属考核类别"> |
|||
<el-select v-model="projectSearchInfo.parentId" clearable placeholder="请选择状态"> |
|||
<el-option |
|||
v-for="item in dutyclasslist" |
|||
:key="item.outId" |
|||
:label="item.title" |
|||
:value="item.outId"> |
|||
</el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-form-item> |
|||
<el-button size="mini" type="primary" icon="el-icon-search" @click="onSubmit">查询</el-button> |
|||
<!-- <el-button size="mini" icon="el-icon-refresh" @click="onReset">重置</el-button> --> |
|||
</el-form-item> |
|||
</el-form> |
|||
</div> |
|||
<div class="gva-table-box"> |
|||
<el-table :data="assessList" @sort-change="sortChange" @selection-change="handleSelectionChange"> |
|||
<!-- <el-table-column |
|||
type="selection" |
|||
width="55" |
|||
/> --> |
|||
<el-table-column align="left" label="所属考核类别" prop="parentTitle"/> |
|||
<el-table-column align="left" label="考核项目名称" prop="title"/> |
|||
<el-table-column align="left" label="考核项目说明" prop="content"/> |
|||
<el-table-column align="left" fixed="right" label="操作" width="200"> |
|||
<template #default="scope"> |
|||
<el-button type="primary" round @click="checked(scope.row)">选中</el-button> |
|||
|
|||
</template> |
|||
</el-table-column> |
|||
</el-table> |
|||
<div class="gva-pagination"> |
|||
<el-pagination |
|||
:current-page="projectSearchInfo.page" |
|||
:page-size="projectSearchInfo.pageSize" |
|||
:page-sizes="[10, 30, 50, 100]" |
|||
:total="total" |
|||
layout="total, sizes, prev, pager, next, jumper" |
|||
@current-change="handleCurrentChange" |
|||
@size-change="handleSizeChange" |
|||
/> |
|||
</div> |
|||
</div> |
|||
<!-- <span slot="footer" class="dialog-footer"> |
|||
<el-button @click="dialogVisible = false">取 消</el-button> |
|||
<el-button type="primary" @click="dialogVisible = false">确 定</el-button> |
|||
</span> --> |
|||
</el-dialog> |
|||
|
|||
</div> |
|||
</template> |
|||
|
|||
<script> |
|||
import { |
|||
dutyclasslist, |
|||
assessList, |
|||
} from '@/api/dataEntry' |
|||
export default { |
|||
data() { |
|||
return { |
|||
projectTitle:'', |
|||
total:'', |
|||
searchList:{ |
|||
page:1, |
|||
pagesize:10000, |
|||
}, |
|||
dutyclasslist:{}, |
|||
projectSearchInfo:{ |
|||
page: 1, |
|||
pageSize: 10, |
|||
state:1, |
|||
}, |
|||
dialogVisible: false, |
|||
assessList:null, |
|||
} |
|||
}, |
|||
created () { |
|||
this.getProjectList(); |
|||
this.getDutyclasslist(); |
|||
}, |
|||
methods: { |
|||
// 条件搜索前端看此方法 |
|||
onSubmit() { |
|||
this.page = 1 |
|||
this.pageSize = 10 |
|||
|
|||
this.getProjectList() |
|||
}, |
|||
// pagesize改变 |
|||
handleSizeChange(val) { |
|||
this.projectSearchInfo.pageSize=val |
|||
}, |
|||
// 页码改变 |
|||
handleCurrentChange(val) { |
|||
this.projectSearchInfo.page=val |
|||
}, |
|||
// 获取考核类别列表 |
|||
async getDutyclasslist(){ |
|||
const res = await dutyclasslist(this.searchList) |
|||
this.dutyclasslist=res.data.list; |
|||
}, |
|||
// 点击按钮事件 |
|||
showDialog(){ |
|||
this.dialogVisible=true; |
|||
}, |
|||
// 获取考核项目列表 |
|||
async getProjectList(){ |
|||
const res = await assessList(this.projectSearchInfo) |
|||
this.assessList=res.data.list; |
|||
this.projectSearchInfo.page=res.data.page; |
|||
this.projectSearchInfo.pageSize=res.data.pageSize; |
|||
this.total=res.data.total; |
|||
}, |
|||
// 选中 |
|||
checked(row){ |
|||
this.projectTitle=row.title; |
|||
this.$emit('checkedInfo',row) |
|||
this.dialogVisible=false |
|||
}, |
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style lang="scss" scoped> |
|||
|
|||
</style> |
|||
@ -0,0 +1,178 @@ |
|||
<template> |
|||
<div id="userLayout"> |
|||
<div class="login_panle"> |
|||
<div class="login_panle_form"> |
|||
<div class="login_panle_form_title"> |
|||
<!-- <img |
|||
class="login_panle_form_title_logo" |
|||
:src="$GIN_VUE_ADMIN.appLogo" |
|||
alt |
|||
/> --> |
|||
<p class="login_panle_form_title_p">绩效考核用户端登录</p> |
|||
</div> |
|||
<el-form |
|||
ref="loginForm" |
|||
:model="loginForm" |
|||
:rules="rules" |
|||
@keyup.enter="submitForm" |
|||
> |
|||
<el-form-item prop="username"> |
|||
<el-input v-model="loginForm.username" placeholder="请输入工号"> |
|||
<template #suffix> |
|||
<i class="el-input__icon el-icon-user" /> |
|||
</template> |
|||
</el-input> |
|||
</el-form-item> |
|||
<el-form-item prop="password"> |
|||
<el-input |
|||
v-model="loginForm.password" |
|||
:type="lock === 'lock' ? 'password' : 'text'" |
|||
placeholder="请输入密码" |
|||
> |
|||
<template #suffix> |
|||
<i |
|||
:class="'el-input__icon el-icon-' + lock" |
|||
@click="changeLock" |
|||
/> |
|||
</template> |
|||
</el-input> |
|||
</el-form-item> |
|||
<el-form-item style="position: relative" prop="captcha"> |
|||
<el-input |
|||
v-model="loginForm.captcha" |
|||
name="logVerify" |
|||
placeholder="请输入验证码" |
|||
style="width: 60%" |
|||
/> |
|||
<div class="vPic"> |
|||
<img |
|||
v-if="picPath" |
|||
:src="picPath" |
|||
alt="请输入验证码" |
|||
@click="loginVerify()" |
|||
/> |
|||
</div> |
|||
</el-form-item> |
|||
<el-form-item> |
|||
<!-- <el-button type="primary" style="width: 46%" @click="checkInit" |
|||
>前往初始化</el-button |
|||
> --> |
|||
<el-button |
|||
type="primary" |
|||
style="width: 46%; margin-left: 25%" |
|||
@click="submitForm" |
|||
>登 录</el-button |
|||
> |
|||
</el-form-item> |
|||
</el-form> |
|||
</div> |
|||
<div class="login_panle_right" /> |
|||
</div> |
|||
</div> |
|||
</template> |
|||
<script> |
|||
import { mapActions } from 'vuex' |
|||
import { captcha } from '@/api/user' |
|||
import { checkDB } from '@/api/initdb' |
|||
export default { |
|||
name: 'Login', |
|||
data() { |
|||
const checkUsername = (rule, value, callback) => { |
|||
if (value.length < 5) { |
|||
return callback(new Error('请输入正确的用户名')) |
|||
} else { |
|||
callback() |
|||
} |
|||
} |
|||
const checkPassword = (rule, value, callback) => { |
|||
if (value.length < 6) { |
|||
return callback(new Error('请输入正确的密码')) |
|||
} else { |
|||
callback() |
|||
} |
|||
} |
|||
return { |
|||
curYear: 0, |
|||
lock: 'lock', |
|||
loginForm: { |
|||
username: 'admin', |
|||
password: '123456', |
|||
captcha: '', |
|||
captchaId: '' |
|||
}, |
|||
rules: { |
|||
username: [{ validator: checkUsername, trigger: 'blur' }], |
|||
password: [{ validator: checkPassword, trigger: 'blur' }], |
|||
captcha: [{ required: true, message: '请输入验证码', trigger: 'blur' }, |
|||
{ |
|||
min: 5, |
|||
max: 6, |
|||
message: '验证码格式不正确', |
|||
trigger: 'blur', |
|||
}] |
|||
}, |
|||
logVerify: '', |
|||
picPath: '' |
|||
} |
|||
}, |
|||
created() { |
|||
this.loginVerify() |
|||
this.curYear = new Date().getFullYear() |
|||
}, |
|||
methods: { |
|||
...mapActions('user', ['LoginIn']), |
|||
async checkInit() { |
|||
const res = await checkDB() |
|||
if (res.code === 0) { |
|||
if (res.data?.needInit) { |
|||
this.$store.commit('user/NeedInit') |
|||
this.$router.push({ name: 'Init' }) |
|||
} else { |
|||
this.$message({ |
|||
type: 'info', |
|||
message: '已配置数据库信息,无法初始化' |
|||
}) |
|||
} |
|||
} |
|||
}, |
|||
async login() { |
|||
return await this.LoginIn(this.loginForm) |
|||
}, |
|||
async submitForm() { |
|||
this.$refs.loginForm.validate(async(v) => { |
|||
if (v) { |
|||
const flag = await this.login() |
|||
if (!flag) { |
|||
this.loginVerify() |
|||
} |
|||
} else { |
|||
this.$message({ |
|||
type: 'error', |
|||
message: '请正确填写登录信息', |
|||
showClose: true |
|||
}) |
|||
this.loginVerify() |
|||
return false |
|||
} |
|||
}) |
|||
}, |
|||
changeLock() { |
|||
this.lock = this.lock === 'lock' ? 'unlock' : 'lock' |
|||
}, |
|||
loginVerify() { |
|||
captcha({}).then((ele) => { |
|||
this.picPath = ele.data.picPath |
|||
this.loginForm.captchaId = ele.data.captchaId |
|||
}) |
|||
} |
|||
} |
|||
} |
|||
|
|||
</script> |
|||
|
|||
|
|||
|
|||
|
|||
<style lang="scss" scoped> |
|||
@import "@/style/newLogin.scss"; |
|||
</style> |
|||
@ -0,0 +1,385 @@ |
|||
<template> |
|||
<!-- 履职尽责考核表录入 --> |
|||
<div> |
|||
<div class="gva-search-box"> |
|||
<el-form ref="searchForm" :inline="true" :model="searchInfo"> |
|||
<el-form-item label="所属部门"> |
|||
<el-select v-model="searchInfo.workSection" clearable placeholder="请选择部门"> |
|||
<el-option value="1" label="a工段">煤焦分厂</el-option> |
|||
<el-option value="2" label="b工段">化产分厂</el-option> |
|||
<el-option value="2" label="b工段">甲醇分厂</el-option> |
|||
<el-option value="2" label="b工段">动力分厂</el-option> |
|||
<el-option value="2" label="b工段">生产部</el-option> |
|||
<el-option value="2" label="b工段">技术部</el-option> |
|||
<el-option value="2" label="b工段">质检中心</el-option> |
|||
<el-option value="2" label="b工段">安全部</el-option> |
|||
<el-option value="2" label="b工段">环保部</el-option> |
|||
<el-option value="2" label="b工段">营销部</el-option> |
|||
<el-option value="2" label="b工段">仓储中心</el-option> |
|||
<el-option value="2" label="b工段">物流中心</el-option> |
|||
<el-option value="2" label="b工段">人力资源部</el-option> |
|||
<el-option value="2" label="b工段">财务部</el-option> |
|||
<el-option value="2" label="b工段">综合办</el-option> |
|||
<el-option value="2" label="b工段">企管部</el-option> |
|||
<el-option value="2" label="b工段">保卫部</el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-form-item> |
|||
<el-button size="mini" type="primary" icon="el-icon-search" @click="onSubmit">查询</el-button> |
|||
<el-button size="mini" icon="el-icon-refresh" @click="onReset">重置</el-button> |
|||
</el-form-item> |
|||
</el-form> |
|||
</div> |
|||
<div class="gva-table-box"> |
|||
<div class="gva-btn-list"> |
|||
<el-button size="mini" type="primary" icon="el-icon-plus" @click="openDialog('addApi')">新增</el-button> |
|||
<el-button size="mini" type="primary" icon="el-icon-upload" @click="openDialog('addApi')">导入题库数据</el-button> |
|||
<el-popover v-model:visible="deleteVisible" placement="top" width="160"> |
|||
<p>确定要删除吗?</p> |
|||
<div style="text-align: right; margin-top: 8px;"> |
|||
<el-button size="mini" type="text" @click="deleteVisible = false">取消</el-button> |
|||
<el-button size="mini" type="primary" @click="onDelete">确定</el-button> |
|||
</div> |
|||
<template #reference> |
|||
<el-button icon="el-icon-delete" size="mini" :disabled="!apis.length" style="margin-left: 10px;">删除</el-button> |
|||
</template> |
|||
</el-popover> |
|||
</div> |
|||
<el-table :data="tableData" @sort-change="sortChange" @selection-change="handleSelectionChange"> |
|||
<el-table-column |
|||
type="selection" |
|||
width="55" |
|||
/> |
|||
<el-table-column align="left" label="部门" min-width="150" prop="description"/> |
|||
<el-table-column align="left" label="考核类别" min-width="60" prop="ID"/> |
|||
<el-table-column align="left" label="权重(%)" min-width="150" prop="path"/> |
|||
<el-table-column align="left" label="考核项目" min-width="150" prop="apiGroup"/> |
|||
<el-table-column align="left" label="考核说明" min-width="150" prop="apiGroup"/> |
|||
<!-- <el-table-column align="left" label="创建时间" min-width="150" prop="method"> |
|||
<template #default="scope"> |
|||
<div> |
|||
{{ scope.row.method }} / {{ methodFiletr(scope.row.method) }} |
|||
</div> |
|||
</template> |
|||
</el-table-column> --> |
|||
|
|||
<el-table-column align="left" fixed="right" label="操作" width="200"> |
|||
<template #default="scope"> |
|||
<el-button |
|||
icon="el-icon-edit" |
|||
size="small" |
|||
type="text" |
|||
@click="editApi(scope.row)" |
|||
>编辑</el-button> |
|||
<el-button |
|||
icon="el-icon-delete" |
|||
size="small" |
|||
type="text" |
|||
@click="deleteApi(scope.row)" |
|||
>删除</el-button> |
|||
</template> |
|||
</el-table-column> |
|||
</el-table> |
|||
<div class="gva-pagination"> |
|||
<el-pagination |
|||
:current-page="page" |
|||
:page-size="pageSize" |
|||
:page-sizes="[10, 30, 50, 100]" |
|||
:total="total" |
|||
layout="total, sizes, prev, pager, next, jumper" |
|||
@current-change="handleCurrentChange" |
|||
@size-change="handleSizeChange" |
|||
/> |
|||
</div> |
|||
|
|||
</div> |
|||
|
|||
<el-dialog v-model="dialogFormVisible" :before-close="closeDialog" :title="dialogTitle" width="20%"> |
|||
|
|||
<el-form ref="apiForm" :model="form" :rules="rules" label-width="80px"> |
|||
<el-form-item label="考核类别" prop="category"> |
|||
<el-input v-model="form.category" autocomplete="off" /> |
|||
</el-form-item> |
|||
<el-form-item label="部门" prop="department"> |
|||
<el-select v-model="form.department" placeholder="请选择部门" style="width:100%"> |
|||
<el-option value="1" label="a工段">煤焦分厂</el-option> |
|||
<el-option value="2" label="b工段">化产分厂</el-option> |
|||
<el-option value="2" label="b工段">甲醇分厂</el-option> |
|||
<el-option value="2" label="b工段">动力分厂</el-option> |
|||
<el-option value="2" label="b工段">生产部</el-option> |
|||
<el-option value="2" label="b工段">技术部</el-option> |
|||
<el-option value="2" label="b工段">质检中心</el-option> |
|||
<el-option value="2" label="b工段">安全部</el-option> |
|||
<el-option value="2" label="b工段">环保部</el-option> |
|||
<el-option value="2" label="b工段">营销部</el-option> |
|||
<el-option value="2" label="b工段">仓储中心</el-option> |
|||
<el-option value="2" label="b工段">物流中心</el-option> |
|||
<el-option value="2" label="b工段">人力资源部</el-option> |
|||
<el-option value="2" label="b工段">财务部</el-option> |
|||
<el-option value="2" label="b工段">综合办</el-option> |
|||
<el-option value="2" label="b工段">企管部</el-option> |
|||
<el-option value="2" label="b工段">保卫部</el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-form-item label="考核项目" prop="apiGrprojectoup"> |
|||
<el-input v-model="form.project" autocomplete="off" /> |
|||
</el-form-item> |
|||
<el-form-item label="权重" prop="weights"> |
|||
<el-input placeholder="请输入内容" v-model="form.weights"> |
|||
<template #append>%</template> |
|||
</el-input> |
|||
</el-form-item> |
|||
<el-form-item label="考核说明" prop="instruction"> |
|||
<el-input |
|||
v-model="form.instruction" |
|||
:rows="2" |
|||
type="textarea" |
|||
placeholder="请输入考核说明" |
|||
/> |
|||
<!-- <el-input v-model="form.instruction" autocomplete="off" /> --> |
|||
</el-form-item> |
|||
</el-form> |
|||
<template #footer> |
|||
<div class="dialog-footer"> |
|||
<el-button size="small" @click="closeDialog">取 消</el-button> |
|||
<el-button size="small" type="primary" @click="enterDialog">确 定</el-button> |
|||
</div> |
|||
</template> |
|||
</el-dialog> |
|||
</div> |
|||
</template> |
|||
|
|||
<script> |
|||
// 获取列表内容封装在mixins内部 getTableData方法 初始化已封装完成 条件搜索时候 请把条件安好后台定制的结构体字段 放到 this.searchInfo 中即可实现条件搜索 |
|||
|
|||
import { |
|||
getApiById, |
|||
getApiList, |
|||
createApi, |
|||
updateApi, |
|||
deleteApi, |
|||
deleteApisByIds |
|||
} from '@/api/api' |
|||
import infoList from '@/mixins/infoList' |
|||
import { toSQLLine } from '@/utils/stringFun' |
|||
import warningBar from '@/components/warningBar/warningBar.vue' |
|||
const methodOptions = [ |
|||
{ |
|||
value: 'POST', |
|||
label: '创建', |
|||
type: 'success' |
|||
}, |
|||
{ |
|||
value: 'GET', |
|||
label: '查看', |
|||
type: '' |
|||
}, |
|||
{ |
|||
value: 'PUT', |
|||
label: '更新', |
|||
type: 'warning' |
|||
}, |
|||
{ |
|||
value: 'DELETE', |
|||
label: '删除', |
|||
type: 'danger' |
|||
} |
|||
] |
|||
|
|||
export default { |
|||
name: 'Api', |
|||
components: { |
|||
warningBar |
|||
}, |
|||
mixins: [infoList], |
|||
data() { |
|||
return { |
|||
deleteVisible: false, |
|||
listApi: getApiList, |
|||
dialogFormVisible: false, |
|||
dialogTitle: '新增', |
|||
apis: [], |
|||
form: { |
|||
path: '', |
|||
apiGroup: '', |
|||
method: '', |
|||
description: '' |
|||
}, |
|||
methodOptions: methodOptions, |
|||
type: '', |
|||
rules: { |
|||
path: [{ required: true, message: '请输入api路径', trigger: 'blur' }], |
|||
apiGroup: [ |
|||
{ required: true, message: '请输入组名称', trigger: 'blur' } |
|||
], |
|||
method: [ |
|||
{ required: true, message: '请选择请求方式', trigger: 'blur' } |
|||
], |
|||
description: [ |
|||
{ required: true, message: '请输入api介绍', trigger: 'blur' } |
|||
] |
|||
} |
|||
} |
|||
}, |
|||
created() { |
|||
this.getTableData() |
|||
}, |
|||
methods: { |
|||
methodFiletr(value) { |
|||
const target = methodOptions.filter(item => item.value === value)[0] |
|||
return target && `${target.label}` |
|||
}, |
|||
tagTypeFiletr(value) { |
|||
const target = methodOptions.filter(item => item.value === value)[0] |
|||
return target && `${target.type}` |
|||
}, |
|||
// 选中api |
|||
handleSelectionChange(val) { |
|||
this.apis = val |
|||
}, |
|||
async onDelete() { |
|||
const ids = this.apis.forEach(item => item.ID) |
|||
const res = await deleteApisByIds({ ids }) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: res.msg |
|||
}) |
|||
if (this.tableData.length === ids.length && this.page > 1) { |
|||
this.page-- |
|||
} |
|||
this.deleteVisible = false |
|||
this.getTableData() |
|||
} |
|||
}, |
|||
// 排序 |
|||
sortChange({ prop, order }) { |
|||
if (prop) { |
|||
this.searchInfo.orderKey = toSQLLine(prop) |
|||
this.searchInfo.desc = order === 'descending' |
|||
} |
|||
this.getTableData() |
|||
}, |
|||
onReset() { |
|||
this.searchInfo = {} |
|||
}, |
|||
// 条件搜索前端看此方法 |
|||
onSubmit() { |
|||
this.page = 1 |
|||
this.pageSize = 10 |
|||
this.getTableData() |
|||
}, |
|||
initForm() { |
|||
this.$refs.apiForm.resetFields() |
|||
this.form = { |
|||
path: '', |
|||
apiGroup: '', |
|||
method: '', |
|||
description: '' |
|||
} |
|||
}, |
|||
closeDialog() { |
|||
this.initForm() |
|||
this.dialogFormVisible = false |
|||
}, |
|||
openDialog(type) { |
|||
switch (type) { |
|||
case 'addApi': |
|||
this.dialogTitle = '新增' |
|||
break |
|||
case 'edit': |
|||
this.dialogTitle = '编辑' |
|||
break |
|||
default: |
|||
break |
|||
} |
|||
this.type = type |
|||
this.dialogFormVisible = true |
|||
}, |
|||
async editApi(row) { |
|||
const res = await getApiById({ id: row.ID }) |
|||
this.form = res.data.api |
|||
this.openDialog('edit') |
|||
}, |
|||
async deleteApi(row) { |
|||
this.$confirm('此操作将永久删除所有角色下该api, 是否继续?', '提示', { |
|||
confirmButtonText: '确定', |
|||
cancelButtonText: '取消', |
|||
type: 'warning' |
|||
}) |
|||
.then(async() => { |
|||
const res = await deleteApi(row) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '删除成功!' |
|||
}) |
|||
if (this.tableData.length === 1 && this.page > 1) { |
|||
this.page-- |
|||
} |
|||
this.getTableData() |
|||
} |
|||
}) |
|||
}, |
|||
async enterDialog() { |
|||
this.$refs.apiForm.validate(async valid => { |
|||
if (valid) { |
|||
switch (this.type) { |
|||
case 'addApi': |
|||
{ |
|||
const res = await createApi(this.form) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '添加成功', |
|||
showClose: true |
|||
}) |
|||
} |
|||
this.getTableData() |
|||
this.closeDialog() |
|||
} |
|||
|
|||
break |
|||
case 'edit': |
|||
{ |
|||
const res = await updateApi(this.form) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '编辑成功', |
|||
showClose: true |
|||
}) |
|||
} |
|||
this.getTableData() |
|||
this.closeDialog() |
|||
} |
|||
break |
|||
default: |
|||
// eslint-disable-next-line no-lone-blocks |
|||
{ |
|||
this.$message({ |
|||
type: 'error', |
|||
message: '未知操作', |
|||
showClose: true |
|||
}) |
|||
} |
|||
break |
|||
} |
|||
} |
|||
}) |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style scoped lang="scss"> |
|||
.button-box { |
|||
padding: 10px 20px; |
|||
.el-button { |
|||
float: right; |
|||
} |
|||
} |
|||
.warning { |
|||
color: #dc143c; |
|||
} |
|||
</style> |
|||
@ -0,0 +1,443 @@ |
|||
<template> |
|||
<!-- 被考核部门录入 --> |
|||
<div> |
|||
<div class="gva-search-box"> |
|||
<el-form ref="searchForm" :inline="true" :model="searchInfo"> |
|||
<el-form-item label="考核类别名称"> |
|||
<el-input |
|||
placeholder="请输入名称" |
|||
v-model="searchInfo.title" |
|||
clearable> |
|||
</el-input> |
|||
</el-form-item> |
|||
</el-form> |
|||
</div> |
|||
<div class="gva-table-box"> |
|||
<div class="gva-btn-list"> |
|||
<el-button size="mini" type="primary" icon="el-icon-plus" @click="openDialog('addApi')">新增</el-button> |
|||
</div> |
|||
<el-table :data="tableData" @sort-change="sortChange" @selection-change="handleSelectionChange"> |
|||
<!-- <el-table-column |
|||
type="selection" |
|||
width="55" |
|||
/> --> |
|||
<el-table-column align="left" label="考核类别" prop="classTitle"/> |
|||
<el-table-column align="left" label="考核项目" prop="assessTitle"/> |
|||
<el-table-column align="left" label="具体职责" prop="duryTitle"/> |
|||
<el-table-column align="left" label="部门名称" prop="parentTitle"> |
|||
<template #default="scope"> |
|||
{{scope.row.groupTitle}}{{scope.row.parentTitle}} |
|||
</template> |
|||
</el-table-column> |
|||
<el-table-column align="left" label="状态"> |
|||
<template #default="scope"> |
|||
<el-switch |
|||
inline-prompt |
|||
active-text="正常" |
|||
inactive-text="禁止" |
|||
v-model="scope.row.state" |
|||
active-color="#13ce66" |
|||
inactive-color="#ff4949" |
|||
:active-value=1 |
|||
:inactive-value=2 |
|||
@change="changeVal($event,scope.row.outId)" |
|||
/> |
|||
</template> |
|||
</el-table-column> |
|||
<el-table-column align="left" fixed="right" label="操作" width="200"> |
|||
<template #default="scope"> |
|||
<el-button |
|||
icon="el-icon-edit" |
|||
size="small" |
|||
type="text" |
|||
@click="editApi(scope.row)" |
|||
>编辑</el-button> |
|||
<el-button |
|||
icon="el-icon-delete" |
|||
size="small" |
|||
type="text" |
|||
@click="deleteOperate(scope.row)" |
|||
>删除</el-button> |
|||
</template> |
|||
</el-table-column> |
|||
</el-table> |
|||
<div class="gva-pagination"> |
|||
<el-pagination |
|||
:current-page="page" |
|||
:page-size="pageSize" |
|||
:page-sizes="[10, 30, 50, 100]" |
|||
:total="total" |
|||
layout="total, sizes, prev, pager, next, jumper" |
|||
@current-change="handleCurrentChange" |
|||
@size-change="handleSizeChange" |
|||
/> |
|||
</div> |
|||
|
|||
</div> |
|||
|
|||
<el-dialog v-model="dialogFormVisible" :before-close="closeDialog" :title="dialogTitle" width="20%"> |
|||
|
|||
<el-form ref="apiForm" :model="form" :rules="rules" label-width="150px"> |
|||
<el-form-item label="考核类别" prop="title"> |
|||
<el-select @change="getClassId" v-model="form.classId" clearable placeholder="请选择考核类别"> |
|||
<el-option |
|||
v-for="item in dutyclasslist" |
|||
:key="item.outId" |
|||
:label="item.title" |
|||
:value="item.outId" |
|||
|
|||
> |
|||
</el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-form-item v-if="showAssess" label="考核项目" prop="title"> |
|||
<el-select v-model="form.assessId" clearable placeholder="请选择考核项目" @change="getAssessId"> |
|||
<el-option |
|||
v-for="item in assessList" |
|||
:key="item.outId" |
|||
:label="item.title" |
|||
:value="item.outId" |
|||
> |
|||
</el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-form-item v-if="showDuty" label="具体职责" prop="title"> |
|||
<el-select v-model="form.dutyId" clearable placeholder="请选择具体职责"> |
|||
<el-option |
|||
v-for="item in dutylist" |
|||
:key="item.outId" |
|||
:label="item.title" |
|||
:value="item.outId" |
|||
> |
|||
</el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-form-item label="分值" prop="title"> |
|||
<el-input v-model="form.title" autocomplete="off" /> |
|||
</el-form-item> |
|||
</el-form> |
|||
<template #footer> |
|||
<div class="dialog-footer"> |
|||
<el-button size="small" @click="closeDialog">取 消</el-button> |
|||
<el-button size="small" type="primary" @click="enterDialog">确 定</el-button> |
|||
</div> |
|||
</template> |
|||
</el-dialog> |
|||
</div> |
|||
</template> |
|||
|
|||
<script> |
|||
// 获取列表内容封装在mixins内部 getTableData方法 初始化已封装完成 条件搜索时候 请把条件安好后台定制的结构体字段 放到 this.searchInfo 中即可实现条件搜索 |
|||
|
|||
import { |
|||
specdutylist, |
|||
addspecdutyinfo, |
|||
getspecdutyinfo, |
|||
eitespecdutyinfo, |
|||
dutyclasslist, |
|||
assessList, |
|||
dutylist, |
|||
eitespecdutystate |
|||
} from '@/api/dataEntry' |
|||
import infoList from '@/mixins/infoList' |
|||
import { toSQLLine } from '@/utils/stringFun' |
|||
import warningBar from '@/components/warningBar/warningBar.vue' |
|||
const methodOptions = [ |
|||
{ |
|||
value: 'POST', |
|||
label: '创建', |
|||
type: 'success' |
|||
}, |
|||
{ |
|||
value: 'GET', |
|||
label: '查看', |
|||
type: '' |
|||
}, |
|||
{ |
|||
value: 'PUT', |
|||
label: '更新', |
|||
type: 'warning' |
|||
}, |
|||
{ |
|||
value: 'DELETE', |
|||
label: '删除', |
|||
type: 'danger' |
|||
} |
|||
] |
|||
|
|||
export default { |
|||
name: 'Api', |
|||
components: { |
|||
warningBar |
|||
}, |
|||
mixins: [infoList], |
|||
data() { |
|||
return { |
|||
showDuty:false, |
|||
assessList:{}, |
|||
dutylist:{}, |
|||
showAssess:false, |
|||
searchList:{ |
|||
page:1, |
|||
pagesize:10000, |
|||
state:1, |
|||
}, |
|||
deleFrom:{ |
|||
outid:'', |
|||
state:Number |
|||
}, |
|||
switchFrom:{ |
|||
outid:'', |
|||
state:Number |
|||
}, |
|||
editFrom:{ |
|||
outid:'', |
|||
}, |
|||
deleteVisible: false, |
|||
listApi: specdutylist, |
|||
dialogFormVisible: false, |
|||
dialogTitle: '新增', |
|||
apis: [], |
|||
form: { |
|||
title:'', |
|||
}, |
|||
methodOptions: methodOptions, |
|||
type: '', |
|||
rules: { |
|||
title: [{ required: true, message: '考核类别名称', trigger: 'blur' }], |
|||
|
|||
} |
|||
} |
|||
}, |
|||
created() { |
|||
this.getTableData() |
|||
this.getDutyclasslist() |
|||
}, |
|||
methods: { |
|||
// 监听选择考核项目 |
|||
async getAssessId(data){ |
|||
// 根据选中的考核项目请求具体职责 |
|||
const dutyFrom={ |
|||
page: 1, |
|||
pagesize: 10000, |
|||
state:1, |
|||
parentId:'' |
|||
} |
|||
dutyFrom.parentId=data; |
|||
const res = await dutylist(dutyFrom) |
|||
this.dutylist=res.data.list |
|||
if(data==""){ |
|||
this.showDuty=false; |
|||
}else{ |
|||
this.showDuty=true; |
|||
} |
|||
}, |
|||
// 监听选择考核类别 |
|||
async getClassId(data){ |
|||
// 根据选中的考核类别请求考核项目 |
|||
const assessFrom={ |
|||
page: 1, |
|||
pagesize: 10000, |
|||
state:1, |
|||
parentId:'' |
|||
} |
|||
assessFrom.parentId=data; |
|||
const res = await assessList(assessFrom) |
|||
this.assessList=res.data.list |
|||
if(data==""){ |
|||
this.showAssess=false; |
|||
}else{ |
|||
this.showAssess=true; |
|||
} |
|||
}, |
|||
// 获取考核类别列表 |
|||
async getDutyclasslist(){ |
|||
const res = await dutyclasslist(this.searchList) |
|||
this.dutyclasslist=res.data.list |
|||
}, |
|||
// 开关状态监听 |
|||
async changeVal(val,id){ |
|||
console.log(val) |
|||
this.switchFrom.outid=id |
|||
if (val==1) { |
|||
this.switchFrom.state=1; |
|||
const res = await eitespecdutystate(this.switchFrom) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '修改状态成功', |
|||
showClose: true |
|||
}) |
|||
this.getTableData() |
|||
} |
|||
} else { |
|||
this.switchFrom.state=2; |
|||
const res = await eitespecdutystate(this.switchFrom) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '修改状态成功', |
|||
showClose: true |
|||
}) |
|||
this.getTableData() |
|||
} |
|||
} |
|||
}, |
|||
methodFiletr(value) { |
|||
const target = methodOptions.filter(item => item.value === value)[0] |
|||
return target && `${target.label}` |
|||
}, |
|||
tagTypeFiletr(value) { |
|||
const target = methodOptions.filter(item => item.value === value)[0] |
|||
return target && `${target.type}` |
|||
}, |
|||
// 选中api |
|||
handleSelectionChange(val) { |
|||
this.apis = val |
|||
}, |
|||
async onDelete() { |
|||
const ids = this.apis.forEach(item => item.ID) |
|||
const res = await deleteApisByIds({ ids }) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: res.msg |
|||
}) |
|||
if (this.tableData.length === ids.length && this.page > 1) { |
|||
this.page-- |
|||
} |
|||
this.deleteVisible = false |
|||
this.getTableData() |
|||
} |
|||
}, |
|||
// 排序 |
|||
sortChange({ prop, order }) { |
|||
if (prop) { |
|||
this.searchInfo.orderKey = toSQLLine(prop) |
|||
this.searchInfo.desc = order === 'descending' |
|||
} |
|||
this.getTableData() |
|||
}, |
|||
onReset() { |
|||
this.searchInfo = {} |
|||
}, |
|||
// 条件搜索前端看此方法 |
|||
onSubmit() { |
|||
this.page = 1 |
|||
this.pageSize = 10 |
|||
this.getTableData() |
|||
}, |
|||
initForm() { |
|||
this.$refs.apiForm.resetFields() |
|||
this.form = { |
|||
} |
|||
}, |
|||
closeDialog() { |
|||
this.initForm() |
|||
this.dialogFormVisible = false |
|||
}, |
|||
openDialog(type) { |
|||
switch (type) { |
|||
case 'addApi': |
|||
this.dialogTitle = '新增' |
|||
break |
|||
case 'edit': |
|||
this.dialogTitle = '编辑' |
|||
break |
|||
default: |
|||
break |
|||
} |
|||
this.type = type |
|||
this.dialogFormVisible = true |
|||
}, |
|||
async editApi(row) { |
|||
this.editFrom.outid=row.outId |
|||
const res = await getdutyclassinfo(this.editFrom) |
|||
this.form = res.data |
|||
this.openDialog('edit') |
|||
}, |
|||
//删除操作 |
|||
async deleteOperate(row) { |
|||
this.$confirm('此操作将永久删除, 是否继续?', '提示', { |
|||
confirmButtonText: '确定', |
|||
cancelButtonText: '取消', |
|||
type: 'warning' |
|||
}) |
|||
.then(async() => { |
|||
this.deleFrom.state=3; |
|||
console.log(row.outID) |
|||
this.deleFrom.outid=row.outId; |
|||
const res = await eitespecdutystate(this.deleFrom) |
|||
if (res.code === 0) { |
|||
|
|||
this.$message({ |
|||
type: 'success', |
|||
message: '删除成功!' |
|||
}) |
|||
|
|||
this.getTableData() |
|||
} |
|||
}) |
|||
}, |
|||
async enterDialog() { |
|||
this.$refs.apiForm.validate(async valid => { |
|||
if (valid) { |
|||
switch (this.type) { |
|||
case 'addApi': |
|||
{ |
|||
const res = await adddutyclass(this.form) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '添加成功', |
|||
showClose: true |
|||
}) |
|||
} |
|||
this.getTableData() |
|||
this.closeDialog() |
|||
} |
|||
|
|||
break |
|||
case 'edit': |
|||
{ |
|||
const res = await eitedutyclassinfo(this.form) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '编辑成功', |
|||
showClose: true |
|||
}) |
|||
} |
|||
this.getTableData() |
|||
this.closeDialog() |
|||
} |
|||
break |
|||
default: |
|||
// eslint-disable-next-line no-lone-blocks |
|||
{ |
|||
this.$message({ |
|||
type: 'error', |
|||
message: '未知操作', |
|||
showClose: true |
|||
}) |
|||
} |
|||
break |
|||
} |
|||
} |
|||
}) |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style scoped lang="scss"> |
|||
.button-box { |
|||
padding: 10px 20px; |
|||
.el-button { |
|||
float: right; |
|||
} |
|||
} |
|||
.warning { |
|||
color: #dc143c; |
|||
} |
|||
</style> |
|||
@ -0,0 +1,543 @@ |
|||
<template> |
|||
<!-- 被考核部门录入 --> |
|||
<div> |
|||
<div class="gva-search-box"> |
|||
<el-form ref="searchForm" :inline="true" :model="searchInfo"> |
|||
<el-form-item label="考核类别名称"> |
|||
<el-input |
|||
placeholder="请输入名称" |
|||
v-model="searchInfo.title" |
|||
clearable> |
|||
</el-input> |
|||
</el-form-item> |
|||
</el-form> |
|||
</div> |
|||
<div class="gva-table-box"> |
|||
<div class="gva-btn-list"> |
|||
<el-button size="mini" type="primary" icon="el-icon-plus" @click="openDialog('addApi')">新增</el-button> |
|||
</div> |
|||
<el-table :data="tableData" @sort-change="sortChange" @selection-change="handleSelectionChange"> |
|||
<!-- <el-table-column |
|||
type="selection" |
|||
width="55" |
|||
/> --> |
|||
<el-table-column align="left" label="考核类别" prop="classTitle"/> |
|||
<el-table-column align="left" label="考核项目" prop="assessTitle"/> |
|||
<el-table-column align="left" label="具体职责" prop="duryTitle"/> |
|||
<el-table-column align="left" label="部门名称" prop="parentTitle"> |
|||
<template #default="scope"> |
|||
{{scope.row.groupTitle}}{{scope.row.parentTitle}} |
|||
</template> |
|||
</el-table-column> |
|||
<el-table-column align="left" label="状态"> |
|||
<template #default="scope"> |
|||
<el-switch |
|||
inline-prompt |
|||
active-text="正常" |
|||
inactive-text="禁止" |
|||
v-model="scope.row.state" |
|||
active-color="#13ce66" |
|||
inactive-color="#ff4949" |
|||
:active-value=1 |
|||
:inactive-value=2 |
|||
@change="changeVal($event,scope.row.outId)" |
|||
/> |
|||
</template> |
|||
</el-table-column> |
|||
<el-table-column align="left" label="分值" prop="rescore"/> |
|||
<el-table-column align="left" fixed="right" label="操作" width="200"> |
|||
<template #default="scope"> |
|||
<el-button |
|||
icon="el-icon-edit" |
|||
size="small" |
|||
type="text" |
|||
@click="editApi(scope.row)" |
|||
>编辑</el-button> |
|||
<el-button |
|||
icon="el-icon-delete" |
|||
size="small" |
|||
type="text" |
|||
@click="deleteOperate(scope.row)" |
|||
>删除</el-button> |
|||
</template> |
|||
</el-table-column> |
|||
</el-table> |
|||
<div class="gva-pagination"> |
|||
<el-pagination |
|||
:current-page="page" |
|||
:page-size="pageSize" |
|||
:page-sizes="[10, 30, 50, 100]" |
|||
:total="total" |
|||
layout="total, sizes, prev, pager, next, jumper" |
|||
@current-change="handleCurrentChange" |
|||
@size-change="handleSizeChange" |
|||
/> |
|||
</div> |
|||
|
|||
</div> |
|||
<!-- 添加 --> |
|||
<el-dialog v-model="dialogFormVisible" :before-close="closeDialog" :title="dialogTitle" width="30%"> |
|||
|
|||
<el-form ref="apiForm" :model="form" :rules="rules" label-width="150px"> |
|||
|
|||
<el-form-item label="所属考核项目"> |
|||
<span> |
|||
<el-tag v-if="addChildInfo.title!=''">{{addChildInfo.title}}</el-tag> |
|||
<dutyDialog @checkedInfo="getCheckedfrom"></dutyDialog> |
|||
</span> |
|||
</el-form-item> |
|||
<el-form-item label="选择部门" prop="parentId"> |
|||
<el-cascader clearable v-model="form.parentId" :options="grouplist" :show-all-levels="false" :props="props"></el-cascader> |
|||
</el-form-item> |
|||
|
|||
<el-form-item label="分值" prop="score"> |
|||
<el-input v-model="form.score" autocomplete="off" /> |
|||
</el-form-item> |
|||
</el-form> |
|||
<template #footer> |
|||
<div class="dialog-footer"> |
|||
<el-button size="small" @click="closeDialog">取 消</el-button> |
|||
<el-button size="small" type="primary" @click="enterDialog">确 定</el-button> |
|||
</div> |
|||
</template> |
|||
</el-dialog> |
|||
<!-- 编辑 --> |
|||
<el-dialog v-model="editDialogFormVisible" :before-close="closeEditDialog" title="编辑" width="30%"> |
|||
|
|||
<el-form ref="apiForm" :model="editForm" :rules="editRules" label-width="150px"> |
|||
|
|||
<el-form-item label="所属考核项目"> |
|||
<span> |
|||
<el-tag v-if="editChildInfo.title!=''">{{editChildInfo.title}}</el-tag> |
|||
<dutyDialog @checkedInfo="getEditCheckedfrom"></dutyDialog> |
|||
</span> |
|||
</el-form-item> |
|||
<el-form-item label="选择部门" prop="parentId"> |
|||
<el-cascader clearable v-model="editForm.parentId" :options="grouplist" :show-all-levels="false" :props="props"></el-cascader> |
|||
</el-form-item> |
|||
<el-form-item label="分值" prop="rescore"> |
|||
<el-input v-model="editForm.rescore"/> |
|||
</el-form-item> |
|||
</el-form> |
|||
<template #footer> |
|||
<div class="dialog-footer"> |
|||
<el-button size="small" @click="closeEditDialog">取 消</el-button> |
|||
<el-button size="small" type="primary" @click="editInfo">确 定</el-button> |
|||
</div> |
|||
</template> |
|||
</el-dialog> |
|||
</div> |
|||
</template> |
|||
|
|||
<script> |
|||
// 获取列表内容封装在mixins内部 getTableData方法 初始化已封装完成 条件搜索时候 请把条件安好后台定制的结构体字段 放到 this.searchInfo 中即可实现条件搜索 |
|||
|
|||
import { |
|||
specdutylist, |
|||
adddepartdutyinfo, |
|||
getspecdutyinfo, |
|||
eitespecdutyinfo, |
|||
dutyclasslist, |
|||
assessList, |
|||
dutylist, |
|||
eitespecdutystate, |
|||
eitedepartdutyinfo |
|||
} from '@/api/dataEntry' |
|||
import { |
|||
getgroupdepartmap, |
|||
} from '@/api/group' |
|||
import infoList from '@/mixins/infoList' |
|||
import { toSQLLine } from '@/utils/stringFun' |
|||
import dutyDialog from '@/components/dutyDialog/index.vue' |
|||
const methodOptions = [ |
|||
{ |
|||
value: 'POST', |
|||
label: '创建', |
|||
type: 'success' |
|||
}, |
|||
{ |
|||
value: 'GET', |
|||
label: '查看', |
|||
type: '' |
|||
}, |
|||
{ |
|||
value: 'PUT', |
|||
label: '更新', |
|||
type: 'warning' |
|||
}, |
|||
{ |
|||
value: 'DELETE', |
|||
label: '删除', |
|||
type: 'danger' |
|||
} |
|||
] |
|||
|
|||
export default { |
|||
name: 'Api', |
|||
components: { |
|||
dutyDialog |
|||
}, |
|||
mixins: [infoList], |
|||
data() { |
|||
return { |
|||
editForm:{ |
|||
}, |
|||
editDialogFormVisible:false, |
|||
addChildInfo:{ |
|||
title:'' |
|||
}, |
|||
editChildInfo:{ |
|||
title:'' |
|||
}, |
|||
props: { |
|||
value: "id", |
|||
label: "name", |
|||
children: "children", |
|||
emitPath:false |
|||
}, |
|||
showDuty:false, |
|||
assessList:{}, |
|||
dutylist:{}, |
|||
showAssess:false, |
|||
searchList:{ |
|||
page:1, |
|||
pagesize:10000, |
|||
state:1, |
|||
}, |
|||
deleFrom:{ |
|||
outid:'', |
|||
state:Number |
|||
}, |
|||
switchFrom:{ |
|||
outid:'', |
|||
state:Number |
|||
}, |
|||
editFrom:{ |
|||
outid:'', |
|||
rescore:'', |
|||
score:Number |
|||
}, |
|||
deleteVisible: false, |
|||
listApi: specdutylist, |
|||
dialogFormVisible: false, |
|||
dialogTitle: '新增', |
|||
apis: [], |
|||
form: { |
|||
parentId:'', |
|||
dutyId:'', |
|||
}, |
|||
methodOptions: methodOptions, |
|||
type: '', |
|||
rules: { |
|||
parentId: [{ required: true, message: '请选择部门', trigger: 'blur' }], |
|||
score: [{ required: true, message: '请输入分值', trigger: 'blur' }], |
|||
}, |
|||
editRules: { |
|||
parentId: [{ required: true, message: '请选择部门', trigger: 'blur' }], |
|||
rescore: [{ required: true, message: '请输入分值', trigger: 'blur' }], |
|||
} |
|||
} |
|||
}, |
|||
created() { |
|||
this.getTableData() |
|||
this.getDutyclasslist() |
|||
this.getGrouplist() |
|||
}, |
|||
methods: { |
|||
// 编辑提交 |
|||
async editInfo(){ |
|||
// this.editform.userid=this.editform.userid.toString(); |
|||
// delete this.editform.id |
|||
this.editForm.score=parseInt(this.editForm.rescore); |
|||
this.editForm.dutyId=this.editForm.dutyId.toString(); |
|||
this.editForm.parentId=this.editForm.parentId.toString(); |
|||
const res = await eitedepartdutyinfo(this.editForm) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '编辑成功', |
|||
showClose: true |
|||
}) |
|||
} |
|||
this.getTableData() |
|||
this.closeEditDialog() |
|||
}, |
|||
// 修改时获取选中组件值 |
|||
getEditCheckedfrom(data){ |
|||
this.editChildInfo=data |
|||
this.editForm.dutyId=this.editChildInfo.outId |
|||
}, |
|||
// 获取部门 |
|||
async getGrouplist(){ |
|||
const res = await getgroupdepartmap() |
|||
this.grouplist=res.data.list |
|||
|
|||
}, |
|||
// 添加获取选中组件值 |
|||
getCheckedfrom(data){ |
|||
this.addChildInfo=data |
|||
}, |
|||
// 监听选择考核项目 |
|||
async getAssessId(data){ |
|||
// 根据选中的考核项目请求具体职责 |
|||
const dutyFrom={ |
|||
page: 1, |
|||
pagesize: 10000, |
|||
state:1, |
|||
parentId:'' |
|||
} |
|||
dutyFrom.parentId=data; |
|||
const res = await dutylist(dutyFrom) |
|||
this.dutylist=res.data.list |
|||
if(data==""){ |
|||
this.showDuty=false; |
|||
}else{ |
|||
this.showDuty=true; |
|||
} |
|||
}, |
|||
// 监听选择考核类别 |
|||
async getClassId(data){ |
|||
// 根据选中的考核类别请求考核项目 |
|||
const assessFrom={ |
|||
page: 1, |
|||
pagesize: 10000, |
|||
state:1, |
|||
parentId:'' |
|||
} |
|||
assessFrom.parentId=data; |
|||
const res = await assessList(assessFrom) |
|||
this.assessList=res.data.list |
|||
if(data==""){ |
|||
this.showAssess=false; |
|||
}else{ |
|||
this.showAssess=true; |
|||
} |
|||
}, |
|||
// 获取考核类别列表 |
|||
async getDutyclasslist(){ |
|||
const res = await dutyclasslist(this.searchList) |
|||
this.dutyclasslist=res.data.list |
|||
}, |
|||
// 开关状态监听 |
|||
async changeVal(val,id){ |
|||
console.log(val) |
|||
this.switchFrom.outid=id |
|||
if (val==1) { |
|||
this.switchFrom.state=1; |
|||
const res = await eitespecdutystate(this.switchFrom) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '修改状态成功', |
|||
showClose: true |
|||
}) |
|||
this.getTableData() |
|||
} |
|||
} else { |
|||
this.switchFrom.state=2; |
|||
const res = await eitespecdutystate(this.switchFrom) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '修改状态成功', |
|||
showClose: true |
|||
}) |
|||
this.getTableData() |
|||
} |
|||
} |
|||
}, |
|||
|
|||
methodFiletr(value) { |
|||
const target = methodOptions.filter(item => item.value === value)[0] |
|||
return target && `${target.label}` |
|||
}, |
|||
tagTypeFiletr(value) { |
|||
const target = methodOptions.filter(item => item.value === value)[0] |
|||
return target && `${target.type}` |
|||
}, |
|||
// 选中api |
|||
handleSelectionChange(val) { |
|||
this.apis = val |
|||
}, |
|||
async onDelete() { |
|||
const ids = this.apis.forEach(item => item.ID) |
|||
const res = await deleteApisByIds({ ids }) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: res.msg |
|||
}) |
|||
if (this.tableData.length === ids.length && this.page > 1) { |
|||
this.page-- |
|||
} |
|||
this.deleteVisible = false |
|||
this.getTableData() |
|||
} |
|||
}, |
|||
// 排序 |
|||
sortChange({ prop, order }) { |
|||
if (prop) { |
|||
this.searchInfo.orderKey = toSQLLine(prop) |
|||
this.searchInfo.desc = order === 'descending' |
|||
} |
|||
this.getTableData() |
|||
}, |
|||
onReset() { |
|||
this.searchInfo = {} |
|||
}, |
|||
// 条件搜索前端看此方法 |
|||
onSubmit() { |
|||
this.page = 1 |
|||
this.pageSize = 10 |
|||
this.getTableData() |
|||
}, |
|||
initForm() { |
|||
this.$refs.apiForm.resetFields() |
|||
this.form = { |
|||
parentId:'', |
|||
dutyId:'', |
|||
} |
|||
}, |
|||
editInitForm (){ |
|||
this.editForm = { |
|||
} |
|||
}, |
|||
closeDialog() { |
|||
this.initForm() |
|||
this.dialogFormVisible = false |
|||
}, |
|||
closeEditDialog() { |
|||
this.editChildInfo={ |
|||
title:'' |
|||
} |
|||
this.editInitForm() |
|||
this.editDialogFormVisible = false |
|||
}, |
|||
openDialog(type) { |
|||
switch (type) { |
|||
case 'addApi': |
|||
this.dialogTitle = '新增' |
|||
break |
|||
case 'edit': |
|||
this.dialogTitle = '编辑' |
|||
break |
|||
default: |
|||
break |
|||
} |
|||
this.type = type |
|||
this.dialogFormVisible = true |
|||
}, |
|||
// editApi:async(row) => { |
|||
// this.editFrom.outid=row.outId |
|||
// const res = await getspecdutyinfo(this.editFrom) |
|||
// this.editChildInfo.title=res.data.duryTitle |
|||
// this.editForm = res.data |
|||
// this.$set(this.editForm,'rescore',res.data.rescore) |
|||
// this.editForm.parentId=parseInt(this.editForm.parentId); |
|||
// this.editDialogFormVisible=true |
|||
// }, |
|||
|
|||
async editApi(row) { |
|||
|
|||
this.editFrom.outid=row.outId |
|||
const res = await getspecdutyinfo(this.editFrom) |
|||
|
|||
this.editChildInfo.title=res.data.duryTitle |
|||
this.editForm = res.data |
|||
this.editForm.score=res.data.rescore |
|||
// this.editForm.rescore=this.editForm.rescore.toString(); |
|||
|
|||
this.editForm.parentId=parseInt(this.editForm.parentId); |
|||
console.log("editForm") |
|||
console.log(this.editForm) |
|||
this.editDialogFormVisible=true |
|||
}, |
|||
//删除操作 |
|||
async deleteOperate(row) { |
|||
this.$confirm('此操作将永久删除, 是否继续?', '提示', { |
|||
confirmButtonText: '确定', |
|||
cancelButtonText: '取消', |
|||
type: 'warning' |
|||
}) |
|||
.then(async() => { |
|||
this.deleFrom.state=3; |
|||
console.log(row.outID) |
|||
this.deleFrom.outid=row.outId; |
|||
const res = await eitespecdutystate(this.deleFrom) |
|||
if (res.code === 0) { |
|||
|
|||
this.$message({ |
|||
type: 'success', |
|||
message: '删除成功!' |
|||
}) |
|||
|
|||
this.getTableData() |
|||
} |
|||
}) |
|||
}, |
|||
async enterDialog() { |
|||
this.$refs.apiForm.validate(async valid => { |
|||
if (valid) { |
|||
switch (this.type) { |
|||
case 'addApi': |
|||
{ |
|||
console.log(this.addChildInfo) |
|||
this.form.dutyId=this.addChildInfo.outId |
|||
this.form.parentId=this.form.parentId.toString() |
|||
this.form.score=parseInt(this.form.score); |
|||
const res = await adddepartdutyinfo(this.form) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '添加成功', |
|||
showClose: true |
|||
}) |
|||
} |
|||
this.getTableData() |
|||
this.closeDialog() |
|||
} |
|||
|
|||
break |
|||
case 'edit': |
|||
{ |
|||
const res = await eitedutyclassinfo(this.form) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '编辑成功', |
|||
showClose: true |
|||
}) |
|||
} |
|||
this.getTableData() |
|||
this.closeDialog() |
|||
} |
|||
break |
|||
default: |
|||
// eslint-disable-next-line no-lone-blocks |
|||
{ |
|||
this.$message({ |
|||
type: 'error', |
|||
message: '未知操作', |
|||
showClose: true |
|||
}) |
|||
} |
|||
break |
|||
} |
|||
} |
|||
}) |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style scoped lang="scss"> |
|||
.button-box { |
|||
padding: 10px 20px; |
|||
.el-button { |
|||
float: right; |
|||
} |
|||
} |
|||
.warning { |
|||
color: #dc143c; |
|||
} |
|||
</style> |
|||
@ -0,0 +1,373 @@ |
|||
<template> |
|||
<!-- 考核类别录入 --> |
|||
<div> |
|||
<div class="gva-search-box"> |
|||
<el-form ref="searchForm" :inline="true" :model="searchInfo"> |
|||
<el-form-item label="考核类别名称"> |
|||
<el-input |
|||
placeholder="请输入名称" |
|||
v-model="searchInfo.title" |
|||
clearable> |
|||
</el-input> |
|||
</el-form-item> |
|||
<el-form-item label="考核类别状态"> |
|||
<el-select v-model="searchInfo.state" clearable placeholder="请选择状态"> |
|||
<el-option :value=1 label="正常">正常</el-option> |
|||
<el-option :value=2 label="禁止">禁止</el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-form-item> |
|||
<el-button size="mini" type="primary" icon="el-icon-search" @click="onSubmit">查询</el-button> |
|||
<el-button size="mini" icon="el-icon-refresh" @click="onReset">重置</el-button> |
|||
</el-form-item> |
|||
</el-form> |
|||
</div> |
|||
<div class="gva-table-box"> |
|||
<div class="gva-btn-list"> |
|||
<el-button size="mini" type="primary" icon="el-icon-plus" @click="openDialog('addApi')">新增</el-button> |
|||
<!-- <el-popover v-model:visible="deleteVisible" placement="top" width="160"> |
|||
<p>确定要删除吗?</p> |
|||
<div style="text-align: right; margin-top: 8px;"> |
|||
<el-button size="mini" type="text" @click="deleteVisible = false">取消</el-button> |
|||
<el-button size="mini" type="primary" @click="onDelete">确定</el-button> |
|||
</div> |
|||
<template #reference> |
|||
<el-button icon="el-icon-delete" size="mini" :disabled="!apis.length" style="margin-left: 10px;">删除</el-button> |
|||
</template> |
|||
</el-popover> --> |
|||
</div> |
|||
<el-table :data="tableData" @sort-change="sortChange" @selection-change="handleSelectionChange"> |
|||
<!-- <el-table-column |
|||
type="selection" |
|||
width="55" |
|||
/> --> |
|||
<el-table-column align="left" label="考核类别ID" prop="outId"/> |
|||
<el-table-column align="left" label="考核类别名称" prop="title"/> |
|||
<el-table-column align="left" label="考核类别状态"> |
|||
<template #default="scope"> |
|||
<el-switch |
|||
inline-prompt |
|||
active-text="正常" |
|||
inactive-text="禁止" |
|||
v-model="scope.row.state" |
|||
active-color="#13ce66" |
|||
inactive-color="#ff4949" |
|||
:active-value=1 |
|||
:inactive-value=2 |
|||
@change="changeVal($event,scope.row.outId)" |
|||
/> |
|||
</template> |
|||
</el-table-column> |
|||
<el-table-column align="left" fixed="right" label="操作" width="200"> |
|||
<template #default="scope"> |
|||
<el-button |
|||
icon="el-icon-edit" |
|||
size="small" |
|||
type="text" |
|||
@click="editApi(scope.row)" |
|||
>编辑</el-button> |
|||
<el-button |
|||
icon="el-icon-delete" |
|||
size="small" |
|||
type="text" |
|||
@click="deleteOperate(scope.row)" |
|||
>删除</el-button> |
|||
</template> |
|||
</el-table-column> |
|||
</el-table> |
|||
<div class="gva-pagination"> |
|||
<el-pagination |
|||
:current-page="page" |
|||
:page-size="pageSize" |
|||
:page-sizes="[10, 30, 50, 100]" |
|||
:total="total" |
|||
layout="total, sizes, prev, pager, next, jumper" |
|||
@current-change="handleCurrentChange" |
|||
@size-change="handleSizeChange" |
|||
/> |
|||
</div> |
|||
|
|||
</div> |
|||
|
|||
<el-dialog v-model="dialogFormVisible" :before-close="closeDialog" :title="dialogTitle" width="20%"> |
|||
|
|||
<el-form ref="apiForm" :model="form" :rules="rules" label-width="150px"> |
|||
<el-form-item label="考核类别名称" prop="title"> |
|||
<el-input v-model="form.title" autocomplete="off" /> |
|||
</el-form-item> |
|||
</el-form> |
|||
<template #footer> |
|||
<div class="dialog-footer"> |
|||
<el-button size="small" @click="closeDialog">取 消</el-button> |
|||
<el-button size="small" type="primary" @click="enterDialog">确 定</el-button> |
|||
</div> |
|||
</template> |
|||
</el-dialog> |
|||
</div> |
|||
</template> |
|||
|
|||
<script> |
|||
// 获取列表内容封装在mixins内部 getTableData方法 初始化已封装完成 条件搜索时候 请把条件安好后台定制的结构体字段 放到 this.searchInfo 中即可实现条件搜索 |
|||
|
|||
import { |
|||
dutyclasslist, |
|||
adddutyclass, |
|||
getdutyclassinfo, |
|||
eitedutyclassinfo, |
|||
statedutyclass |
|||
} from '@/api/dataEntry' |
|||
import infoList from '@/mixins/infoList' |
|||
import { toSQLLine } from '@/utils/stringFun' |
|||
import warningBar from '@/components/warningBar/warningBar.vue' |
|||
const methodOptions = [ |
|||
{ |
|||
value: 'POST', |
|||
label: '创建', |
|||
type: 'success' |
|||
}, |
|||
{ |
|||
value: 'GET', |
|||
label: '查看', |
|||
type: '' |
|||
}, |
|||
{ |
|||
value: 'PUT', |
|||
label: '更新', |
|||
type: 'warning' |
|||
}, |
|||
{ |
|||
value: 'DELETE', |
|||
label: '删除', |
|||
type: 'danger' |
|||
} |
|||
] |
|||
|
|||
export default { |
|||
name: 'Api', |
|||
components: { |
|||
warningBar |
|||
}, |
|||
mixins: [infoList], |
|||
data() { |
|||
return { |
|||
deleFrom:{ |
|||
outid:'', |
|||
state:Number |
|||
}, |
|||
switchFrom:{ |
|||
outid:'', |
|||
state:Number |
|||
}, |
|||
editFrom:{ |
|||
outid:'', |
|||
}, |
|||
deleteVisible: false, |
|||
listApi: dutyclasslist, |
|||
dialogFormVisible: false, |
|||
dialogTitle: '新增', |
|||
apis: [], |
|||
form: { |
|||
title:'', |
|||
}, |
|||
methodOptions: methodOptions, |
|||
type: '', |
|||
rules: { |
|||
title: [{ required: true, message: '考核类别名称', trigger: 'blur' }], |
|||
|
|||
} |
|||
} |
|||
}, |
|||
created() { |
|||
this.getTableData() |
|||
}, |
|||
methods: { |
|||
// 开关状态监听 |
|||
async changeVal(val,id){ |
|||
console.log(val) |
|||
this.switchFrom.outid=id |
|||
if (val==1) { |
|||
this.switchFrom.state=1; |
|||
const res = await statedutyclass(this.switchFrom) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '修改状态成功', |
|||
showClose: true |
|||
}) |
|||
this.getTableData() |
|||
} |
|||
} else { |
|||
this.switchFrom.state=2; |
|||
const res = await statedutyclass(this.switchFrom) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '修改状态成功', |
|||
showClose: true |
|||
}) |
|||
this.getTableData() |
|||
} |
|||
} |
|||
}, |
|||
methodFiletr(value) { |
|||
const target = methodOptions.filter(item => item.value === value)[0] |
|||
return target && `${target.label}` |
|||
}, |
|||
tagTypeFiletr(value) { |
|||
const target = methodOptions.filter(item => item.value === value)[0] |
|||
return target && `${target.type}` |
|||
}, |
|||
// 选中api |
|||
handleSelectionChange(val) { |
|||
this.apis = val |
|||
}, |
|||
async onDelete() { |
|||
const ids = this.apis.forEach(item => item.ID) |
|||
const res = await deleteApisByIds({ ids }) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: res.msg |
|||
}) |
|||
if (this.tableData.length === ids.length && this.page > 1) { |
|||
this.page-- |
|||
} |
|||
this.deleteVisible = false |
|||
this.getTableData() |
|||
} |
|||
}, |
|||
// 排序 |
|||
sortChange({ prop, order }) { |
|||
if (prop) { |
|||
this.searchInfo.orderKey = toSQLLine(prop) |
|||
this.searchInfo.desc = order === 'descending' |
|||
} |
|||
this.getTableData() |
|||
}, |
|||
onReset() { |
|||
this.searchInfo = {} |
|||
}, |
|||
// 条件搜索前端看此方法 |
|||
onSubmit() { |
|||
this.page = 1 |
|||
this.pageSize = 10 |
|||
this.getTableData() |
|||
}, |
|||
initForm() { |
|||
this.$refs.apiForm.resetFields() |
|||
this.form = { |
|||
path: '', |
|||
apiGroup: '', |
|||
method: '', |
|||
description: '' |
|||
} |
|||
}, |
|||
closeDialog() { |
|||
this.initForm() |
|||
this.dialogFormVisible = false |
|||
}, |
|||
openDialog(type) { |
|||
switch (type) { |
|||
case 'addApi': |
|||
this.dialogTitle = '新增' |
|||
break |
|||
case 'edit': |
|||
this.dialogTitle = '编辑' |
|||
break |
|||
default: |
|||
break |
|||
} |
|||
this.type = type |
|||
this.dialogFormVisible = true |
|||
}, |
|||
async editApi(row) { |
|||
this.editFrom.outid=row.outId |
|||
const res = await getdutyclassinfo(this.editFrom) |
|||
this.form = res.data |
|||
this.openDialog('edit') |
|||
}, |
|||
//删除操作 |
|||
async deleteOperate(row) { |
|||
this.$confirm('此操作将永久删除, 是否继续?', '提示', { |
|||
confirmButtonText: '确定', |
|||
cancelButtonText: '取消', |
|||
type: 'warning' |
|||
}) |
|||
.then(async() => { |
|||
this.deleFrom.state=3; |
|||
console.log(row.outID) |
|||
this.deleFrom.outid=row.outId; |
|||
const res = await statedutyclass(this.deleFrom) |
|||
if (res.code === 0) { |
|||
|
|||
this.$message({ |
|||
type: 'success', |
|||
message: '删除成功!' |
|||
}) |
|||
|
|||
this.getTableData() |
|||
} |
|||
}) |
|||
}, |
|||
async enterDialog() { |
|||
this.$refs.apiForm.validate(async valid => { |
|||
if (valid) { |
|||
switch (this.type) { |
|||
case 'addApi': |
|||
{ |
|||
const res = await adddutyclass(this.form) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '添加成功', |
|||
showClose: true |
|||
}) |
|||
} |
|||
this.getTableData() |
|||
this.closeDialog() |
|||
} |
|||
|
|||
break |
|||
case 'edit': |
|||
{ |
|||
const res = await eitedutyclassinfo(this.form) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '编辑成功', |
|||
showClose: true |
|||
}) |
|||
} |
|||
this.getTableData() |
|||
this.closeDialog() |
|||
} |
|||
break |
|||
default: |
|||
// eslint-disable-next-line no-lone-blocks |
|||
{ |
|||
this.$message({ |
|||
type: 'error', |
|||
message: '未知操作', |
|||
showClose: true |
|||
}) |
|||
} |
|||
break |
|||
} |
|||
} |
|||
}) |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style scoped lang="scss"> |
|||
.button-box { |
|||
padding: 10px 20px; |
|||
.el-button { |
|||
float: right; |
|||
} |
|||
} |
|||
.warning { |
|||
color: #dc143c; |
|||
} |
|||
</style> |
|||
@ -0,0 +1,602 @@ |
|||
<template> |
|||
<!-- 具体职责录入 --> |
|||
<div> |
|||
<div class="gva-search-box"> |
|||
<el-form ref="searchForm" :inline="true" :model="searchInfo"> |
|||
<el-form-item label="所属考核项目"> |
|||
<span> |
|||
<el-tag v-if="childInfo.title!=''">{{childInfo.title}}</el-tag> |
|||
<projectDialog @checkedInfo="getCheckedInfo"></projectDialog> |
|||
</span> |
|||
|
|||
</el-form-item> |
|||
<el-form-item label="考核项目状态"> |
|||
<el-select v-model="searchInfo.state" clearable placeholder="请选择状态"> |
|||
<el-option :value=1 label="正常">正常</el-option> |
|||
<el-option :value=2 label="禁止">禁止</el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-form-item label="考核项目名称"> |
|||
<el-input |
|||
placeholder="请输入名称" |
|||
v-model="searchInfo.title" |
|||
clearable> |
|||
</el-input> |
|||
</el-form-item> |
|||
<el-form-item> |
|||
<el-button size="mini" type="primary" icon="el-icon-search" @click="onSubmit">查询</el-button> |
|||
<el-button size="mini" icon="el-icon-refresh" @click="onReset">重置</el-button> |
|||
</el-form-item> |
|||
</el-form> |
|||
</div> |
|||
<div class="gva-table-box"> |
|||
<div class="gva-btn-list"> |
|||
<el-button size="mini" type="primary" icon="el-icon-plus" @click="openDialog('addApi')">新增</el-button> |
|||
</div> |
|||
<el-table :data="tableData" @sort-change="sortChange" @selection-change="handleSelectionChange"> |
|||
<!-- <el-table-column |
|||
type="selection" |
|||
width="55" |
|||
/> --> |
|||
<el-table-column align="left" label="所属考核项目" prop="parentTitle"/> |
|||
<el-table-column align="left" label="具体职责ID" prop="outId"/> |
|||
<el-table-column align="left" label="具体职责名称" prop="title"/> |
|||
<el-table-column align="left" label="考核部门" prop="dumpTitle"/> |
|||
<el-table-column align="left" label="考核人" prop="username"/> |
|||
<el-table-column align="left" label="具体职责状态"> |
|||
<template #default="scope"> |
|||
<el-switch |
|||
inline-prompt |
|||
active-text="正常" |
|||
inactive-text="禁止" |
|||
v-model="scope.row.state" |
|||
active-color="#13ce66" |
|||
inactive-color="#ff4949" |
|||
:active-value=1 |
|||
:inactive-value=2 |
|||
@change="changeVal($event,scope.row.outId)" |
|||
/> |
|||
</template> |
|||
</el-table-column> |
|||
<el-table-column align="left" fixed="right" label="操作" width="200"> |
|||
<template #default="scope"> |
|||
<el-button |
|||
icon="el-icon-edit" |
|||
size="small" |
|||
type="text" |
|||
@click="editApi(scope.row)" |
|||
>编辑</el-button> |
|||
<el-button |
|||
icon="el-icon-delete" |
|||
size="small" |
|||
type="text" |
|||
@click="deleteOperate(scope.row)" |
|||
>删除</el-button> |
|||
</template> |
|||
</el-table-column> |
|||
</el-table> |
|||
<div class="gva-pagination"> |
|||
<el-pagination |
|||
:current-page="page" |
|||
:page-size="pageSize" |
|||
:page-sizes="[10, 30, 50, 100]" |
|||
:total="total" |
|||
layout="total, sizes, prev, pager, next, jumper" |
|||
@current-change="handleCurrentChange" |
|||
@size-change="handleSizeChange" |
|||
/> |
|||
</div> |
|||
|
|||
</div> |
|||
<!-- 添加 --> |
|||
<el-dialog v-model="dialogFormVisible" :before-close="closeDialog" :title="dialogTitle" width="25%"> |
|||
<el-form ref="apiForm" :model="form" :rules="rules" label-width="125px"> |
|||
<el-form-item label="所属考核项目"> |
|||
<span> |
|||
<el-tag v-if="addChildInfo.title!=''">{{addChildInfo.title}}</el-tag> |
|||
<projectDialog @checkedInfo="getCheckedfrom"></projectDialog> |
|||
</span> |
|||
</el-form-item> |
|||
<el-form-item label="具体职责名称" prop="title"> |
|||
<el-input |
|||
type="textarea" |
|||
:autosize="{ minRows: 2, maxRows: 4}" |
|||
placeholder="请输入内容" |
|||
v-model="form.title"> |
|||
</el-input> |
|||
</el-form-item> |
|||
<el-form-item label="考核部门类型" prop="type"> |
|||
<el-radio border size="small" v-model="form.type" :label=1>指定人</el-radio> |
|||
<el-radio border size="small" v-model="form.type" :label=2>指定部门</el-radio> |
|||
</el-form-item> |
|||
<el-form-item v-if="form.type==2" label="选择部门" prop="userid"> |
|||
<el-cascader clearable v-model="form.userid" :options="grouplist" :show-all-levels="false" :props="props"></el-cascader> |
|||
</el-form-item> |
|||
<el-form-item v-if="form.type==1" label="选择考核人" prop="userid"> |
|||
<el-cascader clearable v-model="form.userid" :options="grouplistBackup" :show-all-levels="false" :props="userProps"></el-cascader> |
|||
</el-form-item> |
|||
</el-form> |
|||
<template #footer> |
|||
<div class="dialog-footer"> |
|||
<el-button size="small" @click="closeDialog">取 消</el-button> |
|||
<el-button size="small" type="primary" @click="enterDialog">确 定</el-button> |
|||
</div> |
|||
</template> |
|||
</el-dialog> |
|||
<!-- 编辑 --> |
|||
<el-dialog v-model="editDialogFormVisible" :before-close="closeEditDialog" title="编辑" width="25%"> |
|||
<el-form ref="apiForm" :model="editform" :rules="editrules" label-width="125px"> |
|||
<el-form-item label="所属考核项目"> |
|||
<span> |
|||
<el-tag v-if="editChildInfo.title!=''">{{editChildInfo.title}}</el-tag> |
|||
<projectDialog @checkedInfo="getEditCheckedfrom"></projectDialog> |
|||
</span> |
|||
</el-form-item> |
|||
<el-form-item label="具体职责名称" prop="title"> |
|||
<el-input |
|||
type="textarea" |
|||
:autosize="{ minRows: 2, maxRows: 4}" |
|||
placeholder="请输入内容" |
|||
v-model="editform.title"> |
|||
</el-input> |
|||
</el-form-item> |
|||
<el-form-item label="考核部门类型" prop="type"> |
|||
<el-radio border size="small" v-model="editform.userType" :label=1>指定人</el-radio> |
|||
<el-radio border size="small" v-model="editform.userType" :label=2>指定部门</el-radio> |
|||
</el-form-item> |
|||
<el-form-item v-if="editform.userType==2" label="选择部门" prop="userid"> |
|||
<el-cascader clearable v-model="editform.dump" :options="grouplist" :show-all-levels="false" :props="props"></el-cascader> |
|||
</el-form-item> |
|||
<el-form-item v-if="editform.userType==1" label="选择考核人" prop="userid"> |
|||
<el-cascader clearable v-model="editform.userDumpId" :options="grouplistBackup" :show-all-levels="false" :props="userProps"></el-cascader> |
|||
</el-form-item> |
|||
<!-- 16047344045376832 --> |
|||
</el-form> |
|||
<template #footer> |
|||
<div class="dialog-footer"> |
|||
<el-button size="small" @click="closeEditDialog">取 消</el-button> |
|||
<el-button size="small" type="primary" @click="editInfo">确 定</el-button> |
|||
</div> |
|||
</template> |
|||
</el-dialog> |
|||
</div> |
|||
</template> |
|||
|
|||
<script> |
|||
// 获取列表内容封装在mixins内部 getTableData方法 初始化已封装完成 条件搜索时候 请把条件安好后台定制的结构体字段 放到 this.searchInfo 中即可实现条件搜索 |
|||
|
|||
import { |
|||
dutylist, |
|||
assessList, |
|||
adddutyinfo, |
|||
getdutyinfo, |
|||
eitedutystate, |
|||
eitedutyinfo |
|||
} from '@/api/dataEntry' |
|||
import { |
|||
getgroupdepartmap, |
|||
getgroupuser |
|||
} from '@/api/group' |
|||
|
|||
import projectDialog from '@/components/projectDialog/index.vue' |
|||
import infoList from '@/mixins/infoList' |
|||
import { toSQLLine } from '@/utils/stringFun' |
|||
import warningBar from '@/components/warningBar/warningBar.vue' |
|||
const methodOptions = [ |
|||
{ |
|||
value: 'POST', |
|||
label: '创建', |
|||
type: 'success' |
|||
}, |
|||
{ |
|||
value: 'GET', |
|||
label: '查看', |
|||
type: '' |
|||
}, |
|||
{ |
|||
value: 'PUT', |
|||
label: '更新', |
|||
type: 'warning' |
|||
}, |
|||
{ |
|||
value: 'DELETE', |
|||
label: '删除', |
|||
type: 'danger' |
|||
} |
|||
] |
|||
|
|||
export default { |
|||
name: 'Api', |
|||
components: { |
|||
warningBar, |
|||
projectDialog |
|||
}, |
|||
mixins: [infoList], |
|||
data() { |
|||
return { |
|||
editChildInfo:{ |
|||
title:'' |
|||
}, |
|||
editform:{}, |
|||
editDialogFormVisible:false, |
|||
props: { |
|||
value: "id", |
|||
label: "name", |
|||
children: "children", |
|||
emitPath:false |
|||
}, |
|||
userProps: { |
|||
value: "id", |
|||
label: "name", |
|||
children: "groupUser", |
|||
emitPath:false |
|||
}, |
|||
grouplist:{}, |
|||
grouplistBackup:{}, |
|||
groupListFrom:{ |
|||
parentid:3 |
|||
}, |
|||
childInfo:{ |
|||
title:'' |
|||
}, |
|||
addChildInfo:{ |
|||
title:'' |
|||
}, |
|||
projectTitle:'', |
|||
dutyclasslist:{}, |
|||
searchList:{ |
|||
page:1, |
|||
pagesize:10000, |
|||
}, |
|||
dutyclasslist:'', |
|||
deleFrom:{ |
|||
outid:'', |
|||
state:Number |
|||
}, |
|||
switchFrom:{ |
|||
outid:'', |
|||
state:Number |
|||
}, |
|||
editFrom:{ |
|||
outid:'', |
|||
}, |
|||
deleteVisible: false, |
|||
listApi: dutylist, |
|||
dialogFormVisible: false, |
|||
dialogTitle: '新增', |
|||
apis: [], |
|||
form: { |
|||
title:'', |
|||
|
|||
}, |
|||
methodOptions: methodOptions, |
|||
type: '', |
|||
rules: { |
|||
parentId: [{ required: true, message: '请选择所属考核类别', trigger: 'blur' }], |
|||
title: [{ required: true, message: '考核项目名称', trigger: 'blur' }], |
|||
type: [{ required: true, message: '考核部门类型', trigger: 'blur' }], |
|||
userid: [{ required: true, message: '考核人或部门', trigger: 'blur' }], |
|||
} |
|||
} |
|||
}, |
|||
created() { |
|||
this.getTableData() |
|||
// this.getDutyclasslist() |
|||
this.getGrouplist() |
|||
this.getSystemadminlist() |
|||
}, |
|||
methods: { |
|||
// 添加获取选中组件值 |
|||
getEditCheckedfrom(data){ |
|||
this.editChildInfo=data |
|||
this.editform.parentId=this.editChildInfo.outId |
|||
}, |
|||
// 添加获取选中组件值 |
|||
getCheckedfrom(data){ |
|||
this.addChildInfo=data |
|||
}, |
|||
// 获取部门 |
|||
async getGrouplist(){ |
|||
const res = await getgroupdepartmap() |
|||
this.grouplist=res.data.list |
|||
|
|||
}, |
|||
// async getGrouplist(){ |
|||
// const res = await grouplist(this.groupListFrom) |
|||
// this.grouplist=res.data.list |
|||
// // 取消vue的双向绑定 |
|||
// this.grouplistBackup=JSON.parse(JSON.stringify(res.data.list)) |
|||
// this.grouplist.forEach((data) => { |
|||
// data.children.forEach((res) => { |
|||
|
|||
// if(res.hasOwnProperty('children')){ |
|||
// delete res.children |
|||
// } |
|||
// }); |
|||
// }); |
|||
// // 下是循环人员列表 |
|||
// this.grouplistBackup.forEach((data) => { |
|||
// data.children.forEach(async(res) => { |
|||
// const systemadminFrom = { |
|||
// page:1, |
|||
// pagesize:10000, |
|||
// branchFactoryId:'' |
|||
// } |
|||
// systemadminFrom.branchFactoryId=res.id |
|||
// const result = await stafflist(systemadminFrom) |
|||
|
|||
// res.children = result.data.list; |
|||
// // this.$set(res,"children", result.data.list) |
|||
|
|||
|
|||
// }); |
|||
// }); |
|||
// console.log("部门列表无基层") |
|||
// console.log(this.grouplist) |
|||
// console.log("员工列表") |
|||
// console.log(this.grouplistBackup) |
|||
// }, |
|||
// 获取员工列表 |
|||
async getSystemadminlist(){ |
|||
const res = await getgroupuser() |
|||
this.grouplistBackup=res.data.list |
|||
}, |
|||
// 获取选中组件值 |
|||
getCheckedInfo(data){ |
|||
this.childInfo=data |
|||
}, |
|||
// 获取考核类别列表 |
|||
async getDutyclasslist(){ |
|||
const res = await dutyclasslist(this.searchList) |
|||
this.dutyclasslist=res.data.list |
|||
}, |
|||
// 开关状态监听 |
|||
async changeVal(val,id){ |
|||
console.log(val) |
|||
this.switchFrom.outid=id |
|||
if (val==1) { |
|||
this.switchFrom.state=1; |
|||
const res = await eitedutystate(this.switchFrom) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '修改状态成功', |
|||
showClose: true |
|||
}) |
|||
this.getTableData() |
|||
} |
|||
} else { |
|||
this.switchFrom.state=2; |
|||
const res = await eitedutystate(this.switchFrom) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '修改状态成功', |
|||
showClose: true |
|||
}) |
|||
this.getTableData() |
|||
} |
|||
} |
|||
}, |
|||
methodFiletr(value) { |
|||
const target = methodOptions.filter(item => item.value === value)[0] |
|||
return target && `${target.label}` |
|||
}, |
|||
tagTypeFiletr(value) { |
|||
const target = methodOptions.filter(item => item.value === value)[0] |
|||
return target && `${target.type}` |
|||
}, |
|||
// 选中api |
|||
handleSelectionChange(val) { |
|||
this.apis = val |
|||
}, |
|||
async onDelete() { |
|||
const ids = this.apis.forEach(item => item.ID) |
|||
const res = await deleteApisByIds({ ids }) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: res.msg |
|||
}) |
|||
if (this.tableData.length === ids.length && this.page > 1) { |
|||
this.page-- |
|||
} |
|||
this.deleteVisible = false |
|||
this.getTableData() |
|||
} |
|||
}, |
|||
// 排序 |
|||
sortChange({ prop, order }) { |
|||
if (prop) { |
|||
this.searchInfo.orderKey = toSQLLine(prop) |
|||
this.searchInfo.desc = order === 'descending' |
|||
} |
|||
this.getTableData() |
|||
}, |
|||
onReset() { |
|||
this.searchInfo = {}; |
|||
this.childInfo={ |
|||
title:'' |
|||
} |
|||
|
|||
}, |
|||
// 条件搜索前端看此方法 |
|||
onSubmit() { |
|||
this.page = 1 |
|||
this.pageSize = 10 |
|||
this.searchInfo.parentId=this.childInfo.outId |
|||
this.getTableData() |
|||
}, |
|||
initForm() { |
|||
this.$refs.apiForm.resetFields() |
|||
this.form = { |
|||
} |
|||
}, |
|||
editInitForm(){ |
|||
this.editform = { |
|||
} |
|||
}, |
|||
closeDialog() { |
|||
this.addChildInfo={ |
|||
title:'' |
|||
} |
|||
this.initForm() |
|||
this.dialogFormVisible = false |
|||
}, |
|||
openDialog(type) { |
|||
switch (type) { |
|||
case 'addApi': |
|||
this.dialogTitle = '新增' |
|||
break |
|||
case 'edit': |
|||
this.dialogTitle = '编辑' |
|||
break |
|||
default: |
|||
break |
|||
} |
|||
this.type = type |
|||
this.dialogFormVisible = true |
|||
}, |
|||
// 显示详情 |
|||
async editApi(row) { |
|||
this.editFrom.outid=row.outId |
|||
const res = await getdutyinfo(this.editFrom) |
|||
this.editform = res.data |
|||
this.editform.parentId=res.data.parentIdStr |
|||
this.editChildInfo.title=res.data.parentTitle |
|||
console.log(this.editform) |
|||
this.editDialogFormVisible=true |
|||
}, |
|||
//删除操作 |
|||
async deleteOperate(row) { |
|||
this.$confirm('此操作将永久删除, 是否继续?', '提示', { |
|||
confirmButtonText: '确定', |
|||
cancelButtonText: '取消', |
|||
type: 'warning' |
|||
}) |
|||
.then(async() => { |
|||
this.deleFrom.state=3; |
|||
console.log(row.outID) |
|||
this.deleFrom.outid=row.outId; |
|||
const res = await eitedutystate(this.deleFrom) |
|||
if (res.code === 0) { |
|||
|
|||
this.$message({ |
|||
type: 'success', |
|||
message: '删除成功!' |
|||
}) |
|||
|
|||
this.getTableData() |
|||
} |
|||
}) |
|||
}, |
|||
async editInfo(){ |
|||
if(this.editform.userType==1){ |
|||
delete this.editform.dump |
|||
this.editform.userid=this.editform.userDumpId |
|||
} |
|||
if(this.editform.userType==2){ |
|||
delete this.editform.userDumpId |
|||
this.editform.userid=this.editform.dump |
|||
} |
|||
this.editform.type=this.editform.userType |
|||
this.editform.outid=this.editform.outId |
|||
this.editform.userid=this.editform.userid.toString(); |
|||
delete this.editform.outId |
|||
delete this.editform.userDump |
|||
delete this.editform.userDumpId |
|||
delete this.editform.userType |
|||
delete this.editform.username |
|||
delete this.editform.username |
|||
// delete this.editform.id |
|||
delete this.editform.dump |
|||
delete this.editform.dumpTitle |
|||
delete this.editform.parentIdStr |
|||
delete this.editform.parentTitle |
|||
delete this.editform.partId |
|||
delete this.editform.time |
|||
delete this.editform.state |
|||
const res = await eitedutyinfo(this.editform) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '编辑成功', |
|||
showClose: true |
|||
}) |
|||
} |
|||
this.getTableData() |
|||
this.closeEditDialog() |
|||
}, |
|||
closeEditDialog(){ |
|||
this.editChildInfo={ |
|||
title:'' |
|||
} |
|||
this.editInitForm() |
|||
this.editDialogFormVisible = false |
|||
}, |
|||
async enterDialog() { |
|||
console.log(this.grouplistBackup) |
|||
console.log(this.form.userid) |
|||
this.$refs.apiForm.validate(async valid => { |
|||
if (valid) { |
|||
switch (this.type) { |
|||
case 'addApi': |
|||
{ |
|||
this.form.userid=this.form.userid.toString(); |
|||
this.form.parentId=this.addChildInfo.outId |
|||
const res = await adddutyinfo(this.form) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '添加成功', |
|||
showClose: true |
|||
}) |
|||
} |
|||
this.getTableData() |
|||
this.closeDialog() |
|||
} |
|||
|
|||
break |
|||
case 'edit': |
|||
{ |
|||
const res = await eiteassessinfo(this.form) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '编辑成功', |
|||
showClose: true |
|||
}) |
|||
} |
|||
this.getTableData() |
|||
this.closeDialog() |
|||
} |
|||
break |
|||
default: |
|||
// eslint-disable-next-line no-lone-blocks |
|||
{ |
|||
this.$message({ |
|||
type: 'error', |
|||
message: '未知操作', |
|||
showClose: true |
|||
}) |
|||
} |
|||
break |
|||
} |
|||
} |
|||
}) |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style scoped lang="scss"> |
|||
.button-box { |
|||
padding: 10px 20px; |
|||
.el-button { |
|||
float: right; |
|||
} |
|||
} |
|||
.warning { |
|||
color: #dc143c; |
|||
} |
|||
</style> |
|||
@ -0,0 +1,395 @@ |
|||
<template> |
|||
<!-- 考核项目录入 --> |
|||
<div> |
|||
<div class="gva-search-box"> |
|||
<el-form ref="searchForm" :inline="true" :model="searchInfo"> |
|||
<el-form-item label="考核项目名称"> |
|||
<el-input |
|||
placeholder="请输入名称" |
|||
v-model="searchInfo.title" |
|||
clearable> |
|||
</el-input> |
|||
</el-form-item> |
|||
<el-form-item label="考核项目状态"> |
|||
<el-select v-model="searchInfo.state" clearable placeholder="请选择状态"> |
|||
<el-option :value=1 label="正常">正常</el-option> |
|||
<el-option :value=2 label="禁止">禁止</el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-form-item label="所属考核类别"> |
|||
<el-select v-model="searchInfo.parentId" clearable placeholder="请选择状态"> |
|||
<el-option |
|||
v-for="item in dutyclasslist" |
|||
:key="item.outId" |
|||
:label="item.title" |
|||
:value="item.outId"> |
|||
</el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-form-item> |
|||
<el-button size="mini" type="primary" icon="el-icon-search" @click="onSubmit">查询</el-button> |
|||
<el-button size="mini" icon="el-icon-refresh" @click="onReset">重置</el-button> |
|||
</el-form-item> |
|||
</el-form> |
|||
</div> |
|||
<div class="gva-table-box"> |
|||
<div class="gva-btn-list"> |
|||
<el-button size="mini" type="primary" icon="el-icon-plus" @click="openDialog('addApi')">新增</el-button> |
|||
<!-- <el-popover v-model:visible="deleteVisible" placement="top" width="160"> |
|||
<p>确定要删除吗?</p> |
|||
<div style="text-align: right; margin-top: 8px;"> |
|||
<el-button size="mini" type="text" @click="deleteVisible = false">取消</el-button> |
|||
<el-button size="mini" type="primary" @click="onDelete">确定</el-button> |
|||
</div> |
|||
<template #reference> |
|||
<el-button icon="el-icon-delete" size="mini" :disabled="!apis.length" style="margin-left: 10px;">删除</el-button> |
|||
</template> |
|||
</el-popover> --> |
|||
</div> |
|||
<el-table :data="tableData" @sort-change="sortChange" @selection-change="handleSelectionChange"> |
|||
<!-- <el-table-column |
|||
type="selection" |
|||
width="55" |
|||
/> --> |
|||
<el-table-column align="left" label="所属考核类别" prop="parentTitle"/> |
|||
<el-table-column align="left" label="考核项目ID" prop="outId"/> |
|||
<el-table-column align="left" label="考核项目名称" prop="title"/> |
|||
<el-table-column align="left" label="考核项目说明" prop="content"/> |
|||
<el-table-column align="left" label="考核项目状态"> |
|||
<template #default="scope"> |
|||
<el-switch |
|||
inline-prompt |
|||
active-text="正常" |
|||
inactive-text="禁止" |
|||
v-model="scope.row.state" |
|||
active-color="#13ce66" |
|||
inactive-color="#ff4949" |
|||
:active-value=1 |
|||
:inactive-value=2 |
|||
@change="changeVal($event,scope.row.outId)" |
|||
/> |
|||
</template> |
|||
</el-table-column> |
|||
<el-table-column align="left" fixed="right" label="操作" width="200"> |
|||
<template #default="scope"> |
|||
<el-button |
|||
icon="el-icon-edit" |
|||
size="small" |
|||
type="text" |
|||
@click="editApi(scope.row)" |
|||
>编辑</el-button> |
|||
<el-button |
|||
icon="el-icon-delete" |
|||
size="small" |
|||
type="text" |
|||
@click="deleteOperate(scope.row)" |
|||
>删除</el-button> |
|||
</template> |
|||
</el-table-column> |
|||
</el-table> |
|||
<div class="gva-pagination"> |
|||
<el-pagination |
|||
:current-page="page" |
|||
:page-size="pageSize" |
|||
:page-sizes="[10, 30, 50, 100]" |
|||
:total="total" |
|||
layout="total, sizes, prev, pager, next, jumper" |
|||
@current-change="handleCurrentChange" |
|||
@size-change="handleSizeChange" |
|||
/> |
|||
</div> |
|||
|
|||
</div> |
|||
|
|||
<el-dialog v-model="dialogFormVisible" :before-close="closeDialog" :title="dialogTitle" width="20%"> |
|||
|
|||
<el-form ref="apiForm" :model="form" :rules="rules" label-width="125px"> |
|||
<el-form-item label="所属考核类别" prop="parentId"> |
|||
<el-select v-model="form.parentId" clearable placeholder="请选择考核类别"> |
|||
<el-option |
|||
v-for="item in dutyclasslist" |
|||
:key="item.outId" |
|||
:label="item.title" |
|||
:value="item.outId"> |
|||
</el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-form-item label="考核项目名称" prop="title"> |
|||
<el-input v-model="form.title" autocomplete="off" /> |
|||
</el-form-item> |
|||
<el-form-item label="考核项目说明" prop="content"> |
|||
<el-input |
|||
type="textarea" |
|||
:autosize="{ minRows: 2, maxRows: 4}" |
|||
placeholder="请输入内容" |
|||
v-model="form.content"> |
|||
</el-input> |
|||
</el-form-item> |
|||
</el-form> |
|||
<template #footer> |
|||
<div class="dialog-footer"> |
|||
<el-button size="small" @click="closeDialog">取 消</el-button> |
|||
<el-button size="small" type="primary" @click="enterDialog">确 定</el-button> |
|||
</div> |
|||
</template> |
|||
</el-dialog> |
|||
</div> |
|||
</template> |
|||
|
|||
<script> |
|||
// 获取列表内容封装在mixins内部 getTableData方法 初始化已封装完成 条件搜索时候 请把条件安好后台定制的结构体字段 放到 this.searchInfo 中即可实现条件搜索 |
|||
|
|||
import { |
|||
dutyclasslist, |
|||
assessList, |
|||
addassessinfo, |
|||
getassessinfo, |
|||
eiteassessinfo, |
|||
eiteassessstate |
|||
} from '@/api/dataEntry' |
|||
import infoList from '@/mixins/infoList' |
|||
import { toSQLLine } from '@/utils/stringFun' |
|||
import warningBar from '@/components/warningBar/warningBar.vue' |
|||
|
|||
export default { |
|||
name: 'Api', |
|||
components: { |
|||
warningBar |
|||
}, |
|||
mixins: [infoList], |
|||
data() { |
|||
return { |
|||
dutyclasslist:{}, |
|||
searchList:{ |
|||
page:1, |
|||
pagesize:10000, |
|||
}, |
|||
deleFrom:{ |
|||
outid:'', |
|||
state:Number |
|||
}, |
|||
switchFrom:{ |
|||
outid:'', |
|||
state:Number |
|||
}, |
|||
editFrom:{ |
|||
outid:'', |
|||
}, |
|||
deleteVisible: false, |
|||
listApi: assessList, |
|||
dialogFormVisible: false, |
|||
dialogTitle: '新增', |
|||
apis: [], |
|||
form: { |
|||
title:'', |
|||
}, |
|||
|
|||
type: '', |
|||
rules: { |
|||
parentId: [{ required: true, message: '请选择所属考核类别', trigger: 'blur' }], |
|||
title: [{ required: true, message: '考核项目名称', trigger: 'blur' }], |
|||
content: [{ required: true, message: '考核项目说明', trigger: 'blur' }], |
|||
} |
|||
} |
|||
}, |
|||
created() { |
|||
this.getTableData() |
|||
this.getDutyclasslist() |
|||
}, |
|||
methods: { |
|||
// 获取考核类别列表 |
|||
async getDutyclasslist(){ |
|||
const res = await dutyclasslist(this.searchList) |
|||
this.dutyclasslist=res.data.list |
|||
}, |
|||
// 开关状态监听 |
|||
async changeVal(val,id){ |
|||
console.log(val) |
|||
this.switchFrom.outid=id |
|||
if (val==1) { |
|||
this.switchFrom.state=1; |
|||
const res = await eiteassessstate(this.switchFrom) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '修改状态成功', |
|||
showClose: true |
|||
}) |
|||
this.getTableData() |
|||
} |
|||
} else { |
|||
this.switchFrom.state=2; |
|||
const res = await eiteassessstate(this.switchFrom) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '修改状态成功', |
|||
showClose: true |
|||
}) |
|||
this.getTableData() |
|||
} |
|||
} |
|||
}, |
|||
methodFiletr(value) { |
|||
const target = methodOptions.filter(item => item.value === value)[0] |
|||
return target && `${target.label}` |
|||
}, |
|||
tagTypeFiletr(value) { |
|||
const target = methodOptions.filter(item => item.value === value)[0] |
|||
return target && `${target.type}` |
|||
}, |
|||
// 选中api |
|||
handleSelectionChange(val) { |
|||
this.apis = val |
|||
}, |
|||
async onDelete() { |
|||
const ids = this.apis.forEach(item => item.ID) |
|||
const res = await deleteApisByIds({ ids }) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: res.msg |
|||
}) |
|||
if (this.tableData.length === ids.length && this.page > 1) { |
|||
this.page-- |
|||
} |
|||
this.deleteVisible = false |
|||
this.getTableData() |
|||
} |
|||
}, |
|||
// 排序 |
|||
sortChange({ prop, order }) { |
|||
if (prop) { |
|||
this.searchInfo.orderKey = toSQLLine(prop) |
|||
this.searchInfo.desc = order === 'descending' |
|||
} |
|||
this.getTableData() |
|||
}, |
|||
onReset() { |
|||
this.searchInfo = {} |
|||
}, |
|||
// 条件搜索前端看此方法 |
|||
onSubmit() { |
|||
this.page = 1 |
|||
this.pageSize = 10 |
|||
this.getTableData() |
|||
}, |
|||
initForm() { |
|||
this.$refs.apiForm.resetFields() |
|||
this.form = { |
|||
path: '', |
|||
apiGroup: '', |
|||
method: '', |
|||
description: '' |
|||
} |
|||
}, |
|||
closeDialog() { |
|||
this.initForm() |
|||
this.dialogFormVisible = false |
|||
}, |
|||
openDialog(type) { |
|||
switch (type) { |
|||
case 'addApi': |
|||
this.dialogTitle = '新增' |
|||
break |
|||
case 'edit': |
|||
this.dialogTitle = '编辑' |
|||
break |
|||
default: |
|||
break |
|||
} |
|||
this.type = type |
|||
this.dialogFormVisible = true |
|||
}, |
|||
async editApi(row) { |
|||
this.editFrom.outid=row.outId |
|||
const res = await getassessinfo(this.editFrom) |
|||
this.form = res.data |
|||
this.form.parentId=res.data.parentIdStr |
|||
this.openDialog('edit') |
|||
}, |
|||
//删除操作 |
|||
async deleteOperate(row) { |
|||
this.$confirm('此操作将永久删除, 是否继续?', '提示', { |
|||
confirmButtonText: '确定', |
|||
cancelButtonText: '取消', |
|||
type: 'warning' |
|||
}) |
|||
.then(async() => { |
|||
this.deleFrom.state=3; |
|||
console.log(row.outID) |
|||
this.deleFrom.outid=row.outId; |
|||
const res = await eiteassessstate(this.deleFrom) |
|||
if (res.code === 0) { |
|||
|
|||
this.$message({ |
|||
type: 'success', |
|||
message: '删除成功!' |
|||
}) |
|||
|
|||
this.getTableData() |
|||
} |
|||
}) |
|||
}, |
|||
async enterDialog() { |
|||
this.$refs.apiForm.validate(async valid => { |
|||
if (valid) { |
|||
switch (this.type) { |
|||
case 'addApi': |
|||
{ |
|||
const res = await addassessinfo(this.form) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '添加成功', |
|||
showClose: true |
|||
}) |
|||
} |
|||
this.getTableData() |
|||
this.closeDialog() |
|||
} |
|||
|
|||
break |
|||
case 'edit': |
|||
{ |
|||
const res = await eiteassessinfo(this.form) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '编辑成功', |
|||
showClose: true |
|||
}) |
|||
} |
|||
this.getTableData() |
|||
this.closeDialog() |
|||
} |
|||
break |
|||
default: |
|||
// eslint-disable-next-line no-lone-blocks |
|||
{ |
|||
this.$message({ |
|||
type: 'error', |
|||
message: '未知操作', |
|||
showClose: true |
|||
}) |
|||
} |
|||
break |
|||
} |
|||
} |
|||
}) |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style scoped lang="scss"> |
|||
.button-box { |
|||
padding: 10px 20px; |
|||
.el-button { |
|||
float: right; |
|||
} |
|||
} |
|||
.warning { |
|||
color: #dc143c; |
|||
} |
|||
</style> |
|||
@ -0,0 +1,17 @@ |
|||
<template> |
|||
<div> |
|||
<router-view v-slot="{ Component }"> |
|||
<transition mode="out-in" name="el-fade-in-linear"> |
|||
<keep-alive :include="$store.getters['router/keepAliveRouters']"> |
|||
<component :is="Component" /> |
|||
</keep-alive> |
|||
</transition> |
|||
</router-view> |
|||
</div> |
|||
</template> |
|||
|
|||
<script> |
|||
export default { |
|||
name: 'performance' |
|||
} |
|||
</script> |
|||
@ -0,0 +1,385 @@ |
|||
<template> |
|||
<!-- 主要考核评分指标录入 --> |
|||
<div> |
|||
<div class="gva-search-box"> |
|||
<el-form ref="searchForm" :inline="true" :model="searchInfo"> |
|||
<el-form-item label="部门"> |
|||
<el-select v-model="searchInfo.workSection" clearable placeholder="请选择部门"> |
|||
<el-option value="1" label="煤焦分厂">煤焦分厂</el-option> |
|||
<el-option value="2" label="化产分厂">化产分厂</el-option> |
|||
<el-option value="3" label="甲醇分厂">甲醇分厂</el-option> |
|||
<el-option value="4" label="动力分厂">动力分厂</el-option> |
|||
<el-option value="5" label="生产部">生产部</el-option> |
|||
<el-option value="6" label="技术部">技术部</el-option> |
|||
<el-option value="7" label="质检中心">质检中心</el-option> |
|||
<el-option value="8" label="安全部">安全部</el-option> |
|||
<el-option value="9" label="环保部">环保部</el-option> |
|||
<el-option value="10" label="营销部">营销部</el-option> |
|||
<el-option value="11" label="仓储中心">仓储中心</el-option> |
|||
<el-option value="12" label="物流中心">物流中心</el-option> |
|||
<el-option value="13" label="人力资源部">人力资源部</el-option> |
|||
<el-option value="14" label="财务部">财务部</el-option> |
|||
<el-option value="15" label="综合办">综合办</el-option> |
|||
<el-option value="16" label="企管部">企管部</el-option> |
|||
<el-option value="17" label="保卫部">保卫部</el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-form-item> |
|||
<el-button size="mini" type="primary" icon="el-icon-search" @click="onSubmit">查询</el-button> |
|||
<el-button size="mini" icon="el-icon-refresh" @click="onReset">重置</el-button> |
|||
</el-form-item> |
|||
</el-form> |
|||
</div> |
|||
<div class="gva-table-box"> |
|||
<div class="gva-btn-list"> |
|||
<el-button size="mini" type="primary" icon="el-icon-plus" @click="openDialog('addApi')">新增</el-button> |
|||
<el-button size="mini" type="primary" icon="el-icon-upload" @click="openDialog('addApi')">导入题库数据</el-button> |
|||
<el-popover v-model:visible="deleteVisible" placement="top" width="160"> |
|||
<p>确定要删除吗?</p> |
|||
<div style="text-align: right; margin-top: 8px;"> |
|||
<el-button size="mini" type="text" @click="deleteVisible = false">取消</el-button> |
|||
<el-button size="mini" type="primary" @click="onDelete">确定</el-button> |
|||
</div> |
|||
<template #reference> |
|||
<el-button icon="el-icon-delete" size="mini" :disabled="!apis.length" style="margin-left: 10px;">删除</el-button> |
|||
</template> |
|||
</el-popover> |
|||
</div> |
|||
<el-table :data="tableData" @sort-change="sortChange" @selection-change="handleSelectionChange"> |
|||
<el-table-column |
|||
type="selection" |
|||
width="55" |
|||
/> |
|||
<el-table-column align="left" label="部门" min-width="150" prop="description"/> |
|||
<el-table-column align="left" label="考核类别" min-width="60" prop="ID"/> |
|||
<el-table-column align="left" label="权重(%)" min-width="150" prop="path"/> |
|||
<el-table-column align="left" label="考核项目" min-width="150" prop="apiGroup"/> |
|||
<el-table-column align="left" label="考核说明" min-width="150" prop="apiGroup"/> |
|||
<!-- <el-table-column align="left" label="创建时间" min-width="150" prop="method"> |
|||
<template #default="scope"> |
|||
<div> |
|||
{{ scope.row.method }} / {{ methodFiletr(scope.row.method) }} |
|||
</div> |
|||
</template> |
|||
</el-table-column> --> |
|||
|
|||
<el-table-column align="left" fixed="right" label="操作" width="200"> |
|||
<template #default="scope"> |
|||
<el-button |
|||
icon="el-icon-edit" |
|||
size="small" |
|||
type="text" |
|||
@click="editApi(scope.row)" |
|||
>编辑</el-button> |
|||
<el-button |
|||
icon="el-icon-delete" |
|||
size="small" |
|||
type="text" |
|||
@click="deleteApi(scope.row)" |
|||
>删除</el-button> |
|||
</template> |
|||
</el-table-column> |
|||
</el-table> |
|||
<div class="gva-pagination"> |
|||
<el-pagination |
|||
:current-page="page" |
|||
:page-size="pageSize" |
|||
:page-sizes="[10, 30, 50, 100]" |
|||
:total="total" |
|||
layout="total, sizes, prev, pager, next, jumper" |
|||
@current-change="handleCurrentChange" |
|||
@size-change="handleSizeChange" |
|||
/> |
|||
</div> |
|||
|
|||
</div> |
|||
|
|||
<el-dialog v-model="dialogFormVisible" :before-close="closeDialog" :title="dialogTitle" width="20%"> |
|||
|
|||
<el-form ref="apiForm" :model="form" :rules="rules" label-width="80px"> |
|||
<el-form-item label="考核类别" prop="category"> |
|||
<el-input v-model="form.category" autocomplete="off" /> |
|||
</el-form-item> |
|||
<el-form-item label="部门" prop="department"> |
|||
<el-select v-model="form.department" placeholder="请选择部门" style="width:100%"> |
|||
<el-option value="1" label="a工段">煤焦分厂</el-option> |
|||
<el-option value="2" label="b工段">化产分厂</el-option> |
|||
<el-option value="2" label="b工段">甲醇分厂</el-option> |
|||
<el-option value="2" label="b工段">动力分厂</el-option> |
|||
<el-option value="2" label="b工段">生产部</el-option> |
|||
<el-option value="2" label="b工段">技术部</el-option> |
|||
<el-option value="2" label="b工段">质检中心</el-option> |
|||
<el-option value="2" label="b工段">安全部</el-option> |
|||
<el-option value="2" label="b工段">环保部</el-option> |
|||
<el-option value="2" label="b工段">营销部</el-option> |
|||
<el-option value="2" label="b工段">仓储中心</el-option> |
|||
<el-option value="2" label="b工段">物流中心</el-option> |
|||
<el-option value="2" label="b工段">人力资源部</el-option> |
|||
<el-option value="2" label="b工段">财务部</el-option> |
|||
<el-option value="2" label="b工段">综合办</el-option> |
|||
<el-option value="2" label="b工段">企管部</el-option> |
|||
<el-option value="2" label="b工段">保卫部</el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-form-item label="考核项目" prop="apiGrprojectoup"> |
|||
<el-input v-model="form.project" autocomplete="off" /> |
|||
</el-form-item> |
|||
<el-form-item label="权重" prop="weights"> |
|||
<el-input placeholder="请输入内容" v-model="form.weights"> |
|||
<template #append>%</template> |
|||
</el-input> |
|||
</el-form-item> |
|||
<el-form-item label="考核说明" prop="instruction"> |
|||
<el-input |
|||
v-model="form.instruction" |
|||
:rows="2" |
|||
type="textarea" |
|||
placeholder="请输入考核说明" |
|||
/> |
|||
<!-- <el-input v-model="form.instruction" autocomplete="off" /> --> |
|||
</el-form-item> |
|||
</el-form> |
|||
<template #footer> |
|||
<div class="dialog-footer"> |
|||
<el-button size="small" @click="closeDialog">取 消</el-button> |
|||
<el-button size="small" type="primary" @click="enterDialog">确 定</el-button> |
|||
</div> |
|||
</template> |
|||
</el-dialog> |
|||
</div> |
|||
</template> |
|||
|
|||
<script> |
|||
// 获取列表内容封装在mixins内部 getTableData方法 初始化已封装完成 条件搜索时候 请把条件安好后台定制的结构体字段 放到 this.searchInfo 中即可实现条件搜索 |
|||
|
|||
import { |
|||
getApiById, |
|||
getApiList, |
|||
createApi, |
|||
updateApi, |
|||
deleteApi, |
|||
deleteApisByIds |
|||
} from '@/api/api' |
|||
import infoList from '@/mixins/infoList' |
|||
import { toSQLLine } from '@/utils/stringFun' |
|||
import warningBar from '@/components/warningBar/warningBar.vue' |
|||
const methodOptions = [ |
|||
{ |
|||
value: 'POST', |
|||
label: '创建', |
|||
type: 'success' |
|||
}, |
|||
{ |
|||
value: 'GET', |
|||
label: '查看', |
|||
type: '' |
|||
}, |
|||
{ |
|||
value: 'PUT', |
|||
label: '更新', |
|||
type: 'warning' |
|||
}, |
|||
{ |
|||
value: 'DELETE', |
|||
label: '删除', |
|||
type: 'danger' |
|||
} |
|||
] |
|||
|
|||
export default { |
|||
name: 'Api', |
|||
components: { |
|||
warningBar |
|||
}, |
|||
mixins: [infoList], |
|||
data() { |
|||
return { |
|||
deleteVisible: false, |
|||
listApi: getApiList, |
|||
dialogFormVisible: false, |
|||
dialogTitle: '新增', |
|||
apis: [], |
|||
form: { |
|||
path: '', |
|||
apiGroup: '', |
|||
method: '', |
|||
description: '' |
|||
}, |
|||
methodOptions: methodOptions, |
|||
type: '', |
|||
rules: { |
|||
path: [{ required: true, message: '请输入api路径', trigger: 'blur' }], |
|||
apiGroup: [ |
|||
{ required: true, message: '请输入组名称', trigger: 'blur' } |
|||
], |
|||
method: [ |
|||
{ required: true, message: '请选择请求方式', trigger: 'blur' } |
|||
], |
|||
description: [ |
|||
{ required: true, message: '请输入api介绍', trigger: 'blur' } |
|||
] |
|||
} |
|||
} |
|||
}, |
|||
created() { |
|||
this.getTableData() |
|||
}, |
|||
methods: { |
|||
methodFiletr(value) { |
|||
const target = methodOptions.filter(item => item.value === value)[0] |
|||
return target && `${target.label}` |
|||
}, |
|||
tagTypeFiletr(value) { |
|||
const target = methodOptions.filter(item => item.value === value)[0] |
|||
return target && `${target.type}` |
|||
}, |
|||
// 选中api |
|||
handleSelectionChange(val) { |
|||
this.apis = val |
|||
}, |
|||
async onDelete() { |
|||
const ids = this.apis.forEach(item => item.ID) |
|||
const res = await deleteApisByIds({ ids }) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: res.msg |
|||
}) |
|||
if (this.tableData.length === ids.length && this.page > 1) { |
|||
this.page-- |
|||
} |
|||
this.deleteVisible = false |
|||
this.getTableData() |
|||
} |
|||
}, |
|||
// 排序 |
|||
sortChange({ prop, order }) { |
|||
if (prop) { |
|||
this.searchInfo.orderKey = toSQLLine(prop) |
|||
this.searchInfo.desc = order === 'descending' |
|||
} |
|||
this.getTableData() |
|||
}, |
|||
onReset() { |
|||
this.searchInfo = {} |
|||
}, |
|||
// 条件搜索前端看此方法 |
|||
onSubmit() { |
|||
this.page = 1 |
|||
this.pageSize = 10 |
|||
this.getTableData() |
|||
}, |
|||
initForm() { |
|||
this.$refs.apiForm.resetFields() |
|||
this.form = { |
|||
path: '', |
|||
apiGroup: '', |
|||
method: '', |
|||
description: '' |
|||
} |
|||
}, |
|||
closeDialog() { |
|||
this.initForm() |
|||
this.dialogFormVisible = false |
|||
}, |
|||
openDialog(type) { |
|||
switch (type) { |
|||
case 'addApi': |
|||
this.dialogTitle = '新增' |
|||
break |
|||
case 'edit': |
|||
this.dialogTitle = '编辑' |
|||
break |
|||
default: |
|||
break |
|||
} |
|||
this.type = type |
|||
this.dialogFormVisible = true |
|||
}, |
|||
async editApi(row) { |
|||
const res = await getApiById({ id: row.ID }) |
|||
this.form = res.data.api |
|||
this.openDialog('edit') |
|||
}, |
|||
async deleteApi(row) { |
|||
this.$confirm('此操作将永久删除所有角色下该api, 是否继续?', '提示', { |
|||
confirmButtonText: '确定', |
|||
cancelButtonText: '取消', |
|||
type: 'warning' |
|||
}) |
|||
.then(async() => { |
|||
const res = await deleteApi(row) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '删除成功!' |
|||
}) |
|||
if (this.tableData.length === 1 && this.page > 1) { |
|||
this.page-- |
|||
} |
|||
this.getTableData() |
|||
} |
|||
}) |
|||
}, |
|||
async enterDialog() { |
|||
this.$refs.apiForm.validate(async valid => { |
|||
if (valid) { |
|||
switch (this.type) { |
|||
case 'addApi': |
|||
{ |
|||
const res = await createApi(this.form) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '添加成功', |
|||
showClose: true |
|||
}) |
|||
} |
|||
this.getTableData() |
|||
this.closeDialog() |
|||
} |
|||
|
|||
break |
|||
case 'edit': |
|||
{ |
|||
const res = await updateApi(this.form) |
|||
if (res.code === 0) { |
|||
this.$message({ |
|||
type: 'success', |
|||
message: '编辑成功', |
|||
showClose: true |
|||
}) |
|||
} |
|||
this.getTableData() |
|||
this.closeDialog() |
|||
} |
|||
break |
|||
default: |
|||
// eslint-disable-next-line no-lone-blocks |
|||
{ |
|||
this.$message({ |
|||
type: 'error', |
|||
message: '未知操作', |
|||
showClose: true |
|||
}) |
|||
} |
|||
break |
|||
} |
|||
} |
|||
}) |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style scoped lang="scss"> |
|||
.button-box { |
|||
padding: 10px 20px; |
|||
.el-button { |
|||
float: right; |
|||
} |
|||
} |
|||
.warning { |
|||
color: #dc143c; |
|||
} |
|||
</style> |
|||
@ -0,0 +1,367 @@ |
|||
<template> |
|||
<div class="logic-flow-view"> |
|||
<h3 class="demo-title">LogicFlow Vue demo</h3> |
|||
<!-- 辅助工具栏 --> |
|||
<Control |
|||
class="demo-control" |
|||
v-if="lf" |
|||
:lf="lf" |
|||
@catData="$_catData" |
|||
></Control> |
|||
<!-- 节点面板 --> |
|||
<NodePanel v-if="lf" :lf="lf" :nodeList="nodeList"></NodePanel> |
|||
<!-- 画布 --> |
|||
<div id="LF-view"></div> |
|||
<!-- 用户节点自定义操作面板 --> |
|||
<AddPanel |
|||
v-if="showAddPanel" |
|||
class="add-panel" |
|||
:style="addPanelStyle" |
|||
:lf="lf" |
|||
:nodeData="addClickNode" |
|||
@addNodeFinish="hideAddPanel" |
|||
> |
|||
</AddPanel> |
|||
<!-- 属性面板 --> |
|||
<el-drawer |
|||
title="设置节点属性" |
|||
:visible.sync="dialogVisible" |
|||
direction="rtl" |
|||
size="500px" |
|||
:before-close="closeDialog"> |
|||
<PropertyDialog |
|||
v-if="dialogVisible" |
|||
:nodeData="clickNode" |
|||
:lf="lf" |
|||
@setPropertiesFinish="closeDialog" |
|||
></PropertyDialog> |
|||
</el-drawer> |
|||
<!-- 数据查看面板 --> |
|||
<el-dialog |
|||
title="数据" |
|||
:visible.sync="dataVisible" |
|||
width="50%"> |
|||
<DataDialog :graphData="graphData"></DataDialog> |
|||
</el-dialog> |
|||
<h4>更多示例: |
|||
<el-button type="text" @click="goto">BpmnElement & TurboAdpter</el-button> |
|||
</h4> |
|||
<el-drawer |
|||
title="我是标题" |
|||
:visible.sync="drawer" |
|||
:direction="rtl"> |
|||
<span>我来啦!</span> |
|||
</el-drawer> |
|||
</div> |
|||
</template> |
|||
<script> |
|||
import LogicFlow from '@logicflow/core' |
|||
// const LogicFlow = window.LogicFlow |
|||
import { Menu, Snapshot } from '@logicflow/extension' |
|||
import '@logicflow/core/dist/style/index.css' |
|||
import '@logicflow/extension/lib/style/index.css' |
|||
import NodePanel from './LFComponents/NodePanel.vue' |
|||
import AddPanel from './LFComponents/AddPanel.vue' |
|||
import Control from './LFComponents/Control.vue' |
|||
import PropertyDialog from './PropertySetting/PropertyDialog.vue' |
|||
import DataDialog from './LFComponents/DataDialog.vue' |
|||
import { nodeList } from './config' |
|||
|
|||
import registerStart from './registerNode/registerStart' |
|||
import registerUser from './registerNode/registerUser' |
|||
import registerEnd from './registerNode/registerEnd' |
|||
import registerPush from './registerNode/registerPush' |
|||
import registerDownload from './registerNode/registerDownload' |
|||
import registerPolyline from './registerNode/registerPolyline' |
|||
import registerTask from './registerNode/registerTask' |
|||
// import registerConnect from './registerNode/registerConnect' |
|||
// import { |
|||
// registerStart, |
|||
// registerUser, |
|||
// registerEnd, |
|||
// registerPush, |
|||
// registerDownload, |
|||
// registerPolyline, |
|||
// registerTask, |
|||
// registerConnect, |
|||
// } from './registerNode' |
|||
const demoData = import.meta.glob('./data.json') |
|||
|
|||
export default { |
|||
name: 'LF', |
|||
components: { NodePanel, AddPanel, Control, PropertyDialog, DataDialog }, |
|||
data () { |
|||
return { |
|||
drawer: false, |
|||
lf: null, |
|||
showAddPanel: false, |
|||
addPanelStyle: { |
|||
top: 0, |
|||
left: 0 |
|||
}, |
|||
nodeData: null, |
|||
addClickNode: null, |
|||
clickNode: null, |
|||
dialogVisible: false, |
|||
graphData: null, |
|||
dataVisible: false, |
|||
config: { |
|||
background: { |
|||
color: '#f7f9ff' |
|||
}, |
|||
grid: { |
|||
size: 10, |
|||
visible: false |
|||
}, |
|||
keyboard: { |
|||
enabled: true |
|||
}, |
|||
style: { |
|||
rect: { |
|||
radius: 6, |
|||
}, |
|||
edgeText: { // 边文本样式 |
|||
background: { |
|||
fill: '#fff' |
|||
} |
|||
}, |
|||
}, |
|||
edgeTextDraggable: true, |
|||
guards: { |
|||
beforeClone (data) { |
|||
console.log('beforeClone', data) |
|||
return true |
|||
}, |
|||
beforeDelete (data) { |
|||
// 可以根据data数据判断是否允许删除,允许返回true,不允许返回false |
|||
// 文档: http://logic-flow.org/guide/basic/keyboard.html#%E5%A6%82%E4%BD%95%E9%98%BB%E6%AD%A2%E5%88%A0%E9%99%A4%E6%88%96%E8%80%85%E6%8B%B7%E8%B4%9D%E8%A1%8C%E4%B8%BA |
|||
console.log('beforeDelete', data) |
|||
// _this.$message('不允许删除', 'error') |
|||
return true |
|||
} |
|||
} |
|||
}, |
|||
moveData: {}, |
|||
nodeList, |
|||
} |
|||
}, |
|||
mounted () { |
|||
this.$_initLf() |
|||
}, |
|||
methods: { |
|||
$_initLf () { |
|||
// 画布配置 |
|||
|
|||
// 使用插件 |
|||
LogicFlow.use(Menu) |
|||
LogicFlow.use(Snapshot) |
|||
const lf = new LogicFlow({...this.config, container: document.querySelector('#LF-view'),}) |
|||
this.lf = lf |
|||
// lf.setDefaultEdgeType('bpmn:sequenceFlow'); |
|||
// 菜单配置文档:http://logic-flow.org/guide/extension/extension-components.html#%E8%8F%9C%E5%8D%95 |
|||
// 重置,增加,节点自由配置(以user节点为示例) |
|||
// lf.setMenuConfig({ |
|||
// nodeMenu: [], |
|||
// edgeMenu: [] |
|||
// }) |
|||
// lf.addMenuConfig({ |
|||
// nodeMenu: [ |
|||
// { |
|||
// text: '分享', |
|||
// callback () { |
|||
// alert('分享成功!') |
|||
// } |
|||
// }, |
|||
// { |
|||
// text: '属性', |
|||
// callback (node) { |
|||
// alert(` |
|||
// 节点id:${node.id} |
|||
// 节点类型:${node.type} |
|||
// 节点坐标:(x: ${node.x}, y: ${node.y})` |
|||
// ) |
|||
// } |
|||
// } |
|||
// ], |
|||
// edgeMenu: [ |
|||
// { |
|||
// text: '属性', |
|||
// callback (edge) { |
|||
// alert(` |
|||
// 边id:${edge.id} |
|||
// 边类型:${edge.type} |
|||
// 边坐标:(x: ${edge.x}, y: ${edge.y}) |
|||
// 源节点id:${edge.sourceNodeId} |
|||
// 目标节点id:${edge.targetNodeId}` |
|||
// ) |
|||
// } |
|||
// } |
|||
// ] |
|||
// }) |
|||
// 设置主题 |
|||
lf.setTheme({ |
|||
circle: { |
|||
r: 20, |
|||
stroke: '#000000', |
|||
outlineColor: '#88f', |
|||
strokeWidth: 1 |
|||
}, |
|||
rect: { |
|||
outlineColor: '#88f', |
|||
strokeWidth: 1 |
|||
}, |
|||
polygon: { |
|||
strokeWidth: 1 |
|||
}, |
|||
polyline: { |
|||
stroke: '#000000', |
|||
hoverStroke: '#000000', |
|||
selectedStroke: '#000000', |
|||
outlineColor: '#88f', |
|||
strokeWidth: 1 |
|||
}, |
|||
nodeText: { |
|||
color: '#000000' |
|||
}, |
|||
edgeText: { |
|||
color: '#000000', |
|||
background: { |
|||
fill: '#f7f9ff' |
|||
} |
|||
} |
|||
}) |
|||
this.$_registerNode() |
|||
}, |
|||
// 自定义 |
|||
$_registerNode () { |
|||
registerStart(this.lf) |
|||
registerUser(this.lf) |
|||
registerEnd(this.lf) |
|||
registerPush(this.lf, this.clickPlus, this.mouseDownPlus) |
|||
registerDownload(this.lf) |
|||
registerPolyline(this.lf) |
|||
registerTask(this.lf) |
|||
// registerConnect(this.lf) |
|||
this.$_render() |
|||
}, |
|||
$_render () { |
|||
this.lf.render(demoData) |
|||
this.$_LfEvent() |
|||
}, |
|||
$_getData () { |
|||
const data = this.lf.getGraphData() |
|||
console.log(JSON.stringify(data)) |
|||
}, |
|||
$_LfEvent () { |
|||
|
|||
this.lf.on('node:click', ({data}) => { |
|||
|
|||
console.log(data) |
|||
this.$data.clickNode = data |
|||
// console.log(this.$data.clickNode) |
|||
// console.log(this.$data.dialogVisible) |
|||
this.dialogVisible = true |
|||
|
|||
this.$data.drawer=false |
|||
console.log(this.$data.drawer) |
|||
}) |
|||
this.lf.on('edge:click', ({data}) => { |
|||
console.log('edge:click', data) |
|||
this.$data.clickNode = data |
|||
this.$data.dialogVisible = true |
|||
}) |
|||
this.lf.on('element:click', () => { |
|||
this.hideAddPanel() |
|||
}) |
|||
this.lf.on('edge:add', ({data}) => { |
|||
console.log('edge:add', data) |
|||
}) |
|||
this.lf.on('node:mousemove', ({data}) => { |
|||
console.log('node:mousemove') |
|||
this.moveData = data |
|||
}) |
|||
this.lf.on('blank:click', () => { |
|||
this.hideAddPanel() |
|||
}) |
|||
this.lf.on('connection:not-allowed', (data) => { |
|||
this.$message({ |
|||
type: 'error', |
|||
message: data.msg |
|||
}) |
|||
}) |
|||
this.lf.on('node:mousemove', () => { |
|||
console.log('on mousemove') |
|||
}) |
|||
}, |
|||
clickPlus (e, attributes) { |
|||
e.stopPropagation() |
|||
console.log('clickPlus', e, attributes) |
|||
const { clientX, clientY } = e |
|||
console.log(clientX, clientY) |
|||
this.$data.addPanelStyle.top = (clientY - 40) + 'px' |
|||
this.$data.addPanelStyle.left = clientX + 'px' |
|||
this.$data.showAddPanel = true |
|||
this.$data.addClickNode = attributes |
|||
}, |
|||
mouseDownPlus (e, attributes) { |
|||
e.stopPropagation() |
|||
console.log('mouseDownPlus', e, attributes) |
|||
}, |
|||
hideAddPanel () { |
|||
this.$data.showAddPanel = false |
|||
this.$data.addPanelStyle.top = 0 |
|||
this.$data.addPanelStyle.left = 0 |
|||
this.$data.addClickNode = null |
|||
}, |
|||
closeDialog () { |
|||
this.$data.dialogVisible = false |
|||
}, |
|||
$_catData(){ |
|||
console.log() |
|||
this.$data.graphData = this.$data.lf.getGraphData(); |
|||
this.$data.dataVisible = true; |
|||
}, |
|||
goto () { |
|||
this.$router.push('/TurboAdpter') |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
<style> |
|||
.logic-flow-view { |
|||
height: 100vh; |
|||
position: relative; |
|||
} |
|||
.demo-title{ |
|||
text-align: center; |
|||
margin: 20px; |
|||
} |
|||
.demo-control{ |
|||
position: absolute; |
|||
top: 50px; |
|||
right: 50px; |
|||
z-index: 2; |
|||
} |
|||
#LF-view{ |
|||
width: calc(100% - 100px); |
|||
height: 80%; |
|||
outline: none; |
|||
margin-left: 50px; |
|||
} |
|||
.time-plus{ |
|||
cursor: pointer; |
|||
} |
|||
.add-panel { |
|||
position: absolute; |
|||
z-index: 11; |
|||
background-color: white; |
|||
padding: 10px 5px; |
|||
} |
|||
.el-drawer__body { |
|||
height: 80%; |
|||
overflow: auto; |
|||
margin-top: -30px; |
|||
z-index: 3; |
|||
} |
|||
</style> |
|||
|
|||
@ -0,0 +1,108 @@ |
|||
<template> |
|||
<el-tabs tab-position="left"> |
|||
<el-tab-pane label="添加动作"> |
|||
<div v-for="item in nodeList" :key="item.type"> |
|||
<el-button class="add-node-btn" type="primary" size="mini" @click="$_addNode(item)">{{item.label}}</el-button> |
|||
</div> |
|||
</el-tab-pane> |
|||
<el-tab-pane label="添加组"> |
|||
<el-button class="add-node-btn" type="primary" size="mini" @click="$_addTempalte">模板</el-button> |
|||
</el-tab-pane> |
|||
</el-tabs> |
|||
</template> |
|||
<script> |
|||
export default { |
|||
name: 'AddPanel', |
|||
props: { |
|||
nodeData: Object, |
|||
lf: Object || String |
|||
}, |
|||
data () { |
|||
return { |
|||
nodeList: [ |
|||
{ |
|||
type: 'user', |
|||
label: '用户' |
|||
}, |
|||
{ |
|||
type: 'push', |
|||
label: '推送' |
|||
} |
|||
] |
|||
} |
|||
}, |
|||
methods: { |
|||
$_addNode (item) { |
|||
const {lf, nodeData} = this.$props |
|||
const { id, x, y } = nodeData |
|||
const nextNode = lf.addNode({ |
|||
type: item.type, |
|||
x: x + 150, |
|||
y: y + 150 |
|||
}) |
|||
const nextId = nextNode.id |
|||
lf.createEdge({sourceNodeId: id, targetNodeId: nextId}) |
|||
this.$emit('addNodeFinish') |
|||
}, |
|||
$_addTempalte () { |
|||
const {lf, nodeData} = this.$props |
|||
const { id, x, y } = nodeData |
|||
const timeNode = lf.addNode({ |
|||
type: 'download', |
|||
x, |
|||
y: y + 150 |
|||
}) |
|||
const userNode = lf.addNode({ |
|||
type: 'user', |
|||
x: x + 150, |
|||
y: y + 150 |
|||
}) |
|||
const pushNode = lf.addNode({ |
|||
type: 'push', |
|||
x: x + 150, |
|||
y: y + 300, |
|||
properties: {} |
|||
}) |
|||
const endNode = lf.addNode({ |
|||
type: 'end', |
|||
x: x + 300, |
|||
y: y + 150 |
|||
}) |
|||
const endNode2 = lf.addNode({ |
|||
type: 'end', |
|||
x: x + 300, |
|||
y: y + 300 |
|||
}) |
|||
lf.createEdge({sourceNodeId: id, targetNodeId: timeNode.id}) |
|||
lf.createEdge({sourceNodeId: timeNode.id, targetNodeId: userNode.id}) |
|||
lf.createEdge({ |
|||
sourceNodeId: userNode.id, |
|||
targetNodeId: endNode.id, |
|||
endPoint: {x: x + 280, y: y + 150}, |
|||
text: { |
|||
value: 'Y', |
|||
x: x + 230, |
|||
y: y + 140 |
|||
} |
|||
}) |
|||
lf.createEdge({ |
|||
sourceNodeId: userNode.id, |
|||
targetNodeId: pushNode.id, |
|||
text: { |
|||
value: 'N', |
|||
x: x + 160, |
|||
y: y + 230 |
|||
} |
|||
}) |
|||
lf.createEdge({sourceNodeId: pushNode.id, targetNodeId: endNode2.id, endPoint: {x: x + 280, y: y + 300}}) |
|||
this.$emit('addNodeFinish') |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
<style scoped> |
|||
.add-node-btn{ |
|||
margin-bottom: 10px; |
|||
margin-right: 20px; |
|||
} |
|||
</style> |
|||
@ -0,0 +1,74 @@ |
|||
<template> |
|||
<div> |
|||
<el-button-group> |
|||
<el-button type="plain" size="small" @click="$_zoomIn">放大</el-button> |
|||
<el-button type="plain" size="small" @click="$_zoomOut">缩小</el-button> |
|||
<el-button type="plain" size="small" @click="$_zoomReset">大小适应</el-button> |
|||
<el-button type="plain" size="small" @click="$_translateRest">定位还原</el-button> |
|||
<el-button type="plain" size="small" @click="$_reset">还原(大小&定位)</el-button> |
|||
<el-button type="plain" size="small" @click="$_undo" :disabled="undoDisable">上一步(ctrl+z)</el-button> |
|||
<el-button type="plain" size="small" @click="$_redo" :disabled="redoDisable">下一步(ctrl+y)</el-button> |
|||
<el-button type="plain" size="small" @click="$_download">下载图片</el-button> |
|||
<el-button type="plain" size="small" @click="$_catData">查看数据</el-button> |
|||
<el-button v-if="catTurboData" type="plain" size="small" @click="$_catTurboData">查看turbo数据</el-button> |
|||
</el-button-group> |
|||
</div> |
|||
</template> |
|||
<script> |
|||
export default { |
|||
name: 'Control', |
|||
props: { |
|||
lf: Object || String, |
|||
catTurboData: Boolean |
|||
}, |
|||
data () { |
|||
return { |
|||
undoDisable: true, |
|||
redoDisable: true, |
|||
graphData: null, |
|||
dataVisible: false, |
|||
} |
|||
}, |
|||
mounted () { |
|||
this.$props.lf.on('history:change', ({ data: { undoAble, redoAble } }) => { |
|||
this.$data.undoDisable = !undoAble |
|||
this.$data.redoDisable = !redoAble |
|||
}); |
|||
}, |
|||
methods: { |
|||
$_zoomIn(){ |
|||
this.$props.lf.zoom(true); |
|||
}, |
|||
$_zoomOut(){ |
|||
this.$props.lf.zoom(false); |
|||
}, |
|||
$_zoomReset(){ |
|||
this.$props.lf.resetZoom(); |
|||
}, |
|||
$_translateRest(){ |
|||
this.$props.lf.resetTranslate(); |
|||
}, |
|||
$_reset(){ |
|||
this.$props.lf.resetZoom(); |
|||
this.$props.lf.resetTranslate(); |
|||
}, |
|||
$_undo(){ |
|||
this.$props.lf.undo(); |
|||
}, |
|||
$_redo(){ |
|||
this.$props.lf.redo(); |
|||
}, |
|||
$_download(){ |
|||
this.$props.lf.getSnapshot(); |
|||
}, |
|||
$_catData(){ |
|||
this.$emit('catData'); |
|||
}, |
|||
$_catTurboData(){ |
|||
this.$emit('catTurboData'); |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
<style scoped> |
|||
</style> |
|||
@ -0,0 +1,20 @@ |
|||
<template> |
|||
<div> |
|||
<vue-json-pretty :path="'res'" :data="graphData"> </vue-json-pretty> |
|||
</div> |
|||
</template> |
|||
<script> |
|||
import VueJsonPretty from 'vue-json-pretty'; |
|||
import 'vue-json-pretty/lib/styles.css'; |
|||
|
|||
export default { |
|||
props: { |
|||
graphData: Object |
|||
}, |
|||
components: { |
|||
VueJsonPretty, |
|||
}, |
|||
}; |
|||
</script> |
|||
<style scoped> |
|||
</style> |
|||
@ -0,0 +1,104 @@ |
|||
<template> |
|||
<div class="node-panel"> |
|||
<div class="node-item" |
|||
v-for="item in nodeList" |
|||
:key="item.text" |
|||
@mousedown="$_dragNode(item)"> |
|||
<div class="node-item-icon" :class="item.class"> |
|||
<div v-if="item.type === 'user' || item.type === 'time'" class="shape"></div> |
|||
</div> |
|||
<span class="node-label">{{item.text}}</span> |
|||
</div> |
|||
</div> |
|||
</template> |
|||
<script> |
|||
export default { |
|||
name: 'NodePanel', |
|||
props: { |
|||
lf: Object, |
|||
nodeList: Array, |
|||
}, |
|||
methods: { |
|||
$_dragNode (item) { |
|||
this.$props.lf.dnd.startDrag({ |
|||
type: item.type, |
|||
}) |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
<style> |
|||
.node-panel { |
|||
position: absolute; |
|||
top: 100px; |
|||
left: 50px; |
|||
width: 70px; |
|||
padding: 20px 10px; |
|||
background-color: white; |
|||
box-shadow: 0 0 10px 1px rgb(228, 224, 219); |
|||
border-radius: 6px; |
|||
text-align: center; |
|||
z-index: 101; |
|||
} |
|||
.node-item { |
|||
margin-bottom: 20px; |
|||
} |
|||
.node-item-icon { |
|||
width: 30px; |
|||
height: 30px; |
|||
margin-left: 20px; |
|||
background-size: cover; |
|||
} |
|||
.node-label { |
|||
font-size: 12px; |
|||
margin-top: 5px; |
|||
user-select: none; |
|||
} |
|||
.node-start{ |
|||
background: url('../background/start.png') no-repeat; |
|||
background-size: cover; |
|||
} |
|||
.node-rect{ |
|||
border: 1px solid black; |
|||
} |
|||
.node-user{ |
|||
background: url('../background/user.png') no-repeat; |
|||
background-size: cover; |
|||
} |
|||
.node-time{ |
|||
background: url('../background/time.png') no-repeat; |
|||
background-size: cover; |
|||
} |
|||
.node-push{ |
|||
background: url('../background/push.png') no-repeat; |
|||
background-size: cover; |
|||
} |
|||
.node-download{ |
|||
background: url('../background/download.png') no-repeat; |
|||
background-size: cover; |
|||
} |
|||
.node-click{ |
|||
background: url('../background/click.png') no-repeat; |
|||
background-size: cover; |
|||
} |
|||
.node-end{ |
|||
background: url('../background/end.png') no-repeat; |
|||
background-size: cover; |
|||
} |
|||
.bpmn-start { |
|||
background: url() center center no-repeat; |
|||
cursor: grab; |
|||
} |
|||
.bpmn-end { |
|||
background: url() center center no-repeat; |
|||
cursor: grab; |
|||
} |
|||
.bpmn-user { |
|||
background: url() center center no-repeat; |
|||
cursor: grab; |
|||
} |
|||
.bpmn-exclusiveGateway { |
|||
background: url() center center no-repeat; |
|||
cursor: grab; |
|||
} |
|||
</style> |
|||
@ -0,0 +1,74 @@ |
|||
<template> |
|||
<div> |
|||
<el-form label-width="80px" :model="formData"> |
|||
<el-form-item label="文案"> |
|||
<el-input v-model="formData.text"></el-input> |
|||
</el-form-item> |
|||
<el-form-item label="名称"> |
|||
<el-input v-model="formData.name"></el-input> |
|||
</el-form-item> |
|||
<el-form-item label="活动区域"> |
|||
<el-input v-model="formData.region"></el-input> |
|||
</el-form-item> |
|||
<el-form-item label="活动形式"> |
|||
<el-input v-model="formData.type"></el-input> |
|||
</el-form-item> |
|||
<el-form-item label="A"> |
|||
<el-input v-model="formData.a.a1"></el-input> |
|||
<el-input v-model="formData.a.a2"></el-input> |
|||
</el-form-item> |
|||
<el-form-item> |
|||
<el-button type="primary" @click="onSubmit">保存</el-button> |
|||
</el-form-item> |
|||
</el-form> |
|||
</div> |
|||
</template> |
|||
<script> |
|||
export default { |
|||
name: '', |
|||
props: { |
|||
nodeData: Object, |
|||
lf: Object || String, |
|||
}, |
|||
mounted() { |
|||
const { properties, text } = this.$props.nodeData |
|||
if (properties) { |
|||
this.$data.formData = Object.assign({}, this.$data.formData, properties) |
|||
} |
|||
if (text && text.value) { |
|||
this.$data.formData.text = text.value |
|||
} |
|||
if (text && text.value) { |
|||
this.$data.text = text.value |
|||
} |
|||
}, |
|||
data () { |
|||
return { |
|||
text: '', |
|||
formData: { |
|||
text: '', |
|||
name: '', |
|||
region: '', |
|||
type: '', |
|||
a: { |
|||
a1: '', |
|||
a2: '' |
|||
} |
|||
} |
|||
} |
|||
}, |
|||
methods: { |
|||
onSubmit() { |
|||
const { id } = this.$props.nodeData |
|||
this.$props.lf.setProperties(id, { |
|||
...this.$data.formData |
|||
}); |
|||
console.log(6666, this.$data.formData); |
|||
this.$props.lf.updateText(id, this.$data.formData.text); |
|||
this.$emit('onClose') |
|||
}, |
|||
} |
|||
} |
|||
</script> |
|||
<style scoped> |
|||
</style> |
|||
@ -0,0 +1,43 @@ |
|||
<template> |
|||
<div class="property-dialog"> |
|||
<User |
|||
v-if="nodeData.type === 'user'" |
|||
:nodeData="nodeData" |
|||
:lf="lf" |
|||
@onClose="handleClose"/> |
|||
<CommonProperty |
|||
v-else |
|||
:nodeData="nodeData" |
|||
:lf="lf" |
|||
@onClose="handleClose"/> |
|||
</div> |
|||
</template> |
|||
<script> |
|||
import CommonProperty from './CommonProperty.vue' |
|||
import User from './User.vue' |
|||
|
|||
export default { |
|||
name: 'PropertyDialog', |
|||
components: { |
|||
CommonProperty, |
|||
User |
|||
}, |
|||
props: { |
|||
nodeData: Object, |
|||
lf: Object |
|||
}, |
|||
data () { |
|||
return {} |
|||
}, |
|||
methods: { |
|||
handleClose () { |
|||
this.$emit('setPropertiesFinish') |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
<style> |
|||
.property-dialog{ |
|||
padding: 20px; |
|||
} |
|||
</style> |
|||
@ -0,0 +1,90 @@ |
|||
<template> |
|||
<div> |
|||
<el-form ref="form" :model="form" label-width="80px"> |
|||
<el-form-item label="活动名称"> |
|||
<el-input v-model="form.name"></el-input> |
|||
</el-form-item> |
|||
<el-form-item label="活动区域"> |
|||
<el-select v-model="form.region" placeholder="请选择活动区域"> |
|||
<el-option label="区域一" value="shanghai"></el-option> |
|||
<el-option label="区域二" value="beijing"></el-option> |
|||
</el-select> |
|||
</el-form-item> |
|||
<el-form-item label="活动时间"> |
|||
<el-col :span="11"> |
|||
<el-date-picker type="date" placeholder="选择日期" v-model="form.date1" style="width: 100%;"></el-date-picker> |
|||
</el-col> |
|||
<el-col class="line" :span="2">-</el-col> |
|||
<el-col :span="11"> |
|||
<el-time-picker placeholder="选择时间" v-model="form.date2" style="width: 100%;"></el-time-picker> |
|||
</el-col> |
|||
</el-form-item> |
|||
<el-form-item label="即时配送"> |
|||
<el-switch v-model="form.delivery"></el-switch> |
|||
</el-form-item> |
|||
<el-form-item label="活动性质"> |
|||
<el-checkbox-group v-model="form.type"> |
|||
<el-checkbox label="美食/餐厅线上活动" name="type"></el-checkbox> |
|||
<el-checkbox label="地推活动" name="type"></el-checkbox> |
|||
<el-checkbox label="线下主题活动" name="type"></el-checkbox> |
|||
<el-checkbox label="单纯品牌曝光" name="type"></el-checkbox> |
|||
</el-checkbox-group> |
|||
</el-form-item> |
|||
<el-form-item label="特殊资源"> |
|||
<el-radio-group v-model="form.resource"> |
|||
<el-radio label="线上品牌商赞助"></el-radio> |
|||
<el-radio label="线下场地免费"></el-radio> |
|||
</el-radio-group> |
|||
</el-form-item> |
|||
<el-form-item label="活动形式"> |
|||
<el-input type="textarea" v-model="form.desc"></el-input> |
|||
</el-form-item> |
|||
<el-form-item> |
|||
<el-button type="primary" @click="onSubmit">保存</el-button> |
|||
</el-form-item> |
|||
</el-form> |
|||
</div> |
|||
</template> |
|||
<script> |
|||
export default { |
|||
name: '', |
|||
props: { |
|||
nodeData: Object, |
|||
lf: Object || String, |
|||
}, |
|||
mounted() { |
|||
const { properties } = this.$props.nodeData |
|||
if (properties) { |
|||
this.$data.form = Object.assign({}, this.$data.form, properties) |
|||
} |
|||
}, |
|||
data() { |
|||
return { |
|||
form: { |
|||
name: '', |
|||
region: '', |
|||
date1: '', |
|||
date2: '', |
|||
delivery: false, |
|||
type: [], |
|||
resource: '', |
|||
desc: '' |
|||
} |
|||
} |
|||
}, |
|||
methods: { |
|||
onSubmit() { |
|||
console.log('submit!'); |
|||
// const { id } = this.$props.nodeData |
|||
// this.$props.lf.setProperties(id, this.$data.form); |
|||
const nodeData = this.$props.nodeData |
|||
nodeData.properties = this.$data.form |
|||
console.log(nodeData); |
|||
this.$props.lf.setNodeData(nodeData); |
|||
this.$emit('onClose') |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
<style scoped> |
|||
</style> |
|||
@ -0,0 +1,21 @@ |
|||
<template> |
|||
<div> |
|||
测试 |
|||
<el-button @click="goto">流程</el-button> |
|||
</div> |
|||
</template> |
|||
<script> |
|||
export default { |
|||
name: 'Test', |
|||
data () { |
|||
return {} |
|||
}, |
|||
methods: { |
|||
goto () { |
|||
this.$router.push('/') |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
<style scoped> |
|||
</style> |
|||
@ -0,0 +1,167 @@ |
|||
<template> |
|||
<div class="logic-flow-view"> |
|||
<h3 class="demo-title">LogicFlow Turbo Adpter</h3> |
|||
<!-- 辅助工具栏 --> |
|||
<Control |
|||
class="demo-control" |
|||
v-if="lf" |
|||
:lf="lf" |
|||
catTurboData=true |
|||
@catData="$_catData" |
|||
@catTurboData="$_catTurboData" |
|||
></Control> |
|||
<!-- 节点面板 --> |
|||
<NodePanel :lf="lf" :nodeList="nodeList"></NodePanel> |
|||
<!-- 画布 --> |
|||
<div id="LF-Turbo"></div> |
|||
<!-- 数据查看面板 --> |
|||
<el-dialog |
|||
title="数据" |
|||
:visible.sync="dataVisible" |
|||
width="50%"> |
|||
<DataDialog :graphData="graphData"></DataDialog> |
|||
</el-dialog> |
|||
<h4>更多示例: |
|||
<el-button type="text" @click="goto">LogicFlow</el-button> |
|||
</h4> |
|||
</div> |
|||
</template> |
|||
<script> |
|||
import LogicFlow from '@logicflow/core' |
|||
import { Snapshot, BpmnElement,BpmnAdapter } from '@logicflow/extension' |
|||
import '@logicflow/core/dist/style/index.css' |
|||
import '@logicflow/extension/lib/style/index.css' |
|||
import NodePanel from './LFComponents/NodePanel.vue' |
|||
import Control from './LFComponents/Control.vue' |
|||
import DataDialog from './LFComponents/DataDialog.vue' |
|||
import { toTurboData, toLogicflowData } from './Util/AdpterForTurbo'; |
|||
import { BpmnNode } from './config' |
|||
const demoData = import.meta.glob('./dataTurbo.json') |
|||
|
|||
export default { |
|||
name: 'LF', |
|||
components: { NodePanel, Control, DataDialog }, |
|||
data () { |
|||
return { |
|||
lf: null, |
|||
dialogVisible: false, |
|||
graphData: null, |
|||
dataVisible: false, |
|||
config: { |
|||
grid: true, |
|||
background: { |
|||
color: '#f7f9ff' |
|||
}, |
|||
keyboard: { |
|||
enabled: true |
|||
}, |
|||
}, |
|||
nodeList: BpmnNode, |
|||
} |
|||
}, |
|||
mounted () { |
|||
this.$_initLf() |
|||
}, |
|||
methods: { |
|||
$_initLf () { |
|||
// 画布配置 |
|||
LogicFlow.use(Snapshot) |
|||
// 使用bpmn插件,引入bpmn元素,这些元素可以在turbo中转换后使用 |
|||
LogicFlow.use(BpmnElement) |
|||
const lf = new LogicFlow({...this.config, container: document.querySelector('#LF-Turbo')}) |
|||
this.lf = lf |
|||
// 设置边类型bpmn:sequenceFlow为默认类型 |
|||
lf.setDefaultEdgeType('bpmn:sequenceFlow') |
|||
this.$_render() |
|||
}, |
|||
$_render () { |
|||
|
|||
// Turbo数据转换为LogicFlow内部识别的数据结构 |
|||
const lFData = toLogicflowData(demoData) |
|||
|
|||
this.lf.render(lFData) |
|||
console.log("lFData") |
|||
console.log(lFData) |
|||
}, |
|||
closeDialog () { |
|||
this.$data.dialogVisible = false |
|||
}, |
|||
$_catData(){ |
|||
LogicFlow.use(BpmnAdapter); |
|||
|
|||
// 示例化 LogicFlow |
|||
const lf = new LogicFlow(); |
|||
lf.render(); |
|||
|
|||
// 通过 getGraphData 来获取转换后的数据 |
|||
this.$data.graphData =lf.getGraphData(); |
|||
console.log(this.$data.graphData) |
|||
// console.log(this.$data.lf.getGraphRawData) |
|||
// this.$data.graphData = this.$data.lf.getGraphData(); |
|||
// console.log(this.$data.graphData) |
|||
// this.$data.dataVisible = true; |
|||
}, |
|||
$_catTurboData(){ |
|||
const graphData = this.$data.lf.getGraphData(); |
|||
// 数据转化为Turbo识别的数据结构 |
|||
console.log("graphData") |
|||
console.log(graphData) |
|||
this.$data.graphData = toTurboData(graphData) |
|||
this.$data.dataVisible = true; |
|||
console.log("this.$data.graphData") |
|||
console.log(this.$data.graphData) |
|||
}, |
|||
$_xml(){ |
|||
LogicFlow.use(BpmnAdapter); |
|||
|
|||
// 示例化 LogicFlow |
|||
const lf = new LogicFlow(); |
|||
lf.render(); |
|||
|
|||
// 通过 getGraphData 来获取转换后的数据 |
|||
lf.getGraphData(); |
|||
}, |
|||
goto () { |
|||
this.$router.push('/') |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
<style> |
|||
.logic-flow-view { |
|||
height: 100vh; |
|||
position: relative; |
|||
} |
|||
.demo-title{ |
|||
text-align: center; |
|||
margin: 20px; |
|||
} |
|||
.demo-control{ |
|||
position: absolute; |
|||
top: 50px; |
|||
right: 50px; |
|||
z-index: 2; |
|||
} |
|||
#LF-Turbo{ |
|||
width: calc(100% - 100px); |
|||
height: 80%; |
|||
outline: none; |
|||
margin-left: 50px; |
|||
} |
|||
.time-plus{ |
|||
cursor: pointer; |
|||
} |
|||
.add-panel { |
|||
position: absolute; |
|||
z-index: 11; |
|||
background-color: white; |
|||
padding: 10px 5px; |
|||
} |
|||
.el-drawer__body { |
|||
height: 80%; |
|||
overflow: auto; |
|||
margin-top: -30px; |
|||
z-index: 3; |
|||
} |
|||
</style> |
|||
|
|||
@ -0,0 +1,166 @@ |
|||
|
|||
const TurboType = { |
|||
SEQUENCE_FLOW: 1, |
|||
START_EVENT : 2, |
|||
END_EVENT : 3, |
|||
USER_TASK: 4, |
|||
SERVICE_TASK : 5, |
|||
EXCLUSIVE_GATEWAY : 6, |
|||
} |
|||
|
|||
function getTurboType (type) { |
|||
switch (type) { |
|||
case 'bpmn:sequenceFlow': |
|||
return TurboType.SEQUENCE_FLOW; |
|||
case 'bpmn:startEvent': |
|||
return TurboType.START_EVENT; |
|||
case 'bpmn:endEvent': |
|||
return TurboType.END_EVENT; |
|||
case 'bpmn:userTask': |
|||
return TurboType.USER_TASK; |
|||
case 'bpmn:serviceTask': |
|||
return TurboType.SERVICE_TASK; |
|||
case 'bpmn:exclusiveGateway': |
|||
return TurboType.EXCLUSIVE_GATEWAY; |
|||
default: |
|||
return type; |
|||
} |
|||
} |
|||
|
|||
function convertNodeToTurboElement(node) { |
|||
const { id, type, x, y, text = '', properties } = node; |
|||
return { |
|||
incoming: [], |
|||
outgoing: [], |
|||
dockers: [], |
|||
type: getTurboType(node.type), |
|||
properties: { |
|||
...properties, |
|||
name: text && text.value || '', |
|||
x: x, |
|||
y: y, |
|||
text, |
|||
logicFlowType: type, |
|||
}, |
|||
key: id, |
|||
}; |
|||
} |
|||
function convertEdgeToTurboElement (edge) { |
|||
const { |
|||
id, |
|||
type, |
|||
sourceNodeId, |
|||
targetNodeId, |
|||
startPoint, |
|||
endPoint, |
|||
pointsList, |
|||
text = '', |
|||
properties } = edge; |
|||
return { |
|||
incoming: [sourceNodeId], |
|||
outgoing: [targetNodeId], |
|||
type: getTurboType(type), |
|||
dockers: [], |
|||
properties: { |
|||
...properties, |
|||
name: text && text.value || '', |
|||
text, |
|||
startPoint, |
|||
endPoint, |
|||
pointsList, |
|||
logicFlowType: type, |
|||
}, |
|||
key: id, |
|||
}; |
|||
} |
|||
|
|||
export function toTurboData(data) { |
|||
const nodeMap = new Map(); |
|||
const turboData = { |
|||
flowElementList: [], |
|||
}; |
|||
data.nodes.forEach((node) => { |
|||
const flowElement = convertNodeToTurboElement(node); |
|||
turboData.flowElementList.push(flowElement); |
|||
nodeMap.set(node.id, flowElement); |
|||
}); |
|||
data.edges.forEach((edge) => { |
|||
const flowElement = convertEdgeToTurboElement(edge); |
|||
const sourceElement = nodeMap.get(edge.sourceNodeId); |
|||
sourceElement.outgoing.push(flowElement.key); |
|||
const targetElement = nodeMap.get(edge.targetNodeId); |
|||
targetElement.incoming.push(flowElement.key); |
|||
turboData.flowElementList.push(flowElement); |
|||
}); |
|||
return turboData; |
|||
} |
|||
|
|||
|
|||
function convertFlowElementToEdge(element) { |
|||
const { incoming, outgoing, properties, key } = element; |
|||
const { |
|||
text, |
|||
startPoint, |
|||
endPoint, |
|||
pointsList, |
|||
logicFlowType |
|||
} = properties; |
|||
const edge = { |
|||
id: key, |
|||
type: logicFlowType, |
|||
sourceNodeId: incoming[0], |
|||
targetNodeId: outgoing[0], |
|||
text, |
|||
startPoint, |
|||
endPoint, |
|||
pointsList, |
|||
properties: {} |
|||
}; |
|||
const excludeProperties = ['startPoint', 'endPoint', 'pointsList', 'text', 'logicFlowType']; |
|||
Object.keys(element.properties).forEach(property => { |
|||
if (excludeProperties.indexOf(property) === -1) { |
|||
edge.properties[property] = element.properties[property]; |
|||
} |
|||
}); |
|||
return edge; |
|||
} |
|||
|
|||
function convertFlowElementToNode(element) { |
|||
const { properties, key } = element; |
|||
const { x, y, text, logicFlowType } = properties; |
|||
const node = { |
|||
id: key, |
|||
type: logicFlowType, |
|||
x, |
|||
y, |
|||
text, |
|||
properties: {} |
|||
}; |
|||
const excludeProperties = ['x', 'y', 'text', 'logicFlowType']; |
|||
Object.keys(element.properties).forEach(property => { |
|||
if (excludeProperties.indexOf(property) === -1) { |
|||
node.properties[property] = element.properties[property]; |
|||
} |
|||
}); |
|||
return node; |
|||
|
|||
} |
|||
|
|||
|
|||
export function toLogicflowData(data) { |
|||
const lfData = { |
|||
nodes: [], |
|||
edges: [], |
|||
}; |
|||
const list = data.flowElementList; |
|||
list && list.length > 0 && list.forEach(element => { |
|||
if (element.type === TurboType.SEQUENCE_FLOW) { |
|||
const edge = convertFlowElementToEdge(element); |
|||
lfData.edges.push(edge); |
|||
} else { |
|||
const node = convertFlowElementToNode(element); |
|||
lfData.nodes.push(node); |
|||
} |
|||
}) |
|||
return lfData; |
|||
} |
|||
|
After Width: | Height: | Size: 2.6 KiB |
|
After Width: | Height: | Size: 2.0 KiB |
|
After Width: | Height: | Size: 4.8 KiB |
|
After Width: | Height: | Size: 2.2 KiB |
|
After Width: | Height: | Size: 3.9 KiB |
|
After Width: | Height: | Size: 2.9 KiB |
|
After Width: | Height: | Size: 40 KiB |
@ -0,0 +1,60 @@ |
|||
export const nodeList = [ |
|||
{ |
|||
text: '开始', |
|||
type: 'start', |
|||
class: 'node-start' |
|||
}, |
|||
{ |
|||
text: '矩形', |
|||
type: 'rect', |
|||
class: 'node-rect' |
|||
}, |
|||
{ |
|||
type: 'user', |
|||
text: '用户', |
|||
class: 'node-user' |
|||
}, |
|||
{ |
|||
type: 'push', |
|||
text: '推送', |
|||
class: 'node-push' |
|||
}, |
|||
{ |
|||
type: 'download', |
|||
text: '位置', |
|||
class: 'node-download' |
|||
}, |
|||
{ |
|||
type: 'connect', |
|||
text: 'Html', |
|||
class: 'node-push' |
|||
}, |
|||
{ |
|||
type: 'end', |
|||
text: '结束', |
|||
class: 'node-end' |
|||
}, |
|||
]; |
|||
|
|||
export const BpmnNode = [ |
|||
{ |
|||
type: 'bpmn:startEvent', |
|||
text: '开始', |
|||
class: 'bpmn-start' |
|||
}, |
|||
{ |
|||
type: 'bpmn:endEvent', |
|||
text: '结束', |
|||
class: 'bpmn-end' |
|||
}, |
|||
{ |
|||
type: 'bpmn:exclusiveGateway', |
|||
text: '网关', |
|||
class: 'bpmn-exclusiveGateway' |
|||
}, |
|||
{ |
|||
type: 'bpmn:userTask', |
|||
text: '用户', |
|||
class: 'bpmn-user' |
|||
}, |
|||
] |
|||
@ -0,0 +1,346 @@ |
|||
{ |
|||
"nodes": [ |
|||
{ |
|||
"id": "742356ea-762b-4899-b96a-bd567e3c4361", |
|||
"type": "start", |
|||
"x": 220, |
|||
"y": 170, |
|||
"text": { |
|||
"x": 350, |
|||
"y": 190, |
|||
"value": "sdfasf" |
|||
}, |
|||
"properties": {}, |
|||
"baseType": "node" |
|||
}, |
|||
{ |
|||
"id": "dacda6b6-48d3-4dff-911d-287704eb23d8", |
|||
"type": "rect", |
|||
"x": 350, |
|||
"y": 170, |
|||
"properties": {}, |
|||
"baseType": "node", |
|||
"text": { |
|||
"x": 350, |
|||
"y": 170, |
|||
"value": "基础节点" |
|||
} |
|||
}, |
|||
{ |
|||
"id": "49106603-2b88-4b2c-b1e8-723c1f2210bd", |
|||
"type": "user", |
|||
"x": 530, |
|||
"y": 170, |
|||
"properties": {}, |
|||
"baseType": "node", |
|||
"text": { |
|||
"x": 530, |
|||
"y": 220, |
|||
"value": "自定义节点" |
|||
} |
|||
}, |
|||
{ |
|||
"id": "647fa2bc-98ee-40cf-99c5-4756c0bc130d", |
|||
"type": "push", |
|||
"x": 690, |
|||
"y": 170, |
|||
"properties": {}, |
|||
"baseType": "node", |
|||
"text": { |
|||
"x": 690, |
|||
"y": 220, |
|||
"value": "自定义节点 可添加下一个节点/节点组" |
|||
} |
|||
}, |
|||
{ |
|||
"id": "37e7bac3-8804-4237-abe9-7b6065c207e9", |
|||
"type": "download", |
|||
"x": 690, |
|||
"y": 320, |
|||
"properties": {}, |
|||
"baseType": "node" |
|||
}, |
|||
{ |
|||
"id": "6bb4396f-54c9-4b1c-b34c-87ef004f2e29", |
|||
"type": "user", |
|||
"x": 840, |
|||
"y": 320, |
|||
"properties": {}, |
|||
"baseType": "node" |
|||
}, |
|||
{ |
|||
"id": "abf76937-63b8-493c-a978-a4a58bc4f6b8", |
|||
"type": "push", |
|||
"x": 840, |
|||
"y": 470, |
|||
"properties": {}, |
|||
"baseType": "node" |
|||
}, |
|||
{ |
|||
"id": "b119f24f-2669-4a90-a837-afd853b2ffcc", |
|||
"type": "end", |
|||
"x": 990, |
|||
"y": 320, |
|||
"properties": {}, |
|||
"baseType": "node" |
|||
}, |
|||
{ |
|||
"id": "60326ad9-cae2-4a85-ae98-d340fb7bd67f", |
|||
"type": "end", |
|||
"x": 990, |
|||
"y": 470, |
|||
"properties": {}, |
|||
"baseType": "node" |
|||
}, |
|||
{ |
|||
"id": "414fe028-3609-4450-b0f4-e5aca7705e8c", |
|||
"type": "download", |
|||
"x": 860, |
|||
"y": 170, |
|||
"properties": {}, |
|||
"baseType": "node", |
|||
"text": { |
|||
"x": 860, |
|||
"y": 220, |
|||
"value": "自定义节点-设置颜色" |
|||
} |
|||
} |
|||
], |
|||
"edges": [ |
|||
{ |
|||
"id": "00f55245-513e-43a2-9cb0-adb61b01adc8", |
|||
"type": "polyline", |
|||
"sourceNodeId": "742356ea-762b-4899-b96a-bd567e3c4361", |
|||
"targetNodeId": "dacda6b6-48d3-4dff-911d-287704eb23d8", |
|||
"startPoint": { |
|||
"x": 240, |
|||
"y": 170 |
|||
}, |
|||
"endPoint": { |
|||
"x": 300, |
|||
"y": 170 |
|||
}, |
|||
"properties": {}, |
|||
"pointsList": [ |
|||
{ |
|||
"x": 240, |
|||
"y": 170 |
|||
}, |
|||
{ |
|||
"x": 300, |
|||
"y": 170 |
|||
} |
|||
] |
|||
}, |
|||
{ |
|||
"id": "bbf9754f-603e-48e4-85fe-84ed44459a6a", |
|||
"type": "polyline", |
|||
"sourceNodeId": "dacda6b6-48d3-4dff-911d-287704eb23d8", |
|||
"targetNodeId": "49106603-2b88-4b2c-b1e8-723c1f2210bd", |
|||
"startPoint": { |
|||
"x": 400, |
|||
"y": 170 |
|||
}, |
|||
"endPoint": { |
|||
"x": 495, |
|||
"y": 170 |
|||
}, |
|||
"properties": {}, |
|||
"pointsList": [ |
|||
{ |
|||
"x": 400, |
|||
"y": 170 |
|||
}, |
|||
{ |
|||
"x": 495, |
|||
"y": 170 |
|||
} |
|||
] |
|||
}, |
|||
{ |
|||
"id": "12bb443b-4070-4a08-ad4d-2755ee856f0d", |
|||
"type": "polyline", |
|||
"sourceNodeId": "49106603-2b88-4b2c-b1e8-723c1f2210bd", |
|||
"targetNodeId": "647fa2bc-98ee-40cf-99c5-4756c0bc130d", |
|||
"startPoint": { |
|||
"x": 565, |
|||
"y": 170 |
|||
}, |
|||
"endPoint": { |
|||
"x": 655, |
|||
"y": 170 |
|||
}, |
|||
"properties": {}, |
|||
"pointsList": [ |
|||
{ |
|||
"x": 565, |
|||
"y": 170 |
|||
}, |
|||
{ |
|||
"x": 655, |
|||
"y": 170 |
|||
} |
|||
] |
|||
}, |
|||
{ |
|||
"id": "33fa3c09-9c29-4cb7-8373-67d537b8b623", |
|||
"type": "polyline", |
|||
"sourceNodeId": "647fa2bc-98ee-40cf-99c5-4756c0bc130d", |
|||
"targetNodeId": "37e7bac3-8804-4237-abe9-7b6065c207e9", |
|||
"startPoint": { |
|||
"x": 690, |
|||
"y": 205 |
|||
}, |
|||
"endPoint": { |
|||
"x": 690, |
|||
"y": 295 |
|||
}, |
|||
"properties": {}, |
|||
"pointsList": [ |
|||
{ |
|||
"x": 690, |
|||
"y": 205 |
|||
}, |
|||
{ |
|||
"x": 690, |
|||
"y": 295 |
|||
} |
|||
] |
|||
}, |
|||
{ |
|||
"id": "2b5a5e89-005e-4fda-9a44-dc795050534f", |
|||
"type": "polyline", |
|||
"sourceNodeId": "37e7bac3-8804-4237-abe9-7b6065c207e9", |
|||
"targetNodeId": "6bb4396f-54c9-4b1c-b34c-87ef004f2e29", |
|||
"startPoint": { |
|||
"x": 715, |
|||
"y": 320 |
|||
}, |
|||
"endPoint": { |
|||
"x": 805, |
|||
"y": 320 |
|||
}, |
|||
"properties": {}, |
|||
"pointsList": [ |
|||
{ |
|||
"x": 715, |
|||
"y": 320 |
|||
}, |
|||
{ |
|||
"x": 805, |
|||
"y": 320 |
|||
} |
|||
] |
|||
}, |
|||
{ |
|||
"id": "62b54f8a-bcfd-494b-9144-5aeb09ca77a1", |
|||
"type": "polyline", |
|||
"sourceNodeId": "6bb4396f-54c9-4b1c-b34c-87ef004f2e29", |
|||
"targetNodeId": "b119f24f-2669-4a90-a837-afd853b2ffcc", |
|||
"startPoint": { |
|||
"x": 875, |
|||
"y": 320 |
|||
}, |
|||
"endPoint": { |
|||
"x": 970, |
|||
"y": 320 |
|||
}, |
|||
"properties": {}, |
|||
"text": { |
|||
"x": 920, |
|||
"y": 310, |
|||
"value": "Y" |
|||
}, |
|||
"pointsList": [ |
|||
{ |
|||
"x": 875, |
|||
"y": 320 |
|||
}, |
|||
{ |
|||
"x": 970, |
|||
"y": 320 |
|||
} |
|||
] |
|||
}, |
|||
{ |
|||
"id": "ba816d4a-5785-4911-9f78-03933f1463a1", |
|||
"type": "polyline", |
|||
"sourceNodeId": "6bb4396f-54c9-4b1c-b34c-87ef004f2e29", |
|||
"targetNodeId": "abf76937-63b8-493c-a978-a4a58bc4f6b8", |
|||
"startPoint": { |
|||
"x": 840, |
|||
"y": 355 |
|||
}, |
|||
"endPoint": { |
|||
"x": 840, |
|||
"y": 435 |
|||
}, |
|||
"properties": {}, |
|||
"text": { |
|||
"x": 850, |
|||
"y": 400, |
|||
"value": "N" |
|||
}, |
|||
"pointsList": [ |
|||
{ |
|||
"x": 840, |
|||
"y": 355 |
|||
}, |
|||
{ |
|||
"x": 840, |
|||
"y": 435 |
|||
} |
|||
] |
|||
}, |
|||
{ |
|||
"id": "2b3007ed-7a13-4db7-a1ea-6691d7564c34", |
|||
"type": "polyline", |
|||
"sourceNodeId": "abf76937-63b8-493c-a978-a4a58bc4f6b8", |
|||
"targetNodeId": "60326ad9-cae2-4a85-ae98-d340fb7bd67f", |
|||
"startPoint": { |
|||
"x": 875, |
|||
"y": 470 |
|||
}, |
|||
"endPoint": { |
|||
"x": 970, |
|||
"y": 470 |
|||
}, |
|||
"properties": {}, |
|||
"pointsList": [ |
|||
{ |
|||
"x": 875, |
|||
"y": 470 |
|||
}, |
|||
{ |
|||
"x": 970, |
|||
"y": 470 |
|||
} |
|||
] |
|||
}, |
|||
{ |
|||
"id": "262e2263-6c8c-4a38-b223-97848e9b5767", |
|||
"type": "polyline", |
|||
"sourceNodeId": "647fa2bc-98ee-40cf-99c5-4756c0bc130d", |
|||
"targetNodeId": "414fe028-3609-4450-b0f4-e5aca7705e8c", |
|||
"startPoint": { |
|||
"x": 725, |
|||
"y": 170 |
|||
}, |
|||
"endPoint": { |
|||
"x": 835, |
|||
"y": 170 |
|||
}, |
|||
"properties": {}, |
|||
"pointsList": [ |
|||
{ |
|||
"x": 725, |
|||
"y": 170 |
|||
}, |
|||
{ |
|||
"x": 835, |
|||
"y": 170 |
|||
} |
|||
] |
|||
} |
|||
] |
|||
} |
|||
@ -0,0 +1,214 @@ |
|||
{ |
|||
"nodes": [ |
|||
{ |
|||
"id": "Event_1d42u4p", |
|||
"type": "bpmn:startEvent", |
|||
"x": 280, |
|||
"y": 200, |
|||
"properties": { |
|||
"a": "efrwe", |
|||
"b": "wewe", |
|||
"name": "开始" |
|||
}, |
|||
"text": { |
|||
"x": 280, |
|||
"y": 200, |
|||
"value": "开始" |
|||
} |
|||
}, |
|||
{ |
|||
"id": "Event_08p8i6q", |
|||
"type": "bpmn:endEvent", |
|||
"x": 920, |
|||
"y": 200, |
|||
"properties": { |
|||
"a": "efrwe", |
|||
"b": "wewe", |
|||
"name": "结束" |
|||
}, |
|||
"text": { |
|||
"x": 920, |
|||
"y": 200, |
|||
"value": "结束" |
|||
} |
|||
}, |
|||
{ |
|||
"id": "Gateway_1fngqgj", |
|||
"type": "bpmn:exclusiveGateway", |
|||
"x": 580, |
|||
"y": 200, |
|||
"properties": { |
|||
"a": "efrwe", |
|||
"b": "wewe", |
|||
"name": "网关" |
|||
}, |
|||
"text": { |
|||
"x": 580, |
|||
"y": 200, |
|||
"value": "网关" |
|||
} |
|||
}, |
|||
{ |
|||
"id": "Activity_2mgtaia", |
|||
"type": "bpmn:userTask", |
|||
"x": 420, |
|||
"y": 200, |
|||
"properties": { |
|||
"a": "efrwe", |
|||
"b": "wewe", |
|||
"name": "用户" |
|||
}, |
|||
"text": { |
|||
"x": 420, |
|||
"y": 200, |
|||
"value": "用户" |
|||
} |
|||
}, |
|||
{ |
|||
"id": "Activity_1sp8qc8", |
|||
"type": "bpmn:serviceTask", |
|||
"x": 760, |
|||
"y": 200, |
|||
"properties": { |
|||
"a": "efrwe", |
|||
"b": "wewe", |
|||
"name": "服务" |
|||
}, |
|||
"text": { |
|||
"x": 760, |
|||
"y": 200, |
|||
"value": "服务" |
|||
} |
|||
} |
|||
], |
|||
"edges": [ |
|||
{ |
|||
"id": "Flow_33inf2k", |
|||
"type": "bpmn:sequenceFlow", |
|||
"sourceNodeId": "Event_1d42u4p", |
|||
"targetNodeId": "Activity_2mgtaia", |
|||
"startPoint": { |
|||
"x": 298, |
|||
"y": 200 |
|||
}, |
|||
"endPoint": { |
|||
"x": 370, |
|||
"y": 200 |
|||
}, |
|||
"properties": { |
|||
"name": "边" |
|||
}, |
|||
"text": { |
|||
"x": 331, |
|||
"y": 200, |
|||
"value": "边" |
|||
}, |
|||
"pointsList": [ |
|||
{ |
|||
"x": 298, |
|||
"y": 200 |
|||
}, |
|||
{ |
|||
"x": 370, |
|||
"y": 200 |
|||
} |
|||
] |
|||
}, |
|||
{ |
|||
"id": "Flow_0pfouf0", |
|||
"type": "bpmn:sequenceFlow", |
|||
"sourceNodeId": "Activity_2mgtaia", |
|||
"targetNodeId": "Gateway_1fngqgj", |
|||
"startPoint": { |
|||
"x": 470, |
|||
"y": 200 |
|||
}, |
|||
"endPoint": { |
|||
"x": 555, |
|||
"y": 200 |
|||
}, |
|||
"properties": { |
|||
"name": "边2" |
|||
}, |
|||
"text": { |
|||
"x": 507, |
|||
"y": 200, |
|||
"value": "边2" |
|||
}, |
|||
"pointsList": [ |
|||
{ |
|||
"x": 470, |
|||
"y": 200 |
|||
}, |
|||
{ |
|||
"x": 555, |
|||
"y": 200 |
|||
} |
|||
] |
|||
}, |
|||
{ |
|||
"id": "Flow_3918lhh", |
|||
"type": "bpmn:sequenceFlow", |
|||
"sourceNodeId": "Gateway_1fngqgj", |
|||
"targetNodeId": "Activity_1sp8qc8", |
|||
"startPoint": { |
|||
"x": 605, |
|||
"y": 200 |
|||
}, |
|||
"endPoint": { |
|||
"x": 710, |
|||
"y": 200 |
|||
}, |
|||
"properties": { |
|||
"name": "边3" |
|||
}, |
|||
"text": { |
|||
"x": 664, |
|||
"y": 200, |
|||
"value": "边3" |
|||
}, |
|||
"pointsList": [ |
|||
{ |
|||
"x": 605, |
|||
"y": 200 |
|||
}, |
|||
{ |
|||
"x": 710, |
|||
"y": 200 |
|||
} |
|||
] |
|||
}, |
|||
{ |
|||
"id": "Flow_379e0o9", |
|||
"type": "bpmn:sequenceFlow", |
|||
"sourceNodeId": "Activity_1sp8qc8", |
|||
"targetNodeId": "Event_08p8i6q", |
|||
"startPoint": { |
|||
"x": 810, |
|||
"y": 200 |
|||
}, |
|||
"endPoint": { |
|||
"x": 902, |
|||
"y": 200 |
|||
}, |
|||
"properties": { |
|||
"name": "边4" |
|||
}, |
|||
"text": { |
|||
"x": 871, |
|||
"y": 200, |
|||
"value": "边4" |
|||
}, |
|||
"pointsList": [ |
|||
{ |
|||
"x": 810, |
|||
"y": 200 |
|||
}, |
|||
{ |
|||
"x": 902, |
|||
"y": 200 |
|||
} |
|||
] |
|||
} |
|||
] |
|||
} |
|||
@ -0,0 +1,240 @@ |
|||
{ |
|||
"flowElementList": [ |
|||
{ |
|||
"incoming": [], |
|||
"outgoing": ["Flow_33inf2k"], |
|||
"dockers": [], |
|||
"type": 2, |
|||
"properties": { |
|||
"a": "efrwe", |
|||
"b": "wewe", |
|||
"name": "开始", |
|||
"x": 280, |
|||
"y": 200, |
|||
"text": { |
|||
"x": 280, |
|||
"y": 200, |
|||
"value": "开始" |
|||
}, |
|||
"logicFlowType": "bpmn:startEvent" |
|||
}, |
|||
"key": "Event_1d42u4p" |
|||
}, |
|||
{ |
|||
"incoming": ["Flow_379e0o9"], |
|||
"outgoing": [], |
|||
"dockers": [], |
|||
"type": 3, |
|||
"properties": { |
|||
"a": "efrwe", |
|||
"b": "wewe", |
|||
"name": "结束", |
|||
"x": 920, |
|||
"y": 200, |
|||
"text": { |
|||
"x": 920, |
|||
"y": 200, |
|||
"value": "结束" |
|||
}, |
|||
"logicFlowType": "bpmn:endEvent" |
|||
}, |
|||
"key": "Event_08p8i6q" |
|||
}, |
|||
{ |
|||
"incoming": ["Flow_0pfouf0"], |
|||
"outgoing": ["Flow_3918lhh"], |
|||
"dockers": [], |
|||
"type": 6, |
|||
"properties": { |
|||
"a": "efrwe", |
|||
"b": "wewe", |
|||
"name": "网关", |
|||
"x": 580, |
|||
"y": 200, |
|||
"text": { |
|||
"x": 580, |
|||
"y": 200, |
|||
"value": "网关" |
|||
}, |
|||
"logicFlowType": "bpmn:exclusiveGateway" |
|||
}, |
|||
"key": "Gateway_1fngqgj" |
|||
}, |
|||
{ |
|||
"incoming": ["Flow_33inf2k"], |
|||
"outgoing": ["Flow_0pfouf0"], |
|||
"dockers": [], |
|||
"type": 4, |
|||
"properties": { |
|||
"a": "efrwe", |
|||
"b": "wewe", |
|||
"name": "用户", |
|||
"x": 420, |
|||
"y": 200, |
|||
"text": { |
|||
"x": 420, |
|||
"y": 200, |
|||
"value": "用户" |
|||
}, |
|||
"logicFlowType": "bpmn:userTask" |
|||
}, |
|||
"key": "Activity_2mgtaia" |
|||
}, |
|||
{ |
|||
"incoming": ["Flow_3918lhh"], |
|||
"outgoing": ["Flow_379e0o9"], |
|||
"dockers": [], |
|||
"type": 5, |
|||
"properties": { |
|||
"a": "efrwe", |
|||
"b": "wewe", |
|||
"name": "服务", |
|||
"x": 760, |
|||
"y": 200, |
|||
"text": { |
|||
"x": 760, |
|||
"y": 200, |
|||
"value": "服务" |
|||
}, |
|||
"logicFlowType": "bpmn:serviceTask" |
|||
}, |
|||
"key": "Activity_1sp8qc8" |
|||
}, |
|||
{ |
|||
"incoming": ["Event_1d42u4p"], |
|||
"outgoing": ["Activity_2mgtaia"], |
|||
"type": 1, |
|||
"dockers": [], |
|||
"properties": { |
|||
"name": "边", |
|||
"text": { |
|||
"x": 331, |
|||
"y": 200, |
|||
"value": "边" |
|||
}, |
|||
"startPoint": { |
|||
"x": 298, |
|||
"y": 200 |
|||
}, |
|||
"endPoint": { |
|||
"x": 370, |
|||
"y": 200 |
|||
}, |
|||
"pointsList": [ |
|||
{ |
|||
"x": 298, |
|||
"y": 200 |
|||
}, |
|||
{ |
|||
"x": 370, |
|||
"y": 200 |
|||
} |
|||
], |
|||
"logicFlowType": "bpmn:sequenceFlow" |
|||
}, |
|||
"key": "Flow_33inf2k" |
|||
}, |
|||
{ |
|||
"incoming": ["Activity_2mgtaia"], |
|||
"outgoing": ["Gateway_1fngqgj"], |
|||
"type": 1, |
|||
"dockers": [], |
|||
"properties": { |
|||
"name": "边2", |
|||
"text": { |
|||
"x": 507, |
|||
"y": 200, |
|||
"value": "边2" |
|||
}, |
|||
"startPoint": { |
|||
"x": 470, |
|||
"y": 200 |
|||
}, |
|||
"endPoint": { |
|||
"x": 555, |
|||
"y": 200 |
|||
}, |
|||
"pointsList": [ |
|||
{ |
|||
"x": 470, |
|||
"y": 200 |
|||
}, |
|||
{ |
|||
"x": 555, |
|||
"y": 200 |
|||
} |
|||
], |
|||
"logicFlowType": "bpmn:sequenceFlow" |
|||
}, |
|||
"key": "Flow_0pfouf0" |
|||
}, |
|||
{ |
|||
"incoming": ["Gateway_1fngqgj"], |
|||
"outgoing": ["Activity_1sp8qc8"], |
|||
"type": 1, |
|||
"dockers": [], |
|||
"properties": { |
|||
"name": "边3", |
|||
"text": { |
|||
"x": 664, |
|||
"y": 200, |
|||
"value": "边3" |
|||
}, |
|||
"startPoint": { |
|||
"x": 605, |
|||
"y": 200 |
|||
}, |
|||
"endPoint": { |
|||
"x": 710, |
|||
"y": 200 |
|||
}, |
|||
"pointsList": [ |
|||
{ |
|||
"x": 605, |
|||
"y": 200 |
|||
}, |
|||
{ |
|||
"x": 710, |
|||
"y": 200 |
|||
} |
|||
], |
|||
"logicFlowType": "bpmn:sequenceFlow" |
|||
}, |
|||
"key": "Flow_3918lhh" |
|||
}, |
|||
{ |
|||
"incoming": ["Activity_1sp8qc8"], |
|||
"outgoing": ["Event_08p8i6q"], |
|||
"type": 1, |
|||
"dockers": [], |
|||
"properties": { |
|||
"name": "边4", |
|||
"text": { |
|||
"x": 871, |
|||
"y": 200, |
|||
"value": "边4" |
|||
}, |
|||
"startPoint": { |
|||
"x": 810, |
|||
"y": 200 |
|||
}, |
|||
"endPoint": { |
|||
"x": 902, |
|||
"y": 200 |
|||
}, |
|||
"pointsList": [ |
|||
{ |
|||
"x": 810, |
|||
"y": 200 |
|||
}, |
|||
{ |
|||
"x": 902, |
|||
"y": 200 |
|||
} |
|||
], |
|||
"logicFlowType": "bpmn:sequenceFlow" |
|||
}, |
|||
"key": "Flow_379e0o9" |
|||
} |
|||
] |
|||
} |
|||
@ -0,0 +1,43 @@ |
|||
<template> |
|||
<div class="connect"> |
|||
<p>{{name}}</p> |
|||
<p>您好,请问需要买保险吗?</p> |
|||
<div class="button-list"> |
|||
<button @mousedown.stop="done(1)">有保险了</button> |
|||
<button @mousedown.stop="done(2)">不需要</button> |
|||
<button @mousedown.stop="done(3)">需要</button> |
|||
<button @mousedown.stop="done(4)">特殊</button> |
|||
</div> |
|||
</div> |
|||
</template> |
|||
|
|||
<script> |
|||
export default { |
|||
props: { |
|||
name: String |
|||
}, |
|||
methods: { |
|||
done(type) { |
|||
this.$emit('select-button', type) |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style scoped> |
|||
.connect { |
|||
width: 100%; |
|||
height: 100%; |
|||
background: #FFF; |
|||
border: 1px solid #9a9a9b; |
|||
box-sizing: border-box; |
|||
padding: 10px; |
|||
} |
|||
.connect p { |
|||
margin: 0; |
|||
} |
|||
.button-list { |
|||
position: absolute; |
|||
bottom: 10px; |
|||
} |
|||
</style> |
|||
@ -0,0 +1,13 @@ |
|||
|
|||
// svg png 图片资源来自阿里字体库
|
|||
// [阿里字体库](https://www.iconfont.cn/collections/index?spm=a313x.7781069.1998910419.4)
|
|||
// svg图标建议使用自己创建的
|
|||
import registerStart from './registerStart' |
|||
import registerUser from './registerUser' |
|||
import registerEnd from './registerEnd' |
|||
import registerPush from './registerPush' |
|||
import registerDownload from './registerDownload' |
|||
import registerPolyline from './registerPolyline' |
|||
import registerTask from './registerTask' |
|||
import registerConnect from './registerConnect' |
|||
export { registerStart, registerUser, registerEnd, registerPush, registerDownload, registerPolyline, registerTask, registerConnect } |
|||
@ -0,0 +1,58 @@ |
|||
import Vue from 'vue' |
|||
import Connect from './Connect.vue' |
|||
|
|||
export default function registerConnect (lf) { |
|||
lf.register('connect', ({ HtmlNode, HtmlNodeModel }) => { |
|||
class ConnectNode extends HtmlNode { |
|||
shouldUpdate() { |
|||
const { properties } = this.getAttributes(); |
|||
if (this.currrentProperties && this.currrentProperties === JSON.stringify(properties)) return false; |
|||
this.currrentProperties = JSON.stringify(properties) |
|||
return true; |
|||
} |
|||
setHtml(rootEl) { |
|||
// todo: 和react不一样,还没有找到合适的利用vue内置的diff算法来计算节点是否需要更新。
|
|||
if (!this.shouldUpdate()) return; |
|||
const { properties } = this.getAttributes(); |
|||
const el = document.createElement('div'); |
|||
rootEl.innerHTML = ''; |
|||
rootEl.appendChild(el); |
|||
const Profile = Vue.extend({ |
|||
render: function (h) { |
|||
return h(Connect, { |
|||
props: { |
|||
name: properties.name |
|||
}, |
|||
on: { |
|||
'select-button': (type) => { |
|||
console.log('select-button', type) |
|||
} |
|||
} |
|||
}) |
|||
} |
|||
}) |
|||
new Profile().$mount(el) |
|||
} |
|||
} |
|||
class ConnectNodeModel extends HtmlNodeModel { |
|||
setAttributes() { |
|||
this.text.editable = false; |
|||
const width = 300; |
|||
const height = 150; |
|||
this.width = width; |
|||
this.height = height; |
|||
|
|||
this.anchorsOffset = [ |
|||
[width / 2, 0], |
|||
[0, height / 2], |
|||
[-width / 2, 0], |
|||
[0, -height/2], |
|||
] |
|||
} |
|||
} |
|||
return { |
|||
view: ConnectNode, |
|||
model: ConnectNodeModel |
|||
} |
|||
}) |
|||
} |
|||
@ -0,0 +1,92 @@ |
|||
const NODE_COLOR = '#9932CC' |
|||
export default function registerDownload(lf) { |
|||
lf.register('download', ({ PolygonNode, PolygonNodeModel, h }) => { |
|||
class Node extends PolygonNode { |
|||
getIconShape () { |
|||
return h( |
|||
'svg', |
|||
{ |
|||
x: 14, |
|||
y: 13, |
|||
width: 23, |
|||
height: 23, |
|||
viewBox: '0 0 1024 1024' |
|||
}, |
|||
h( |
|||
'path', |
|||
{ |
|||
fill: NODE_COLOR, |
|||
d: 'M831.513034 319.863005h-95.945189c-17.662265 0-31.980365 14.3181-31.980365 31.980365 0 17.662265 14.3181 31.980365 31.980365 31.980366h64.218604c17.520025 0 31.722492 14.202467 31.722492 31.722492V863.786065c0 17.520025-14.202467 31.722492-31.722492 31.722492H159.66442c-17.520025 0-31.722492-14.202467-31.722493-31.722492V415.546228c0-17.520025 14.202467-31.722492 31.722493-31.722492h64.218603c17.662265 0 31.980365-14.3181 31.980366-31.980366 0-17.662265-14.3181-31.980365-31.980366-31.980365H127.937834c-35.322483 0-63.956637 28.634154-63.956637 63.956637v511.693008c0 35.322483 28.634154 63.956637 63.956637 63.956638h703.5752c35.322483 0 63.956637-28.634154 63.956638-63.956638V383.819642c0-35.32146-28.634154-63.956637-63.956638-63.956637z' |
|||
} |
|||
), |
|||
h( |
|||
'path', |
|||
{ |
|||
fill: NODE_COLOR, |
|||
d: 'M310.382073 521.036817c-12.388145-12.388145-32.473599-12.388145-44.862767 0l-0.364297 0.364297c-12.388145 12.388145-12.388145 32.473599 0 44.862767l190.186573 190.186574c5.818519 6.813173 14.465456 11.137665 24.126491 11.137664h0.515746c9.662057 0 18.307971-4.324492 24.12649-11.137664L694.296883 566.263881c12.388145-12.388145 12.388145-32.473599 0-44.862767l-0.364297-0.364297c-12.388145-12.388145-32.473599-12.388145-44.862767 0L511.706311 658.400325V95.743598c0-17.520025-14.202467-31.722492-31.722492-31.722492h-0.515746c-17.520025 0-31.722492 14.202467-31.722493 31.722492v562.656727L310.382073 521.036817z' |
|||
} |
|||
) |
|||
) |
|||
} |
|||
getShape () { |
|||
const attributes = this.getAttributes() |
|||
const { |
|||
width, |
|||
height, |
|||
x, |
|||
y, |
|||
fill, |
|||
fillOpacity, |
|||
strokeWidth, |
|||
stroke, |
|||
strokeOpacity, |
|||
points |
|||
} = attributes |
|||
const transform = `matrix(1 0 0 1 ${x - width / 2} ${y - height / 2})` |
|||
const pointsPath = points.map(point => point.join(',')).join(' ') |
|||
return h( |
|||
'g', |
|||
{ |
|||
transform |
|||
}, |
|||
[ |
|||
h( |
|||
'polygon', |
|||
{ |
|||
points: pointsPath, |
|||
fill, |
|||
stroke, |
|||
strokeWidth, |
|||
strokeOpacity, |
|||
fillOpacity |
|||
} |
|||
), |
|||
this.getIconShape() |
|||
] |
|||
) |
|||
} |
|||
} |
|||
class Model extends PolygonNodeModel { |
|||
constructor (data, graphModel) { |
|||
data.text = { |
|||
value: (data.text && data.text.value) || '', |
|||
x: data.x, |
|||
y: data.y + 50 |
|||
} |
|||
super(data, graphModel) |
|||
const lenght = 25 |
|||
this.points = [ |
|||
[lenght, 0], |
|||
[lenght * 2, lenght], |
|||
[lenght, lenght * 2], |
|||
[0, lenght] |
|||
] |
|||
this.stroke = NODE_COLOR |
|||
} |
|||
} |
|||
return { |
|||
view: Node, |
|||
model: Model |
|||
} |
|||
}) |
|||
} |
|||
@ -0,0 +1,101 @@ |
|||
export default function registerEnd (lf) { |
|||
lf.register('end', ({ CircleNode, CircleNodeModel, h }) => { |
|||
class EndNode extends CircleNode { |
|||
getIconShape () { |
|||
const attributes = this.getAttributes() |
|||
const { |
|||
x, |
|||
y, |
|||
width, |
|||
height |
|||
} = attributes |
|||
const stroke = '#404040' |
|||
return h( |
|||
'svg', |
|||
{ |
|||
x: x - width / 2, |
|||
y: y - height / 2, |
|||
width: 40, |
|||
height: 40, |
|||
viewBox: '0 0 1024 1024' |
|||
}, |
|||
h( |
|||
'path', |
|||
{ |
|||
fill: stroke, |
|||
d: 'M212.992 526.336 212.992 526.336 212.992 526.336 215.04 526.336 212.992 526.336Z' |
|||
} |
|||
), |
|||
// 圆形外框隐藏
|
|||
// h(
|
|||
// 'path',
|
|||
// {
|
|||
// fill: stroke,
|
|||
// d: 'M817.152 202.752 817.152 202.752C737.28 122.88 628.736 75.776 509.952 75.776c-118.784 0-229.376 49.152-307.2 126.976l0 0c-77.824 77.824-126.976 186.368-126.976 307.2 0 118.784 49.152 229.376 126.976 307.2 77.824 79.872 188.416 126.976 307.2 126.976 120.832 0 229.376-49.152 307.2-126.976 79.872-77.824 126.976-186.368 126.976-307.2C946.176 389.12 897.024 280.576 817.152 202.752zM770.048 770.048c-65.536 65.536-157.696 108.544-260.096 108.544-102.4 0-194.56-40.96-260.096-108.544C184.32 704.512 141.312 612.352 141.312 509.952s40.96-194.56 108.544-260.096C317.44 184.32 409.6 141.312 509.952 141.312c100.352 0 192.512 40.96 258.048 106.496l2.048 2.048c65.536 65.536 108.544 157.696 108.544 260.096S837.632 704.512 770.048 770.048z'
|
|||
// }
|
|||
// ),
|
|||
h( |
|||
'path', |
|||
{ |
|||
fill: stroke, |
|||
d: 'M724.992 296.96 724.992 296.96 296.96 296.96 296.96 724.992 724.992 724.992 724.992 296.96Z' |
|||
} |
|||
) |
|||
) |
|||
} |
|||
getShape () { |
|||
const attributes = this.getAttributes() |
|||
const { |
|||
x, |
|||
y, |
|||
r, |
|||
fill, |
|||
stroke, |
|||
strokeWidth |
|||
} = attributes |
|||
return h( |
|||
'g', |
|||
{ |
|||
}, |
|||
[ |
|||
h( |
|||
'circle', |
|||
{ |
|||
cx: x, |
|||
cy: y, |
|||
r, |
|||
fill, |
|||
stroke, |
|||
strokeWidth |
|||
} |
|||
), |
|||
this.getIconShape() |
|||
] |
|||
) |
|||
} |
|||
} |
|||
class EndModel extends CircleNodeModel { |
|||
constructor (data, graphModel) { |
|||
data.text = { |
|||
value: (data.text && data.text.value) || '', |
|||
x: data.x, |
|||
y: data.y + 35 |
|||
} |
|||
super(data, graphModel) |
|||
} |
|||
getConnectedSourceRules () { |
|||
const rules = super.getConnectedSourceRules() |
|||
const notAsTarget = { |
|||
message: '终止节点不能作为连线的起点', |
|||
validate: () => false |
|||
} |
|||
rules.push(notAsTarget) |
|||
return rules |
|||
} |
|||
} |
|||
return { |
|||
view: EndNode, |
|||
model: EndModel |
|||
} |
|||
}) |
|||
} |
|||
@ -0,0 +1,13 @@ |
|||
export default function registerPolyline (lf) { |
|||
lf.register('polyline', ({ PolylineEdge, PolylineEdgeModel }) => { |
|||
class ConnnectionModel extends PolylineEdgeModel { |
|||
constructor (data, graphModel) { |
|||
super(data, graphModel) |
|||
} |
|||
} |
|||
return { |
|||
view: PolylineEdge, |
|||
model: ConnnectionModel |
|||
} |
|||
}) |
|||
} |
|||
@ -0,0 +1,139 @@ |
|||
export default function registerPush (lf, clickPlus, mouseDownPlus) { |
|||
lf.register('push', ({ PolygonNode, PolygonNodeModel, h }) => { |
|||
class Node extends PolygonNode { |
|||
getIconShape () { |
|||
const attributes = this.getAttributes() |
|||
const { |
|||
stroke |
|||
} = attributes |
|||
return h( |
|||
'svg', |
|||
{ |
|||
x: 18, |
|||
y: 18, |
|||
width: 30, |
|||
height: 30, |
|||
viewBox: '0 0 1024 1024' |
|||
}, |
|||
h( |
|||
'path', |
|||
{ |
|||
fill: stroke, |
|||
d: 'M866.461538 39.384615H393.846154c-43.323077 0-78.769231 35.446154-78.769231 78.769231v1.969231c0 13.784615 7.876923 27.569231 19.692308 35.446154 5.907692 3.938462 80.738462 78.769231 80.738461 78.769231 5.907692 5.907692 15.753846 0 15.753846-7.876924 0-15.753846 13.784615-31.507692 29.538462-31.507692h334.769231c15.753846 0 31.507692 15.753846 31.507692 31.507692v531.692308c0 15.753846-15.753846 27.569231-31.507692 27.569231h-334.769231c-15.753846 0-27.569231-11.815385-27.569231-27.569231v-1.969231c0-7.876923-9.846154-11.815385-15.753846-5.907692 0 0-74.830769 74.830769-82.707692 78.769231-11.815385 7.876923-19.692308 19.692308-19.692308 35.446154v39.384615c0 43.323077 33.476923 78.769231 76.8 78.769231h472.615385c43.323077 0 80.738462-35.446154 80.738461-78.769231V118.153846c0-43.323077-35.446154-78.769231-78.769231-78.769231zM630.153846 945.230769c-33.476923 0-59.076923-25.6-59.076923-59.076923s25.6-59.076923 59.076923-59.076923 59.076923 25.6 59.076923 59.076923-25.6 59.076923-59.076923 59.076923z m-86.646154-474.584615L297.353846 224.492308c-11.815385-11.815385-29.538462-11.815385-41.353846 0l-41.353846 41.353846c-11.815385 11.815385-11.815385 29.538462 0 41.353846l90.584615 90.584615c11.815385 11.815385 3.938462 33.476923-13.784615 33.476923H29.538462c-15.753846 1.969231-29.538462 15.753846-29.538462 31.507693v59.076923c0 15.753846 13.784615 29.538462 29.538462 29.538461h259.938461c17.723077 0 25.6 21.661538 13.784615 33.476923l-90.584615 90.584616c-11.815385 11.815385-11.815385 29.538462 0 41.353846l41.353846 41.353846c11.815385 11.815385 29.538462 11.815385 41.353846 0L543.507692 512c9.846154-9.846154 9.846154-29.538462 0-41.353846z' |
|||
} |
|||
) |
|||
) |
|||
} |
|||
getPulsShape () { |
|||
const attributes = this.getAttributes() |
|||
// 判断当前节点是否子节点
|
|||
const graphData = lf.getGraphData() |
|||
const edges = graphData.edges |
|||
let hasChildNode = false |
|||
edges.some(item => { |
|||
if (item.sourceNodeId === attributes.id) { |
|||
hasChildNode = true |
|||
return true |
|||
} |
|||
}) |
|||
if (hasChildNode) { |
|||
return |
|||
} |
|||
return h( |
|||
'svg', |
|||
{ |
|||
x: 70, |
|||
y: 20, |
|||
width: 30, |
|||
height: 30, |
|||
viewBox: '0 0 1024 1024', |
|||
class: 'time-plus', |
|||
onClick: (e) => clickPlus(e, attributes), |
|||
onMousedown: (e) => mouseDownPlus(e, attributes), |
|||
onMouseUp: (e) => mouseDownPlus(e, attributes) |
|||
}, |
|||
h( |
|||
'path', |
|||
{ |
|||
fill: '#f17611', |
|||
d: 'M512 512m-448 0a448 448 0 1 0 896 0 448 448 0 1 0-896 0Z' |
|||
} |
|||
), |
|||
h( |
|||
'path', |
|||
{ |
|||
fill: '#ffffff', |
|||
d: 'M448 298.666667h128v426.666666h-128z' |
|||
} |
|||
), |
|||
h( |
|||
'path', |
|||
{ |
|||
fill: '#ffffff', |
|||
d: 'M298.666667 448h426.666666v128H298.666667z' |
|||
} |
|||
) |
|||
) |
|||
} |
|||
getShape () { |
|||
const attributes = this.getAttributes() |
|||
const { |
|||
width, |
|||
height, |
|||
x, |
|||
y, |
|||
fill, |
|||
fillOpacity, |
|||
strokeWidth, |
|||
stroke, |
|||
strokeOpacity, |
|||
points |
|||
} = attributes |
|||
const transform = `matrix(1 0 0 1 ${x - width / 2} ${y - height / 2})` |
|||
const pointsPath = points.map(point => point.join(',')).join(' ') |
|||
return h( |
|||
'g', |
|||
{ |
|||
transform |
|||
}, |
|||
[ |
|||
h( |
|||
'polygon', |
|||
{ |
|||
points: pointsPath, |
|||
fill, |
|||
stroke, |
|||
strokeWidth, |
|||
strokeOpacity, |
|||
fillOpacity |
|||
} |
|||
), |
|||
this.getIconShape(), |
|||
this.getPulsShape() |
|||
] |
|||
) |
|||
} |
|||
} |
|||
class Model extends PolygonNodeModel { |
|||
constructor (data, graphModel) { |
|||
data.text = { |
|||
value: (data.text && data.text.value) || '', |
|||
x: data.x, |
|||
y: data.y + 50 |
|||
} |
|||
super(data, graphModel) |
|||
const lenght = 35 |
|||
this.points = [ |
|||
[lenght, 0], |
|||
[lenght * 2, lenght], |
|||
[lenght, lenght * 2], |
|||
[0, lenght] |
|||
] |
|||
} |
|||
} |
|||
return { |
|||
view: Node, |
|||
model: Model |
|||
} |
|||
}) |
|||
} |
|||
@ -0,0 +1,80 @@ |
|||
export default function registerStart (lf) { |
|||
lf.register('start', ({ CircleNode, CircleNodeModel, h }) => { |
|||
class StartNode extends CircleNode { |
|||
getLabelShape () { |
|||
const attributes = this.getAttributes() |
|||
const { |
|||
x, |
|||
y |
|||
} = attributes |
|||
return h( |
|||
'text', |
|||
{ |
|||
fill: '#000000', |
|||
fontSize: 12, |
|||
x: x - 12, |
|||
y: y + 4, |
|||
width: 50, |
|||
height: 25 |
|||
}, |
|||
'Start' |
|||
) |
|||
} |
|||
getShape () { |
|||
const attributes = this.getAttributes() |
|||
const { |
|||
x, |
|||
y, |
|||
r, |
|||
fill, |
|||
stroke, |
|||
strokeWidth |
|||
} = attributes |
|||
return h( |
|||
'g', |
|||
{ |
|||
}, |
|||
[ |
|||
h( |
|||
'circle', |
|||
{ |
|||
cx: x, |
|||
cy: y, |
|||
r, |
|||
fill, |
|||
stroke, |
|||
strokeWidth |
|||
} |
|||
), |
|||
this.getLabelShape() |
|||
] |
|||
) |
|||
} |
|||
} |
|||
class StartModel extends CircleNodeModel { |
|||
constructor (data, graphModel) { |
|||
data.text = { |
|||
value: (data.text && data.text.value) || '', |
|||
x: data.x, |
|||
y: data.y + 35, |
|||
dragable: false, |
|||
editable: true |
|||
} |
|||
super(data, graphModel) |
|||
} |
|||
getConnectedTargetRules () { |
|||
const rules = super.getConnectedTargetRules() |
|||
const notAsTarget = { |
|||
message: '起始节点不能作为连线的终点', |
|||
validate: () => false |
|||
} |
|||
rules.push(notAsTarget) |
|||
return rules |
|||
} |
|||
} |
|||
return { |
|||
view: StartNode, |
|||
model: StartModel |
|||
} |
|||
}) |
|||
} |
|||
@ -0,0 +1,30 @@ |
|||
export default function registerTask (lf) { |
|||
lf.register('task', ({ RectNode, RectNodeModel, h }) => { |
|||
class View extends RectNode { |
|||
getShape() { |
|||
const style = this.getShapeStyle(); |
|||
console.log(style); |
|||
const { width, height } = style; |
|||
const { x, y } = this.getAttributes(); |
|||
const position = { |
|||
x: x - width / 2, |
|||
y: y- height / 2, |
|||
} |
|||
return h("rect", { |
|||
...style, |
|||
...position, |
|||
}); |
|||
} |
|||
} |
|||
class Model extends RectNodeModel { |
|||
constructor (data, graphModel) { |
|||
super(data, graphModel) |
|||
this.radius = 20; |
|||
} |
|||
} |
|||
return { |
|||
view: View, |
|||
model: Model |
|||
} |
|||
}) |
|||
} |
|||
@ -0,0 +1,112 @@ |
|||
export default function registerUser (lf) { |
|||
lf.register('user', ({ PolygonNode, PolygonNodeModel, h }) => { |
|||
class Node extends PolygonNode { |
|||
getIconShape () { |
|||
const attributes = this.getAttributes() |
|||
const { |
|||
stroke |
|||
} = attributes |
|||
return h( |
|||
'svg', |
|||
{ |
|||
x: 20, |
|||
y: 18, |
|||
width: 30, |
|||
height: 30, |
|||
viewBox: '0 0 1126 1024' |
|||
}, |
|||
h( |
|||
'path', |
|||
{ |
|||
fill: stroke, |
|||
d: 'M792.576 379.392a25.6 25.6 0 0 0 25.2928 25.8048h283.2384A25.6 25.6 0 0 0 1126.4 379.392a25.6 25.6 0 0 0-25.2928-25.8048h-283.2384a25.6 25.6 0 0 0-25.344 25.8048z m303.9232 80.7424H761.856c-16.5376 0-29.9008 11.6224-29.9008 25.7536 0 14.1824 13.312 25.7536 29.9008 25.7536h334.6432c16.4864 0 29.9008-11.5712 29.9008-25.7536 0-14.1312-13.4144-25.7536-29.9008-25.7536z m4.608 106.496h-283.2384a25.6 25.6 0 0 0-25.344 25.7536 25.6 25.6 0 0 0 25.344 25.7536h283.2384A25.6 25.6 0 0 0 1126.4 592.384a25.6 25.6 0 0 0-25.2928-25.8048zM543.0272 1024H341.6576C150.8352 1024 0 1024 0 923.648v-20.1216c0-188.16 153.2928-341.1968 341.7088-341.1968h201.2672c188.416 0 341.76 153.0368 341.76 341.1968v20.0704C884.6848 1024 726.3232 1024 542.976 1024z m-203.1616-405.1456c-158.464 0-287.4368 128.4096-287.4368 286.208v20.48c0 40.9088 166.0928 40.9088 287.4368 40.9088h204.9536c100.4544 0 287.4368 0 287.4368-40.96v-20.3776c0-157.8496-128.9728-286.208-287.4368-286.208H339.8656z m92.416-76.7488a271.4112 271.4112 0 0 1-271.2064-271.0528A271.36 271.36 0 0 1 432.2816 0a271.36 271.36 0 0 1 271.2064 271.0528 271.4624 271.4624 0 0 1-271.2064 271.0528z m-215.3472-271.872c0 118.1696 96.6144 214.3232 215.3472 214.3232 118.784 0 215.3984-96.1536 215.3984-214.3232 0-118.2208-96.6144-214.3232-215.3984-214.3232S216.9344 152.0128 216.9344 270.2336z' |
|||
} |
|||
) |
|||
) |
|||
} |
|||
getShape () { |
|||
const attributes = this.getAttributes() |
|||
const { |
|||
width, |
|||
height, |
|||
x, |
|||
y, |
|||
fill, |
|||
fillOpacity, |
|||
strokeWidth, |
|||
stroke, |
|||
strokeOpacity, |
|||
points |
|||
} = attributes |
|||
const transform = `matrix(1 0 0 1 ${x - width / 2} ${y - height / 2})` |
|||
const pointsPath = points.map(point => point.join(',')).join(' ') |
|||
return h( |
|||
'g', |
|||
{ |
|||
transform |
|||
}, |
|||
[ |
|||
h( |
|||
'polygon', |
|||
{ |
|||
points: pointsPath, |
|||
fill, |
|||
stroke, |
|||
strokeWidth, |
|||
strokeOpacity, |
|||
fillOpacity |
|||
} |
|||
), |
|||
this.getIconShape() |
|||
] |
|||
) |
|||
} |
|||
} |
|||
class Model extends PolygonNodeModel { |
|||
constructor (data, graphModel) { |
|||
data.text = { |
|||
value: (data.text && data.text.value) || '', |
|||
x: data.x, |
|||
y: data.y + 50 |
|||
} |
|||
super(data, graphModel) |
|||
const lenght = 35 |
|||
this.points = [ |
|||
[lenght, 0], |
|||
[lenght * 2, lenght], |
|||
[lenght, lenght * 2], |
|||
[0, lenght] |
|||
] |
|||
// 右键菜单自由配置,也可以通过边的properties或者其他属性条件更换不同菜单
|
|||
this.menu = [ |
|||
{ |
|||
className: 'lf-menu-delete', |
|||
text: 'delete', |
|||
callback (node) { |
|||
// const comfirm = window.confirm('你确定要删除吗?')
|
|||
lf.deleteNode(node.id) |
|||
} |
|||
}, |
|||
{ |
|||
text: 'edit', |
|||
className: 'lf-menu-item', |
|||
callback (node) { |
|||
lf.editNodeText(node.id) |
|||
} |
|||
}, |
|||
{ |
|||
text: 'copy', |
|||
className: 'lf-menu-item', |
|||
callback (node) { |
|||
lf.cloneNode(node.id) |
|||
} |
|||
} |
|||
] |
|||
} |
|||
} |
|||
return { |
|||
view: Node, |
|||
model: Model |
|||
} |
|||
}) |
|||
} |
|||
@ -0,0 +1,20 @@ |
|||
import translate from '../bpmn1/translate'; |
|||
|
|||
|
|||
export default function customTranslate(template, replacements) { |
|||
replacements = replacements || {}; |
|||
|
|||
// Translate
|
|||
template = translate[template] || template; |
|||
|
|||
// Replace
|
|||
return template.replace(/{([^}]+)}/g, function(_, key) { |
|||
|
|||
var str=replacements[key]; |
|||
if(translate[replacements[key]]!=null&&translate[replacements[key]]!='undefined'){ |
|||
str=translate[replacements[key]]; |
|||
} |
|||
return str || '{' + key + '}'; |
|||
|
|||
}); |
|||
} |
|||
@ -0,0 +1,210 @@ |
|||
<template> |
|||
<div class="processDrawBody"> |
|||
<el-button-group> |
|||
<el-button size="mini" @click="showProcessInfo">xml数据</el-button> |
|||
<el-button type="primary" size="mini" @click="handleUndo">撤销</el-button> |
|||
<el-button type="success" size="mini" @click="handleRedo">恢复</el-button> |
|||
<el-button type="warning" size="mini" @click="handleDownload">下载</el-button> |
|||
<el-upload |
|||
style="display: inline-block;" |
|||
:file-list="fileList" |
|||
class="upload-demo" |
|||
action="" |
|||
:auto-upload="false" |
|||
:show-file-list="false" |
|||
:http-request="httpRequest" |
|||
:on-change="handleOnchangeFile" |
|||
:on-remove="handleRemove" |
|||
:before-remove="beforeRemove" |
|||
> |
|||
<el-button type="danger" size="mini">导入</el-button> |
|||
</el-upload> |
|||
</el-button-group> |
|||
<div class="containerBox" style="position: relative;"> |
|||
<div id="container"> |
|||
</div> |
|||
<div id="js-properties-panel" class="panel"></div> |
|||
</div> |
|||
</div> |
|||
</template> |
|||
<script> |
|||
import CustomTranslate from '../bpmn1/CustomTranslate'; |
|||
|
|||
import { markRaw } from 'vue'; |
|||
// bpmn-js相关 |
|||
import 'bpmn-js/dist/assets/diagram-js.css'; |
|||
import 'bpmn-js/dist/assets/bpmn-font/css/bpmn-embedded.css'; |
|||
import BpmnModeler from 'bpmn-js/lib/Modeler'; |
|||
// bpmn-js-properties-panel相关 |
|||
import 'bpmn-js-properties-panel/dist/assets/bpmn-js-properties-panel.css' |
|||
import propertiesPanelModule from 'bpmn-js-properties-panel' |
|||
import propertiesProviderModule from 'bpmn-js-properties-panel/lib/provider/camunda' |
|||
import camundaModdleDescriptor from 'camunda-bpmn-moddle/resources/camunda' |
|||
// 其他 |
|||
// import { processDeployment, getProcessXml } from "@/api/index.js"; |
|||
export default { |
|||
props: ['deploymentId'], |
|||
data() { |
|||
return { |
|||
containerEl: null, |
|||
bpmnModeler: null, |
|||
fileList: [] |
|||
}; |
|||
}, |
|||
mounted() { |
|||
// 初始化流程图 |
|||
this.init(); |
|||
}, |
|||
methods: { |
|||
/** |
|||
* 初始化流程图 |
|||
*/ |
|||
init() { |
|||
// 汉化 |
|||
var customTranslate = { |
|||
translate: ['value', CustomTranslate] |
|||
}; |
|||
this.containerEl = document.getElementById('container'); |
|||
// 加markRaw去除双向绑定作用域 |
|||
this.bpmnModeler = markRaw(new BpmnModeler({ |
|||
container: this.containerEl, |
|||
// 添加控制板 |
|||
propertiesPanel: { |
|||
parent: '#js-properties-panel' |
|||
}, |
|||
// 右侧属性面板 |
|||
additionalModules: [ |
|||
|
|||
propertiesPanelModule, |
|||
propertiesProviderModule, |
|||
customTranslate |
|||
], |
|||
moddleExtensions: { |
|||
camunda: camundaModdleDescriptor |
|||
} |
|||
})); |
|||
this.bpmnModeler.createDiagram(() => { |
|||
this.bpmnModeler.get('canvas').zoom('fit-viewport'); |
|||
}); |
|||
let _this = this; |
|||
// 如果deploymentId存在,则为编辑,导入xml信息 |
|||
if (_this.deploymentId) { |
|||
getProcessXml({"deploymentId":_this.deploymentId}) |
|||
.then((res) => { |
|||
_this.bpmnModeler.importXML(res.data, (err) => { |
|||
this.$message.success('加载成功!'); |
|||
}); |
|||
}) |
|||
.catch((error) => { |
|||
this.$message.error('获取流程信息失败'); |
|||
}); |
|||
} |
|||
}, |
|||
handleRemove(file) { |
|||
for (let i = 0; i < this.fileList.length; i++) { |
|||
if (file.name === this.fileList[i].name) { |
|||
this.fileList.splice(i, 1); |
|||
} |
|||
} |
|||
}, |
|||
beforeRemove(file) { |
|||
return this.$confirm(`确定移除 ${file.name}?`); |
|||
}, |
|||
// 后退 |
|||
handleUndo() { |
|||
this.bpmnModeler.get('commandStack').undo(); |
|||
}, |
|||
// 前进 |
|||
handleRedo() { |
|||
this.bpmnModeler.get('commandStack').redo(); |
|||
}, |
|||
// 下载 |
|||
handleDownload() { |
|||
this.bpmnModeler.saveXML({format: true}, (err, data) => { |
|||
const dataTrack = 'bpmn'; |
|||
const a = document.createElement('a'); |
|||
const name = `diagram.${dataTrack}`; |
|||
a.setAttribute( |
|||
'href', |
|||
`data:application/bpmn20-xml;charset=UTF-8,${encodeURIComponent(data)}` |
|||
); |
|||
a.setAttribute('target', '_blank'); |
|||
a.setAttribute('dataTrack', `diagram:download-${dataTrack}`); |
|||
a.setAttribute('download', name); |
|||
document.body.appendChild(a); |
|||
a.click(); |
|||
document.body.removeChild(a); |
|||
}); |
|||
}, |
|||
// 导入成功回调 |
|||
handleOnchangeFile(file) { |
|||
const reader = new FileReader(); |
|||
let data = ''; |
|||
reader.readAsText(file.raw); |
|||
reader.onload = (event) => { |
|||
data = event.target.result; |
|||
this.bpmnModeler.importXML(data, (err) => { |
|||
debugger |
|||
if (err) { |
|||
this.$message.info('导入失败'); |
|||
} else { |
|||
this.$message.success('导入成功'); |
|||
} |
|||
}); |
|||
}; |
|||
}, |
|||
// 取xml信息 |
|||
showProcessInfo() { |
|||
this.bpmnModeler.saveXML({format: true}, (err, data) => { |
|||
alert(data); |
|||
}); |
|||
}, |
|||
/** |
|||
* 保存 |
|||
*/ |
|||
save() { |
|||
this.bpmnModeler.saveXML({format: true}, (err, data) => { |
|||
let processInfo = {}; |
|||
processInfo.xml = data.replace(/camunda/ig,"activiti"); |
|||
processInfo.processId = document.getElementById("camunda-id").value; |
|||
processInfo.processName = document.getElementById("camunda-name").innerHTML; |
|||
processDeployment(processInfo) |
|||
.then((res) => { |
|||
console.log(res); |
|||
}) |
|||
.catch((error) => { |
|||
console.log(error); |
|||
}); |
|||
}); |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
<style> |
|||
.processDrawBody { |
|||
height: 100%; |
|||
text-align: left; |
|||
} |
|||
.containerBox { |
|||
height: 600px; |
|||
} |
|||
.containerBox #container { |
|||
height: 100%; |
|||
border: 1px solid rgb(121, 121, 121); |
|||
} |
|||
.bpp-properties-panel [type=text] { |
|||
box-sizing: border-box; |
|||
} |
|||
.panel { |
|||
width: 400px; |
|||
position: absolute; |
|||
top: 1px; |
|||
right: 1px; |
|||
height:100%; |
|||
overflow: auto; |
|||
} |
|||
/* 右下角logo */ |
|||
.bjs-powered-by { |
|||
display: none; |
|||
} |
|||
</style> |
|||
@ -0,0 +1,258 @@ |
|||
export default { |
|||
'Activate the global connect tool': '激活全局连接工具', |
|||
'Append {type}': '添加 {type}', |
|||
'Add Lane above': '在上面添加道', |
|||
'Divide into two Lanes': '分割成两个道', |
|||
'Divide into three Lanes': '分割成三个道', |
|||
'Add Lane below': '在下面添加道', |
|||
'Append compensation activity': '追加补偿活动', |
|||
'Change type': '修改类型', |
|||
'Connect using Association': '使用关联连接', |
|||
'Connect using Sequence/MessageFlow or Association': '使用顺序/消息流或者关联连接', |
|||
'Connect using DataInputAssociation': '使用数据输入关联连接', |
|||
'Remove': '移除', |
|||
'Activate the hand tool': '激活抓手工具', |
|||
'Activate the lasso tool': '激活套索工具', |
|||
'Activate the create/remove space tool': '激活创建/删除空间工具', |
|||
'Create expanded SubProcess': '创建扩展子过程', |
|||
'Create IntermediateThrowEvent/BoundaryEvent': '创建中间抛出事件/边界事件', |
|||
'Create Pool/Participant': '创建池/参与者', |
|||
'Create Group':'创建组', |
|||
'Parallel Multi Instance': '并行多重事件', |
|||
'Sequential Multi Instance': '时序多重事件', |
|||
'DataObjectReference': '数据对象参考', |
|||
'DataStoreReference': '数据存储参考', |
|||
'Loop': '循环', |
|||
'Ad-hoc': '即席', |
|||
'Create {type}': '创建 {type}', |
|||
'Task': '任务', |
|||
'Send Task': '发送任务', |
|||
'Receive Task': '接收任务', |
|||
'User Task': '用户任务', |
|||
'Manual Task': '手工任务', |
|||
'Business Rule Task': '业务规则任务', |
|||
'Service Task': '服务任务', |
|||
'Script Task': '脚本任务', |
|||
'Call Activity': '调用活动', |
|||
'Sub Process (collapsed)': '子流程(折叠的)', |
|||
'Sub Process (expanded)': '子流程(展开的)', |
|||
'Start Event': '开始事件', |
|||
'StartEvent': '开始事件', |
|||
'Intermediate Throw Event': '中间事件', |
|||
'End Event': '结束事件', |
|||
'EndEvent': '结束事件', |
|||
'Create Gateway': '创建网关', |
|||
'Create ExclusiveGateway': '创建互斥网关', |
|||
'Create ParallelGateway': '创建并行网关', |
|||
'Create InclusiveGateway': '创建相容网关', |
|||
'Create ComplexGateway': '创建复杂网关', |
|||
'Create EventbasedGateway': '创建事件网关', |
|||
'Create Intermediate/Boundary Event': '创建中间/边界事件', |
|||
'Message Start Event': '消息开始事件', |
|||
'Timer Start Event': '定时开始事件', |
|||
'Conditional Start Event': '条件开始事件', |
|||
'Signal Start Event': '信号开始事件', |
|||
'Error Start Event': '错误开始事件', |
|||
'Escalation Start Event': '升级开始事件', |
|||
'Compensation Start Event': '补偿开始事件', |
|||
'Message Start Event (non-interrupting)': '消息开始事件(非中断)', |
|||
'Timer Start Event (non-interrupting)': '定时开始事件(非中断)', |
|||
'Conditional Start Event (non-interrupting)': '条件开始事件(非中断)', |
|||
'Signal Start Event (non-interrupting)': '信号开始事件(非中断)', |
|||
'Escalation Start Event (non-interrupting)': '升级开始事件(非中断)', |
|||
'Message Intermediate Catch Event': '消息中间捕获事件', |
|||
'Message Intermediate Throw Event': '消息中间抛出事件', |
|||
'Timer Intermediate Catch Event': '定时中间捕获事件', |
|||
'Escalation Intermediate Throw Event': '升级中间抛出事件', |
|||
'Conditional Intermediate Catch Event': '条件中间捕获事件', |
|||
'Link Intermediate Catch Event': '链接中间捕获事件', |
|||
'Link Intermediate Throw Event': '链接中间抛出事件', |
|||
'Compensation Intermediate Throw Event': '补偿中间抛出事件', |
|||
'Signal Intermediate Catch Event': '信号中间捕获事件', |
|||
'Signal Intermediate Throw Event': '信号中间抛出事件', |
|||
'Message End Event': '消息结束事件', |
|||
'Escalation End Event': '定时结束事件', |
|||
'Error End Event': '错误结束事件', |
|||
'Cancel End Event': '取消结束事件', |
|||
'Compensation End Event': '补偿结束事件', |
|||
'Signal End Event': '信号结束事件', |
|||
'Terminate End Event': '终止结束事件', |
|||
'Message Boundary Event': '消息边界事件', |
|||
'Message Boundary Event (non-interrupting)': '消息边界事件(非中断)', |
|||
'Timer Boundary Event': '定时边界事件', |
|||
'Timer Boundary Event (non-interrupting)': '定时边界事件(非中断)', |
|||
'Escalation Boundary Event': '升级边界事件', |
|||
'Escalation Boundary Event (non-interrupting)': '升级边界事件(非中断)', |
|||
'Conditional Boundary Event': '条件边界事件', |
|||
'Conditional Boundary Event (non-interrupting)': '条件边界事件(非中断)', |
|||
'Error Boundary Event': '错误边界事件', |
|||
'Cancel Boundary Event': '取消边界事件', |
|||
'Signal Boundary Event': '信号边界事件', |
|||
'Signal Boundary Event (non-interrupting)': '信号边界事件(非中断)', |
|||
'Compensation Boundary Event': '补偿边界事件', |
|||
'Exclusive Gateway': '互斥网关', |
|||
'Parallel Gateway': '并行网关', |
|||
'Inclusive Gateway': '相容网关', |
|||
'Complex Gateway': '复杂网关', |
|||
'Event based Gateway': '事件网关', |
|||
'Transaction': '转运', |
|||
'Sub Process': '子流程', |
|||
'Event Sub Process': '事件子流程', |
|||
'Collapsed Pool': '折叠池', |
|||
'Expanded Pool': '展开池', |
|||
|
|||
// Errors
|
|||
'no parent for {element} in {parent}': '在{parent}里,{element}没有父类', |
|||
'no shape type specified': '没有指定的形状类型', |
|||
'flow elements must be children of pools/participants': '流元素必须是池/参与者的子类', |
|||
'out of bounds release': 'out of bounds release', |
|||
'more than {count} child lanes': '子道大于{count} ', |
|||
'element required': '元素不能为空', |
|||
'diagram not part of bpmn:Definitions': '流程图不符合bpmn规范', |
|||
'no diagram to display': '没有可展示的流程图', |
|||
'no process or collaboration to display': '没有可展示的流程/协作', |
|||
'element {element} referenced by {referenced}#{property} not yet drawn': '由{referenced}#{property}引用的{element}元素仍未绘制', |
|||
'already rendered {element}': '{element} 已被渲染', |
|||
'failed to import {element}': '导入{element}失败', |
|||
'Id must be a valid QName.':'编号必须以字母或下划线开头', |
|||
'Element must have an unique id.':'元素必须具有唯一的id', |
|||
|
|||
//属性面板的参数
|
|||
'zjId': '自己编号', |
|||
'Id': '编号', |
|||
'Name': '名称', |
|||
'General': '常规', |
|||
'Details': '详情', |
|||
'Message Name': '消息名称', |
|||
'Message': '消息', |
|||
'Initiator': '创建者', |
|||
'Asynchronous Continuations': '持续异步', |
|||
'Asynchronous Before': '异步前', |
|||
'Asynchronous After': '异步后', |
|||
'Job Configuration': '工作配置', |
|||
'Exclusive': '排除', |
|||
'Job Priority': '工作优先级', |
|||
'Retry Time Cycle': '重试时间周期', |
|||
'Documentation': '文档', |
|||
'Element Documentation': '元素文档', |
|||
'History Configuration': '历史配置', |
|||
'History Time To Live': '历史的生存时间', |
|||
'Forms': '表单', |
|||
'Form Key': '表单key', |
|||
'Form Fields': '表单字段', |
|||
'Business Key': '业务key', |
|||
'Form Field': '表单字段', |
|||
'ID': '编号', |
|||
'Type': '类型', |
|||
'Label': '名称', |
|||
'Default Value': '默认值', |
|||
'Validation': '校验', |
|||
'Add Constraint': '添加约束', |
|||
'Config': '配置', |
|||
'Properties': '属性', |
|||
'Add Property': '添加属性', |
|||
'Value': '值', |
|||
'Listeners': '监听器', |
|||
'Execution Listener': '执行监听', |
|||
'Event Type': '事件类型', |
|||
'Listener Type': '监听器类型', |
|||
'Java Class': 'Java类', |
|||
'Expression': '表达式', |
|||
'Must provide a value': '必须提供一个值', |
|||
'Delegate Expression': '代理表达式', |
|||
'Script': '脚本', |
|||
'Script Format': '脚本格式', |
|||
'Script Type': '脚本类型', |
|||
'Inline Script': '内联脚本', |
|||
'External Script': '外部脚本', |
|||
'Resource': '资源', |
|||
'Field Injection': '字段注入', |
|||
'Extensions': '扩展', |
|||
'Input/Output': '输入/输出', |
|||
'Input Parameters': '输入参数', |
|||
'Output Parameters': '输出参数', |
|||
'Parameters': '参数', |
|||
'Output Parameter': '输出参数', |
|||
'Timer Definition Type': '定时器定义类型', |
|||
'Timer Definition': '定时器定义', |
|||
'Date': '日期', |
|||
'Duration': '持续', |
|||
'Cycle': '循环', |
|||
'Signal': '信号', |
|||
'Signal Name': '信号名称', |
|||
'Escalation': '升级', |
|||
'Error': '错误', |
|||
'Link Name': '链接名称', |
|||
'Condition': '条件名称', |
|||
'Variable Name': '变量名称', |
|||
'Variable Event': '变量事件', |
|||
'Specify more than one variable change event as a comma separated list.': '多个变量事件以逗号隔开', |
|||
'Wait for Completion': '等待完成', |
|||
'Activity Ref': '活动参考', |
|||
'Version Tag': '版本标签', |
|||
'Executable': '可执行文件', |
|||
'External Task Configuration': '扩展任务配置', |
|||
'Task Priority': '任务优先级', |
|||
'External': '外部', |
|||
'Connector': '连接器', |
|||
'Must configure Connector': '必须配置连接器', |
|||
'Connector Id': '连接器编号', |
|||
'Implementation': '实现方式', |
|||
'Field Injections': '字段注入', |
|||
'Fields': '字段', |
|||
'Result Variable': '结果变量', |
|||
'Topic': '主题', |
|||
'Configure Connector': '配置连接器', |
|||
'Input Parameter': '输入参数', |
|||
'Assignee': '代理人', |
|||
'Candidate Users': '候选用户', |
|||
'Candidate Groups': '候选组', |
|||
'Due Date': '到期时间', |
|||
'Follow Up Date': '跟踪日期', |
|||
'Priority': '优先级', |
|||
'The follow up date as an EL expression (e.g. ${someDate} or an ISO date (e.g. 2015-06-26T09:54:00)': '跟踪日期必须符合EL表达式,如: ${someDate} ,或者一个ISO标准日期,如:2015-06-26T09:54:00', |
|||
'The due date as an EL expression (e.g. ${someDate} or an ISO date (e.g. 2015-06-26T09:54:00)': '跟踪日期必须符合EL表达式,如: ${someDate} ,或者一个ISO标准日期,如:2015-06-26T09:54:00', |
|||
'Variables': '变量', |
|||
'Create DataObjectReference': '创建数据对象', |
|||
'Create Task': '创建任务', |
|||
'Create SendTask': '创建发送任务', |
|||
'Create ReceiveTask': '创建接收任务', |
|||
'Create UserTask': '创建用户任务', |
|||
'Create ManualTask': '创建手工任务', |
|||
'Create BusinessRuleTask': '创建业务规则任务', |
|||
'Create ServiceTask': '创建服务任务', |
|||
'Create ScriptTask': '创建脚本任务', |
|||
'Create CallActivityTask': '创建调用活动', |
|||
'Create SubProcessCollapsed': '创建子流程(折叠的)', |
|||
'Create SubProcessExpanded': '创建子流程(展开的)', |
|||
'Create StartEvent': '创建开始事件', |
|||
'Create EndEvent': '创建结束事件', |
|||
'Create DataStoreReference': '创建数据存储引用', |
|||
'Tasklist Configuration': '任务列表配置', |
|||
'Candidate Starter Configuration': '候选启动程序配置', |
|||
'Candidate Starter Groups': '候选启动组', |
|||
'Candidate Starter Users': '候选启动器用户', |
|||
'Specify more than one group as a comma separated list.':'将多个组指定为逗号分隔的列表。', |
|||
'Specify more than one user as a comma separated list.':'将多个用户指定为逗号分隔的列表。', |
|||
'This maps to the process definition key.':'映射到流程定义键。', |
|||
'Startable':'可启动', |
|||
'TextAnnotation':'文本批注', |
|||
'Append Intermediate/Boundary Event':'追加中间/边界事件', |
|||
'Append EndEvent':'附加事件', |
|||
'Append Gateway':'附加网关', |
|||
'Append Task':'追加任务', |
|||
'Parameter must have a name':'参数必须有名称', |
|||
'CallActivity Type':'调用活动类型', |
|||
'In Mapping':'在映射中', |
|||
'Out Mapping':'输出映射', |
|||
'Case Ref':'参考案例', |
|||
'Binding':'捆绑', |
|||
'Tenant Id':'机构ID', |
|||
'deployment':'调度。', |
|||
'Source':'来源', |
|||
'Target':'目标', |
|||
'Mapping must have a source':'映射必须有一个源', |
|||
'Mapping must have a target':'映射必须有一个目标', |
|||
'Task Listener':'任务侦听器', |
|||
}; |
|||
|
|||
@ -0,0 +1,201 @@ |
|||
<template> |
|||
<div> |
|||
<div class="header"> |
|||
<el-menu :default-active="activeIndex" class="el-menu-demo" mode="horizontal" @select="handleSelect"> |
|||
<el-menu-item index="/layout/baseSetup" @click="to('/layout/baseSetup')">基础设置</el-menu-item> |
|||
<el-menu-item index="/layout/formDesign" @click="to('/layout/formDesign')">表单设计</el-menu-item> |
|||
<el-menu-item index="/layout/processDesign" @click="to('/layout/processDesign')">流程设计</el-menu-item> |
|||
<el-menu-item index="/layout/seniorSetup" @click="to('/layout/seniorSetup')">高级设置</el-menu-item> |
|||
</el-menu> |
|||
<div class="publish"> |
|||
<el-button size="mini" @click="preview"><i class="el-icon-view"></i>预览</el-button> |
|||
<el-button size="mini" type="primary" @click="publish"><i class="el-icon-s-promotion"></i>发布</el-button> |
|||
</div> |
|||
<div class="back"> |
|||
<el-button @click="exit" size="medium" icon="el-icon-arrow-left" circle></el-button> |
|||
<span> |
|||
<i :class="setup.icon" :style="'background:' + setup.background"></i> |
|||
<span>{{setup.name}}</span> |
|||
</span> |
|||
</div> |
|||
</div> |
|||
|
|||
<el-dialog title="请使用手机扫码预览" :visible.sync="viewCode" width="300px" :close-on-click-modal="false" center> |
|||
<img src="../assets/image/code.png" width="250" height="250"> |
|||
</el-dialog> |
|||
|
|||
<div class="layout-body"> |
|||
<transition name="router-fade" mode="out-in"> |
|||
<router-view v-if="!$route.meta.keepAlive"/> |
|||
</transition> |
|||
</div> |
|||
</div> |
|||
</template> |
|||
|
|||
<script> |
|||
// import {updateFormDetail, updateTemplate} from '@/api/setting' |
|||
|
|||
export default { |
|||
data() { |
|||
return { |
|||
activeIndex: '/layout/baseSetup', |
|||
viewCode: false, |
|||
}; |
|||
}, |
|||
computed:{ |
|||
setup() { |
|||
return this.$store.state.template.baseSetup; |
|||
}, |
|||
template() { |
|||
return this.$store.state.template; |
|||
} |
|||
}, |
|||
created(){ |
|||
this.check() |
|||
}, |
|||
mounted() { |
|||
this.activeIndex = this.$route.path |
|||
console.log(document.body.offsetWidth) |
|||
if (document.body.offsetWidth <= 970){ |
|||
this.$msgbox.alert("本设计器未适配中小屏幕,建议您在PC电脑端浏览器进行操作") |
|||
} |
|||
this.listener() |
|||
}, |
|||
methods: { |
|||
publish() { |
|||
this.$confirm('您确定审批流程已配置完毕,并需要将其发布,发布后立即生效,是否继续?', '提示', { |
|||
confirmButtonText: '发布', |
|||
cancelButtonText: '取消', |
|||
type: 'warning' |
|||
}).then(() => { |
|||
console.log(this.setup) |
|||
let template = { |
|||
templateId: this.template.id, |
|||
templateName: this.setup.name, |
|||
icon: this.setup.icon, |
|||
group: this.setup.group, |
|||
background: this.setup.background, |
|||
whoCommit: JSON.stringify(this.setup.whoCommit.map( |
|||
wc => {return {id: wc.id, type: wc.type, name: wc.name}})), |
|||
whoEdit: JSON.stringify(this.setup.whoEdit.map( |
|||
wc => {return {id: wc.id, type: wc.type, name: wc.name}})), |
|||
whoExport: JSON.stringify(this.setup.whoExport.map( |
|||
wc => {return {id: wc.id, type: wc.type, name: wc.name}})), |
|||
formItems: JSON.stringify(this.template.form), |
|||
remark: this.setup.remark, |
|||
process: JSON.stringify(this.template.process), |
|||
} |
|||
if (this.valid()){ |
|||
// updateFormDetail(template).then(rsp => { |
|||
// let isAdd = this.template.id === undefined |
|||
// let params = {templateId: isAdd ? this.template.id:rsp.data, |
|||
// type:'move', groupId: this.setup.group} |
|||
// updateTemplate(params).then(rsp => { |
|||
// this.$message.success(rsp.data) |
|||
// this.$store.commit('clearTemplate') |
|||
// this.$router.push('/formListPanel') |
|||
// }).catch(err => this.$message.error(err.response.data)) |
|||
// }).catch(err => this.$message.error(err.response.data)) |
|||
} |
|||
}) |
|||
}, |
|||
preview() { |
|||
this.viewCode = true; |
|||
}, |
|||
valid(){ |
|||
if (!this.$isNotEmpty(this.setup.group)){ |
|||
this.$message.warning('请选择分组') |
|||
this.$router.push('/layout/baseSetup') |
|||
return false; |
|||
} |
|||
return true; |
|||
}, |
|||
exit(){ |
|||
this.$confirm('未发布的内容将不会被保存,是否直接退出 ?', '提示', { |
|||
confirmButtonText: '退出', |
|||
cancelButtonText: '取消', |
|||
type: 'warning' |
|||
}).then(() => { |
|||
//sessionStorage.setItem('router-path','/formListPanel') |
|||
//window.location.reload() |
|||
this.$store.commit('clearTemplate') |
|||
this.$router.push('/formListPanel') |
|||
}) |
|||
}, |
|||
to(path) { |
|||
if (path !== this.$route.path){ |
|||
this.$router.push(path); |
|||
} |
|||
}, |
|||
handleSelect(key, keyPath) { |
|||
console.log(key, keyPath); |
|||
}, |
|||
listener(){ |
|||
window.onunload = this.closeBefore() |
|||
window.onbeforeunload = this.closeBefore() |
|||
//window.on('beforeunload',this.closeBefore()) |
|||
}, |
|||
closeBefore(){ |
|||
//alert("您将要离开本页") |
|||
return false |
|||
}, |
|||
check(){ |
|||
if(this.$store.state.isEdit === null){ |
|||
this.$router.push("/workPanel"); |
|||
} |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
<style lang="less" scoped> |
|||
@import "@/assets/global"; |
|||
|
|||
.layout-body{ |
|||
min-width: 980px; |
|||
} |
|||
|
|||
/deep/ .header { |
|||
min-width: 980px; |
|||
position: relative; |
|||
.el-menu { |
|||
top: 0; |
|||
z-index: 999; |
|||
display: flex; |
|||
justify-content: center; |
|||
width: 100%; |
|||
} |
|||
|
|||
.publish { |
|||
position: absolute; |
|||
top: 15px; |
|||
right: 20px; |
|||
z-index: 1000; |
|||
|
|||
i { |
|||
margin-right: 6px; |
|||
} |
|||
|
|||
button { |
|||
border-radius: 15px; |
|||
} |
|||
} |
|||
|
|||
.back{ |
|||
position: absolute; |
|||
z-index: 1000; |
|||
top: 10px; |
|||
left: 20px; |
|||
font-size: small; |
|||
span{ |
|||
i{ |
|||
border-radius: 10px; |
|||
padding: 7.8px; |
|||
font-size: 20px; |
|||
color: #ffffff; |
|||
margin: 0 10px; |
|||
} |
|||
} |
|||
|
|||
} |
|||
} |
|||
</style> |
|||
@ -0,0 +1,51 @@ |
|||
<template> |
|||
<div style="height:auto;"> |
|||
<iframe style="width:100%;height:100%;" :src="bdTokenUrl" frameborder="0" scrolling="no" id="bdIframe"> |
|||
</iframe> |
|||
</div> |
|||
</template> |
|||
|
|||
<script type="text/javascript"> |
|||
|
|||
|
|||
export default { |
|||
name: 'turnoverfamily', |
|||
data(){ |
|||
return{ |
|||
bdTokenUrl : 'http://localhost:88/workPanel' |
|||
} |
|||
}, |
|||
created() { |
|||
// this.getUrl(); |
|||
this.$nextTick(()=>{ |
|||
this.getCode(); |
|||
}); |
|||
}, |
|||
mounted(){ |
|||
/** |
|||
* iframe-宽高自适应显示 |
|||
*/ |
|||
const oIframe = document.getElementById('bdIframe'); |
|||
const deviceWidth = document.documentElement.clientWidth; |
|||
const deviceHeight = document.documentElement.clientHeight; |
|||
oIframe.style.width = (Number(deviceWidth)-220) + 'px'; //数字是页面布局宽度差值 |
|||
oIframe.style.height = (Number(deviceHeight)-120) + 'px'; //数字是页面布局高度差 |
|||
}, |
|||
methods: { |
|||
/** |
|||
* 获取-外部接口信息 |
|||
*/ |
|||
// getUrl() { |
|||
// let that = this |
|||
// let bdUrl = {queryurl: this.$paths.bdpath+'/locate'}; |
|||
// this.$api.getBdToken(bdUrl,function(res) { |
|||
// that.bdTokenUrl = res.data.data; |
|||
// }) |
|||
// }, |
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style> |
|||
|
|||
</style> |
|||
@ -0,0 +1,17 @@ |
|||
<template> |
|||
<div> |
|||
<router-view v-slot="{ Component }"> |
|||
<transition mode="out-in" name="el-fade-in-linear"> |
|||
<keep-alive :include="$store.getters['router/keepAliveRouters']"> |
|||
<component :is="Component" /> |
|||
</keep-alive> |
|||
</transition> |
|||
</router-view> |
|||
</div> |
|||
</template> |
|||
|
|||
<script> |
|||
export default { |
|||
name: 'Process' |
|||
} |
|||
</script> |
|||
@ -0,0 +1,182 @@ |
|||
<template> |
|||
<div class="containers" ref="content"> |
|||
<!-- 画布 --> |
|||
<div class="canvas" ref="canvas"></div> |
|||
<!-- 面板 --> |
|||
<div id="js-properties-panel" class="panel"></div> |
|||
<!-- 下载图 --> |
|||
<ul class="buttons"> |
|||
<li>下载</li> |
|||
<li> |
|||
<a ref="saveDiagram" href="javascript:" title="下载BPMN图">BPMN图</a> |
|||
</li> |
|||
<li> |
|||
<a ref="saveSvg" href="javascript:" title="下载SVG图">SVG图</a> |
|||
</li> |
|||
</ul> |
|||
</div> |
|||
</template> |
|||
|
|||
<script> |
|||
// 引入组件 |
|||
import VueBpmn from "vue-bpmn"; |
|||
// 渲染器 |
|||
import BpmnModeler from "bpmn-js/lib/Modeler"; |
|||
// 左边工具栏 |
|||
import propertiesPanelModule from "bpmn-js-properties-panel"; |
|||
// 右边工具栏,扩展属性 |
|||
import propertiesProviderModule from "bpmn-js-properties-panel/lib/provider/camunda"; |
|||
import camundaModdleDescriptor from "camunda-bpmn-moddle/resources/camunda"; |
|||
|
|||
export default { |
|||
components: { |
|||
|
|||
}, |
|||
data() { |
|||
return { |
|||
// bpmn建模器 |
|||
bpmnModeler: null, |
|||
container: null, |
|||
canvas: null, |
|||
xmlStr: null, |
|||
processName: "" |
|||
}; |
|||
}, |
|||
mounted() { |
|||
|
|||
// 获取到属性ref为“content”的dom节点 |
|||
this.container = this.$refs.content; |
|||
// 获取到属性ref为“canvas”的dom节点 |
|||
const canvas = this.$refs.canvas; |
|||
// 建模,官方文档这里讲的很详细 |
|||
this.bpmnModeler = new BpmnModeler({ |
|||
container: canvas, |
|||
// 添加控制板 |
|||
// propertiesPanel: { |
|||
// parent: '#js-properties-panel' |
|||
// }, |
|||
additionalModules: [ |
|||
// 左边工具栏以及节点 |
|||
propertiesProviderModule, |
|||
// 右边的工具栏 |
|||
propertiesPanelModule |
|||
], |
|||
moddleExtensions: { |
|||
camunda: camundaModdleDescriptor |
|||
} |
|||
}); |
|||
|
|||
// 下载画图 |
|||
let _this = this |
|||
// 获取a标签dom节点 |
|||
const downloadLink = this.$refs.saveDiagram |
|||
const downloadSvgLink = this.$refs.saveSvg |
|||
const modeler = new BpmnModeler({container: '#modeler'}) |
|||
// 给图绑定事件,当图有发生改变就会触发这个事件 |
|||
modeler.on('commandStack.changed', function () { |
|||
_this.saveSVG(function (err, svg) { |
|||
_this.setEncoded(downloadSvgLink, 'diagram.svg', err ? null : svg) |
|||
}) |
|||
// 保存图 |
|||
_this.saveDiagram(function (err, xml) { |
|||
_this.setEncoded(downloadLink, 'diagram.bpmn', err ? null : xml) |
|||
}) |
|||
}) |
|||
// 创建新图 |
|||
this.createNewDiagram(this.bpmnModeler) |
|||
|
|||
}, |
|||
methods: { |
|||
createNewDiagram() { |
|||
const bpmnXmlStr = |
|||
'<?xml version="1.0" encoding="UTF-8"?>\n' + |
|||
'<bpmn2:definitions xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:bpmn2="http://www.omg.org/spec/BPMN/20100524/MODEL" xmlns:bpmndi="http://www.omg.org/spec/BPMN/20100524/DI" xmlns:dc="http://www.omg.org/spec/DD/20100524/DC" xmlns:di="http://www.omg.org/spec/DD/20100524/DI" xsi:schemaLocation="http://www.omg.org/spec/BPMN/20100524/MODEL BPMN20.xsd" id="sample-diagram" targetNamespace="http://bpmn.io/schema/bpmn">\n' + |
|||
' <bpmn2:process id="Process_1" isExecutable="false">\n' + |
|||
' <bpmn2:startEvent id="StartEvent_1"/>\n' + |
|||
" </bpmn2:process>\n" + |
|||
' <bpmndi:BPMNDiagram id="BPMNDiagram_1">\n' + |
|||
' <bpmndi:BPMNPlane id="BPMNPlane_1" bpmnElement="Process_1">\n' + |
|||
' <bpmndi:BPMNShape id="_BPMNShape_StartEvent_2" bpmnElement="StartEvent_1">\n' + |
|||
' <dc:Bounds height="36.0" width="36.0" x="412.0" y="240.0"/>\n' + |
|||
" </bpmndi:BPMNShape>\n" + |
|||
" </bpmndi:BPMNPlane>\n" + |
|||
" </bpmndi:BPMNDiagram>\n" + |
|||
"</bpmn2:definitions>"; |
|||
// 将字符串转换成图显示出来 |
|||
this.bpmnModeler.importXML(bpmnXmlStr, function(err) { |
|||
if (err) { |
|||
console.error(err); |
|||
} |
|||
}); |
|||
}, |
|||
// 下载为SVG格式,done是个函数,调用的时候传入的 |
|||
saveSVG(done) { |
|||
// 把传入的done再传给bpmn原型的saveSVG函数调用 |
|||
this.bpmnModeler.saveSVG(done); |
|||
}, |
|||
// 下载为SVG格式,done是个函数,调用的时候传入的 |
|||
saveDiagram(done) { |
|||
// 把传入的done再传给bpmn原型的saveXML函数调用 |
|||
this.bpmnModeler.saveXML({ format: true }, function(err, xml) { |
|||
done(err, xml); |
|||
}); |
|||
}, |
|||
// 当图发生改变的时候会调用这个函数,这个data就是图的xml |
|||
setEncoded(link, name, data) { |
|||
// 把xml转换为URI,下载要用到的 |
|||
const encodedData = encodeURIComponent(data); |
|||
// 获取到图的xml,保存就是把这个xml提交给后台 |
|||
this.xmlStr = data; |
|||
// 下载图的具体操作,改变a的属性,className令a标签可点击,href令能下载,download是下载的文件的名字 |
|||
if (data) { |
|||
link.className = "active"; |
|||
link.href = "data:application/bpmn20-xml;charset=UTF-8," + encodedData; |
|||
link.download = name; |
|||
} |
|||
} |
|||
} |
|||
}; |
|||
</script> |
|||
|
|||
<style scoped lang="scss"> |
|||
// 最外层容器 |
|||
.containers{ |
|||
position: absolute; |
|||
background-color: #ffffff; |
|||
width: 100%; |
|||
height: 100%; |
|||
} |
|||
// 画布 |
|||
.canvas{ |
|||
width: 100%; |
|||
height: 100%; |
|||
} |
|||
// 面板 |
|||
.panel{ |
|||
position: absolute; |
|||
right: 0; |
|||
top: 0; |
|||
width: 300px; |
|||
} |
|||
// 下载按钮 |
|||
.buttons{ |
|||
position: absolute; |
|||
left: 20px; |
|||
bottom: 20px; |
|||
&>li{ |
|||
display:inline-block;margin: 5px; |
|||
&>a{ |
|||
color: #999; |
|||
background: #eee; |
|||
cursor: not-allowed; |
|||
padding: 8px; |
|||
border: 1px solid #ccc; |
|||
&.active{ |
|||
color: #333; |
|||
background: #fff; |
|||
cursor: pointer; |
|||
} |
|||
} |
|||
} |
|||
} |
|||
</style> |
|||
@ -0,0 +1,23 @@ |
|||
/*explain:背景配置;@author: wxm; @version: 1.0; date: 2021/5/19;*/ |
|||
export const BackgroundConfig = { |
|||
// image:"https://ss1.bdstatic.com/70cFuXSh_Q1YnxGkpoWK1HF6hhy/it/u=2920685919,2017597770&fm=26&gp=0.jpg",
|
|||
opacity:0.2, |
|||
size:"100%", |
|||
repeat:"no-repeat", |
|||
} |
|||
|
|||
// export type BackgroundConfig = {
|
|||
// image?: string; // 背景图片地址
|
|||
// color?: string; // 背景色
|
|||
// repeat?: string; // 背景图片重复
|
|||
// position?: string; // 背景图片位置
|
|||
// size?: string; // 背景图片尺寸
|
|||
// opacity?: number; // 背景透明度 1-0
|
|||
// };
|
|||
|
|||
// repeat
|
|||
// repeat 默认。背景图像将在垂直方向和水平方向重复。
|
|||
// repeat-x 背景图像将在水平方向重复。
|
|||
// repeat-y 背景图像将在垂直方向重复。
|
|||
// no-repeat 背景图像将仅显示一次。
|
|||
// inherit 规定应该从父元素继承 background-repeat 属性的设置。
|
|||
@ -0,0 +1,18 @@ |
|||
/*explain:网格配置;@author: wxm; @version: 1.0; date: 2021/5/19;*/ |
|||
export const GridOptionsConfig = { |
|||
size:20, |
|||
visible:true, |
|||
type:'dot', |
|||
config:{ |
|||
color:'Black', |
|||
thickness:1, |
|||
} |
|||
} |
|||
|
|||
// size?: number // 栅格
|
|||
// visible?: boolean, // 是否可见,false则隐藏网格线但是保留栅格效果
|
|||
// type?: 'dot' | 'mesh', // 网格样式,目前内置支持点状'dot'和网格'mesh'
|
|||
// config?: {
|
|||
// color: string, // 网格颜色
|
|||
// thickness?: number, // 网格线宽度
|
|||
// }
|
|||
@ -0,0 +1,35 @@ |
|||
/*explain:组件样式配置;@author: wxm; @version: 1.0; date: 2021/5/19;*/ |
|||
export const StyleConfig = { |
|||
rect: { // 矩形样式
|
|||
width: 100, |
|||
height: 50, |
|||
radius: 6, |
|||
fill: '#34415b', |
|||
strokeWidth: 0 |
|||
}, |
|||
circle: { // 圆形样式
|
|||
r: 40, |
|||
fill: '#34415b', |
|||
strokeWidth: 0 |
|||
}, |
|||
ellipse: { //椭圆样式
|
|||
fill: '#34415b', |
|||
}, |
|||
polygon: { //多边形样式
|
|||
fill: '#34415b', |
|||
}, |
|||
text: { //文本样式
|
|||
fill: '#34415b', |
|||
}, |
|||
nodeText: { // 节点文本样式
|
|||
fontSize: 16, |
|||
//color: '#ffffff'
|
|||
}, |
|||
edgeText: { // 边文本样式
|
|||
fontSize: 16, |
|||
color: '#34415b' |
|||
}, |
|||
anchor: { // 锚点样式
|
|||
fill: "#6edd97" |
|||
} |
|||
} |
|||
|
After Width: | Height: | Size: 12 KiB |
@ -0,0 +1,357 @@ |
|||
<!--@author: wxm; @version: 1.0; date: 2021/5/15;--> |
|||
<template> |
|||
<div id="app"> |
|||
<el-container style="height: 100%"> |
|||
<!--工具栏--> |
|||
<!-- <el-header style="position: absolute;right: 0;top:20px;height: 40px; z-index: 101;">--> |
|||
<!-- <el-button @click="methods.zoom(true)">放大</el-button>--> |
|||
<!-- <el-button @click="methods.zoom(false)">缩小</el-button>--> |
|||
<!-- <el-button @click="methods.resetZoom()">还原大小</el-button>--> |
|||
<!-- <el-button @click="methods.focusOn()">位置还原</el-button>--> |
|||
<el-button @click="methods.getGraphData()">获取数据</el-button> |
|||
<!-- <el-button @click="methods.undo()">上一步</el-button>--> |
|||
<!-- <el-button @click="methods.redo()">下一步</el-button>--> |
|||
<!-- </el-header>--> |
|||
<el-button @click="methods.downloadImg()">下载</el-button> |
|||
|
|||
|
|||
|
|||
<el-container style="height: 100%"> |
|||
<!--组件栏--> |
|||
<div class="node-panel"> |
|||
<div class="node-item" @mousedown='methods.mouseDownHandle(item)' v-for="(item,index) in shapeList" :key="index"> |
|||
<div class="node-item-icon" :class="item.class"> |
|||
<span class="node-label">{{item.text}}</span> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
|
|||
<!--内容区--> |
|||
<el-main id="graph" style="height: 100%;"></el-main> |
|||
</el-container> |
|||
</el-container> |
|||
</div> |
|||
</template> |
|||
|
|||
<script> |
|||
import {toRefs,reactive,onMounted} from 'vue' |
|||
|
|||
import LogicFlow from '@logicflow/core'; |
|||
import '@logicflow/core/dist/style/index.css'; |
|||
//插件库 |
|||
import { NodeResize, Menu } from '@logicflow/extension'; |
|||
import '@logicflow/extension/lib/style/index.css' |
|||
|
|||
// 右键菜单 |
|||
LogicFlow.use(Menu); |
|||
|
|||
//节点缩放 |
|||
// 样式不要 |
|||
// NodeResize.style.outline = { |
|||
// style: { |
|||
// outline: { |
|||
// stroke: '#000000', |
|||
// strokeWidth: 1, |
|||
// strokeDasharray: '3,3', |
|||
// }, |
|||
// controlPoint: { |
|||
// width: 7, |
|||
// height: 7, |
|||
// fill: '#FFFFFF', |
|||
// stroke: '#000000', |
|||
// }, |
|||
// }, |
|||
// ...NodeResize.style.outline, |
|||
// stroke: '#1E90FF', |
|||
// strokeDasharray: '', |
|||
// } |
|||
LogicFlow.use(NodeResize); |
|||
NodeResize.step = 4; |
|||
LogicFlow.use(NodeResize); |
|||
|
|||
//框选 |
|||
import {SelectionSelect} from '@logicflow/extension'; |
|||
LogicFlow.use(SelectionSelect); |
|||
//SelectionSelect.open(); 此事件无效 |
|||
|
|||
//迷你地图 |
|||
// import {MiniMap} from '@logicflow/extension'; |
|||
// LogicFlow.use(MiniMap); |
|||
|
|||
//控制面板 |
|||
// import {Control} from '@logicflow/extension'; |
|||
// LogicFlow.use(Control ) |
|||
|
|||
//图片导出 |
|||
import { Snapshot } from '@logicflow/extension'; |
|||
LogicFlow.use(Snapshot); |
|||
|
|||
|
|||
import {BackgroundConfig} from './config/BackgroundConfig' |
|||
import {GridOptionsConfig} from './config/GridOptionsConfig' |
|||
import {StyleConfig} from './config/StyleConfig' |
|||
|
|||
import {registerMyRectNodeModel} from './node/myRectNode' |
|||
|
|||
export default { |
|||
name: 'App', |
|||
components:{ |
|||
}, |
|||
setup(){ |
|||
onMounted(()=>{ |
|||
methods.init(); |
|||
window.onkeydown = function (){ |
|||
let key = window.event.keyCode; |
|||
if (key === 46) { |
|||
methods.deleteNode(); |
|||
} |
|||
console.log(key) |
|||
} |
|||
}); |
|||
const data = reactive({ |
|||
lf:null, |
|||
logicFlowData:{ |
|||
nodes:[ |
|||
{id: 1,type: 'rect', x: 400, y: 400, text: '矩形节点',width:200,height:200,}, |
|||
{id: 2,type: 'circle', x: 120, y: 80, text: {value: '圆形节点',x: 120, y: 80,},}, |
|||
{id: 3,type: 'ellipse', x: 200, y: 310, text: '椭圆节点',}, |
|||
{id: 5,type: 'ellipse', x: 250, y: 310, text: '椭圆节点',}, |
|||
{id: 4,type: 'my-rect', x: 250, y: 500, text: '自定义',}, |
|||
] |
|||
}, |
|||
shapeList: [ |
|||
{type: 'rect', text: '矩形',class:'node-rect'}, |
|||
{type: 'diamond', text: '菱形',class:'node-diamond'}, |
|||
{type: 'circle', text: '圆形',class:'node-circle'}, |
|||
{type: 'ellipse', text: '椭圆',class:'node-ellipse'}, |
|||
{type: 'my-rect', text: '自定义',class:'node-rect'}, |
|||
// {type: 'chatBubble', text: 'chatBubble',class:'node-polygon'}, |
|||
// {type: 'text=1', text: 'text=1',class:'node-polygon'}, |
|||
], |
|||
clickNodeId:'', |
|||
clickEdgeId:'', |
|||
}); |
|||
const methods = { |
|||
/** |
|||
* 初始化画板 |
|||
*/ |
|||
init : function () { |
|||
data.lf = new LogicFlow({ |
|||
// 容器配置 |
|||
container: document.querySelector('#graph'), |
|||
background: BackgroundConfig, |
|||
grid: GridOptionsConfig, |
|||
textEdit: true, //是否开启文本编辑 |
|||
isSilentMode: false, //仅浏览不可编辑模式,默认不开启 |
|||
edgeType: 'polyline', //line 直线 polyline 折线 bezier 贝塞尔曲线 |
|||
snapline: true, //是否启用节点辅助对齐线 |
|||
style: StyleConfig,//样式 |
|||
keyboard: {//cv快捷键 |
|||
enabled: true |
|||
}, |
|||
metaKeyMultipleSelected:true,//metaKeyMultipleSelected Boolean false - 是否开启功能键按住多选 |
|||
}); |
|||
|
|||
//注册自定义组件 |
|||
methods.registerNode(); |
|||
data.lf.render(data.logicFlowData); |
|||
//监听事件 |
|||
methods.monitorEvent(); |
|||
|
|||
//开启多选模式 |
|||
data.lf.updateEditConfig({ |
|||
stopMoveGraph: true |
|||
}) |
|||
|
|||
//开启地图 |
|||
//MiniMap.show(1000,100); |
|||
}, |
|||
|
|||
/** |
|||
* 注册自定义组件 |
|||
**/ |
|||
registerNode : function(){ |
|||
registerMyRectNodeModel(data.lf); |
|||
}, |
|||
|
|||
/** |
|||
* 拖拽 |
|||
* @param item 拖拽属性 |
|||
*/ |
|||
mouseDownHandle : function (item) { |
|||
//生成ID |
|||
let id = data.logicFlowData.nodes[data.logicFlowData.nodes.length -1].id + 1; |
|||
console.log(item,id) |
|||
data.lf.dnd.startDrag({ |
|||
id: id.toString(), |
|||
type:item.type, |
|||
text:item.text, |
|||
properties:{} |
|||
}); |
|||
}, |
|||
|
|||
// 放大或缩小画布 isZoomIn:boolean |
|||
zoom : function (isZoomIn){ |
|||
data.lf.zoom(isZoomIn); |
|||
}, |
|||
//还原 |
|||
resetZoom : function (){ |
|||
data.lf.resetZoom(); |
|||
}, |
|||
//等比缩小 size:number |
|||
setZoomMiniSize :function(size){ |
|||
data.lf.setZoomMiniSize(size) |
|||
}, |
|||
//等比放大 size:number |
|||
setZoomMaxSize : function (size){ |
|||
data.lf.setZoomMaxSize(size); |
|||
}, |
|||
|
|||
// 将图形移动到画布中心 focusOnArgs:{id:"内容ID",coordinate: {x: 11,y: 22}} |
|||
focusOn : function (){ |
|||
data.lf.focusOn({coordinate: {x: 180,y: 280}}); |
|||
}, |
|||
|
|||
//返回值,如果是应用了adapter插件,且设置为adapterOut,返回为转换后的数据格式,否则为默认的格式 |
|||
getGraphData : function (){ |
|||
console.log(data.lf.getGraphData()) |
|||
}, |
|||
|
|||
//撤销一步 |
|||
undo : function (){ |
|||
data.lf.undo(); |
|||
}, |
|||
|
|||
// 向前一步 |
|||
redo : function (){ |
|||
data.lf.redo(); |
|||
}, |
|||
|
|||
//监听事件 |
|||
monitorEvent : function (){ |
|||
//点击节点将 节点ID记录下来 |
|||
data.lf.on('element:click', (callback) => { |
|||
console.log('节点/线点击事件:' + 'element:click',callback) |
|||
//有连线起始节点的id 说明是线 |
|||
if (callback.data.sourceNodeId){ |
|||
data.clickEdgeId = callback.data.id; |
|||
//清除节点的 |
|||
data.clickNodeId = ''; |
|||
}else{ |
|||
data.clickNodeId = callback.data.id; |
|||
//清除线 |
|||
data.clickEdgeId = ''; |
|||
} |
|||
}) |
|||
|
|||
//点击画板 将记录下来的节点和线ID进行删除 |
|||
data.lf.on('blank:mousedown',() =>{ |
|||
console.log('画板点击事件:' + 'blank:mousedown') |
|||
data.clickNodeId = '' |
|||
data.clickEdgeId = '' |
|||
}) |
|||
}, |
|||
|
|||
//删除节点 |
|||
deleteNode : function (){ |
|||
if (data.clickNodeId){ |
|||
console.log("删除节点") |
|||
data.lf.deleteNode(data.clickNodeId); |
|||
//重置data.clickDataId |
|||
data.clickNodeId = null; |
|||
}else if (data.clickEdgeId){ |
|||
console.log("删除线") |
|||
data.lf.deleteEdge(data.clickEdgeId); |
|||
//重置data.clickEdgeId |
|||
data.clickEdgeId = ''; |
|||
}else{ |
|||
console.log("批量删除"); |
|||
} |
|||
}, |
|||
|
|||
//下载图片 |
|||
downloadImg : function (){ |
|||
data.lf.getSnapshot() |
|||
} |
|||
|
|||
} |
|||
return { |
|||
...toRefs(data), |
|||
methods, |
|||
} |
|||
}, |
|||
} |
|||
</script> |
|||
|
|||
<style> |
|||
>>>.el-main{ |
|||
padding: 10px; |
|||
margin: 0; |
|||
} |
|||
#app { |
|||
height: 100%; |
|||
margin: 0; |
|||
padding: 0; |
|||
} |
|||
.node-panel { |
|||
width: 70px; |
|||
padding: 20px 0; |
|||
background-color: white; |
|||
box-shadow: 0 0 10px 1px rgb(228, 224, 219); |
|||
border-radius: 6px; |
|||
text-align: center; |
|||
z-index: 101; |
|||
} |
|||
.node-item { |
|||
margin-bottom: 20px; |
|||
} |
|||
.node-item-icon { |
|||
width: 30px; |
|||
height: 30px; |
|||
margin-left: 20px; |
|||
background-size: cover; |
|||
text-align: center; |
|||
} |
|||
.node-label { |
|||
font-size: 12px; |
|||
margin-top: 5px; |
|||
user-select: none; |
|||
} |
|||
.node-rect{ |
|||
width: 40px; |
|||
height: 30px; |
|||
border: 2px solid black; |
|||
} |
|||
.node-circle{ |
|||
width: 40px; |
|||
height: 40px; |
|||
border-radius: 50%; |
|||
border: 2px solid black; |
|||
} |
|||
.node-ellipse{ |
|||
border: 2px solid black; |
|||
border-radius: 60%; |
|||
width: 40px; |
|||
height: 30px; |
|||
} |
|||
.node-polygon{ |
|||
width: 40px; |
|||
height: 40px; |
|||
border: 2px solid black; |
|||
transform:rotate(45deg); |
|||
} |
|||
.node-diamond{ |
|||
width: 40px; |
|||
height: 40px; |
|||
border: 2px solid black; |
|||
transform:rotate(45deg); |
|||
} |
|||
/*css 设置*/ |
|||
.lf-menu-delete .lf-menu-item-icon{ |
|||
display: inline-block; |
|||
width: 20px; |
|||
height: 20px; |
|||
background: url('./img/delete.jpg') no-repeat; |
|||
background-size: 20px; |
|||
} |
|||
</style> |
|||
@ -0,0 +1,84 @@ |
|||
/*explain:;@author: wxm; @version: 1.0; date: 2021/6/9;*/ |
|||
import { h } from '@logicflow/core'; |
|||
import { RectResize } from '@logicflow/extension'; |
|||
|
|||
// 自定义节点的 model
|
|||
class Model extends RectResize.model{ |
|||
//自定义节点的样式
|
|||
setAttributes() { |
|||
const size = 100; |
|||
this.width = size; //width number ✅ 节点宽度
|
|||
this.height = size; //height number ✅ 节点高度
|
|||
this.fill = '#5F9EA0'; //fill color ✅ 节点填充颜色
|
|||
this.fillOpacity = 1; //fillOpacity number ✅ 节点填充颜色透明度
|
|||
this.stroke = "#588811"; // stroke color ✅ 节点边框颜色
|
|||
this.strokeOpacity = 1; //strokeOpacity number ✅ 节点边框颜色透明度
|
|||
this.strokeWidth = 1; // strokeWidth number ✅ 节点边框宽度
|
|||
this.opacity = 1; //opacity number ✅ 节点整体透明度
|
|||
this.outlineColor = '#00008B' //outlineColor color ✅ 外框颜色
|
|||
this.hoverOutlineColor = '#008000' // hoverOutlineColor color ✅ hover外边框颜色
|
|||
this.outlineStrokeDashArray = ''; //控制用来描外边框的点划线的图案范式, 设置为空是为实线
|
|||
this.hoverOutlineStrokeDashArray = ''; //控制用来描hover外边框的点划线的图案范式, 设置为空是为实线
|
|||
|
|||
//矩形节点特有
|
|||
this.radius = 5;//radius number ✅ 矩形圆角
|
|||
|
|||
//矩形节点特有
|
|||
this.radius = 5;//radius number ✅ 矩形圆角
|
|||
|
|||
// 设置自定义锚点
|
|||
// 只需要为每个锚点设置相对于节点中心的偏移量
|
|||
this.anchorsOffset = [ |
|||
[size / 2, 0], // x 轴上偏移 size / 2
|
|||
[-size / 2, 0], // x 轴上偏移 -size / 2
|
|||
]; |
|||
} |
|||
//设置连线规则
|
|||
getConnectedTargetRules() { |
|||
const rules = super.getConnectedTargetRules(); |
|||
const notAsTarget = { |
|||
message: '禁止自己连自己', |
|||
validate: (source,target) => { |
|||
return source.id !== target.id; |
|||
}, |
|||
}; |
|||
rules.push(notAsTarget); |
|||
return rules; |
|||
} |
|||
} |
|||
|
|||
// 自定义节点的 view
|
|||
class View extends RectResize.view{ |
|||
getResizeShape() { |
|||
// 通过 getAttributes 获取 model 中的属性
|
|||
const { x, y, width, height, fill, stroke, strokeWidth, radius } = this.getAttributes(); |
|||
const attrs = { |
|||
// rect 标签的 x,y 对应的是图形的左上角
|
|||
// 所以我们要将矩形的中心移动到 x,y
|
|||
x: x - width / 2, |
|||
y: y - height / 2, |
|||
width, |
|||
height, |
|||
stroke, |
|||
fill, |
|||
strokeWidth, |
|||
rx: radius, |
|||
ry: radius, |
|||
} |
|||
// getShape 的返回值是一个通过 h 方法创建的 svg 元素
|
|||
return h("g", {}, [ |
|||
h("rect", { ...attrs }), |
|||
h( |
|||
'svg', |
|||
{x: x - width / 2 + 5, y: y - height / 2 + 5, width: 25, height: 25, viewBox: "0 0 1274 1024",}, |
|||
h('path', {fill: stroke, d: "M655.807326 287.35973m-223.989415 0a218.879 218.879 0 1 0 447.978829 0 218.879 218.879 0 1 0-447.978829 0ZM1039.955839 895.482975c-0.490184-212.177424-172.287821-384.030443-384.148513-384.030443-211.862739 0-383.660376 171.85302-384.15056 384.030443L1039.955839 895.482975z"}) |
|||
), |
|||
] |
|||
); |
|||
|
|||
} |
|||
} |
|||
|
|||
export function registerMyRectNodeModel(lf){ |
|||
lf.register({type:"my-rect",view:View,model:Model}) |
|||
} |
|||