改了很多

This commit is contained in:
xiangheng
2023-12-12 00:49:26 +08:00
parent 0abfbce730
commit f92aa5ded3
39 changed files with 2633 additions and 732 deletions

View File

@@ -0,0 +1,26 @@
import request from '@/utils/request'
// 申请流程列表
export function flow_apply_lists(params?: Record<string, any>) {
return request.get({ url: '/flow_apply/list', params })
}
// 申请流程详情
export function flow_apply_detail(params: Record<string, any>) {
return request.get({ url: '/flow_apply/detail', params })
}
// 申请流程新增
export function flow_apply_add(params: Record<string, any>) {
return request.post({ url: '/flow_apply/add', params })
}
// 申请流程编辑
export function flow_apply_edit(params: Record<string, any>) {
return request.post({ url: '/flow_apply/edit', params })
}
// 申请流程删除
export function flow_apply_delete(params: Record<string, any>) {
return request.post({ url: '/flow_apply/del', params })
}

View File

@@ -0,0 +1,30 @@
import request from '@/utils/request'
// 流程历史列表
export function flow_history_list(params?: Record<string, any>) {
return request.get({ url: '/flow_history/list', params })
}
// 流程历史列表-所有
export function flow_history_list_all(params?: Record<string, any>) {
return request.get({ url: '/flow_history/listAll', params })
}
// 流程历史详情
export function flow_history_detail(params: Record<string, any>) {
return request.get({ url: '/flow_history/detail', params })
}
// 流程历史新增
export function flow_history_add(params: Record<string, any>) {
return request.post({ url: '/flow_history/add', params })
}
// 流程历史编辑
export function flow_history_edit(params: Record<string, any>) {
return request.post({ url: '/flow_history/edit', params })
}
// 流程历史删除
export function flow_history_delete(params: Record<string, any>) {
return request.post({ url: '/flow_history/del', params })
}

View File

@@ -5,6 +5,11 @@ export function flow_template_lists(params?: Record<string, any>) {
return request.get({ url: '/flow_template/list', params })
}
// 流程模板列表-所有
export function flow_template_lists_all(params?: Record<string, any>) {
return request.get({ url: '/flow_template/listAll', params })
}
// 流程模板详情
export function flow_template_detail(params: Record<string, any>) {
return request.get({ url: '/flow_template/detail', params })

View File

@@ -21,9 +21,7 @@
:disabled="item.disabled"
></el-option>
</el-select>
<el-checkbox v-model="formData.myAuditAutoPass"
>发起人审批时自动通过</el-checkbox
>
<el-checkbox v-model="formData.myAuditAutoPass">发起人审批时自动通过</el-checkbox>
</el-form-item>
<el-form-item label="审批意见">
<el-checkbox v-model="formData.remarkRequired">必填</el-checkbox>
@@ -49,48 +47,48 @@
<script>
export default {
components: {},
props: ["conf"],
props: ['conf'],
data() {
return {
formData: {
autoRepeat: false, //审批人去重
myAuditAutoPass: false, //发起人审批时自动通过
remarkTip: "", //审批意见填写提示
remarkTip: '', //审批意见填写提示
remarkRequired: false,
notVisibleForSponsor: false,
notVisibleForSponsor: false
},
rules: {
autoRepeat: [
{
required: true,
message: "请选择选择分组",
trigger: "change",
},
],
message: '请选择选择分组',
trigger: 'change'
}
]
},
autoRepeatOptions: [
{
label: "启用自动去重",
value: true,
label: '启用自动去重',
value: true
},
{
label: "不启用自动去重",
value: false,
},
],
};
label: '不启用自动去重',
value: false
}
]
}
},
created() {
if (typeof this.conf === "object" && this.conf !== null) {
Object.assign(this.formData, this.conf);
if (typeof this.conf === 'object' && this.conf !== null) {
Object.assign(this.formData, this.conf)
}
},
methods: {
getData() {
return this.formData;
},
},
};
return this.formData
}
}
}
</script>
<style lang="scss" scoped>

View File

@@ -11,7 +11,7 @@
style="height: 100vh"
class="flow-config-dialog"
>
<template #header="{ close, titleId, titleClass }">
<template #header="{ close }">
<header class="page__header">
<div class="page-actions">
{{ title }}
@@ -157,7 +157,6 @@ export default {
},
publish() {
const getCmpData = (name) => {
console.log(name)
return this.$refs[name].getData()
}
// basicSetting formDesign processDesign 返回的是Promise 因为要做校验
@@ -172,7 +171,8 @@ export default {
id: this?.mockData?.id,
basicSetting: res[0].formData,
flowFormData: res[1].formData,
flowProcessData: res[2].formData
flowProcessData: res[2].formData,
flowProcessTreeData: res[2].TreeNode
// advancedSetting: getCmpData("advancedSetting"),
}
@@ -185,6 +185,7 @@ export default {
err.msg && this.$message.error(err.msg)
})
},
sendToServer(param) {
this.$notify({
title: '数据已整合完成',

View File

@@ -0,0 +1,81 @@
<template>
<el-dialog
v-model="dialogVisible"
:show-close="false"
:fullscreen="false"
:close-on-click-modal="false"
:close-on-press-escape="false"
:destroy-on-close="true"
top="1px"
class="flow-config-dialog"
>
<v-form-render
:form-json="formJson"
:form-data="formData"
:option-data="optionData"
ref="vFormRef"
>
</v-form-render>
<template #footer>
<span class="dialog-footer">
<el-button @click="dialogVisible = false">Cancel</el-button>
<el-button type="primary" @click="getData"> Confirm </el-button>
</span>
</template>
</el-dialog>
</template>
<script setup>
import { ref } from 'vue'
import 'vform3-builds/dist/designer.style.css' //引入VForm3样式
const formJson = ref({})
const formData = ref({})
const optionData = reactive({})
const vFormRef = ref(null)
const dialogVisible = ref(false)
const rowId = ref(0)
const props = defineProps({
save: {
type: Function,
default: () => {}
}
})
function open(id, form_json, form_data) {
rowId.value = id
formData.value = form_data
formJson.value = form_json
console.log('open')
dialogVisible.value = true
}
function closeFn() {
dialogVisible.value = false
rowId.value = 0
formData.value = {}
formJson.value = {}
}
function getData() {
vFormRef.value.getFormData().then((formData) => {
console.log('formData', formData)
props
.save(rowId.value, formData)
.then(() => {
closeFn()
})
.catch(() => {})
})
}
defineExpose({
getData,
open
})
</script>
<style lang="scss">
// body {
// margin: 0; /* 如果页面出现垂直滚动条则加入此行CSS以消除之 */
// }
</style>

View File

@@ -165,7 +165,7 @@ export default {
*/
return new Promise((resolve, reject) => {
const data = this.lf.getGraphData()
console.log('data', data)
const nodes = data.nodes
const edges = data.edges
@@ -178,7 +178,6 @@ export default {
sourceNodeIdSum[edge.sourceNodeId].push(targetNode)
for (const n of sourceNodeIdSum[edge.sourceNodeId]) {
console.log('n', n)
if (n.type != 'bpmn:exclusiveGateway') {
haveMoreChildNode = true
break
@@ -202,15 +201,36 @@ export default {
// });
// }
// 检查开始节点和结束节点是否存在
const findStartNode = nodes.find((item) => item.type == 'bpmn:startEvent')
const findEndNode = nodes.find((item) => item.type == 'bpmn:endEvent')
if (!findStartNode || !findEndNode) {
const findStartNode = nodes.filter((item) => item.type == 'bpmn:startEvent')
const findEndNode = nodes.filter((item) => item.type == 'bpmn:endEvent')
if (findStartNode.length != 1 || findEndNode.length != 1) {
return reject({
msg: '流程设计-流程必须有开始节点和结束节点'
msg: '流程设计-流程必须有且只有一个开始节点和结束节点'
})
}
function handel(arr, pid) {
const newArr = []
arr.forEach((node) => {
// console.log('sourceNodeIdSum', sourceNodeIdSum, node.id)
const newNode = {
id: node.id,
pid: pid,
type: node.type,
fieldAuth: node?.properties?.fieldAuth,
user: node?.properties?.user || 0
}
if (sourceNodeIdSum[node.id]) {
newNode.children = handel(sourceNodeIdSum[node.id], node.id)
}
newArr.push(newNode)
})
return newArr
}
const TreeNode = handel(findStartNode, 0)
console.log('TreeNode', TreeNode)
// 检查连线方向是否正确;
resolve({ formData: data })
resolve({ formData: data, TreeNode })
})
}
}

View File

@@ -11,23 +11,17 @@
{{ item.name }}
</div>
</div>
<div
class="image-node"
@mousedown.stop.prevent="dragInNode('bpmn:startEvent','开始')"
>
<div class="image-node" @mousedown.stop.prevent="dragInNode('bpmn:startEvent', '开始')">
<div class="pattern-start"></div>
<div>开始</div>
</div>
<div
class="image-node"
@mousedown.stop.prevent="dragInNode('bpmn:userTask','审批')"
>
<div class="image-node" @mousedown.stop.prevent="dragInNode('bpmn:userTask', '审批')">
<div class="pattern-user"></div>
<div>审批</div>
</div>
<div
class="image-node"
@mousedown.stop.prevent="dragInNode('bpmn:serviceTask','系统任务')"
@mousedown.stop.prevent="dragInNode('bpmn:serviceTask', '系统任务')"
>
<div class="pattern-user"></div>
<div>系统</div>
@@ -35,49 +29,45 @@
<div
class="image-node"
@mousedown.stop.prevent="dragInNode('bpmn:exclusiveGateway','网关')"
@mousedown.stop.prevent="dragInNode('bpmn:exclusiveGateway', '网关')"
>
<div class="pattern-condition"></div>
<div>网关</div>
</div>
<div
class="image-node"
@mousedown.stop.prevent="dragInNode('bpmn:endEvent','结束')"
>
<div class="image-node" @mousedown.stop.prevent="dragInNode('bpmn:endEvent', '结束')">
<div class="pattern-end"></div>
<div>结束</div>
</div>
</div>
</template>
<script>
// import IconCircle from './icon/Circle.vue'
import { List } from "./node";
import { List } from './node'
console.log("List", List);
console.log('List', List)
export default {
name: "DiagramSidebar",
name: 'DiagramSidebar',
data() {
return {
list: List.map((item) => {
return {
type: item.type,
...item.info,
};
}),
};
...item.info
}
})
}
},
methods: {
dragInNode(type,text) {
console.log("dragInNode", type);
this.$emit("dragInNode", type,text);
},
},
dragInNode(type, text) {
console.log('dragInNode', type)
this.$emit('dragInNode', type, text)
}
}
// components: {
// // IconCircle,
// }
};
}
</script>
<style scoped>

View File

@@ -1,6 +1,10 @@
<template>
<div>
<div class="toolbar-item" :class="{ 'selection-active': selectionOpened }" @click="$_selectionSelect()">
<div
class="toolbar-item"
:class="{ 'selection-active': selectionOpened }"
@click="$_selectionSelect()"
>
<area-select size="18" />
</div>
<div class="toolbar-item" @click="$_zoomIn()">
@@ -20,7 +24,12 @@
<div class="toolbar-item" @click="$_saveGraph">导出</div>
<div>
<el-select v-model="linetype" @change="$_changeLineType">
<el-option v-for="item in lineOptions" :key="item.value" :value="item.value" :label="item.label"></el-option>
<el-option
v-for="item in lineOptions"
:key="item.value"
:value="item.value"
:label="item.label"
></el-option>
</el-select>
</div>
</div>
@@ -33,30 +42,30 @@
// import IconFont from './icon/Font.vue'
// import IconBlod from './icon/Blod.vue'
// import IconLine from './icon/Line.vue'
import ZoomIn from "./icon/ZoomIn.vue";
import ZoomOut from "./icon/ZoomOut.vue";
import StepBack from "./icon/StepBack.vue";
import StepFoward from "./icon/StepFoward.vue";
import AreaSelect from "./icon/AreaSelect.vue";
import ZoomIn from './icon/ZoomIn.vue'
import ZoomOut from './icon/ZoomOut.vue'
import StepBack from './icon/StepBack.vue'
import StepFoward from './icon/StepFoward.vue'
import AreaSelect from './icon/AreaSelect.vue'
let fileHandle;
let fileHandle
async function getFile() {
[fileHandle] = await window.showOpenFilePicker();
console.log("fileHandle", fileHandle);
;[fileHandle] = await window.showOpenFilePicker()
console.log('fileHandle', fileHandle)
}
async function getText() {
const file = await fileHandle.getFile();
const text = await file.text();
console.log(text);
return text;
const file = await fileHandle.getFile()
const text = await file.text()
console.log(text)
return text
}
async function writeFile() {
const writable = await fileHandle.createWritable();
await writable.write("测试一下");
await writable.close();
const writable = await fileHandle.createWritable()
await writable.write('测试一下')
await writable.close()
}
export default {
@@ -65,90 +74,90 @@ export default {
activeEdges: Array,
fillColor: {
type: String,
default: "",
},
default: ''
}
},
data() {
return {
selectionOpened: false,
undoAble: false,
redoAble: false,
colors: "#345678",
linetype: "pro-polyline",
colors: '#345678',
linetype: 'pro-polyline',
lineOptions: [
{
value: "pro-polyline",
label: "折线",
value: 'pro-polyline',
label: '折线'
},
{
value: "pro-line",
label: "直线",
value: 'pro-line',
label: '直线'
},
{
value: "pro-bezier",
label: "曲线",
},
],
};
value: 'pro-bezier',
label: '曲线'
}
]
}
},
mounted() {
this.$props.lf.on("history:change", ({ data: { undoAble, redoAble } }) => {
this.$data.redoAble = redoAble;
this.$data.undoAble = undoAble;
});
this.$props.lf.on('history:change', ({ data: { undoAble, redoAble } }) => {
this.$data.redoAble = redoAble
this.$data.undoAble = undoAble
})
},
methods: {
async $import() {
try {
await getFile();
let text = await getText();
if(JSON.parse(text)){
this.$emit("importData",JSON.parse(text));
await getFile()
const text = await getText()
if (JSON.parse(text)) {
this.$emit('importData', JSON.parse(text))
}
} catch (error) {
this.$message.error("文件读取错误");
this.$message.error('文件读取错误')
}
},
$_changeFillColor(val) {
this.$emit("changeNodeFillColor", val.hex);
this.$emit('changeNodeFillColor', val.hex)
},
$_saveGraph() {
this.$emit("saveGraph");
this.$emit('saveGraph')
},
$_zoomIn() {
this.$props.lf.zoom(true);
this.$props.lf.zoom(true)
},
$_zoomOut() {
this.$props.lf.zoom(false);
this.$props.lf.zoom(false)
},
$_undo() {
if (this.$data.undoAble) {
this.$props.lf.undo();
this.$props.lf.undo()
}
},
$_redo() {
if (this.$data.redoAble) {
this.$props.lf.redo();
this.$props.lf.redo()
}
},
$_selectionSelect() {
this.selectionOpened = !this.selectionOpened;
this.selectionOpened = !this.selectionOpened
if (this.selectionOpened) {
this.lf.extension.selectionSelect.openSelectionSelect();
this.lf.extension.selectionSelect.openSelectionSelect()
} else {
this.lf.extension.selectionSelect.closeSelectionSelect();
this.lf.extension.selectionSelect.closeSelectionSelect()
}
},
$_changeLineType(value) {
const { lf, activeEdges } = this.$props;
const { graphModel } = lf;
lf.setDefaultEdgeType(value);
const { lf, activeEdges } = this.$props
const { graphModel } = lf
lf.setDefaultEdgeType(value)
if (activeEdges && activeEdges.length > 0) {
activeEdges.forEach((edge) => {
graphModel.changeEdgeType(edge.id, value);
});
graphModel.changeEdgeType(edge.id, value)
})
}
}
},
},
components: {
// ColorFill,
@@ -160,10 +169,10 @@ export default {
ZoomOut,
StepBack,
StepFoward,
AreaSelect,
AreaSelect
// SketchPicker: Sketch
},
};
}
}
</script>
<style scoped>
@@ -176,6 +185,6 @@ export default {
cursor: pointer;
}
.selection-active {
background: rgba(0 ,0,0,0.2);
background: rgba(0, 0, 0, 0.2);
}
</style>

