修改实施采购
This commit is contained in:
@@ -86,3 +86,14 @@ export function getAgentSummary(params?: { deptCode?: string; planStartDate?: st
|
|||||||
params,
|
params,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 重置密码
|
||||||
|
* @param id 代理机构ID
|
||||||
|
*/
|
||||||
|
export function resetPassword(id: string) {
|
||||||
|
return request({
|
||||||
|
url: '/purchase/purchasingagent/resetPassword/' + id,
|
||||||
|
method: 'post',
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|||||||
@@ -12,11 +12,14 @@
|
|||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="登录用户名" prop="username">
|
<el-form-item label="登录用户名" prop="username">
|
||||||
<el-input v-model="dataForm.username" placeholder="请输入登录用户名(不填则自动生成)" clearable :disabled="!!dataForm.id" />
|
<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>
|
||||||
<el-form-item label="备注" prop="remark">
|
<el-form-item label="备注" prop="remark">
|
||||||
<el-input v-model="dataForm.remark" type="textarea" :rows="3" placeholder="请输入备注" clearable />
|
<el-input v-model="dataForm.remark" type="textarea" :rows="3" placeholder="请输入备注" clearable />
|
||||||
</el-form-item>
|
</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>
|
</el-form>
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<span class="dialog-footer">
|
<span class="dialog-footer">
|
||||||
@@ -44,6 +47,7 @@ const dataForm = reactive({
|
|||||||
contactPhone: '',
|
contactPhone: '',
|
||||||
username: '',
|
username: '',
|
||||||
remark: '',
|
remark: '',
|
||||||
|
status: '1',
|
||||||
});
|
});
|
||||||
const visible = ref(false);
|
const visible = ref(false);
|
||||||
const loading = ref(false);
|
const loading = ref(false);
|
||||||
@@ -61,6 +65,7 @@ const openDialog = async (type: string, rowData?: any) => {
|
|||||||
dataForm.contactPhone = '';
|
dataForm.contactPhone = '';
|
||||||
dataForm.username = '';
|
dataForm.username = '';
|
||||||
dataForm.remark = '';
|
dataForm.remark = '';
|
||||||
|
dataForm.status = '1';
|
||||||
|
|
||||||
nextTick(() => {
|
nextTick(() => {
|
||||||
formRef.value?.resetFields();
|
formRef.value?.resetFields();
|
||||||
@@ -77,6 +82,7 @@ const openDialog = async (type: string, rowData?: any) => {
|
|||||||
contactPhone: res.data.contactPhone || '',
|
contactPhone: res.data.contactPhone || '',
|
||||||
username: res.data.username || '',
|
username: res.data.username || '',
|
||||||
remark: res.data.remark || '',
|
remark: res.data.remark || '',
|
||||||
|
status: res.data.status || '1',
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
loading.value = false;
|
loading.value = false;
|
||||||
|
|||||||
@@ -79,6 +79,17 @@
|
|||||||
<span style="margin-left: 4px">登录用户名</span>
|
<span style="margin-left: 4px">登录用户名</span>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</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>
|
<el-table-column prop="remark" label="备注" min-width="200" show-overflow-tooltip>
|
||||||
<template #header>
|
<template #header>
|
||||||
<el-icon><EditPen /></el-icon>
|
<el-icon><EditPen /></el-icon>
|
||||||
@@ -91,7 +102,7 @@
|
|||||||
<span style="margin-left: 4px">创建时间</span>
|
<span style="margin-left: 4px">创建时间</span>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</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">
|
<template #default="scope">
|
||||||
<el-button
|
<el-button
|
||||||
icon="Edit"
|
icon="Edit"
|
||||||
@@ -102,6 +113,15 @@
|
|||||||
>
|
>
|
||||||
编辑
|
编辑
|
||||||
</el-button>
|
</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>
|
<el-button icon="Delete" link type="danger" v-auth="'purchase_purchasingagent_del'" @click="handleDelete(scope.row)"> 删除 </el-button>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
@@ -176,10 +196,10 @@
|
|||||||
<script setup lang="ts" name="PurchaseAgent">
|
<script setup lang="ts" name="PurchaseAgent">
|
||||||
import { ref, reactive, defineAsyncComponent } from 'vue';
|
import { ref, reactive, defineAsyncComponent } from 'vue';
|
||||||
import { BasicTableProps, useTable } from '/@/hooks/table';
|
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 { deptTree } from '/@/api/admin/dept';
|
||||||
import { useMessage, useMessageBox } from '/@/hooks/message';
|
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'));
|
const FormDialog = defineAsyncComponent(() => import('./form.vue'));
|
||||||
@@ -307,6 +327,37 @@ const handleDelete = async (row: any) => {
|
|||||||
useMessage().error(err.msg || '删除失败');
|
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>
|
</script>
|
||||||
|
|
||||||
<style scoped lang="scss">
|
<style scoped lang="scss">
|
||||||
|
|||||||
Reference in New Issue
Block a user