修改实施采购
This commit is contained in:
@@ -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;
|
||||
|
||||
@@ -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">
|
||||
|
||||
Reference in New Issue
Block a user