View File

@@ -1,22 +1,37 @@
<template>
<el-drawer
v-model="drawerVisible"
size="500px"
:title="node?.text?.value"
@close="close"
>
<el-drawer v-model="drawerVisible" size="500px" :title="node?.text?.value" @close="close">
<div class="setting-block">
<!-- 开始节点 -->
{{ node }}
<div v-if="node.type == 'bpmn:startEvent'">开始节点</div>
<div v-if="node.type == 'bpmn:userTask'">
审批节点 设置审批人具体人员角色部门负责人岗位
审批节点
<div>设置审批人具体人员部门负责人岗位</div>
<!-- {{ adminUserList }} -->
<el-form>
<el-form-item label="审批人">
<el-select v-model="properties.user" placeholder="请选择审批人">
<el-option
v-for="item in adminUserList"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
</el-form>
</div>
<div v-if="node.type == 'bpmn:serviceTask'">系统任务</div>
<div v-if="node.type == 'bpmn:serviceTask'">
<div>系统任务</div>
<div>抄送</div>
<div>发送邮件</div>
<div>发送短信</div>
<div>发送站内消息</div>
</div>
<div v-if="node.type == 'bpmn:exclusiveGateway'">
<div>网关</div>
<div>网关只能有一个网关通过</div>
<div>从form取值判断</div>
</div>
@@ -24,11 +39,7 @@
<!-- 网关和结束节点不需要表单权限设置 -->
<el-table
v-if="
['bpmn:startEvent', 'bpmn:userTask', 'bpmn:serviceTask'].includes(
node.type
)
"
v-if="['bpmn:startEvent', 'bpmn:userTask', 'bpmn:serviceTask'].includes(node.type)"
fit
size="small"
:data="fieldList"
@@ -54,14 +65,21 @@
</template>
<script>
import { adminLists } from '@/api/perms/admin'
export default {
name: "PropertyPanel",
name: 'PropertyPanel',
props: {},
data() {
return {
drawerVisible: false,
adminUserList: [],
node: {},
properties: {
user: '', //审批人id
fieldAuth: {} // 字段权限
},
/**
* 表单列表
* [{
@@ -70,46 +88,61 @@ export default {
* auth: 1,
* }]
*/
fieldList: [],
};
fieldList: []
}
},
methods: {
open(node, fieldList) {
this.node = node;
this.node = node
this.properties.user = node?.properties?.user || ''
this.properties.fieldAuth = node?.properties?.fieldAuth || {}
this.fieldList = fieldList.map((item) => {
let auth = 1;
let formId = item?.field?.id;
let auth = 1
const formId = item?.field?.id
if (node?.properties?.fieldAuth?.[formId]) {
auth = node.properties.fieldAuth[formId];
auth = node.properties.fieldAuth[formId]
}
return {
id: formId,
label: item?.field?.options?.label,
auth: auth,
};
});
this.drawerVisible = true;
auth: auth
}
})
this.getAdminList()
this.drawerVisible = true
},
close() {
var fieldAuth = {};
const fieldAuth = {}
this.fieldList.forEach((item) => {
fieldAuth[item.id] = item.auth;
});
this.setProperties("fieldAuth", {
...fieldAuth,
});
fieldAuth[item.id] = item.auth
})
this.setProperties('fieldAuth', {
...fieldAuth
})
this.setProperties('user', this.properties.user)
},
getAdminList() {
adminLists().then((res) => {
console.log('res', res)
this.adminUserList = res.lists.map((item) => {
return {
value: item.id,
label: item.nickname
}
})
})
},
setProperties(key, val) {
this.$emit("setProperties", this.node, {
[key]: val,
});
this.$emit('setProperties', this.node, {
[key]: val
})
}
},
},
components: {},
};
components: {}
}
</script>
<style scoped></style>

View File

@@ -1,12 +0,0 @@
// 元素属性右侧面板默认属性
export const defatuleStyle = {
backgroundColor: '', // 填充色
gradientColor: '', // 渐变色
borderType: 0, // 边框类型
borderColor: '', // 填充颜色
borderWidth: 1, // 边框宽度
borderStyle: '', // 边框类型
fontSize: 12, // 文本大小
fontColor: '', // 文本颜色
fontWeight: '' // 文本加粗
}

View File

