修改实施采购

This commit is contained in:
吴红兵
2026-03-15 13:08:38 +08:00
parent 1ca0e3c452
commit eec90d963d
3 changed files with 72 additions and 4 deletions

View File

@@ -12,11 +12,14 @@
</el-form-item>
<el-form-item label="登录用户名" prop="username">
<el-input v-model="dataForm.username" placeholder="请输入登录用户名(不填则自动生成)" clearable :disabled="!!dataForm.id" />
<div class="form-tip" v-if="!dataForm.id">新增时自动创建系统用户默认密码Aa123456角色招标代理</div>
<div class="form-tip" v-if="!dataForm.id">新增时自动创建系统用户密码随机生成12位含大小写字母数字特殊字符角色招标代理</div>
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-input v-model="dataForm.remark" type="textarea" :rows="3" placeholder="请输入备注" clearable />
</el-form-item>
<el-form-item label="是否启用" prop="status">
<el-switch v-model="dataForm.status" active-value="1" inactive-value="0" />
</el-form-item>
</el-form>
<template #footer>
<span class="dialog-footer">
@@ -44,6 +47,7 @@ const dataForm = reactive({
contactPhone: '',
username: '',
remark: '',
status: '1',
});
const visible = ref(false);
const loading = ref(false);
@@ -61,6 +65,7 @@ const openDialog = async (type: string, rowData?: any) => {
dataForm.contactPhone = '';
dataForm.username = '';
dataForm.remark = '';
dataForm.status = '1';
nextTick(() => {
formRef.value?.resetFields();
@@ -77,6 +82,7 @@ const openDialog = async (type: string, rowData?: any) => {
contactPhone: res.data.contactPhone || '',
username: res.data.username || '',
remark: res.data.remark || '',
status: res.data.status || '1',
});
}
loading.value = false;

View File

@@ -79,6 +79,17 @@
<span style="margin-left: 4px">登录用户名</span>
</template>
</el-table-column>
<el-table-column prop="status" label="是否启用" width="100" align="center">
<template #header>
<el-icon><CircleCheck /></el-icon>
<span style="margin-left: 4px">是否启用</span>
</template>
<template #default="scope">
<el-tag :type="scope.row.status === '1' ? 'success' : 'danger'">
{{ scope.row.status === '1' ? '启用' : '禁用' }}
</el-tag>
</template>
</el-table-column>
<el-table-column prop="remark" label="备注" min-width="200" show-overflow-tooltip>
<template #header>
<el-icon><EditPen /></el-icon>
@@ -91,7 +102,7 @@
<span style="margin-left: 4px">创建时间</span>
</template>
</el-table-column>
<el-table-column label="操作" align="center" fixed="right" width="150">
<el-table-column label="操作" align="center" fixed="right" width="200">
<template #default="scope">
<el-button
icon="Edit"
@@ -102,6 +113,15 @@
>
编辑
</el-button>
<el-button
icon="Key"
link
type="warning"
v-auth="'purchase_purchasingagent_edit'"
@click="handleResetPassword(scope.row)"
>
重置密码
</el-button>
<el-button icon="Delete" link type="danger" v-auth="'purchase_purchasingagent_del'" @click="handleDelete(scope.row)"> 删除 </el-button>
</template>
</el-table-column>
@@ -176,10 +196,10 @@
<script setup lang="ts" name="PurchaseAgent">
import { ref, reactive, defineAsyncComponent } from 'vue';
import { BasicTableProps, useTable } from '/@/hooks/table';
import { getPage, delObj, getAgentSummary } from '/@/api/purchase/purchaseagent';
import { getPage, delObj, getAgentSummary, resetPassword } from '/@/api/purchase/purchaseagent';
import { deptTree } from '/@/api/admin/dept';
import { useMessage, useMessageBox } from '/@/hooks/message';
import { List, Document, EditPen, Clock, Search, User, Phone, UserFilled } from '@element-plus/icons-vue';
import { List, Document, EditPen, Clock, Search, User, Phone, UserFilled, CircleCheck, Key } from '@element-plus/icons-vue';
// 引入组件
const FormDialog = defineAsyncComponent(() => import('./form.vue'));
@@ -307,6 +327,37 @@ const handleDelete = async (row: any) => {
useMessage().error(err.msg || '删除失败');
}
};
/**
* 重置密码
* @param row - 当前行数据
*/
const handleResetPassword = async (row: any) => {
try {
await useMessageBox().confirm('确定要重置该代理机构的登录密码吗?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
});
} catch {
return;
}
try {
const res = await resetPassword(row.id);
const newPassword = res.data || res;
useMessageBox()
.alert(`新密码:${newPassword}`, '密码重置成功', {
confirmButtonText: '确定',
type: 'success',
})
.then(() => {
useMessage().success('密码重置成功');
});
} catch (err: any) {
useMessage().error(err.msg || '重置密码失败');
}
};
</script>
<style scoped lang="scss">