Merge remote-tracking branch 'origin/master'

This commit is contained in:
2024-05-28 16:11:49 +08:00
7 changed files with 220 additions and 220 deletions

View File

@@ -1,36 +1,36 @@
<!--模型分类的新增编辑弹出框-->
<template>
<el-dialog
draggable
class='cn-operate-dialog'
v-model='machineVisible'
:title='title'
style='width: 415px; height: 350px'
top='30vh'
>
<el-scrollbar>
<el-form :inline='false' :model='form' label-width='120px' :rules='rules' ref='formRef'>
<el-form-item label='分类名称' prop='name'>
<el-input v-model='form.name' placeholder='请输入分类名' clearable />
</el-form-item>
<el-form-item label='分类标识' prop='code'>
<el-input v-model='form.code' placeholder='请输入分类标识' clearable />
</el-form-item>
<el-form-item label='分类描述' prop='description'>
<el-input v-model='form.description' placeholder='请输入分类描述' clearable type='textarea'>
</el-input>
</el-form-item>
</el-form>
</el-scrollbar>
<template #footer>
<span class='dialog-footer'>
<el-button @click='machineVisible = false'>取消</el-button>
<el-button type='primary' @click='submit'>确认</el-button>
<el-dialog draggable class="cn-operate-dialog" v-model="machineVisible" :title="title" width="40%">
<el-scrollbar>
<el-form :inline="false" :model="form" label-width="120px" :rules="rules" ref="formRef">
<el-form-item label="分类名称" prop="name">
<el-input v-model="form.name" placeholder="请输入分类名" clearable />
</el-form-item>
<el-form-item label="分类标识" prop="code">
<el-input v-model="form.code" placeholder="请输入分类标识" clearable />
</el-form-item>
<el-form-item label="分类描述" prop="description">
<el-input
v-model="form.description"
placeholder="请输入分类描述"
clearable
type="textarea"
></el-input>
</el-form-item>
<el-form-item label="排序">
<el-input-number style="width: 100%" v-model="form.sort" :min="0" placeholder="请输入排序" />
</el-form-item>
</el-form>
</el-scrollbar>
<template #footer>
<span class="dialog-footer">
<el-button @click="machineVisible = false">取消</el-button>
<el-button type="primary" @click="submit">确认</el-button>
</span>
</template>
</el-dialog>
</template>
</el-dialog>
</template>
<script lang='ts' setup>
<script lang="ts" setup>
import { ref, reactive, inject } from 'vue'
import { ElMessage } from 'element-plus'
import TableStore from '@/utils/tableStore'
@@ -43,58 +43,60 @@ const formRef = ref()
// 注意不要和表单ref的命名冲突
const form = reactive({
id: '',
name: '',
code: '',
description: ''
id: '',
name: '',
code: '',
description: '',
sort: 100
})
//form表单校验规则
const rules = {
name: [{ required: true, message: '分类名不能为空', trigger: 'blur' }],
code: [{ required: true, message: '分类标识不能为空', trigger: 'blur' }]
name: [{ required: true, message: '分类名不能为空', trigger: 'blur' }],
code: [{ required: true, message: '分类标识不能为空', trigger: 'blur' }]
}
const open = (text: string, data?: any) => {
title.value = text
if (data) {
// 表单赋值
for (let key in form) {
form[key] = data[key]
title.value = text
if (data) {
// 表单赋值
for (let key in form) {
form[key] = data[key]
}
} else {
resetForm()
// 在此处恢复默认表单
for (let key in form) {
form[key] = ''
}
form.sort=100
}
} else {
resetForm()
// 在此处恢复默认表单
for (let key in form) {
form[key] = ''
}
}
machineVisible.value = true
machineVisible.value = true
}
//重置表单内容
const resetForm = () => {
if (formRef.value) {
formRef.value.resetFields()
}
if (formRef.value) {
formRef.value.resetFields()
}
}
/**
* 提交用户表单数据
*/
const submit = () => {
formRef.value.validate(async (valid: any) => {
if (valid) {
if (form.id) {
await updateCategory(form)
} else {
await addCategory(form)
}
ElMessage.success('保存成功')
tableStore.index()
machineVisible.value = false
}
})
formRef.value.validate(async (valid: any) => {
if (valid) {
if (form.id) {
await updateCategory(form)
} else {
await addCategory(form)
}
ElMessage.success('保存成功')
tableStore.index()
machineVisible.value = false
}
})
}
defineExpose({ open })
@@ -102,10 +104,10 @@ defineExpose({ open })
<style scoped>
.el-upload-list__item {
transition: none !important;
transition: none !important;
}
.el-select {
min-width: 180px;
min-width: 180px;
}
</style>

View File

@@ -49,6 +49,7 @@ const tableStore = new TableStore({
{ title: '分类标识', field: 'code', minWidth: 130 },
{ title: '分类描述', field: 'description', minWidth: 170 },
{ title: '创建时间', field: 'createTime', minWidth: 170 },
{ title: '排序', field: 'sort', width: 170 },
{
title: '操作',
align: 'center',

View File

@@ -13,8 +13,7 @@
</content-wrap>
<!-- 表单保存的弹窗 -->
<el-dialog v-model='dialogVisible' title='保存表单' class='cn-operate-dialog' style='width: 415px;height: 350px'
top='30vh'>
<el-dialog v-model='dialogVisible' title='保存表单' class='cn-operate-dialog' width="40%">
<el-scrollbar>
<el-form ref='formRef' :model='formData' :rules='formRules' label-width='80px'>
<el-form-item label='表单名' prop='name'>
@@ -34,6 +33,9 @@
<el-form-item label='备注' prop='remark'>
<el-input v-model='formData.remark' placeholder='请输入备注' type='textarea' />
</el-form-item>
<el-form-item label="排序">
<el-input-number style="width: 100%" v-model="formData.sort" :min="0" placeholder="请输入排序" />
</el-form-item>
</el-form>
</el-scrollbar>
<template #footer>
@@ -83,7 +85,8 @@ const formLoading = ref(false) // 表单的加载中:提交的按钮禁用
const formData = ref({
name: '',
status: 1,
remark: ''
remark: '',
sort:100,
})
const formRules = reactive({
name: [{ required: true, message: '表单名不能为空', trigger: 'blur' }],

View File

@@ -64,6 +64,7 @@ const tableStore = new TableStore({
1: '开启',
}
},
{ title: '排序', field: 'sort', width: 170 },
{
title: '操作',
align: 'center',

View File

@@ -1,6 +1,6 @@
<template>
<el-dialog draggable class='cn-operate-dialog' v-model='dialogVisible' :title='title'
style='max-width: 450px;height: 450px'>
width="40%">
<el-scrollbar>
<el-form :inline='false' :model='formData' label-width='120px' :rules='rules' ref='formRef'>

View File

@@ -1,35 +1,27 @@
<!--流程分类页面-->
<template>
<div class='default-main'>
<TableHeader>
<template v-slot:select>
<el-form-item label='标识名称'>
<el-input
v-model='tableStore.table.params.name'
clearable
placeholder='请输入名称'
/>
</el-form-item>
<el-form-item label='标识key'>
<el-input
v-model='tableStore.table.params.signKey'
clearable
placeholder='请输入key'
/>
</el-form-item>
</template>
<template v-slot:operation>
<el-button type='primary' class='ml10' @click='add' :icon='Plus'>新增</el-button>
</template>
</TableHeader>
<!--表格-->
<Table ref='tableRef'></Table>
<!--弹出框-->
<sign-popup ref='signPopup' />
</div>
<div class="default-main">
<TableHeader>
<template v-slot:select>
<el-form-item label="标识名称">
<el-input v-model="tableStore.table.params.name" clearable placeholder="请输入名称" />
</el-form-item>
<el-form-item label="标识key">
<el-input v-model="tableStore.table.params.signKey" clearable placeholder="请输入key" />
</el-form-item>
</template>
<template v-slot:operation>
<el-button type="primary" class="ml10" @click="add" :icon="Plus">新增</el-button>
</template>
</TableHeader>
<!--表格-->
<Table ref="tableRef"></Table>
<!--弹出框-->
<sign-popup ref="signPopup" />
</div>
</template>
<script setup lang='ts'>
<script setup lang="ts">
import TableStore from '@/utils/tableStore'
import Table from '@/components/table/index.vue'
import TableHeader from '@/components/table/header/index.vue'
@@ -41,80 +33,79 @@ import SignPopup from '@/views/system/bpm/sign/signPopup.vue'
import { deleteSign } from '@/api/bpm-boot/sign'
defineOptions({
name: 'bpmSign'
name: 'bpmSign'
})
const { push } = useRouter()
const signPopup = ref()
const tableStore = new TableStore({
url: '/bpm-boot/bpmSign/list',
method: 'POST',
column: [
{ title: '序号', type: 'seq', width: 80 },
{ title: '标识名称', field: 'name', minWidth: 130 },
{ title: '标识key', field: 'signKey', minWidth: 130 },
{ title: '表单查看地址', field: 'viewPath', minWidth: 200 },
{ title: '创建时间', field: 'createTime', minWidth: 170 },
{
title: '操作',
align: 'center',
minWidth: '150',
fixed: 'right',
render: 'buttons',
buttons: [
url: '/bpm-boot/bpmSign/list',
method: 'POST',
column: [
{ title: '序号', type: 'seq', width: 80 },
{ title: '标识名称', field: 'name', minWidth: 130 },
{ title: '标识key', field: 'signKey', minWidth: 130 },
{ title: '表单查看地址', field: 'viewPath', minWidth: 200 },
{ title: '创建时间', field: 'createTime', minWidth: 170 },
{ title: '排序', field: 'sort', width: 170 },
{
name: 'update',
title: '编辑',
type: 'primary',
icon: 'el-icon-EditPen',
render: 'basicButton',
click: row => {
signPopup.value.open('修改流程标识', row)
}
},
{
name: 'update',
title: '删除',
type: 'danger',
icon: 'el-icon-Delete',
render: 'confirmButton',
popconfirm: {
confirmButtonText: '确认',
cancelButtonText: '取消',
confirmButtonType: 'danger',
title: '确定删除吗?'
},
click: row => {
deleteSign(row.id).then(res => {
ElMessage.success('删除成功')
tableStore.index()
})
}
title: '操作',
align: 'center',
minWidth: '150',
fixed: 'right',
render: 'buttons',
buttons: [
{
name: 'update',
title: '编辑',
type: 'primary',
icon: 'el-icon-EditPen',
render: 'basicButton',
click: row => {
signPopup.value.open('修改流程标识', row)
}
},
{
name: 'update',
title: '删除',
type: 'danger',
icon: 'el-icon-Delete',
render: 'confirmButton',
popconfirm: {
confirmButtonText: '确认',
cancelButtonText: '取消',
confirmButtonType: 'danger',
title: '确定删除吗?'
},
click: row => {
deleteSign(row.id).then(res => {
ElMessage.success('删除成功')
tableStore.index()
})
}
}
]
}
],
beforeSearchFun: () => {
for (let key in tableStore.table.params) {
if (tableStore.table.params[key] === '') {
delete tableStore.table.params[key]
}
}
]
}
],
beforeSearchFun: () => {
for (let key in tableStore.table.params) {
if (tableStore.table.params[key] === '') {
delete tableStore.table.params[key]
}
}
}
})
onMounted(() => {
// 加载数据
tableStore.index()
// 加载数据
tableStore.index()
})
tableStore.table.params.name = ''
tableStore.table.params.signKey = ''
provide('tableStore', tableStore)
const add = () => {
signPopup.value.open('新增流程标识')
signPopup.value.open('新增流程标识')
}
</script>

View File

@@ -1,36 +1,36 @@
<!--模型分类的新增编辑弹出框-->
<template>
<el-dialog
draggable
class='cn-operate-dialog'
v-model='machineVisible'
:title='title'
style='width: 415px; height: 350px'
top='30vh'
>
<el-scrollbar>
<el-form :inline='false' :model='form' label-width='120px' :rules='rules' ref='formRef'>
<el-form-item label='标识名称' prop='name'>
<el-input v-model='form.name' placeholder='请输入标识名' clearable />
</el-form-item>
<el-form-item label='分类key' prop='signKey'>
<el-input v-model='form.signKey' placeholder='请输入标识key' clearable />
</el-form-item>
<el-form-item label='查看表单路径' prop='viewPath'>
<el-input v-model='form.viewPath' placeholder='请输入查看表单路径' clearable>
</el-input>
</el-form-item>
</el-form>
</el-scrollbar>
<template #footer>
<span class='dialog-footer'>
<el-button @click='machineVisible = false'>取消</el-button>
<el-button type='primary' @click='submit'>确认</el-button>
<el-dialog draggable class="cn-operate-dialog" v-model="machineVisible" :title="title" width="40%">
<el-scrollbar>
<el-form :inline="false" :model="form" label-width="120px" :rules="rules" ref="formRef">
<el-form-item label="标识名称" prop="name">
<el-input v-model="form.name" placeholder="请输入标识名" clearable />
</el-form-item>
<el-form-item label="分类key" prop="signKey">
<el-input v-model="form.signKey" placeholder="请输入标识key" clearable />
</el-form-item>
<el-form-item label="查看表单路径" prop="viewPath">
<el-input v-model="form.viewPath" placeholder="请输入查看表单路径" clearable></el-input>
</el-form-item>
<el-form-item label="排序">
<el-input-number
style="width: 100%"
v-model="form.sort"
:min="0"
placeholder="请输入排序"
/>
</el-form-item>
</el-form>
</el-scrollbar>
<template #footer>
<span class="dialog-footer">
<el-button @click="machineVisible = false">取消</el-button>
<el-button type="primary" @click="submit">确认</el-button>
</span>
</template>
</el-dialog>
</template>
</el-dialog>
</template>
<script lang='ts' setup>
<script lang="ts" setup>
import { ref, reactive, inject } from 'vue'
import { ElMessage } from 'element-plus'
import TableStore from '@/utils/tableStore'
@@ -43,59 +43,61 @@ const formRef = ref()
// 注意不要和表单ref的命名冲突
const form = reactive({
id: '',
name: '',
signKey: '',
viewPath: ''
id: '',
name: '',
signKey: '',
viewPath: '',
sort:100,
})
//form表单校验规则
const rules = {
name: [{ required: true, message: '标识名不能为空', trigger: 'blur' }],
signKey: [{ required: true, message: '标识key不能为空', trigger: 'blur' }],
viewPath: [{ required: true, message: '查看表单路径不能为空', trigger: 'blur' }],
name: [{ required: true, message: '标识名不能为空', trigger: 'blur' }],
signKey: [{ required: true, message: '标识key不能为空', trigger: 'blur' }],
viewPath: [{ required: true, message: '查看表单路径不能为空', trigger: 'blur' }]
}
const open = (text: string, data?: any) => {
title.value = text
if (data) {
// 表单赋值
for (let key in form) {
form[key] = data[key]
title.value = text
if (data) {
// 表单赋值
for (let key in form) {
form[key] = data[key]
}
} else {
resetForm()
// 在此处恢复默认表单
for (let key in form) {
form[key] = ''
}
form.sort=100
}
} else {
resetForm()
// 在此处恢复默认表单
for (let key in form) {
form[key] = ''
}
}
machineVisible.value = true
machineVisible.value = true
}
//重置表单内容
const resetForm = () => {
if (formRef.value) {
formRef.value.resetFields()
}
if (formRef.value) {
formRef.value.resetFields()
}
}
/**
* 提交用户表单数据
*/
const submit = () => {
formRef.value.validate(async (valid: any) => {
if (valid) {
if (form.id) {
await updateSign(form)
} else {
await addSign(form)
}
ElMessage.success('保存成功')
tableStore.index()
machineVisible.value = false
}
})
formRef.value.validate(async (valid: any) => {
if (valid) {
if (form.id) {
await updateSign(form)
} else {
await addSign(form)
}
ElMessage.success('保存成功')
tableStore.index()
machineVisible.value = false
}
})
}
defineExpose({ open })
@@ -103,10 +105,10 @@ defineExpose({ open })
<style scoped>
.el-upload-list__item {
transition: none !important;
transition: none !important;
}
.el-select {
min-width: 180px;
min-width: 180px;
}
</style>