@@ -11,27 +11,27 @@
</template>
<script>
import LogicFlow from "@logicflow/core";
import { BpmnElement} from "@logicflow/extension";
import LogicFlow from '@logicflow/core'
import { BpmnElement } from '@logicflow/extension'
// import { SelectionSelect, Menu } from "@logicflow/extension";
import "@logicflow/core/dist/style/index.css";
import "@logicflow/extension/lib/style/index.css";
import '@logicflow/core/dist/style/index.css'
import '@logicflow/extension/lib/style/index.css'
import { registerCustomElement } from "./node";
import { registerCustomElement } from './node'
export default {
name: "DiagramView",
name: 'DiagramView',
components: {},
data() {
return {
lf: "",
lf: '',
activeNodes: [],
activeEdges: [],
properties: {},
timer: null,
time: 60000
};
}
},
watch: {
// appStore: {
@@ -39,7 +39,6 @@ export default {
// if (this.lf) {
// // this.lf.graphModel.resize();
// // this.lf.fitView();
// // 侧栏有动画,所以要加延时
// setTimeout(() => {
// this.lf.graphModel.resize();
@@ -52,9 +51,8 @@ export default {
},
mounted() {
// this.initLogicFlow(exportInfo);
},
beforeDestroy() {
beforeUnmount() {
if (this.timer) {
clearInterval(this.timer)
}
@@ -64,7 +62,7 @@ export default {
// 引入框选插件
// LogicFlow.use(SelectionSelect);
// LogicFlow.use(Menu);
LogicFlow.use(BpmnElement);
LogicFlow.use(BpmnElement)
const lf = new LogicFlow({
container: this.$refs.diagram,
overlapMode: 1,
@@ -74,99 +72,123 @@ export default {
stopMoveGraph: true,
metaKeyMultipleSelected: true,
keyboard: {
enabled: false,
enabled: false
},
isSilentMode: true,
grid: {
visible: false,
size: 1,
type: "mesh",
type: 'mesh',
config: {
color: "rgba(255,255,255,0.1)",
thickness: 1,
},
color: 'rgba(255,255,255,0.1)',
thickness: 1
}
},
background: {
backgroundColor: "rgba(29, 32, 98, 1)",
backgroundColor: 'rgba(29, 32, 98, 1)'
// backgroundImage:
// 'url("")',
// backgroundRepeat: "repeat",
},
});
}
})
lf.setTheme({
baseEdge: { strokeWidth: 1 },
baseNode: { strokeWidth: 1 },
nodeText: { overflowMode: "autoWrap", lineHeight: 1.5 },
edgeText: { overflowMode: "autoWrap", lineHeight: 1.5 },
});
nodeText: { overflowMode: 'autoWrap', lineHeight: 1.5 },
edgeText: { overflowMode: 'autoWrap', lineHeight: 1.5 }
})
// 注册自定义元素
registerCustomElement(lf);
lf.setDefaultEdgeType("pro-polyline");
lf.render(data);
lf.fitView();
registerCustomElement(lf)
lf.setDefaultEdgeType('pro-polyline')
lf.render(data)
lf.fitView()
this.lf = lf;
this.lf = lf
},
setType(errorMap) {
const gatwayStatus = {
error: 0,
success: 0
}
let all = this.lf.getGraphRawData();
const all = this.lf.getGraphRawData()
all.nodes.forEach((item) => {
if (!item.type.includes('status')) {
return
}
if (item.properties.deviceType == 1 && errorMap.T80ErrorArr.some(i => i == item.properties.equipmentId)) {
this.lf.changeNodeType(item.id, "status_error");
} else if (item.properties.deviceType == 2 && errorMap.ZLErrorArr.some(i => i == item.properties.equipmentId)) {
this.lf.changeNodeType(item.id, "status_error");
} else if (item.properties.deviceType == 3 && errorMap.TimeOutErrorArr.some(i => i == item.properties.equipmentId)) {
this.lf.changeNodeType(item.id, "status_error");
} else if (item.properties.deviceType == 3 || item.properties.deviceType == 2 || item.properties.deviceType == 1) {
this.lf.changeNodeType(item.id, "status_success");
if (
item.properties.deviceType == 1 &&
errorMap.T80ErrorArr.some((i) => i == item.properties.equipmentId)
) {
this.lf.changeNodeType(item.id, 'status_error')
} else if (
item.properties.deviceType == 2 &&
errorMap.ZLErrorArr.some((i) => i == item.properties.equipmentId)
) {
this.lf.changeNodeType(item.id, 'status_error')
} else if (
item.properties.deviceType == 3 &&
errorMap.TimeOutErrorArr.some((i) => i == item.properties.equipmentId)
) {
this.lf.changeNodeType(item.id, 'status_error')
} else if (
item.properties.deviceType == 3 ||
item.properties.deviceType == 2 ||
item.properties.deviceType == 1
) {
this.lf.changeNodeType(item.id, 'status_success')
} else if (item.properties.deviceType == 4) {
let equipments = item.properties.equipmentId.split(',')
equipments = equipments.map(i => i.trim())
if (equipments.every(equipmentId => errorMap.TimeOutErrorArr.includes(equipmentId))) {
equipments = equipments.map((i) => i.trim())
if (
equipments.every((equipmentId) =>
errorMap.TimeOutErrorArr.includes(equipmentId)
)
) {
gatwayStatus.error++
this.lf.changeNodeType(item.id, "status_error");
this.lf.changeNodeType(item.id, 'status_error')
} else {
gatwayStatus.success++
this.lf.changeNodeType(item.id, "status_success");
this.lf.changeNodeType(item.id, 'status_success')
}
}
});
})
this.$emit('gatewayStatus', gatwayStatus)
},
setTypeByDeviceID(deviceID, itemID, status) {
let all = this.lf.getGraphRawData();
const all = this.lf.getGraphRawData()
all.nodes.forEach((item) => {
if (item.properties.deviceType) {
return
}
if (item.properties.deviceID == deviceID && item.properties.itemID == itemID && status == 1) {
this.lf.changeNodeType(item.id, "status_success");
} else if (item.properties.deviceID == deviceID && item.properties.itemID == itemID && status == 0) {
this.lf.changeNodeType(item.id, "status_error");
if (
item.properties.deviceID == deviceID &&
item.properties.itemID == itemID &&
status == 1
) {
this.lf.changeNodeType(item.id, 'status_success')
} else if (
item.properties.deviceID == deviceID &&
item.properties.itemID == itemID &&
status == 0
) {
this.lf.changeNodeType(item.id, 'status_error')
}
});
})
},
networkError() {
let all = this.lf.getGraphRawData();
const all = this.lf.getGraphRawData()
all.nodes.forEach((item) => {
if (item.properties.deviceType) {
return
}
if (item.properties.deviceID && item.properties.itemID) {
this.lf.changeNodeType(item.id, "status_error");
this.lf.changeNodeType(item.id, 'status_error')
}
});
},
},
};
})
}
}
}
</script>
<style scoped>

View File

@@ -83,14 +83,15 @@
<el-option label="BigDecimal" value="BigDecimal" />
<el-option label="Date" value="Date" />
<el-option label="Boolean" value="Boolean" />
<el-option label="TsTime" value="core.TsTime" />
</el-select>
</template>
</el-table-column>
<el-table-column label="go属性" min-width="100">
<!-- <el-table-column label="go属性" min-width="100">
<template v-slot="{ row }">
<el-input v-model="row.goField" />
</template>
</el-table-column>
</el-table-column> -->
<el-table-column label="必填" width="80">
<template v-slot="{ row }">
<el-checkbox

View File

@@ -0,0 +1,253 @@
<template>
<div class="edit-popup">
<popup
ref="popupRef"
:title="popupTitle"
:async="true"
width="550px"
:clickModalClose="true"
@confirm="handleSubmit"
@close="handleClose"
>
<el-form ref="formRef" :model="formData" label-width="84px" :rules="formRules">
<el-form-item label="模板" prop="templateId">
<el-select
class="flex-1"
v-model="formData.templateId"
placeholder="请输入模板"
@change="handleTemplateChange"
>
<el-option
v-for="(item, index) in flow_template"
:key="index"
:label="item.flowName"
:value="item.id"
clearable
/>
</el-select>
</el-form-item>
<el-form-item label="流程名称" prop="flowName">
<el-input v-model="formData.flowName" placeholder="请输入流程名称" />
</el-form-item>
<el-form-item label="流程分类" prop="flowGroup">
<el-input v-model="formData.flowGroup" placeholder="请输入流程分类" />
</el-form-item>
<el-form-item label="流程描述" prop="flowRemark">
<el-input v-model="formData.flowRemark" placeholder="请输入流程描述" />
</el-form-item>
<el-form-item label="表单配置" prop="flowFormData">
<el-input
v-model="formData.flowFormData"
placeholder="请输入表单配置"
type="textarea"
:autosize="{ minRows: 4, maxRows: 6 }"
/>
</el-form-item>
<el-form-item label="流程配置" prop="flowProcessData">
<el-input
v-model="formData.flowProcessData"
placeholder="请输入流程配置"
type="textarea"
:autosize="{ minRows: 4, maxRows: 6 }"
/>
</el-form-item>
<el-form-item label="formValue" prop="formValue">
<el-input
v-model="formData.formValue"
placeholder="请输入流程配置"
type="textarea"
:autosize="{ minRows: 4, maxRows: 6 }"
/>
</el-form-item>
<!-- <el-form-item label="状态0待提交1审批中2审批完成3审批失败" prop="status">
<el-select
class="flex-1"
v-model.number="formData.status"
placeholder="请选择状态0待提交1审批中2审批完成3审批失败"
>
<el-option
v-for="(item, index) in dictData.flow_apply_status"
:key="index"
:label="item.name"
:value="item.value"
clearable
:disabled="!item.status"
/>
</el-select>
</el-form-item> -->
</el-form>
</popup>
</div>
</template>
<script lang="ts" setup>
import type { FormInstance } from 'element-plus'
import { flow_apply_edit, flow_apply_add, flow_apply_detail } from '@/api/flow_apply'
import { flow_template_lists_all } from '@/api/flow_template'
import Popup from '@/components/popup/index.vue'
import feedback from '@/utils/feedback'
import { shallowRef, ref, computed, reactive } from 'vue'
import type { PropType } from 'vue'
defineProps({
dictData: {
type: Object as PropType<Record<string, any[]>>,
default: () => ({})
}
})
const emit = defineEmits(['success', 'close'])
const formRef = shallowRef<FormInstance>()
const popupRef = shallowRef<InstanceType<typeof Popup>>()
const mode = ref('add')
const popupTitle = computed(() => {
return mode.value == 'edit' ? '编辑申请流程' : '新增申请流程'
})
const formData = reactive({
id: '',
templateId: '',
// applyUserId: '',
// applyUserNickname: '',
flowName: '',
flowGroup: '',
flowRemark: '',
flowFormData: '',
flowProcessData: '',
status: 0,
formValue: ''
})
const formRules = {
id: [
{
required: true,
message: '请输入',
trigger: ['blur']
}
],
templateId: [
{
required: true,
message: '请输入模板',
trigger: ['blur']
}
],
applyUserId: [
{
required: true,
message: '请输入申请人id',
trigger: ['blur']
}
],
applyUserNickname: [
{
required: true,
message: '请输入申请人昵称',
trigger: ['blur']
}
],
flowName: [
{
required: true,
message: '请输入流程名称',
trigger: ['blur']
}
],
flowGroup: [
{
required: true,
message: '请输入流程分类',
trigger: ['blur']
}
],
flowRemark: [
{
required: true,
message: '请输入流程描述',
trigger: ['blur']
}
],
flowFormData: [
{
required: true,
message: '请输入表单配置',
trigger: ['blur']
}
],
flowProcessData: [
{
required: true,
message: '请输入流程配置',
trigger: ['blur']
}
],
status: [
{
required: true,
message: '请选择状态0待提交1审批中2审批完成3审批失败',
trigger: ['blur']
}
]
}
const flow_template = ref([])
const get_flow_template = async () => {
flow_template.value = await flow_template_lists_all()
}
function handleTemplateChange(id: number) {
console.log(id)
flow_template.value.find((item: any) => {
if (item.id == id) {
formData.flowName = item.flowName
formData.flowGroup = item.flowGroup
formData.flowRemark = item.flowRemark
formData.flowFormData = item.flowFormData
formData.flowProcessData = item.flowProcessData
return true
}
})
}
get_flow_template()
const handleSubmit = async () => {
await formRef.value?.validate()
const data: any = { ...formData }
// if ( !data.id) {
// delete data.id
// }
mode.value == 'edit' ? await flow_apply_edit(data) : await flow_apply_add(data)
popupRef.value?.close()
feedback.msgSuccess('操作成功')
emit('success')
}
const open = (type = 'add') => {
mode.value = type
popupRef.value?.open()
}
const setFormData = async (data: Record<string, any>) => {
for (const key in formData) {
if (data[key] != null && data[key] != undefined) {
//@ts-ignore
formData[key] = data[key]
}
}
}
const getDetail = async (row: Record<string, any>) => {
const data = await flow_apply_detail({
id: row.id
})
setFormData(data)
}
const handleClose = () => {
emit('close')
}
defineExpose({
open,
setFormData,
getDetail
})
</script>

View File

@@ -0,0 +1,194 @@
<template>
<div class="index-lists">
<el-card class="!border-none" shadow="never">
<el-form ref="formRef" class="mb-[-16px]" :model="queryParams" :inline="true">
<el-form-item label="模板" prop="templateId">
<el-input class="w-[280px]" v-model="queryParams.templateId" />
</el-form-item>
<el-form-item label="申请人id" prop="applyUserId">
<el-input class="w-[280px]" v-model="queryParams.applyUserId" />
</el-form-item>
<el-form-item label="申请人昵称" prop="applyUserNickname">
<el-input class="w-[280px]" v-model="queryParams.applyUserNickname" />
</el-form-item>
<el-form-item label="流程名称" prop="flowName">
<el-input class="w-[280px]" v-model="queryParams.flowName" />
</el-form-item>
<el-form-item label="流程分类" prop="flowGroup">
<el-input class="w-[280px]" v-model="queryParams.flowGroup" />
</el-form-item>
<el-form-item label="流程描述" prop="flowRemark">
<el-input class="w-[280px]" v-model="queryParams.flowRemark" />
</el-form-item>
<el-form-item label="状态0待提交1审批中2审批完成3审批失败" prop="status">
<el-select v-model="queryParams.status" class="w-[280px]" clearable>
<el-option label="全部" value="" />
<el-option
v-for="(item, index) in dictData.flow_apply_status"
:key="index"
:label="item.name"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="resetPage">查询</el-button>
<el-button @click="resetParams">重置</el-button>
</el-form-item>
</el-form>
</el-card>
<el-card class="!border-none mt-4" shadow="never">
<div>
<el-button v-perms="['flow_apply:add']" type="primary" @click="handleAdd()">
<template #icon>
<icon name="el-icon-Plus" />
</template>
申请
</el-button>
</div>
<el-table class="mt-4" size="large" v-loading="pager.loading" :data="pager.lists">
<el-table-column label="模板" prop="templateId" min-width="100" />
<el-table-column label="申请人id" prop="applyUserId" min-width="100" />
<el-table-column label="申请人昵称" prop="applyUserNickname" min-width="100" />
<el-table-column label="流程名称" prop="flowName" min-width="100" />
<el-table-column label="流程分类" prop="flowGroup" min-width="100" />
<el-table-column label="流程描述" prop="flowRemark" min-width="100" />
<el-table-column label="formValue" prop="formValue" min-width="100" />
<el-table-column label="状态" prop="status" min-width="100">
<template #default="{ row }">
<dict-value :options="dictData.flow_apply_status" :value="row.status" />
</template>
</el-table-column>
<el-table-column label="更新时间" prop="updateTime" min-width="100" />
<el-table-column label="创建时间" prop="createTime" min-width="100" />
<el-table-column label="操作" width="120" fixed="right">
<template #default="{ row }">
<el-button
v-perms="['flow_apply:edit']"
type="primary"
link
@click="OpenViewForm(row)"
>
编辑表单
</el-button>
<el-button
v-perms="['flow_apply:edit']"
type="primary"
link
@click="handleEdit(row)"
>
编辑
</el-button>
<el-button
v-perms="['flow_apply:del']"
type="danger"
link
@click="handleDelete(row.id)"
>
删除
</el-button>
</template>
</el-table-column>
</el-table>
<div class="flex justify-end mt-4">
<pagination v-model="pager" @change="getLists" />
</div>
</el-card>
<edit-popup
v-if="showEdit"
ref="editRef"
:dict-data="dictData"
@success="getLists"
@close="showEdit = false"
/>
<ViewForm ref="viewFormRef" :save="SaveViewForm"></ViewForm>
</div>
</template>
<script lang="ts" setup>
import { flow_apply_delete, flow_apply_lists, flow_apply_edit } from '@/api/flow_apply'
import { useDictData } from '@/hooks/useDictOptions'
import { usePaging } from '@/hooks/usePaging'
import feedback from '@/utils/feedback'
import EditPopup from './edit.vue'
import ViewForm from '@/components/flow/XForm/view.vue'
defineOptions({
name: 'flow_apply'
})
const viewFormRef = shallowRef<InstanceType<typeof EditPopup>>()
const editRef = shallowRef<InstanceType<typeof EditPopup>>()
const showEdit = ref(false)
const queryParams = reactive({
templateId: '',
applyUserId: '',
applyUserNickname: '',
flowName: '',
flowGroup: '',
flowRemark: '',
flowFormData: '',
flowProcessData: '',
status: ''
})
const { pager, getLists, resetPage, resetParams } = usePaging({
fetchFun: flow_apply_lists,
params: queryParams
})
const { dictData } = useDictData<{
flow_apply_status: any[]
}>(['flow_apply_status'])
const handleAdd = async () => {
showEdit.value = true
await nextTick()
editRef.value?.open('add')
}
const handleEdit = async (data: any) => {
showEdit.value = true
await nextTick()
editRef.value?.open('edit')
editRef.value?.getDetail(data)
}
const handleDelete = async (id: number) => {
await feedback.confirm('确定要删除?')
await flow_apply_delete({ id })
feedback.msgSuccess('删除成功')
getLists()
}
const OpenViewForm = async (data: any) => {
let form_data = {}
try {
form_data = JSON.parse(data.formValue)
} catch (error) {}
let form_json = {}
try {
form_json = JSON.parse(data.flowFormData)
} catch (error) {}
console.log(data, form_data, form_json)
viewFormRef.value?.open(data.id, form_json, form_data)
}
const SaveViewForm = (id, form_data) => {
return new Promise((resolve, reject) => {
flow_apply_edit({
id: id,
formValue: JSON.stringify(form_data)
})
.then(() => {
feedback.msgSuccess('保存成功')
getLists()
resolve(true)
})
.catch((err) => {
feedback.msgError(err.message)
reject()
})
})
}
getLists()
</script>

View File

@@ -0,0 +1,208 @@
<template>
<div class="edit-popup">
<popup
ref="popupRef"
:title="popupTitle"
:async="true"
width="550px"
:clickModalClose="true"
@confirm="handleSubmit"
@close="handleClose"
>
<el-form ref="formRef" :model="formData" label-width="84px" :rules="formRules">
<el-form-item label="申请id" prop="applyId">
<el-input v-model="formData.applyId" placeholder="请输入申请id" />
</el-form-item>
<el-form-item label="模板id" prop="templateId">
<el-input v-model="formData.templateId" placeholder="请输入模板id" />
</el-form-item>
<el-form-item label="申请人id" prop="applyUserId">
<el-input v-model="formData.applyUserId" placeholder="请输入申请人id" />
</el-form-item>
<el-form-item label="申请人昵称" prop="applyUserNickname">
<el-input v-model="formData.applyUserNickname" placeholder="请输入申请人昵称" />
</el-form-item>
<el-form-item label="审批人id" prop="approverId">
<el-input v-model="formData.approverId" placeholder="请输入审批人id" />
</el-form-item>
<el-form-item label="审批用户昵称" prop="approverNickname">
<el-input v-model="formData.approverNickname" placeholder="请输入审批用户昵称" />
</el-form-item>
<el-form-item label="节点" prop="nodeId">
<el-input v-model="formData.nodeId" placeholder="请输入节点" />
</el-form-item>
<el-form-item label="表单值" prop="formValue">
<el-input
v-model="formData.formValue"
placeholder="请输入表单值"
type="textarea"
:autosize="{ minRows: 4, maxRows: 6 }"
/>
</el-form-item>
<el-form-item label="通过状态0待处理1通过2拒绝" prop="passStatus">
<el-radio-group v-model="formData.passStatus" placeholder="请选择通过状态0待处理1通过2拒绝">
<el-radio label="0">请选择字典生成</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="通过备注" prop="passRemark">
<el-input v-model="formData.passRemark" placeholder="请输入通过备注" />
</el-form-item>
</el-form>
</popup>
</div>
</template>
<script lang="ts" setup>
import type { FormInstance } from 'element-plus'
import { flow_history_edit, flow_history_add, flow_history_detail } from '@/api/flow_history'
import Popup from '@/components/popup/index.vue'
import feedback from '@/utils/feedback'
import type { PropType } from 'vue'
defineProps({
dictData: {
type: Object as PropType<Record<string, any[]>>,
default: () => ({})
}
})
const emit = defineEmits(['success', 'close'])
const formRef = shallowRef<FormInstance>()
const popupRef = shallowRef<InstanceType<typeof Popup>>()
const mode = ref('add')
const popupTitle = computed(() => {
return mode.value == 'edit' ? '编辑流程历史' : '新增流程历史'
})
const formData = reactive({
id: '',
applyId: '',
templateId: '',
applyUserId: '',
applyUserNickname: '',
approverId: '',
approverNickname: '',
nodeId: '',
formValue: '',
passStatus: '',
passRemark: '',
})
const formRules = {
id: [
{
required: true,
message: '请输入历史id',
trigger: ['blur']
}
],
applyId: [
{
required: true,
message: '请输入申请id',
trigger: ['blur']
}
],
templateId: [
{
required: true,
message: '请输入模板id',
trigger: ['blur']
}
],
applyUserId: [
{
required: true,
message: '请输入申请人id',
trigger: ['blur']
}
],
applyUserNickname: [
{
required: true,
message: '请输入申请人昵称',
trigger: ['blur']
}
],
approverId: [
{
required: true,
message: '请输入审批人id',
trigger: ['blur']
}
],
approverNickname: [
{
required: true,
message: '请输入审批用户昵称',
trigger: ['blur']
}
],
nodeId: [
{
required: true,
message: '请输入节点',
trigger: ['blur']
}
],
formValue: [
{
required: true,
message: '请输入表单值',
trigger: ['blur']
}
],
passStatus: [
{
required: true,
message: '请选择通过状态0待处理1通过2拒绝',
trigger: ['blur']
}
],
passRemark: [
{
required: true,
message: '请输入通过备注',
trigger: ['blur']
}
],
}
const handleSubmit = async () => {
await formRef.value?.validate()
const data: any = { ...formData }
mode.value == 'edit' ? await flow_history_edit(data) : await flow_history_add(data)
popupRef.value?.close()
feedback.msgSuccess('操作成功')
emit('success')
}
const open = (type = 'add') => {
mode.value = type
popupRef.value?.open()
}
const setFormData = async (data: Record<string, any>) => {
for (const key in formData) {
if (data[key] != null && data[key] != undefined) {
//@ts-ignore
formData[key] = data[key]
}
}
}
const getDetail = async (row: Record<string, any>) => {
const data = await flow_history_detail({
id: row.id
})
setFormData(data)
}
const handleClose = () => {
emit('close')
}
defineExpose({
open,
setFormData,
getDetail
})
</script>

View File

@@ -0,0 +1,143 @@
<template>
<div class="index-lists">
<el-card class="!border-none" shadow="never">
<el-form ref="formRef" class="mb-[-16px]" :model="queryParams" :inline="true">
<el-form-item label="申请id" prop="applyId">
<el-input class="w-[280px]" v-model="queryParams.applyId" />
</el-form-item>
<el-form-item label="模板id" prop="templateId">
<el-input class="w-[280px]" v-model="queryParams.templateId" />
</el-form-item>
<el-form-item label="申请人id" prop="applyUserId">
<el-input class="w-[280px]" v-model="queryParams.applyUserId" />
</el-form-item>
<el-form-item label="申请人昵称" prop="applyUserNickname">
<el-input class="w-[280px]" v-model="queryParams.applyUserNickname" />
</el-form-item>
<el-form-item label="审批人id" prop="approverId">
<el-input class="w-[280px]" v-model="queryParams.approverId" />
</el-form-item>
<el-form-item label="审批用户昵称" prop="approverNickname">
<el-input class="w-[280px]" v-model="queryParams.approverNickname" />
</el-form-item>
<el-form-item label="节点" prop="nodeId">
<el-input class="w-[280px]" v-model="queryParams.nodeId" />
</el-form-item>
<el-form-item label="通过状态0待处理1通过2拒绝" prop="passStatus">
<el-select v-model="queryParams.passStatus" class="w-[280px]" clearable>
<el-option label="请选择字典生成" value="" />
</el-select>
</el-form-item>
<el-form-item label="通过备注" prop="passRemark">
<el-input class="w-[280px]" v-model="queryParams.passRemark" />
</el-form-item>
<el-form-item>
<el-button type="primary" @click="resetPage">查询</el-button>
<el-button @click="resetParams">重置</el-button>
</el-form-item>
</el-form>
</el-card>
<el-card class="!border-none mt-4" shadow="never">
<div>
<el-button v-perms="['flow_history:add']" type="primary" @click="handleAdd()">
<template #icon>
<icon name="el-icon-Plus" />
</template>
新增
</el-button>
</div>
<el-table class="mt-4" size="large" v-loading="pager.loading" :data="pager.lists">
<el-table-column label="申请id" prop="applyId" min-width="100" />
<el-table-column label="模板id" prop="templateId" min-width="100" />
<el-table-column label="申请人id" prop="applyUserId" min-width="100" />
<el-table-column label="申请人昵称" prop="applyUserNickname" min-width="100" />
<el-table-column label="审批人id" prop="approverId" min-width="100" />
<el-table-column label="审批用户昵称" prop="approverNickname" min-width="100" />
<el-table-column label="节点" prop="nodeId" min-width="100" />
<el-table-column label="表单值" prop="formValue" min-width="100" />
<el-table-column
label="通过状态0待处理1通过2拒绝"
prop="passStatus"
min-width="100"
/>
<el-table-column label="通过备注" prop="passRemark" min-width="100" />
<el-table-column label="更新时间" prop="updateTime" min-width="100" />
<el-table-column label="创建时间" prop="createTime" min-width="100" />
<el-table-column label="操作" width="120" fixed="right">
<template #default="{ row }">
<el-button
v-perms="['flow_history:edit']"
type="primary"
link
@click="handleEdit(row)"
>
编辑
</el-button>
<el-button
v-perms="['flow_history:del']"
type="danger"
link
@click="handleDelete(row.id)"
>
删除
</el-button>
</template>
</el-table-column>
</el-table>
<div class="flex justify-end mt-4">
<pagination v-model="pager" @change="getLists" />
</div>
</el-card>
<edit-popup v-if="showEdit" ref="editRef" @success="getLists" @close="showEdit = false" />
</div>
</template>
<script lang="ts" setup>
import { flow_history_delete, flow_history_list } from '@/api/flow_history'
import { usePaging } from '@/hooks/usePaging'
import feedback from '@/utils/feedback'
import EditPopup from './edit.vue'
defineOptions({
name: 'flow_history'
})
const editRef = shallowRef<InstanceType<typeof EditPopup>>()
const showEdit = ref(false)
const queryParams = reactive({
applyId: '',
templateId: '',
applyUserId: '',
applyUserNickname: '',
approverId: '',
approverNickname: '',
nodeId: '',
formValue: '',
passStatus: '',
passRemark: ''
})
const { pager, getLists, resetPage, resetParams } = usePaging({
fetchFun: flow_history_list,
params: queryParams
})
const handleAdd = async () => {
showEdit.value = true
await nextTick()
editRef.value?.open('add')
}
const handleEdit = async (data: any) => {
showEdit.value = true
await nextTick()
editRef.value?.open('edit')
editRef.value?.getDetail(data)
}
const handleDelete = async (id: number) => {
await feedback.confirm('确定要删除?')
await flow_history_delete({ id })
feedback.msgSuccess('删除成功')
getLists()
}
getLists()
</script>

View File

@@ -10,6 +10,7 @@
"compilerOptions": {
"module": "esnext",
"moduleResolution": "node",
"allowJs": true,
"isolatedModules": true,
"baseUrl": ".",
"paths": {

View File

@@ -47,6 +47,8 @@ func RegisterGroup(rg *gin.RouterGroup) {
ArticleCollectRoute(rg)
FlowTemplateRoute(rg)
FlowApplyRoute(rg)
FlowHistoryRoute(rg)
captcha.CaptchaRoute(rg)
}

View File

@@ -0,0 +1,129 @@
package flow_apply
import (
"x_admin/config"
"x_admin/core/request"
"x_admin/core/response"
"x_admin/util"
"github.com/gin-gonic/gin"
)
type FlowApplyHandler struct {
Service IFlowApplyService
}
// @Summary 申请流程列表
// @Tags flow_apply-申请流程
// @Produce json
// @Param Token header string true "token"
// @Param PageNo query int true "页码"
// @Param PageSize query int true "每页数量"
// @Param templateId query int false "模板"
// @Param applyUserId query int false "申请人id"
// @Param applyUserNickname query string false "申请人昵称"
// @Param flowName query string false "流程名称"
// @Param flowGroup query int false "流程分类"
// @Param flowRemark query string false "流程描述"
// @Param flowFormData query string false "表单配置"
// @Param flowProcessData query string false "流程配置"
// @Param status query int false "状态0待提交1审批中2审批完成3审批失败"
// @Success 200 {object} []FlowApplyResp "成功"
// @Failure 400 {object} string "请求错误"
// @Router /api/flow_apply/list [get]
func (hd FlowApplyHandler) List(c *gin.Context) {
var page request.PageReq
var listReq FlowApplyListReq
if response.IsFailWithResp(c, util.VerifyUtil.VerifyQuery(c, &page)) {
return
}
if response.IsFailWithResp(c, util.VerifyUtil.VerifyQuery(c, &listReq)) {
return
}
res, err := hd.Service.List(page, listReq)
response.CheckAndRespWithData(c, res, err)
}
// @Summary 申请流程详情
// @Tags flow_apply-申请流程
// @Produce json
// @Param Token header string true "token"
// @Param id query int false ""
// @Success 200 {object} FlowApplyResp "成功"
// @Router /api/flow_apply/detail [get]
func (hd FlowApplyHandler) Detail(c *gin.Context) {
var detailReq FlowApplyDetailReq
if response.IsFailWithResp(c, util.VerifyUtil.VerifyQuery(c, &detailReq)) {
return
}
res, err := hd.Service.Detail(detailReq.Id)
response.CheckAndRespWithData(c, res, err)
}
// @Summary 申请流程新增
// @Tags flow_apply-申请流程
// @Produce json
// @Param Token header string true "token"
// @Param templateId body int false "模板"
// @Param applyUserId body int false "申请人id"
// @Param applyUserNickname body string false "申请人昵称"
// @Param flowName body string false "流程名称"
// @Param flowGroup body int false "流程分类"
// @Param flowRemark body string false "流程描述"
// @Param flowFormData body string false "表单配置"
// @Param flowProcessData body string false "流程配置"
// @Param status body int false "状态0待提交1审批中2审批完成3审批失败"
// @Success 200 {object} response.RespType "成功"
// @Router /api/flow_apply/add [post]
func (hd FlowApplyHandler) Add(c *gin.Context) {
var addReq FlowApplyAddReq
if response.IsFailWithResp(c, util.VerifyUtil.VerifyBody(c, &addReq)) {
return
}
var Nickname = config.AdminConfig.GetNickname(c)
var AdminId = config.AdminConfig.GetAdminId(c)
addReq.ApplyUserNickname = Nickname
addReq.ApplyUserId = int(AdminId)
response.CheckAndResp(c, hd.Service.Add(addReq))
}
// @Summary 申请流程编辑
// @Tags flow_apply-申请流程
// @Produce json
// @Param Token header string true "token"
// @Param id body int false ""
// @Param templateId body int false "模板"
// @Param applyUserId body int false "申请人id"
// @Param applyUserNickname body string false "申请人昵称"
// @Param flowName body string false "流程名称"
// @Param flowGroup body int false "流程分类"
// @Param flowRemark body string false "流程描述"
// @Param flowFormData body string false "表单配置"
// @Param flowProcessData body string false "流程配置"
// @Param status body int false "状态0待提交1审批中2审批完成3审批失败"
// @Success 200 {object} response.RespType "成功"
// @Router /api/flow_apply/edit [post]
func (hd FlowApplyHandler) Edit(c *gin.Context) {
var editReq FlowApplyEditReq
if response.IsFailWithResp(c, util.VerifyUtil.VerifyBody(c, &editReq)) {
return
}
response.CheckAndResp(c, hd.Service.Edit(editReq))
}
// @Summary 申请流程删除
// @Tags flow_apply-申请流程
// @Produce json
// @Param Token header string true "token"
// @Param id body int false ""
// @Success 200 {object} response.RespType "成功"
// @Router /api/flow_apply/del [post]
func (hd FlowApplyHandler) Del(c *gin.Context) {
var delReq FlowApplyDelReq
if response.IsFailWithResp(c, util.VerifyUtil.VerifyBody(c, &delReq)) {
return
}
response.CheckAndResp(c, hd.Service.Del(delReq.Id))
}

View File

@@ -0,0 +1,73 @@
package flow_apply
import "x_admin/core"
//FlowApplyListReq 申请流程列表参数
type FlowApplyListReq struct {
TemplateId int `form:"templateId"` // 模板
ApplyUserId int `form:"applyUserId"` // 申请人id
ApplyUserNickname string `form:"applyUserNickname"` // 申请人昵称
FlowName string `form:"flowName"` // 流程名称
FlowGroup int `form:"flowGroup"` // 流程分类
FlowRemark string `form:"flowRemark"` // 流程描述
FlowFormData string `form:"flowFormData"` // 表单配置
FlowProcessData string `form:"flowProcessData"` // 流程配置
FormValue string `form:"formValue"` // 表单值
Status int `form:"status"` // 状态0待提交1审批中2审批完成3审批失败
}
//FlowApplyDetailReq 申请流程详情参数
type FlowApplyDetailReq struct {
Id int `form:"id"` //
}
//FlowApplyAddReq 申请流程新增参数
type FlowApplyAddReq struct {
TemplateId int `form:"templateId"` // 模板
ApplyUserId int `form:"applyUserId"` // 申请人id
ApplyUserNickname string `form:"applyUserNickname"` // 申请人昵称
FlowName string `form:"flowName"` // 流程名称
FlowGroup int `form:"flowGroup"` // 流程分类
FlowRemark string `form:"flowRemark"` // 流程描述
FlowFormData string `form:"flowFormData"` // 表单配置
FlowProcessData string `form:"flowProcessData"` // 流程配置
FormValue string `form:"formValue"` // 表单值
Status int `form:"status"` // 状态0待提交1审批中2审批完成3审批失败
}
//FlowApplyEditReq 申请流程新增参数
type FlowApplyEditReq struct {
Id int `form:"id"` //
TemplateId int `form:"templateId"` // 模板
ApplyUserId int `form:"applyUserId"` // 申请人id
ApplyUserNickname string `form:"applyUserNickname"` // 申请人昵称
FlowName string `form:"flowName"` // 流程名称
FlowGroup int `form:"flowGroup"` // 流程分类
FlowRemark string `form:"flowRemark"` // 流程描述
FlowFormData string `form:"flowFormData"` // 表单配置
FlowProcessData string `form:"flowProcessData"` // 流程配置
FormValue string `form:"formValue"` // 表单值
Status int `form:"status"` // 状态0待提交1审批中2审批完成3审批失败
}
//FlowApplyDelReq 申请流程新增参数
type FlowApplyDelReq struct {
Id int `form:"id"` //
}
//FlowApplyResp 申请流程返回信息
type FlowApplyResp struct {
Id int `json:"id" structs:"id"` //
TemplateId int `json:"templateId" structs:"templateId"` // 模板
ApplyUserId int `json:"applyUserId" structs:"applyUserId"` // 申请人id
ApplyUserNickname string `json:"applyUserNickname" structs:"applyUserNickname"` // 申请人昵称
FlowName string `json:"flowName" structs:"flowName"` // 流程名称
FlowGroup int `json:"flowGroup" structs:"flowGroup"` // 流程分类
FlowRemark string `json:"flowRemark" structs:"flowRemark"` // 流程描述
FlowFormData string `json:"flowFormData" structs:"flowFormData"` // 表单配置
FlowProcessData string `json:"flowProcessData" structs:"flowProcessData"` // 流程配置
FormValue string `json:"formValue"` // 表单值
Status int `json:"status" structs:"status"` // 状态0待提交1审批中2审批完成3审批失败
UpdateTime core.TsTime `json:"updateTime" structs:"updateTime"` // 更新时间
CreateTime core.TsTime `json:"createTime" structs:"createTime"` // 创建时间
}

View File

@@ -0,0 +1,142 @@
package flow_apply
import (
"x_admin/core/request"
"x_admin/core/response"
"x_admin/model"
"gorm.io/gorm"
)
type IFlowApplyService interface {
List(page request.PageReq, listReq FlowApplyListReq) (res response.PageResp, e error)
Detail(id int) (res FlowApplyResp, e error)
Add(addReq FlowApplyAddReq) (e error)
Edit(editReq FlowApplyEditReq) (e error)
Del(id int) (e error)
}
// NewFlowApplyService 初始化
func NewFlowApplyService(db *gorm.DB) IFlowApplyService {
return &flowApplyService{db: db}
}
// flowApplyService 申请流程服务实现类
type flowApplyService struct {
db *gorm.DB
}
// List 申请流程列表
func (Service flowApplyService) List(page request.PageReq, listReq FlowApplyListReq) (res response.PageResp, e error) {
// 分页信息
limit := page.PageSize
offset := page.PageSize * (page.PageNo - 1)
// 查询
dbModel := Service.db.Model(&model.FlowApply{})
if listReq.TemplateId > 0 {
dbModel = dbModel.Where("template_id = ?", listReq.TemplateId)
}
if listReq.ApplyUserId > 0 {
dbModel = dbModel.Where("apply_user_id = ?", listReq.ApplyUserId)
}
if listReq.ApplyUserNickname != "" {
dbModel = dbModel.Where("apply_user_nickname like ?", "%"+listReq.ApplyUserNickname+"%")
}
if listReq.FlowName != "" {
dbModel = dbModel.Where("flow_name like ?", "%"+listReq.FlowName+"%")
}
if listReq.FlowGroup > 0 {
dbModel = dbModel.Where("flow_group = ?", listReq.FlowGroup)
}
if listReq.FlowRemark != "" {
dbModel = dbModel.Where("flow_remark = ?", listReq.FlowRemark)
}
if listReq.FlowFormData != "" {
dbModel = dbModel.Where("flow_form_data = ?", listReq.FlowFormData)
}
if listReq.FlowProcessData != "" {
dbModel = dbModel.Where("flow_process_data = ?", listReq.FlowProcessData)
}
if listReq.Status > 0 {
dbModel = dbModel.Where("status = ?", listReq.Status)
}
// 总数
var count int64
err := dbModel.Count(&count).Error
if e = response.CheckErr(err, "List Count err"); e != nil {
return
}
// 数据
var objs []model.FlowApply
err = dbModel.Limit(limit).Offset(offset).Order("id desc").Find(&objs).Error
if e = response.CheckErr(err, "List Find err"); e != nil {
return
}
resps := []FlowApplyResp{}
response.Copy(&resps, objs)
return response.PageResp{
PageNo: page.PageNo,
PageSize: page.PageSize,
Count: count,
Lists: resps,
}, nil
}
// Detail 申请流程详情
func (Service flowApplyService) Detail(id int) (res FlowApplyResp, e error) {
var obj model.FlowApply
err := Service.db.Where("id = ?", id).Limit(1).First(&obj).Error
if e = response.CheckErrDBNotRecord(err, "数据不存在!"); e != nil {
return
}
if e = response.CheckErr(err, "Detail First err"); e != nil {
return
}
response.Copy(&res, obj)
return
}
// Add 申请流程新增
func (Service flowApplyService) Add(addReq FlowApplyAddReq) (e error) {
var obj model.FlowApply
response.Copy(&obj, addReq)
err := Service.db.Create(&obj).Error
e = response.CheckErr(err, "Add Create err")
return
}
// Edit 申请流程编辑
func (Service flowApplyService) Edit(editReq FlowApplyEditReq) (e error) {
var obj model.FlowApply
err := Service.db.Where("id = ?", editReq.Id).Limit(1).First(&obj).Error
// 校验
if e = response.CheckErrDBNotRecord(err, "数据不存在!"); e != nil {
return
}
if e = response.CheckErr(err, "Edit First err"); e != nil {
return
}
// 更新
response.Copy(&obj, editReq)
err = Service.db.Model(&obj).Updates(obj).Error
e = response.CheckErr(err, "Edit Updates err")
return
}
// Del 申请流程删除
func (Service flowApplyService) Del(id int) (e error) {
var obj model.FlowApply
err := Service.db.Where("id = ?", id).Limit(1).First(&obj).Error
// 校验
if e = response.CheckErrDBNotRecord(err, "数据不存在!"); e != nil {
return
}
if e = response.CheckErr(err, "Del First err"); e != nil {
return
}
// 删除
err = Service.db.Delete(&obj).Error
e = response.CheckErr(err, "Del Delete err")
return
}

View File

@@ -0,0 +1,42 @@
package admin
import (
"github.com/gin-gonic/gin"
"x_admin/core"
"x_admin/middleware"
"x_admin/admin/flow_apply"
)
/**
集成
1. 导入
- 请先提交git避免文件覆盖!!!
- 下载并解压压缩包后直接复制server、admin文件夹到项目根目录即可
2. 注册路由
请在 admin/entry.go 文件引入FlowApplyRoute注册路由
3. 后台手动添加菜单和按钮
flow_apply:add
flow_apply:edit
flow_apply:del
flow_apply:list
flow_apply:detail
*/
// FlowApplyRoute(rg)
func FlowApplyRoute(rg *gin.RouterGroup) {
db := core.GetDB()
server := flow_apply.NewFlowApplyService(db)
handle := flow_apply.FlowApplyHandler{Service: server}
rg = rg.Group("/", middleware.TokenAuth())
rg.GET("/flow_apply/list", handle.List)
rg.GET("/flow_apply/detail", handle.Detail)
rg.POST("/flow_apply/add", handle.Add)
rg.POST("/flow_apply/edit", handle.Edit)
rg.POST("/flow_apply/del", handle.Del)
}

View File

@@ -0,0 +1,154 @@
package flow_history
import (
"x_admin/core/request"
"x_admin/core/response"
"x_admin/util"
"github.com/gin-gonic/gin"
)
type FlowHistoryHandler struct {
Service IFlowHistoryService
}
// @Summary 流程历史列表
// @Tags flow_history-流程历史
// @Produce json
// @Param Token header string true "token"
// @Param PageNo query int true "页码"
// @Param PageSize query int true "每页数量"
// @Param applyId query int false "申请id"
// @Param templateId query int false "模板id"
// @Param applyUserId query int false "申请人id"
// @Param applyUserNickname query string false "申请人昵称"
// @Param approverId query int false "审批人id"
// @Param approverNickname query string false "审批用户昵称"
// @Param nodeId query string false "节点"
// @Param formValue query string false "表单值"
// @Param passStatus query int false "通过状态0待处理1通过2拒绝"
// @Param passRemark query string false "通过备注"
// @Success 200 {object} []FlowHistoryResp "成功"
// @Failure 400 {object} string "请求错误"
// @Router /api/flow_history/list [get]
func (hd FlowHistoryHandler) List(c *gin.Context) {
var page request.PageReq
var listReq FlowHistoryListReq
if response.IsFailWithResp(c, util.VerifyUtil.VerifyQuery(c, &page)) {
return
}
if response.IsFailWithResp(c, util.VerifyUtil.VerifyQuery(c, &listReq)) {
return
}
res, err := hd.Service.List(page, listReq)
response.CheckAndRespWithData(c, res, err)
}
// @Summary 流程历史列表-所有
// @Tags flow_history-流程历史
// @Produce json
// @Success 200 {object} []FlowHistoryResp "成功"
// @Router /api/flow_history/list [get]
func (hd FlowHistoryHandler) ListAll(c *gin.Context) {
res, err := hd.Service.ListAll()
response.CheckAndRespWithData(c, res, err)
}
// @Summary 流程历史详情
// @Tags flow_history-流程历史
// @Produce json
// @Param Token header string true "token"
// @Param id query int false "历史id"
// @Success 200 {object} FlowHistoryResp "成功"
// @Router /api/flow_history/detail [get]
func (hd FlowHistoryHandler) Detail(c *gin.Context) {
var detailReq FlowHistoryDetailReq
if response.IsFailWithResp(c, util.VerifyUtil.VerifyQuery(c, &detailReq)) {
return
}
res, err := hd.Service.Detail(detailReq.Id)
response.CheckAndRespWithData(c, res, err)
}
// @Summary 流程历史新增
// @Tags flow_history-流程历史
// @Produce json
// @Param Token header string true "token"
// @Param applyId body int false "申请id"
// @Param templateId body int false "模板id"
// @Param applyUserId body int false "申请人id"
// @Param applyUserNickname body string false "申请人昵称"
// @Param approverId body int false "审批人id"
// @Param approverNickname body string false "审批用户昵称"
// @Param nodeId body string false "节点"
// @Param formValue body string false "表单值"
// @Param passStatus body int false "通过状态0待处理1通过2拒绝"
// @Param passRemark body string false "通过备注"
// @Success 200 {object} response.RespType "成功"
// @Router /api/flow_history/add [post]
func (hd FlowHistoryHandler) Add(c *gin.Context) {
var addReq FlowHistoryAddReq
if response.IsFailWithResp(c, util.VerifyUtil.VerifyBody(c, &addReq)) {
return
}
response.CheckAndResp(c, hd.Service.Add(addReq))
}
// @Summary 流程历史编辑
// @Tags flow_history-流程历史
// @Produce json
// @Param Token header string true "token"
// @Param id body int false "历史id"
// @Param applyId body int false "申请id"
// @Param templateId body int false "模板id"
// @Param applyUserId body int false "申请人id"
// @Param applyUserNickname body string false "申请人昵称"
// @Param approverId body int false "审批人id"
// @Param approverNickname body string false "审批用户昵称"
// @Param nodeId body string false "节点"
// @Param formValue body string false "表单值"
// @Param passStatus body int false "通过状态0待处理1通过2拒绝"
// @Param passRemark body string false "通过备注"
// @Success 200 {object} response.RespType "成功"
// @Router /api/flow_history/edit [post]
func (hd FlowHistoryHandler) Edit(c *gin.Context) {
var editReq FlowHistoryEditReq
if response.IsFailWithResp(c, util.VerifyUtil.VerifyBody(c, &editReq)) {
return
}
response.CheckAndResp(c, hd.Service.Edit(editReq))
}
// @Summary 流程历史删除
// @Tags flow_history-流程历史
// @Produce json
// @Param Token header string true "token"
// @Param id body int false "历史id"
// @Success 200 {object} response.RespType "成功"
// @Router /api/flow_history/del [post]
func (hd FlowHistoryHandler) Del(c *gin.Context) {
var delReq FlowHistoryDelReq
if response.IsFailWithResp(c, util.VerifyUtil.VerifyBody(c, &delReq)) {
return
}
response.CheckAndResp(c, hd.Service.Del(delReq.Id))
}
type FlowTree struct {
Id string `json:"id"`
Pid string `json:"pid"`
Type string `json:"type"`
User string `json:"user"`
// FieldAuth map[string]int `json:"fieldAuth"`
Children *FlowTree
}
// 提交申请
// 获取下一个审批节点,中间可能存在系统任务节点和网关
// 同意审批(当前nodeId)
// 拒绝审批,驳回审批

View File

@@ -0,0 +1,73 @@
package flow_history
import "x_admin/core"
//FlowHistoryListReq 流程历史列表参数
type FlowHistoryListReq struct {
ApplyId int `form:"applyId"` // 申请id
TemplateId int `form:"templateId"` // 模板id
ApplyUserId int `form:"applyUserId"` // 申请人id
ApplyUserNickname string `form:"applyUserNickname"` // 申请人昵称
ApproverId int `form:"approverId"` // 审批人id
ApproverNickname string `form:"approverNickname"` // 审批用户昵称
NodeId string `form:"nodeId"` // 节点
FormValue string `form:"formValue"` // 表单值
PassStatus int `form:"passStatus"` // 通过状态0待处理1通过2拒绝
PassRemark string `form:"passRemark"` // 通过备注
}
//FlowHistoryDetailReq 流程历史详情参数
type FlowHistoryDetailReq struct {
Id int `form:"id"` // 历史id
}
//FlowHistoryAddReq 流程历史新增参数
type FlowHistoryAddReq struct {
ApplyId int `form:"applyId"` // 申请id
TemplateId int `form:"templateId"` // 模板id
ApplyUserId int `form:"applyUserId"` // 申请人id
ApplyUserNickname string `form:"applyUserNickname"` // 申请人昵称
ApproverId int `form:"approverId"` // 审批人id
ApproverNickname string `form:"approverNickname"` // 审批用户昵称
NodeId string `form:"nodeId"` // 节点
FormValue string `form:"formValue"` // 表单值
PassStatus int `form:"passStatus"` // 通过状态0待处理1通过2拒绝
PassRemark string `form:"passRemark"` // 通过备注
}
//FlowHistoryEditReq 流程历史新增参数
type FlowHistoryEditReq struct {
Id int `form:"id"` // 历史id
ApplyId int `form:"applyId"` // 申请id
TemplateId int `form:"templateId"` // 模板id
ApplyUserId int `form:"applyUserId"` // 申请人id
ApplyUserNickname string `form:"applyUserNickname"` // 申请人昵称
ApproverId int `form:"approverId"` // 审批人id
ApproverNickname string `form:"approverNickname"` // 审批用户昵称
NodeId string `form:"nodeId"` // 节点
FormValue string `form:"formValue"` // 表单值
PassStatus int `form:"passStatus"` // 通过状态0待处理1通过2拒绝
PassRemark string `form:"passRemark"` // 通过备注
}
//FlowHistoryDelReq 流程历史新增参数
type FlowHistoryDelReq struct {
Id int `form:"id"` // 历史id
}
//FlowHistoryResp 流程历史返回信息
type FlowHistoryResp struct {
Id int `json:"id" structs:"id"` // 历史id
ApplyId int `json:"applyId" structs:"applyId"` // 申请id
TemplateId int `json:"templateId" structs:"templateId"` // 模板id
ApplyUserId int `json:"applyUserId" structs:"applyUserId"` // 申请人id
ApplyUserNickname string `json:"applyUserNickname" structs:"applyUserNickname"` // 申请人昵称
ApproverId int `json:"approverId" structs:"approverId"` // 审批人id
ApproverNickname string `json:"approverNickname" structs:"approverNickname"` // 审批用户昵称
NodeId string `json:"nodeId" structs:"nodeId"` // 节点
FormValue string `json:"formValue" structs:"formValue"` // 表单值
PassStatus int `json:"passStatus" structs:"passStatus"` // 通过状态0待处理1通过2拒绝
PassRemark string `json:"passRemark" structs:"passRemark"` // 通过备注
UpdateTime core.TsTime `json:"updateTime" structs:"updateTime"` // 更新时间
CreateTime core.TsTime `json:"createTime" structs:"createTime"` // 创建时间
}

View File

@@ -0,0 +1,156 @@
package flow_history
import (
"x_admin/core/request"
"x_admin/core/response"
"x_admin/model"
"gorm.io/gorm"
)
type IFlowHistoryService interface {
List(page request.PageReq, listReq FlowHistoryListReq) (res response.PageResp, e error)
ListAll() (res []FlowHistoryResp, e error)
Detail(id int) (res FlowHistoryResp, e error)
Add(addReq FlowHistoryAddReq) (e error)
Edit(editReq FlowHistoryEditReq) (e error)
Del(id int) (e error)
}
//NewFlowHistoryService 初始化
func NewFlowHistoryService(db *gorm.DB) IFlowHistoryService {
return &flowHistoryService{db: db}
}
//flowHistoryService 流程历史服务实现类
type flowHistoryService struct {
db *gorm.DB
}
//List 流程历史列表
func (Service flowHistoryService) List(page request.PageReq, listReq FlowHistoryListReq) (res response.PageResp, e error) {
// 分页信息
limit := page.PageSize
offset := page.PageSize * (page.PageNo - 1)
// 查询
dbModel := Service.db.Model(&model.FlowHistory{})
if listReq.ApplyId > 0 {
dbModel = dbModel.Where("apply_id = ?", listReq.ApplyId)
}
if listReq.TemplateId > 0 {
dbModel = dbModel.Where("template_id = ?", listReq.TemplateId)
}
if listReq.ApplyUserId > 0 {
dbModel = dbModel.Where("apply_user_id = ?", listReq.ApplyUserId)
}
if listReq.ApplyUserNickname != "" {
dbModel = dbModel.Where("apply_user_nickname like ?", "%"+listReq.ApplyUserNickname+"%")
}
if listReq.ApproverId > 0 {
dbModel = dbModel.Where("approver_id = ?", listReq.ApproverId)
}
if listReq.ApproverNickname != "" {
dbModel = dbModel.Where("approver_nickname like ?", "%"+listReq.ApproverNickname+"%")
}
if listReq.NodeId != "" {
dbModel = dbModel.Where("node_id = ?", listReq.NodeId)
}
if listReq.FormValue != "" {
dbModel = dbModel.Where("form_value = ?", listReq.FormValue)
}
if listReq.PassStatus > 0 {
dbModel = dbModel.Where("pass_status = ?", listReq.PassStatus)
}
if listReq.PassRemark != "" {
dbModel = dbModel.Where("pass_remark = ?", listReq.PassRemark)
}
// 总数
var count int64
err := dbModel.Count(&count).Error
if e = response.CheckErr(err, "List Count err"); e != nil {
return
}
// 数据
var objs []model.FlowHistory
err = dbModel.Limit(limit).Offset(offset).Order("id desc").Find(&objs).Error
if e = response.CheckErr(err, "List Find err"); e != nil {
return
}
resps := []FlowHistoryResp{}
response.Copy(&resps, objs)
return response.PageResp{
PageNo: page.PageNo,
PageSize: page.PageSize,
Count: count,
Lists: resps,
}, nil
}
//ListAll 流程历史列表
func (Service flowHistoryService) ListAll() (res []FlowHistoryResp, e error) {
var objs model.FlowHistory
err := Service.db.Find(&objs).Error
if e = response.CheckErr(err, "ListAll Find err"); e != nil {
return
}
response.Copy(&res, objs)
return res, nil
}
//Detail 流程历史详情
func (Service flowHistoryService) Detail(id int) (res FlowHistoryResp, e error) {
var obj model.FlowHistory
err := Service.db.Where("id = ?", id).Limit(1).First(&obj).Error
if e = response.CheckErrDBNotRecord(err, "数据不存在!"); e != nil {
return
}
if e = response.CheckErr(err, "Detail First err"); e != nil {
return
}
response.Copy(&res, obj)
return
}
//Add 流程历史新增
func (Service flowHistoryService) Add(addReq FlowHistoryAddReq) (e error) {
var obj model.FlowHistory
response.Copy(&obj, addReq)
err := Service.db.Create(&obj).Error
e = response.CheckErr(err, "Add Create err")
return
}
//Edit 流程历史编辑
func (Service flowHistoryService) Edit(editReq FlowHistoryEditReq) (e error) {
var obj model.FlowHistory
err := Service.db.Where("id = ?", editReq.Id).Limit(1).First(&obj).Error
// 校验
if e = response.CheckErrDBNotRecord(err, "数据不存在!"); e != nil {
return
}
if e = response.CheckErr(err, "Edit First err"); e != nil {
return
}
// 更新
response.Copy(&obj, editReq)
err = Service.db.Model(&obj).Updates(obj).Error
e = response.CheckErr(err, "Edit Updates err")
return
}
//Del 流程历史删除
func (Service flowHistoryService) Del(id int) (e error) {
var obj model.FlowHistory
err := Service.db.Where("id = ?", id).Limit(1).First(&obj).Error
// 校验
if e = response.CheckErrDBNotRecord(err, "数据不存在!"); e != nil {
return
}
if e = response.CheckErr(err, "Del First err"); e != nil {
return
}
// 删除
err = Service.db.Delete(&obj).Error
e = response.CheckErr(err, "Del Delete err")
return
}

View File

@@ -0,0 +1,44 @@
package admin
import (
"github.com/gin-gonic/gin"
"x_admin/core"
"x_admin/middleware"
"x_admin/admin/flow_history"
)
/**
集成
1. 导入
- 请先提交git避免文件覆盖!!!
- 下载并解压压缩包后直接复制server、admin文件夹到项目根目录即可
2. 注册路由
请在 admin/entry.go 文件引入FlowHistoryRoute注册路由
3. 后台手动添加菜单和按钮
flow_history:add
flow_history:edit
flow_history:del
flow_history:list
flow_history:listAll
flow_history:detail
*/
// FlowHistoryRoute(rg)
func FlowHistoryRoute(rg *gin.RouterGroup) {
db := core.GetDB()
server := flow_history.NewFlowHistoryService(db)
handle := flow_history.FlowHistoryHandler{Service: server}
rg = rg.Group("/", middleware.TokenAuth())
rg.GET("/flow_history/list", handle.List)
rg.GET("/flow_history/listAll", handle.ListAll)
rg.GET("/flow_history/detail", handle.Detail)
rg.POST("/flow_history/add", handle.Add)
rg.POST("/flow_history/edit", handle.Edit)
rg.POST("/flow_history/del", handle.Del)
}

View File

@@ -1,12 +1,12 @@
package flow_template
import (
"github.com/gin-gonic/gin"
"x_admin/core/request"
"x_admin/core/response"
"x_admin/util"
)
"github.com/gin-gonic/gin"
)
type FlowTemplateHandler struct {
Service IFlowTemplateService
@@ -39,6 +39,14 @@ func (hd FlowTemplateHandler) List(c *gin.Context) {
response.CheckAndRespWithData(c, res, err)
}
// @Summary 流程模板列表-所有
// @Tags flow_template-流程模板
// @Router /api/flow_template/listAll [get]
func (hd FlowTemplateHandler) ListAll(c *gin.Context) {
res, err := hd.Service.ListAll()
response.CheckAndRespWithData(c, res, err)
}
// @Summary 流程模板详情
// @Tags flow_template-流程模板
// @Produce json
@@ -55,7 +63,6 @@ func (hd FlowTemplateHandler) Detail(c *gin.Context) {
response.CheckAndRespWithData(c, res, err)
}
// @Summary 流程模板新增
// @Tags flow_template-流程模板
// @Produce json
@@ -74,6 +81,7 @@ func (hd FlowTemplateHandler) Add(c *gin.Context) {
}
response.CheckAndResp(c, hd.Service.Add(addReq))
}
// @Summary 流程模板编辑
// @Tags flow_template-流程模板
// @Produce json
@@ -93,6 +101,7 @@ func (hd FlowTemplateHandler) Edit(c *gin.Context) {
}
response.CheckAndResp(c, hd.Service.Edit(editReq))
}
// @Summary 流程模板删除
// @Tags flow_template-流程模板
// @Produce json

View File

@@ -21,6 +21,7 @@ type FlowTemplateAddReq struct {
FlowRemark string `form:"flowRemark"` // 流程描述
FlowFormData string `form:"flowFormData"` // 表单配置
FlowProcessData string `form:"flowProcessData"` // 流程配置
}
//FlowTemplateEditReq 流程模板新增参数
@@ -31,6 +32,7 @@ type FlowTemplateEditReq struct {
FlowRemark string `form:"flowRemark"` // 流程描述
FlowFormData string `form:"flowFormData"` // 表单配置
FlowProcessData string `form:"flowProcessData"` // 流程配置
}
//FlowTemplateDelReq 流程模板新增参数
@@ -46,4 +48,5 @@ type FlowTemplateResp struct {
FlowRemark string `json:"flowRemark" structs:"flowRemark"` // 流程描述
FlowFormData string `json:"flowFormData" structs:"flowFormData"` // 表单配置
FlowProcessData string `json:"flowProcessData" structs:"flowProcessData"` // 流程配置
}

View File

@@ -4,28 +4,30 @@ import (
"x_admin/core/request"
"x_admin/core/response"
"x_admin/model"
"gorm.io/gorm"
)
type IFlowTemplateService interface {
List(page request.PageReq, listReq FlowTemplateListReq) (res response.PageResp, e error)
ListAll() (res []FlowTemplateResp, e error)
Detail(id int) (res FlowTemplateResp, e error)
Add(addReq FlowTemplateAddReq) (e error)
Edit(editReq FlowTemplateEditReq) (e error)
Del(id int) (e error)
}
//NewFlowTemplateService 初始化
// NewFlowTemplateService 初始化
func NewFlowTemplateService(db *gorm.DB) IFlowTemplateService {
return &flowTemplateService{db: db}
}
//flowTemplateService 流程模板服务实现类
// flowTemplateService 流程模板服务实现类
type flowTemplateService struct {
db *gorm.DB
}
//List 流程模板列表
// List 流程模板列表
func (Service flowTemplateService) List(page request.PageReq, listReq FlowTemplateListReq) (res response.PageResp, e error) {
// 分页信息
limit := page.PageSize
@@ -69,7 +71,18 @@ func (Service flowTemplateService) List(page request.PageReq, listReq FlowTempla
}, nil
}
//Detail 流程模板详情
// ListAll 流程模板列表
func (Service flowTemplateService) ListAll() (res []FlowTemplateResp, e error) {
var objs []model.FlowTemplate
err := Service.db.Find(&objs).Error
if e = response.CheckErr(err, "ListAll Find err"); e != nil {
return
}
response.Copy(&res, objs)
return res, nil
}
// Detail 流程模板详情
func (Service flowTemplateService) Detail(id int) (res FlowTemplateResp, e error) {
var obj model.FlowTemplate
err := Service.db.Where("id = ?", id).Limit(1).First(&obj).Error
@@ -83,7 +96,7 @@ func (Service flowTemplateService) Detail(id int) (res FlowTemplateResp, e error
return
}
//Add 流程模板新增
// Add 流程模板新增
func (Service flowTemplateService) Add(addReq FlowTemplateAddReq) (e error) {
var obj model.FlowTemplate
response.Copy(&obj, addReq)
@@ -92,7 +105,7 @@ func (Service flowTemplateService) Add(addReq FlowTemplateAddReq) (e error) {
return
}
//Edit 流程模板编辑
// Edit 流程模板编辑
func (Service flowTemplateService) Edit(editReq FlowTemplateEditReq) (e error) {
var obj model.FlowTemplate
err := Service.db.Where("id = ?", editReq.Id).Limit(1).First(&obj).Error
@@ -110,7 +123,7 @@ func (Service flowTemplateService) Edit(editReq FlowTemplateEditReq) (e error) {
return
}
//Del 流程模板删除
// Del 流程模板删除
func (Service flowTemplateService) Del(id int) (e error) {
var obj model.FlowTemplate
err := Service.db.Where("id = ?", id).Limit(1).First(&obj).Error

View File

@@ -1,10 +1,11 @@
package admin
import (
"github.com/gin-gonic/gin"
"x_admin/admin/flow_template"
"x_admin/core"
"x_admin/middleware"
"x_admin/admin/flow_template"
"github.com/gin-gonic/gin"
)
/**
@@ -21,10 +22,10 @@ flow_template:add
flow_template:edit
flow_template:del
flow_template:list
flow_template:listAll
flow_template:detail
*/
// FlowTemplateRoute(rg)
func FlowTemplateRoute(rg *gin.RouterGroup) {
db := core.GetDB()
@@ -35,6 +36,7 @@ func FlowTemplateRoute(rg *gin.RouterGroup) {
rg = rg.Group("/", middleware.TokenAuth())
rg.GET("/flow_template/list", handle.List)
rg.GET("/flow_template/listAll", handle.ListAll)
rg.GET("/flow_template/detail", handle.Detail)
rg.POST("/flow_template/add", handle.Add)
rg.POST("/flow_template/edit", handle.Edit)

View File

@@ -45,7 +45,7 @@ func (hd {{{ title (toCamelCase .ModuleName) }}}Handler) List(c *gin.Context) {
// @Success 200 {object} []{{{ title (toCamelCase .EntityName) }}}Resp "成功"
// @Router /api/{{{ .ModuleName }}}/list [get]
func (hd {{{ title (toCamelCase .ModuleName) }}}Handler) ListAll(c *gin.Context) {
res, err := hd.Service.List(page, listReq)
res, err := hd.Service.ListAll()
response.CheckAndRespWithData(c, res, err)
}

View File

@@ -6,6 +6,7 @@ import (
"x_admin/model"
"gorm.io/gorm"
)
import "x_admin/core"
type I{{{ title (toCamelCase .EntityName) }}}Service interface {
List(page request.PageReq, listReq {{{ title (toCamelCase .EntityName) }}}ListReq) (res response.PageResp, e error)

View File

@@ -131,7 +131,7 @@
</div>
</template>
<script lang="ts" setup name="{{{ .ModuleName }}}">
import { {{{ .ModuleName }}}_delete, {{{ .ModuleName }}}_lists } from '@/api/{{{ .ModuleName }}}'
import { {{{ .ModuleName }}}_delete, {{{ .ModuleName }}}_list } from '@/api/{{{ .ModuleName }}}'
import EditPopup from './edit.vue'
import feedback from '@/utils/feedback'
{{{- if ge (len .DictFields) 1 }}}
@@ -162,7 +162,7 @@ const queryParams = reactive({
const getLists = async () => {
loading.value = true
try {
const data = await {{{ .ModuleName }}}_lists(queryParams)
const data = await {{{ .ModuleName }}}_list(queryParams)
lists.value = data
loading.value = false
} catch (error) {

View File

@@ -122,7 +122,7 @@
</div>
</template>
<script lang="ts" setup>
import { {{{ .ModuleName }}}_delete, {{{ .ModuleName }}}_lists } from '@/api/{{{ .ModuleName }}}'
import { {{{ .ModuleName }}}_delete, {{{ .ModuleName }}}_list } from '@/api/{{{ .ModuleName }}}'
{{{- if ge (len .DictFields) 1 }}}
import { useDictData } from '@/hooks/useDictOptions'
{{{- end }}}
@@ -148,7 +148,7 @@ const queryParams = reactive({
})
const { pager, getLists, resetPage, resetParams } = usePaging({
fetchFun: {{{ .ModuleName }}}_lists,
fetchFun: {{{ .ModuleName }}}_list,
params: queryParams
})

View File

@@ -6,7 +6,7 @@ type ArticleCollect struct {
UserId int `gorm:"comment:'用户ID'"` // 用户ID
ArticleId int `gorm:"comment:'文章ID'"` // 文章ID
IsDelete int `gorm:"comment:'是否删除'"` // 是否删除
CreateTime int64 `gorm:"comment:'创建时间'"` // 创建时间
UpdateTime int64 `gorm:"comment:'更新时间'"` // 更新时间
DeleteTime int64 `gorm:"comment:'是否删除'"` // 是否删除
UpdateTime int64 `gorm:"autoUpdateTime;comment:'更新时间'"` // 更新时间
CreateTime int64 `gorm:"autoCreateTime;comment:'创建时间'"` // 创建时间
DeleteTime int64 `gorm:"comment:'删除时间'"` // 删除时间
}

View File

@@ -0,0 +1,19 @@
package model
//FlowApply 申请流程实体
type FlowApply struct {
Id int `gorm:"primarykey;comment:''"` //
TemplateId int `gorm:"comment:'模板'"` // 模板
ApplyUserId int `gorm:"comment:'申请人id'"` // 申请人id
ApplyUserNickname string `gorm:"comment:'申请人昵称'"` // 申请人昵称
FlowName string `gorm:"comment:'流程名称'"` // 流程名称
FlowGroup int `gorm:"comment:'流程分类'"` // 流程分类
FlowRemark string `gorm:"comment:'流程描述'"` // 流程描述
FlowFormData string `gorm:"comment:'表单配置'"` // 表单配置
FlowProcessData string `gorm:"comment:'流程配置'"` // 流程配置
FormValue string `gorm:"comment:'表单值'"` // 表单值
Status int `gorm:"comment:'状态0待提交1审批中2审批完成3审批失败'"` // 状态0待提交1审批中2审批完成3审批失败
UpdateTime int64 `gorm:"autoUpdateTime;comment:'更新时间'"` // 更新时间
CreateTime int64 `gorm:"autoCreateTime;comment:'创建时间'"` // 创建时间
DeleteTime int64 `gorm:"comment:'删除时间'"` // 删除时间
}

View File

@@ -0,0 +1,36 @@
package model
//FlowHistory 流程历史实体
type FlowHistory struct {
Id int `gorm:"primarykey;comment:'历史id'"` // 历史id
ApplyId int `gorm:"comment:'申请id'"` // 申请id
TemplateId int `gorm:"comment:'模板id'"` // 模板id
ApplyUserId int `gorm:"comment:'申请人id'"` // 申请人id
ApplyUserNickname string `gorm:"comment:'申请人昵称'"` // 申请人昵称
ApproverId int `gorm:"comment:'审批人id'"` // 审批人id
ApproverNickname string `gorm:"comment:'审批用户昵称'"` // 审批用户昵称
NodeId string `gorm:"comment:'节点'"` // 节点
FormValue string `gorm:"comment:'表单值'"` // 表单值
PassStatus int `gorm:"comment:'通过状态0待处理1通过2拒绝'"` // 通过状态0待处理1通过2拒绝
PassRemark string `gorm:"comment:'通过备注'"` // 通过备注
UpdateTime int64 `gorm:"autoUpdateTime;comment:'更新时间'"` // 更新时间
CreateTime int64 `gorm:"autoCreateTime;comment:'创建时间'"` // 创建时间
DeleteTime int64 `gorm:"comment:'删除时间'"` // 删除时间
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 210 KiB

After

Width:  |  Height:  |  Size: 40 KiB