<template>
|
<div class="Usermanagement">
|
<div class="content">
|
<div class="checkbox">
|
<div
|
:class="['item', isactive == 1 ? 'isactive' : '']"
|
@click="changeactive(1)"
|
>
|
用户列表
|
</div>
|
<div
|
:class="['item', isactive == 2 ? 'isactive' : '']"
|
@click="changeactive(2)"
|
>
|
用户角色
|
</div>
|
<div
|
:class="['item', isactive == 3 ? 'isactive' : '']"
|
@click="changeactive(3)"
|
>
|
用户班组
|
</div>
|
<div
|
:class="['item', isactive == 4 ? 'isactive' : '']"
|
@click="changeactive(4)"
|
>
|
用户单位
|
</div>
|
<div
|
:class="['item', isactive == 5 ? 'isactive' : '']"
|
@click="changeactive(5)"
|
>
|
用户IP
|
</div>
|
</div>
|
<div class="serch">
|
<div class="time_box">
|
<div class="time">创建日期</div>
|
<el-date-picker
|
v-model="queryForm.selectTime"
|
prefix-icon="none"
|
clear-icon="none"
|
style="
|
font-size: 0.75rem !important;
|
border: 0.06rem solid rgba(222, 222, 222, 1);
|
border-radius: 0 0.25rem 0.25rem 0;
|
box-shadow: none;
|
width: 19rem;
|
height: 2rem;
|
border-left: 0;
|
"
|
class="time_picker"
|
format="YYYY-MM-DD HH:mm:ss"
|
type="datetimerange"
|
range-separator="~"
|
start-placeholder="起始日期"
|
end-placeholder="截止日期"
|
size="small"
|
/>
|
</div>
|
<div class="serch_box">
|
<div class="serchb">
|
<el-select
|
v-model="queryForm.selectType"
|
placeholder="请选择"
|
size="small"
|
style="width: 100%; font-size: 0.15rem"
|
class="select"
|
>
|
<el-option
|
v-for="item in selectoptions"
|
:key="item.value"
|
:label="item.label"
|
:value="item.value"
|
/>
|
</el-select>
|
</div>
|
<input
|
v-model="queryForm.selectInput"
|
placeholder="请输入关键词搜索"
|
style="border-left: 0.06rem solid #e2e2e2"
|
/>
|
</div>
|
<el-button
|
@click="handleQuery"
|
type="primary"
|
size="small"
|
style="margin-left: 0.98rem; height: 2.5rem"
|
class="text_btn"
|
>查询</el-button
|
>
|
<el-button
|
size="small"
|
style="height: 2.5rem"
|
class="text_btn"
|
@click="resetQuery"
|
>重置</el-button
|
>
|
</div>
|
<div class="btns">
|
<div style="display: flex; align-items: center">
|
<!-- 用户列表新建 -->
|
<el-button
|
v-if="isactive == 1"
|
type="primary"
|
size="small"
|
@click="dialogVisible = true"
|
style="
|
width: 5.5rem;
|
height: 2rem;
|
font-size: 0.88rem;
|
display: flex;
|
align-items: center;
|
"
|
class="text_btn"
|
><el-icon style="margin-right: 0.2rem"> <Plus /> </el-icon
|
>新建</el-button
|
>
|
<!-- 用户角色新建 -->
|
<el-button
|
v-if="isactive == 2"
|
type="primary"
|
size="small"
|
@click="AddRole"
|
style="
|
width: 5.5rem;
|
height: 2rem;
|
font-size: 0.88rem;
|
display: flex;
|
align-items: center;
|
"
|
class="text_btn"
|
><el-icon style="margin-right: 0.2rem"> <Plus /> </el-icon
|
>新建</el-button
|
>
|
<!-- 用户班组新建 -->
|
<el-button
|
v-if="isactive == 3"
|
type="primary"
|
size="small"
|
@click="AddGroup"
|
style="
|
width: 5.5rem;
|
height: 2rem;
|
font-size: 0.88rem;
|
display: flex;
|
align-items: center;
|
"
|
class="text_btn"
|
><el-icon style="margin-right: 0.2rem"> <Plus /> </el-icon
|
>新建</el-button
|
>
|
<!-- 用户单位新建 -->
|
<el-button
|
v-if="isactive == 4"
|
type="primary"
|
size="small"
|
@click="AddUnit"
|
style="
|
width: 5.5rem;
|
height: 2rem;
|
font-size: 0.88rem;
|
display: flex;
|
align-items: center;
|
"
|
class="text_btn"
|
><el-icon style="margin-right: 0.2rem"> <Plus /> </el-icon
|
>新建</el-button
|
>
|
<!-- 用户IP新建 -->
|
<el-button
|
v-if="isactive == 5"
|
type="primary"
|
size="small"
|
@click="Addip"
|
style="
|
width: 5.5rem;
|
height: 2rem;
|
font-size: 0.88rem;
|
display: flex;
|
align-items: center;
|
"
|
class="text_btn"
|
><el-icon style="margin-right: 0.2rem"> <Plus /> </el-icon
|
>新建</el-button
|
>
|
<el-button
|
type="primary"
|
size="small"
|
style="width: 5.5rem; height: 2rem; font-size: 0.88rem"
|
class="text_btn"
|
@click="registerdialogVisible = true"
|
>人脸注册</el-button
|
>
|
<el-button
|
size="small"
|
style="width: 5.5rem; height: 2rem; font-size: 0.88rem"
|
@click="printExcel"
|
class="text_btn"
|
>批量导出</el-button
|
>
|
<el-button
|
@click="deleteAll"
|
size="small"
|
style="width: 5.5rem; height: 2rem; font-size: 0.88rem"
|
class="text_btn"
|
>批量删除</el-button
|
>
|
</div>
|
</div>
|
<div style="margin-top: 1rem; height: 100%">
|
<!-- 用户列表 -->
|
<el-table
|
empty-text="暂无数据"
|
:height="isMin ? '950' : '450'"
|
v-if="isactive == 1"
|
:data="tableData"
|
style="width: 100%"
|
:header-cell-style="
|
isMin
|
? {
|
background: 'rgba(250,250,250,1)',
|
color: '#101010',
|
fontSize: '1.5rem',
|
height: '3rem',
|
border: 'none',
|
}
|
: {
|
background: 'rgba(250,250,250,1)',
|
color: '#101010',
|
fontSize: '0.88rem',
|
height: '3rem',
|
border: 'none',
|
}
|
"
|
:row-style="
|
isMin
|
? {
|
color: '#101010',
|
fontSize: '2rem',
|
height: '3rem',
|
}
|
: {
|
color: '#101010',
|
fontSize: '0.88rem',
|
height: '3rem',
|
}
|
"
|
@selection-change="UserSelectionChange"
|
>
|
<el-table-column type="selection" align="center" min-width="1%" />
|
<el-table-column
|
prop="userName"
|
label="登录账号"
|
align="center"
|
min-width="2%"
|
/>
|
<el-table-column
|
prop="userTrueName"
|
label="真实姓名"
|
align="center"
|
min-width="3%"
|
/>
|
<el-table-column
|
prop="phoneNo"
|
label="联系方式"
|
align="center"
|
min-width="3%"
|
/>
|
<el-table-column
|
prop="isLeader"
|
label="用户类型"
|
align="center"
|
min-width="2%"
|
>
|
<template #default="scope">
|
<span v-if="scope.row.isLeader == 0">二级</span>
|
<span v-else-if="scope.row.isLeader == 1">一级</span>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="unit"
|
label="单位"
|
align="center"
|
min-width="3%"
|
/>
|
<el-table-column
|
prop="userteam"
|
label="班组"
|
align="center"
|
min-width="3%"
|
/>
|
<el-table-column
|
prop="address"
|
label="人脸照片"
|
align="center"
|
min-width="3%"
|
>
|
<template #default="scope">
|
<el-image
|
style="width: 5rem; height: 5rem"
|
:src="'http://192.168.1.103:9093' + scope.row.headImageUrl"
|
show-progress
|
:initial-index="4"
|
fit="cover"
|
/>
|
</template>
|
</el-table-column>
|
<el-table-column label="是否启用" align="center" min-width="2%">
|
<template #default="scope">
|
<el-switch
|
:disabled="
|
userInfo.userName == 'admin' || userInfo.roleId == '1'
|
? scope.row.userName == 'admin' || scope.row.user_Id == '1'
|
: scope.row.userName == 'admin' ||
|
scope.row.user_Id == '1' ||
|
scope.row.userName != userInfo.userName
|
"
|
v-model="scope.row.enable"
|
:active-value="1"
|
:inactive-value="0"
|
@change="changeSwitch(scope.row)"
|
/>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="createDate"
|
label="创建日期"
|
align="center"
|
min-width="3%"
|
/>
|
<el-table-column label="操作" align="center" min-width="3%">
|
<template #default="scope">
|
<el-button
|
size="small"
|
type="text"
|
@click="Edit(scope.row)"
|
:disabled="scope.row.isdisabled"
|
>编辑</el-button
|
>
|
<el-button
|
size="small"
|
type="text"
|
:disabled="scope.row.isdisabled"
|
@click="Editpassword(scope.row)"
|
>修改密码</el-button
|
>
|
<el-button
|
size="small"
|
type="text"
|
@click="deletUser(scope.row)"
|
:disabled="scope.row.isdisabled"
|
>删除</el-button
|
>
|
</template>
|
</el-table-column>
|
</el-table>
|
|
<!-- 用户角色 -->
|
<el-table
|
empty-text="暂无数据"
|
:height="isMin ? '950' : '450'"
|
v-if="isactive == 2"
|
:data="grideData"
|
style="width: 100%"
|
:header-cell-style="
|
isMin
|
? {
|
background: 'rgba(250,250,250,1)',
|
color: '#101010',
|
fontSize: '1.5rem',
|
height: '3rem',
|
border: 'none',
|
}
|
: {
|
background: 'rgba(250,250,250,1)',
|
color: '#101010',
|
fontSize: '0.88rem',
|
height: '3rem',
|
border: 'none',
|
}
|
"
|
:row-style="
|
isMin
|
? {
|
color: '#101010',
|
fontSize: '1.88rem',
|
height: '3rem',
|
}
|
: {
|
color: '#101010',
|
fontSize: '0.88rem',
|
height: '3rem',
|
}
|
"
|
@selection-change="RoleSelectionChange"
|
>
|
<el-table-column type="selection" align="center" />
|
<el-table-column prop="roleName" label="角色名称" align="center" />
|
<el-table-column prop="name" label="角色权限" align="center">
|
<template #default="scope">
|
<span
|
v-if="
|
!(userInfo.userName == 'admin' || userInfo.roleId == '1'
|
? scope.row.userName == 'admin' || scope.row.user_Id == '1'
|
: scope.row.userName == 'admin' ||
|
scope.row.user_Id == '1' ||
|
scope.row.userName != userInfo.userName)
|
"
|
@click="toDetail(scope.row)"
|
style="color: #4386ff; cursor: pointer"
|
>管理</span
|
>
|
</template>
|
</el-table-column>
|
<el-table-column prop="isLeader" label="用户类型" align="center">
|
<template #default="scope">
|
<span v-if="scope.row.isLeader == 0">二级</span>
|
<span v-else-if="scope.row.isLeader == 1">一级</span>
|
</template>
|
</el-table-column>
|
<el-table-column prop="deptName" label="备注" align="center" />
|
<el-table-column label="是否启用" align="center">
|
<template #default="scope">
|
<el-switch
|
:disabled="
|
!(userInfo.userName == 'admin' || userInfo.roleId == '1')
|
"
|
v-model="scope.row.enable"
|
:active-value="1"
|
:inactive-value="0"
|
@change="changeRoleSwitch(scope.row)"
|
/>
|
</template>
|
</el-table-column>
|
<el-table-column prop="createDate" label="创建日期" align="center" />
|
<el-table-column label="操作" align="center">
|
<template #default="scope">
|
<span
|
v-if="
|
!(userInfo.userName == 'admin' || userInfo.roleId == '1'
|
? scope.row.userName == 'admin' || scope.row.user_Id == '1'
|
: scope.row.userName == 'admin' ||
|
scope.row.user_Id == '1' ||
|
scope.row.userName != userInfo.userName)
|
"
|
:style="{
|
color: 'blue',
|
fontSize: isMin ? '1.88rem' : '0.88rem',
|
cursor: 'pointer',
|
}"
|
@click="EditRole(scope.row)"
|
>编辑</span
|
>
|
</template></el-table-column
|
>
|
</el-table>
|
|
<!-- 用户班组 -->
|
<el-table
|
empty-text="暂无数据"
|
:height="isMin ? '950' : '450'"
|
v-if="isactive == 3"
|
:data="departmentData"
|
style="width: 100%"
|
:header-cell-style="
|
isMin
|
? {
|
background: 'rgba(250,250,250,1)',
|
color: '#101010',
|
fontSize: '1.5rem',
|
height: '3rem',
|
border: 'none',
|
}
|
: {
|
background: 'rgba(250,250,250,1)',
|
color: '#101010',
|
fontSize: '0.88rem',
|
height: '3rem',
|
border: 'none',
|
}
|
"
|
:row-style="
|
isMin
|
? {
|
color: '#101010',
|
fontSize: '1.88rem',
|
height: '3rem',
|
}
|
: {
|
color: '#101010',
|
fontSize: '0.88rem',
|
height: '3rem',
|
}
|
"
|
@selection-change="TreamSelectionChange"
|
>
|
<el-table-column type="selection" align="center" />
|
<el-table-column prop="teamName" label="班组名称" align="center" />
|
<el-table-column prop="creater" label="创建者" align="center" />
|
<el-table-column prop="createDate" label="创建时间" align="center" />
|
<el-table-column label="操作" align="center">
|
<template #default="scope">
|
<span
|
v-if="
|
!(userInfo.userName == 'admin' || userInfo.roleId == '1'
|
? scope.row.userName == 'admin' || scope.row.user_Id == '1'
|
: scope.row.userName == 'admin' ||
|
scope.row.user_Id == '1' ||
|
scope.row.userName != userInfo.userName)
|
"
|
:style="{
|
color: 'blue',
|
fontSize: isMin ? '1.88rem' : '0.88rem',
|
cursor: 'pointer',
|
}"
|
@click="EditTream(scope.row)"
|
>编辑</span
|
>
|
</template></el-table-column
|
>
|
</el-table>
|
|
<!-- 用户单位 -->
|
<el-table
|
empty-text="暂无数据"
|
:height="isMin ? '950' : '450'"
|
v-if="isactive == 4"
|
:data="unitData"
|
style="width: 100%"
|
:header-cell-style="
|
isMin
|
? {
|
background: 'rgba(250,250,250,1)',
|
color: '#101010',
|
fontSize: '1.5rem',
|
height: '3rem',
|
border: 'none',
|
}
|
: {
|
background: 'rgba(250,250,250,1)',
|
color: '#101010',
|
fontSize: '0.88rem',
|
height: '3rem',
|
border: 'none',
|
}
|
"
|
:row-style="
|
isMin
|
? {
|
color: '#101010',
|
fontSize: '1.88rem',
|
height: '3rem',
|
}
|
: {
|
color: '#101010',
|
fontSize: '0.88rem',
|
height: '3rem',
|
}
|
"
|
@selection-change="UnitSelectionChange"
|
>
|
<el-table-column type="selection" align="center" />
|
<el-table-column prop="unitName" label="单位名称" align="center" />
|
<el-table-column prop="creater" label="创建者" align="center" />
|
<el-table-column prop="createDate" label="创建日期" align="center" />
|
<el-table-column label="操作" align="center">
|
<template #default="scope">
|
<span
|
v-if="
|
!(userInfo.userName == 'admin' || userInfo.roleId == '1'
|
? scope.row.userName == 'admin' || scope.row.user_Id == '1'
|
: scope.row.userName == 'admin' ||
|
scope.row.user_Id == '1' ||
|
scope.row.userName != userInfo.userName)
|
"
|
:style="{
|
color: 'blue',
|
fontSize: isMin ? '1.88rem' : '0.88rem',
|
cursor: 'pointer',
|
}"
|
@click="EditUnit(scope.row)"
|
>编辑</span
|
>
|
</template></el-table-column
|
>
|
</el-table>
|
|
<!-- 用户IP -->
|
<el-table
|
empty-text="暂无数据"
|
:height="isMin ? '950' : '450'"
|
v-if="isactive == 5"
|
:data="ipData"
|
style="width: 100%"
|
:header-cell-style="
|
isMin
|
? {
|
background: 'rgba(250,250,250,1)',
|
color: '#101010',
|
fontSize: '1.5rem',
|
height: '3rem',
|
border: 'none',
|
}
|
: {
|
background: 'rgba(250,250,250,1)',
|
color: '#101010',
|
fontSize: '0.88rem',
|
height: '3rem',
|
border: 'none',
|
}
|
"
|
:row-style="
|
isMin
|
? {
|
color: '#101010',
|
fontSize: '1.88rem',
|
height: '3rem',
|
}
|
: {
|
color: '#101010',
|
fontSize: '0.88rem',
|
height: '3rem',
|
}
|
"
|
@selection-change="IpSelectionChange"
|
>
|
<el-table-column type="selection" align="center" />
|
<el-table-column prop="iPaddress" label="ip地址" align="center" />
|
<el-table-column prop="addressname" label="检修道" align="center" />
|
<el-table-column label="操作" align="center">
|
<template #default="scope">
|
<span
|
:style="{
|
color: 'blue',
|
fontSize: isMin ? '1.88rem' : '0.88rem',
|
cursor: 'pointer',
|
}"
|
@click="Editip(scope.row)"
|
>编辑</span
|
>
|
</template></el-table-column
|
>
|
</el-table>
|
</div>
|
<div
|
style="
|
display: flex;
|
justify-content: right;
|
align-self: flex-end;
|
margin-bottom: 1.19rem;
|
margin-right: 1.25rem;
|
"
|
>
|
<el-pagination
|
v-if="isactive == 1"
|
size="large"
|
background
|
layout="prev, pager, next"
|
:current-page="pageQuery.page"
|
:page-size="pageQuery.rows"
|
:total="pageTotal"
|
@size-change="handleSizeChange"
|
@current-change="handleCurrentChange"
|
/>
|
</div>
|
</div>
|
|
<!-- 用户信息新建编辑弹出框 -->
|
<el-dialog
|
v-model="dialogVisible"
|
title=""
|
width="60%"
|
:before-close="handleClose"
|
:show-close="false"
|
:align-center="true"
|
@close="resetForm(formUserRef)"
|
>
|
<template #title>
|
<div
|
style="
|
height: 3.63rem;
|
display: flex;
|
border-bottom: 1px solid #e6e6e6;
|
"
|
>
|
<span
|
style="color: rgb(16, 16, 16); font-size: 1rem; font-weight: bold"
|
class="font-title"
|
>用户信息</span
|
>
|
</div>
|
</template>
|
<el-form
|
:model="formUser"
|
label-width="auto"
|
label-position="top"
|
:rules="rules"
|
ref="formUserRef"
|
:hide-required-asterisk="true"
|
>
|
<el-row :gutter="20">
|
<el-col :span="8">
|
<el-form-item prop="username">
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
class="from_title"
|
>登录账号</span
|
>
|
</div>
|
</template>
|
<el-input
|
size="small"
|
v-model="formUser.username"
|
placeholder="请输入"
|
/>
|
</el-form-item>
|
</el-col>
|
<el-col :span="8">
|
<el-form-item prop="usertruename">
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
class="from_title"
|
>真实姓名</span
|
>
|
</div>
|
</template>
|
<el-input
|
size="small"
|
v-model="formUser.usertruename"
|
placeholder="请输入"
|
/>
|
</el-form-item>
|
</el-col>
|
<el-col :span="8">
|
<el-form-item prop="phoneno">
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
class="from_title"
|
>联系电话</span
|
>
|
</div>
|
</template>
|
<el-input
|
size="small"
|
v-model="formUser.phoneno"
|
placeholder="请输入"
|
/>
|
</el-form-item>
|
</el-col>
|
</el-row>
|
<el-row :gutter="20">
|
<el-col :span="8">
|
<el-form-item prop="roleid">
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
class="from_title"
|
>角色名字
|
</span>
|
</div>
|
</template>
|
<el-select
|
v-model="formUser.roleid"
|
placeholder="请选择"
|
size="small"
|
@change="handleRoleChange"
|
>
|
<el-option
|
:disabled="item.roleId == 1"
|
v-for="item in groupOptions"
|
:key="item.roleId"
|
:label="item.roleName"
|
:value="item.roleId"
|
/>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
<el-col :span="8">
|
<el-form-item prop="userunit">
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
class="from_title"
|
>单位</span
|
>
|
</div>
|
</template>
|
<el-select
|
v-model="formUser.userunit"
|
placeholder="请选择"
|
size="small"
|
>
|
<el-option
|
v-for="item in unitData"
|
:key="item.id"
|
:label="item.unitName"
|
:value="item.unitName"
|
/>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
<el-col :span="8">
|
<el-form-item prop="enable">
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
class="from_title"
|
>是否启用</span
|
>
|
</div>
|
</template>
|
<el-select
|
v-model="formUser.enable"
|
placeholder="请选择"
|
size="small"
|
>
|
<el-option
|
v-for="item in isoptins"
|
:key="item.value"
|
:label="item.label"
|
:value="item.value"
|
/>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
</el-row>
|
<el-row :gutter="20">
|
<el-col :span="8">
|
<el-form-item prop="userteam">
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
class="from_title"
|
>班组</span
|
>
|
</div>
|
</template>
|
<el-select
|
v-model="formUser.userteam"
|
placeholder="请选择"
|
size="small"
|
>
|
<el-option
|
v-for="item in departmentData"
|
:key="item.id"
|
:label="item.teamName"
|
:value="item.teamName"
|
/>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
<el-col :span="8">
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span style="color: red; margin-right: 0.2rem">*</span>
|
<span
|
style="font-size: 0.88rem; color: black; font-weight: bold"
|
class="from_title"
|
>人脸图片</span
|
>
|
</div>
|
</template>
|
<el-upload
|
ref="uploadRef"
|
name="files"
|
class="avatar-uploader"
|
action="http://192.168.1.103:9093/api/User/SaveFiles"
|
list-type="picture-card"
|
limit="1"
|
:auto-upload="true"
|
@before-upload="beforeAvatarUpload"
|
:on-success="handleAvatarSuccess"
|
:file-list="fileList != [] ? fileList : []"
|
:class="{ hide: showUpload }"
|
>
|
<el-icon>
|
<Plus />
|
</el-icon>
|
<template #file="{ file }">
|
<div>
|
<img
|
class="el-upload-list__item-thumbnail"
|
:src="file.url"
|
alt=""
|
/>
|
<span class="el-upload-list__item-actions">
|
<span
|
class="el-upload-list__item-preview"
|
@click="handlePictureCardPreview(file)"
|
>
|
<el-icon size="15"><zoom-in /></el-icon>
|
</span>
|
<span
|
v-if="!disabled"
|
class="el-upload-list__item-delete"
|
@click="handleDownload(file)"
|
>
|
<el-icon size="15">
|
<Download />
|
</el-icon>
|
</span>
|
<span
|
v-if="!disabled"
|
class="el-upload-list__item-delete"
|
@click="handleRemove(file)"
|
>
|
<el-icon size="15">
|
<Delete />
|
</el-icon>
|
</span>
|
</span>
|
</div>
|
</template>
|
</el-upload>
|
</el-form-item>
|
</el-col>
|
</el-row>
|
</el-form>
|
<template #footer>
|
<div class="dialog-footer" style="text-align: center">
|
<el-button
|
size="small"
|
@click="dialogVisible = false"
|
style="height: 2rem; font-size: 0.88rem"
|
>取消</el-button
|
>
|
|
<el-button
|
size="small"
|
type="primary"
|
@click="saveObj(formUserRef)"
|
style="height: 2rem; font-size: 0.88rem"
|
>
|
保存
|
</el-button>
|
</div>
|
</template>
|
</el-dialog>
|
|
<!-- 用户修改密码弹出框 -->
|
<el-dialog
|
v-model="dialogVisible1"
|
title=""
|
width="30%"
|
:before-close="handleClose"
|
:show-close="false"
|
:align-center="true"
|
>
|
<template #title>
|
<div
|
style="
|
height: 3.63rem;
|
display: flex;
|
border-bottom: 1px solid #e6e6e6;
|
"
|
>
|
<span
|
style="color: rgb(16, 16, 16); font-size: 1rem; font-weight: bold"
|
>用户信息</span
|
>
|
</div>
|
</template>
|
<el-form
|
:model="newobj"
|
label-width="auto"
|
label-position="top"
|
ref="formpasswordRef"
|
:rules="passwordrules"
|
>
|
<el-row>
|
<el-col>
|
<div
|
style="
|
height: 3.63rem;
|
display: flex;
|
align-items: center;
|
background: rgba(81, 184, 32, 0.2);
|
padding: 0 2rem;
|
box-sizing: border-box;
|
border-radius: 0.25rem;
|
"
|
>
|
<span style="color: #51b820; font-size: 1rem" class="formpassword"
|
>账号:{{ formpassword.userName }}</span
|
><span
|
style="color: #51b820; font-size: 1rem; margin-left: 2rem"
|
class="formpassword"
|
>用户:{{ formpassword.roleName }}</span
|
>
|
</div>
|
</el-col>
|
</el-row>
|
<el-form-item prop="newPwd">
|
<el-input
|
style="margin-top: 1rem"
|
size="large"
|
v-model="newobj.newPwd"
|
placeholder="请输入"
|
/>
|
</el-form-item>
|
</el-form>
|
<template #footer>
|
<div class="dialog-footer" style="text-align: center">
|
<el-button
|
size="small"
|
@click="dialogVisible1 = false"
|
style="height: 2rem; font-size: 0.88rem"
|
>取消</el-button
|
>
|
|
<el-button
|
size="small"
|
type="primary"
|
@click="savePassword(formpasswordRef)"
|
style="height: 2rem; font-size: 0.88rem"
|
>
|
保存
|
</el-button>
|
</div>
|
</template>
|
</el-dialog>
|
|
<!-- 用户角色新建 -->
|
<el-dialog
|
v-model="dialogVisible2"
|
title=""
|
width="20%"
|
:before-close="handleClose"
|
:show-close="false"
|
:align-center="true"
|
@close="resetForm1(formRoleRef)"
|
>
|
<template #title>
|
<div
|
style="
|
height: 3.63rem;
|
display: flex;
|
border-bottom: 1px solid #e6e6e6;
|
"
|
>
|
<span
|
:style="{
|
color: 'rgb(16, 16, 16)',
|
fontSize: isMin ? '2rem' : '1rem',
|
fontWeight: 'bold',
|
}"
|
>用户角色</span
|
>
|
</div>
|
</template>
|
<el-form
|
:model="formRole"
|
label-width="auto"
|
label-position="top"
|
ref="formRoleRef"
|
:rules="roleRules"
|
:hide-required-asterisk="true"
|
>
|
<el-form-item prop="roleName">
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span
|
:style="{
|
color: 'red',
|
marginRight: '0.2rem',
|
fontSize: '2rem',
|
}"
|
>*</span
|
>
|
<span
|
:style="{
|
fontSize: isMin ? '2rem' : '0.88rem',
|
color: 'black',
|
fontWeight: bold,
|
}"
|
>角色名称</span
|
>
|
</div>
|
</template>
|
<el-input
|
style="height: 2rem"
|
size="small"
|
v-model="formRole.roleName"
|
placeholder="请输入"
|
/>
|
</el-form-item>
|
<el-form-item prop="isLeader">
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span
|
:style="{
|
color: 'red',
|
marginRight: '0.2rem',
|
fontSize: '2rem',
|
}"
|
>*</span
|
>
|
<span
|
:style="{
|
fontSize: isMin ? '2rem' : '0.88rem',
|
color: 'black',
|
fontWeight: bold,
|
}"
|
>组员类型</span
|
>
|
</div>
|
</template>
|
<el-select
|
v-model="formRole.isLeader"
|
placeholder="请选择"
|
size="small"
|
>
|
<el-option
|
v-for="item in rolekey"
|
:key="item.value"
|
:label="item.label"
|
:value="item.value"
|
/>
|
</el-select>
|
</el-form-item>
|
<el-form-item>
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span
|
:style="{
|
fontSize: isMin ? '2rem' : '0.88rem',
|
color: 'black',
|
fontWeight: 'bold',
|
}"
|
>备注</span
|
>
|
</div>
|
</template>
|
<el-input
|
style="height: 2rem"
|
size="small"
|
v-model="formRole.description"
|
placeholder="请输入"
|
/>
|
</el-form-item>
|
</el-form>
|
<template #footer>
|
<div class="dialog-footer" style="text-align: center">
|
<el-button
|
size="small"
|
@click="dialogVisible2 = false"
|
style="height: 2rem; font-size: 0.88rem"
|
>取消</el-button
|
>
|
|
<el-button
|
size="small"
|
type="primary"
|
@click="saveRole(formRoleRef)"
|
style="height: 2rem; font-size: 0.88rem"
|
>
|
保存
|
</el-button>
|
</div>
|
</template>
|
</el-dialog>
|
|
<!-- 用户班组新建/编辑 -->
|
<el-dialog
|
v-model="TreamdialogVisible"
|
title=""
|
width="20%"
|
:before-close="handleClose"
|
:show-close="false"
|
:align-center="true"
|
@close="resetForm2(formTreamdRef)"
|
>
|
<template #title>
|
<div
|
style="
|
height: 3.63rem;
|
display: flex;
|
border-bottom: 1px solid #e6e6e6;
|
"
|
>
|
<span
|
:style="{
|
color: 'rgb(16, 16, 16)',
|
fontSize: isMin ? '2rem' : '1rem',
|
fontWeight: 'bold',
|
}"
|
>用户班组</span
|
>
|
</div>
|
</template>
|
<el-form
|
:model="formTeam"
|
label-width="auto"
|
label-position="top"
|
ref="formTreamdRef"
|
:rules="roleRules"
|
:hide-required-asterisk="true"
|
>
|
<el-form-item prop="teamName">
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span
|
:style="{
|
color: 'red',
|
marginRight: '0.2rem',
|
fontSize: '2rem',
|
}"
|
>*</span
|
>
|
<span
|
:style="{
|
fontSize: isMin ? '2rem' : '0.88rem',
|
color: 'black',
|
fontWeight: bold,
|
}"
|
>班组名称</span
|
>
|
</div>
|
</template>
|
<el-input
|
style="height: 2rem"
|
size="small"
|
v-model="formTeam.teamName"
|
placeholder="请输入"
|
/>
|
</el-form-item>
|
</el-form>
|
<template #footer>
|
<div class="dialog-footer" style="text-align: center">
|
<el-button
|
size="small"
|
@click="TreamdialogVisible = false"
|
style="height: 2rem; font-size: 0.88rem"
|
>取消</el-button
|
>
|
|
<el-button
|
size="small"
|
type="primary"
|
@click="saveTream(formTreamdRef)"
|
style="height: 2rem; font-size: 0.88rem"
|
>
|
保存
|
</el-button>
|
</div>
|
</template>
|
</el-dialog>
|
|
<!-- 用户单位新建/编辑 -->
|
<el-dialog
|
v-model="UnitdialogVisible"
|
title=""
|
width="20%"
|
:before-close="handleClose"
|
:show-close="false"
|
:align-center="true"
|
@close="resetForm3(formUnitRef)"
|
>
|
<template #title>
|
<div
|
style="
|
height: 3.63rem;
|
display: flex;
|
border-bottom: 1px solid #e6e6e6;
|
"
|
>
|
<span
|
:style="{
|
color: 'rgb(16, 16, 16)',
|
fontSize: isMin ? '2rem' : '1rem',
|
fontWeight: 'bold',
|
}"
|
>用户单位</span
|
>
|
</div>
|
</template>
|
<el-form
|
:model="formUnit"
|
label-width="auto"
|
label-position="top"
|
ref="formUnitRef"
|
:rules="roleRules"
|
:hide-required-asterisk="true"
|
>
|
<el-form-item prop="unitName">
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span
|
:style="{
|
color: 'red',
|
marginRight: '0.2rem',
|
fontSize: '2rem',
|
}"
|
>*</span
|
>
|
<span
|
:style="{
|
fontSize: isMin ? '2rem' : '0.88rem',
|
color: 'black',
|
fontWeight: bold,
|
}"
|
>单位名称</span
|
>
|
</div>
|
</template>
|
<el-input
|
style="height: 2rem"
|
size="small"
|
v-model="formUnit.unitName"
|
placeholder="请输入"
|
/>
|
</el-form-item>
|
</el-form>
|
<template #footer>
|
<div class="dialog-footer" style="text-align: center">
|
<el-button
|
size="small"
|
@click="UnitdialogVisible = false"
|
style="height: 2rem; font-size: 0.88rem"
|
>取消</el-button
|
>
|
|
<el-button
|
size="small"
|
type="primary"
|
@click="saveUnit(formUnitRef)"
|
style="height: 2rem; font-size: 0.88rem"
|
>
|
保存
|
</el-button>
|
</div>
|
</template>
|
</el-dialog>
|
|
<!-- 用户ip新建/编辑 -->
|
<el-dialog
|
v-model="dialogipVisible"
|
title=""
|
width="40%"
|
:before-close="handleClose"
|
:show-close="false"
|
:align-center="true"
|
@close="resetForm4(formipRef)"
|
>
|
<template #title>
|
<div
|
style="
|
height: 3.63rem;
|
display: flex;
|
border-bottom: 1px solid #e6e6e6;
|
"
|
>
|
<span
|
:style="{
|
color: 'rgb(16, 16, 16)',
|
fontSize: isMin ? '2rem' : '1rem',
|
fontWeight: 'bold',
|
}"
|
>用户ip</span
|
>
|
</div>
|
</template>
|
<el-form
|
:model="formip"
|
label-width="auto"
|
label-position="top"
|
ref="formipRef"
|
:rules="ipRules"
|
:hide-required-asterisk="true"
|
>
|
<el-form-item prop="iPaddress">
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span
|
:style="{
|
color: 'red',
|
marginRight: '0.2rem',
|
fontSize: '2rem',
|
}"
|
>*</span
|
>
|
<span
|
:style="{
|
fontSize: isMin ? '2rem' : '0.88rem',
|
color: 'black',
|
fontWeight: bold,
|
}"
|
>ip地址</span
|
>
|
</div>
|
</template>
|
<el-input
|
style="height: 2rem"
|
size="small"
|
v-model="formip.iPaddress"
|
placeholder="请输入"
|
/>
|
</el-form-item>
|
<el-form-item prop="addressname">
|
<template #label>
|
<div style="display: flex; align-items: flex-end">
|
<span
|
:style="{
|
color: 'red',
|
marginRight: '0.2rem',
|
fontSize: '2rem',
|
}"
|
>*</span
|
>
|
<span
|
:style="{
|
fontSize: isMin ? '2rem' : '0.88rem',
|
color: 'black',
|
fontWeight: bold,
|
}"
|
>检修道</span
|
>
|
</div>
|
</template>
|
<el-input
|
style="height: 2rem"
|
size="small"
|
v-model="formip.addressname"
|
placeholder="请输入"
|
/>
|
</el-form-item>
|
</el-form>
|
<template #footer>
|
<div class="dialog-footer" style="text-align: center">
|
<el-button
|
size="small"
|
@click="dialogipVisible = false"
|
style="height: 2rem; font-size: 0.88rem"
|
>取消</el-button
|
>
|
|
<el-button
|
size="small"
|
type="primary"
|
@click="saveIp(formipRef)"
|
style="height: 2rem; font-size: 0.88rem"
|
>
|
保存
|
</el-button>
|
</div>
|
</template>
|
</el-dialog>
|
|
<el-dialog v-model="imgdialogVisible" width="35%" top="3vh">
|
<div
|
style="
|
width: 100%;
|
height: 100%;
|
display: flex;
|
justify-content: center;
|
align-items: center;
|
"
|
>
|
<img
|
w-full
|
style="width: 100%; height: 100%"
|
:src="dialogImageUrl"
|
alt="Preview Image"
|
/>
|
</div>
|
</el-dialog>
|
|
<!-- 人脸注册 -->
|
<el-dialog
|
v-model="registerdialogVisible"
|
title="插件配置"
|
width="500"
|
:before-close="handleClose"
|
top="5vh"
|
>
|
<template #header="{ titleId }">
|
<div class="my-header">
|
<h2 :id="titleId" style="font-size: 2rem">人脸录入</h2>
|
</div>
|
</template>
|
<div class="content_register">
|
<div class="image-container">
|
<img
|
src="@/assets/login/headimg.jpg"
|
id="img"
|
style="width: 100%"
|
class="profile-image"
|
/>
|
</div>
|
<div class="action-buttons" @click="begin(1)">
|
<a href="myapp://" class="btn face-register">
|
<i class="fas fa-user-plus"></i> 人脸录入</a
|
>
|
<button class="btn submit-data" @click="faceEnter()">
|
<i class="fas fa-paper-plane"></i> 提交数据
|
</button>
|
</div>
|
</div>
|
<template #footer>
|
<!-- <div class="dialog-footer">
|
<el-button type="primary" class="downloadreBtn" @click="download(2)"
|
>提交配置</el-button
|
>
|
</div> -->
|
</template>
|
</el-dialog>
|
</div>
|
</template>
|
<script setup>
|
import { ref, reactive, onMounted, toRef } from "vue";
|
import { ElMessage, ElMessageBox, ElLoading } from "element-plus";
|
import {
|
GetUserList,
|
AddUser,
|
UpdateUser,
|
DelApi,
|
ExportApi,
|
ExportApi1,
|
UpdatePwd,
|
DeleteUserData,
|
GetDepartment,
|
GetUserTeam,
|
AddUserTeam,
|
EditUserTeam,
|
DeleteUserTeam,
|
GetUserUnit,
|
AddUserUnit,
|
EditUserUnit,
|
DeleteUserUnit,
|
GetIPData,
|
AddIP,
|
EditIP,
|
DeleteIP,
|
} from "@/api/user";
|
import { useRouter } from "vue-router";
|
import { formatTime } from "@/utils/index.js";
|
import {
|
GetPageDataApi,
|
StatusChangeApiApi,
|
AddRoleApi,
|
UpdateRoleApi,
|
DeleteRoleApi,
|
} from "@/api/role";
|
let obj = {
|
selectName: "",
|
selectTime: [], // 时间范围
|
selectType: "",
|
selectInput: "",
|
};
|
const queryForm = toRef({ ...obj });
|
const router = useRouter();
|
|
const tableData = ref([]);
|
const grideData = ref([]);
|
//用户班组
|
const departmentData = ref([]);
|
//用户单位
|
const unitData = ref([]);
|
//新建用户ref
|
const formUserRef = ref();
|
const userInfo = ref();
|
const isoptins = ref([
|
{
|
value: 0,
|
label: "否",
|
},
|
{ value: 1, label: "是" },
|
]);
|
//角色
|
const groupOptions = ref([]);
|
const formUser = ref({
|
id: undefined,
|
username: "",
|
phoneno: "",
|
roleid: null,
|
rolename: "",
|
enable: 1,
|
path: "",
|
usertruename: "",
|
dept_Id: 1,
|
carnuber: null,
|
userteam: "",
|
isLeader: 0,
|
userunit: "",
|
});
|
const rules = reactive({
|
username: {
|
required: true,
|
message: "请输入用户名",
|
trigger: "blur",
|
},
|
roleid: {
|
required: true,
|
message: "请选择角色",
|
trigger: "change",
|
},
|
newPwd: [
|
{
|
required: true,
|
message: "请输入密码",
|
trigger: "blur",
|
},
|
],
|
realName: {
|
required: true,
|
message: "请输入姓名",
|
trigger: "blur",
|
},
|
phoneno: {
|
required: true,
|
message: "请输入手机号",
|
trigger: "blur",
|
},
|
usertruename: {
|
required: true,
|
message: "请输入真实姓名",
|
trigger: "blur",
|
},
|
userteam: {
|
required: true,
|
message: "请输入组",
|
trigger: "blur",
|
},
|
userunit: {
|
required: true,
|
message: "请选择单位",
|
trigger: "blur",
|
},
|
});
|
const formpasswordRef = ref();
|
const isactive = ref(1);
|
const dialogVisible = ref(false);
|
const imgdialogVisible = ref(false);
|
const dialogImageUrl = ref("");
|
//用户信息修改密码弹出框
|
const dialogVisible1 = ref(false);
|
//用户角色新建
|
const dialogVisible2 = ref(false);
|
//人脸注册
|
const registerdialogVisible = ref(false);
|
//筛选条件
|
const userOptions = [
|
{
|
value: "userName",
|
label: "登录账号",
|
},
|
{
|
value: "userTrueName",
|
label: "真实姓名",
|
},
|
{
|
value: "phoneNo",
|
label: "联系方式",
|
},
|
];
|
const fileList = ref([]);
|
const rolekey = ref([
|
{ value: 1, label: "组长" },
|
{ value: 0, label: "组员" },
|
]);
|
const roleOptions = [
|
{
|
value: "roleName",
|
label: "角色名称",
|
},
|
];
|
const treamOptions = [
|
{
|
value: "teamName",
|
label: "班组名称",
|
},
|
];
|
const unitOptions = [
|
{
|
value: "unitName",
|
label: "单位名称",
|
},
|
];
|
const selectoptions = ref([]);
|
selectoptions.value = userOptions;
|
//用户修改密码
|
const formpassword = ref({
|
oldPwd: "",
|
newPwd: "",
|
});
|
const passwordrules = reactive({
|
newPwd: [
|
{
|
required: true,
|
message: "请输入密码",
|
trigger: "blur",
|
},
|
{
|
min: 6,
|
max: 12,
|
message: "密码长度在 6 到 12 个字符",
|
trigger: "blur",
|
},
|
],
|
});
|
const uploadRef = ref();
|
const showUpload = ref(false);
|
const pageTotal = ref(0);
|
const isMin = ref(false);
|
const newRole = ref({});
|
//获取部门
|
const departmentOptions = ref([]);
|
|
const initData = () => {
|
// 查询条件
|
const startTime = formatTime(queryForm.value.selectTime[0]);
|
const endTime = formatTime(queryForm.value.selectTime[1]);
|
const filter = [
|
{
|
name: queryForm.value.selectType,
|
value: queryForm.value.selectInput,
|
displayType: "like",
|
},
|
{ name: "createDate", value: startTime, displayType: "ThanOrEqual" },
|
{ name: "createDate", value: endTime, displayType: "LessOrEqual" },
|
];
|
GetUserList({
|
pageIndex: 1,
|
pageSize: 10,
|
searchKeyword: "",
|
startDate: formatTime(queryForm.value.selectTime[0]),
|
endDate: formatTime(queryForm.value.selectTime[1]),
|
status: 0,
|
sortField: "",
|
sortOrder: "",
|
account: "",
|
}).then((res) => {
|
tableData.value = res.data.items.map((item) => {
|
return {
|
...item,
|
isdisabled:
|
userInfo.value.userName == "admin" || userInfo.value.roleId == "1"
|
? item.userName == "admin" || item.user_Id == "1"
|
: item.userName == "admin" ||
|
item.user_Id == "1" ||
|
item.userName != userInfo.value.userName,
|
};
|
});
|
pageTotal.value = res.data.totalCount;
|
});
|
getDepartment();
|
};
|
const getDepartment = () => {
|
GetDepartment({
|
page: 1,
|
rows: 100,
|
total: 0,
|
tableName: "string",
|
sort: "string",
|
order: "string",
|
wheres: "string",
|
export: true,
|
value: "string",
|
filter: [
|
{
|
name: "string",
|
value: "string",
|
displayType: "string",
|
},
|
],
|
}).then((res) => {
|
departmentOptions.value = res.rows;
|
});
|
};
|
//分页请求参数
|
const pageQuery = ref({
|
page: 1, //当前页面
|
rows: 10, //每页显示条数
|
order: "desc", //排序方式
|
sort: "", //排序字段
|
wheres: "", //条件查询
|
});
|
|
//数据检索事件
|
const handleQuery = () => {
|
pageQuery.value.page = 1;
|
if (isactive.value == 1) {
|
initData();
|
} else {
|
getRole();
|
}
|
};
|
//重置查询条件
|
const resetQuery = () => {
|
queryForm.value = Object.assign({}, obj);
|
pageQuery.value.page = 1;
|
if (isactive.value == 1) {
|
initData();
|
} else {
|
getRole();
|
}
|
};
|
//分页页面大小改变
|
const handleSizeChange = (val) => {
|
pageQuery.value.rows = val;
|
if (isactive.value == 1) {
|
initData();
|
} else {
|
getRole();
|
}
|
};
|
|
//分页页面改变
|
const handleCurrentChange = (val) => {
|
pageQuery.value.page = val;
|
if (isactive.value == 1) {
|
initData();
|
} else {
|
getRole();
|
}
|
};
|
const handleAvatarSuccess = (response, file, fileList) => {
|
formUser.value.path = response.data;
|
if (fileList.length >= 1) {
|
showUpload.value = true;
|
}
|
};
|
//重置表单
|
const resetForm = (formEl) => {
|
if (!formEl) return;
|
formEl.resetFields();
|
formUser.value = {
|
username: "",
|
phoneno: "",
|
roleid: null,
|
rolename: "",
|
enable: 1,
|
path: "",
|
user_Id: undefined,
|
userteam: "",
|
carnuber: null,
|
isLeader: 0,
|
};
|
fileList.value = [];
|
};
|
const resetForm1 = (formEl) => {
|
if (!formEl) return;
|
formEl.resetFields();
|
formRole.value = {
|
roleName: "",
|
description: "",
|
};
|
};
|
const resetForm2 = (formEl) => {
|
if (!formEl) return;
|
formEl.resetFields();
|
formTeam.value = {
|
teamName: "",
|
};
|
};
|
const resetForm3 = (formEl) => {
|
if (!formEl) return;
|
formEl.resetFields();
|
formUnit.value = {
|
unitName: "",
|
};
|
};
|
const resetForm4 = (formEl) => {
|
if (!formEl) return;
|
formEl.resetFields();
|
formip.value = {
|
creater: "",
|
createDate: "",
|
modifier: "",
|
modifyDate: "",
|
id: 0,
|
iPaddress: "",
|
addressname: "",
|
};
|
};
|
|
const handlePictureCardPreview = (uploadFile) => {
|
dialogImageUrl.value = uploadFile.url;
|
imgdialogVisible.value = true;
|
};
|
const handleRemove = (file, fileList1) => {
|
fileList.value = [];
|
//移除已上传的图片
|
formUser.value.path = "";
|
if (fileList.value.length < 1) {
|
showUpload.value = false;
|
}
|
};
|
const beforeAvatarUpload = (val) => {
|
console.log(val);
|
};
|
const handleRoleChange = (val) => {
|
groupOptions.value.find((item) => {
|
if (item.roleId == val) {
|
newRole.value = item;
|
}
|
});
|
};
|
//新建用户账号
|
const saveObj = async (formEl) => {
|
if (!formEl) return;
|
await formEl.validate((valid, fields) => {
|
if (valid) {
|
if (formUser.value.id != undefined) {
|
// if (!formUser.value.userteam.includes("组")) {
|
// formUser.value.userteam = formUser.value.userteam + "组";
|
// }
|
formUser.value.isLeader = newRole.value.isLeader;
|
formUser.value.rolename = newRole.value.roleName;
|
UpdateUser(formUser.value).then((res) => {
|
ElMessage({ message: "修改成功", type: "success" });
|
dialogVisible.value = false;
|
initData();
|
});
|
} else {
|
// if (!formUser.value.userteam.includes("组")) {
|
// formUser.value.userteam = formUser.value.userteam + "组";
|
// }
|
formUser.value.isLeader = newRole.value.isLeader;
|
AddUser(formUser.value).then((res) => {
|
ElMessage({ message: "提交成功", type: "success" });
|
dialogVisible.value = false;
|
initData();
|
});
|
}
|
} else {
|
console.log("error submit!", fields);
|
}
|
});
|
};
|
//删除用户
|
const deletUser = (val) => {
|
ElMessageBox.confirm("确认删除该用户吗?", {
|
confirmButtonText: "确认",
|
cancelButtonText: "取消",
|
type: "warning",
|
})
|
.then(() => {
|
DeleteUserData({
|
userAccount: val.userName,
|
}).then((res) => {
|
ElMessage({
|
type: "success",
|
message: "删除成功",
|
});
|
initData();
|
});
|
})
|
.catch(() => {
|
ElMessage({
|
type: "info",
|
message: "取消删除",
|
});
|
});
|
};
|
//是否启用
|
const changeSwitch = (val) => {
|
let data = {
|
id: val.user_Id,
|
username: val.userName,
|
phoneno: val.phoneNo,
|
roleid: val.role_Id,
|
rolename: val.roleName,
|
enable: val.enable,
|
path: val.headImageUrl,
|
usertruename: val.userTrueName,
|
cardNumber: val.cardNumber,
|
userteam: val.userteam,
|
userunit: val.unit,
|
dept_Id: val.dept_Id,
|
};
|
UpdateUser(data).then((res) => {
|
ElMessage({ message: "修改成功", type: "success" });
|
dialogVisible.value = false;
|
initData();
|
});
|
console.log(val);
|
};
|
// 用户角色是否启用
|
const changeRoleSwitch = (val) => {
|
let data = Object.assign({}, val);
|
StatusChangeApiApi(data).then((res) => {
|
ElMessage({ message: "修改成功", type: "success" });
|
dialogVisible.value = false;
|
initData();
|
});
|
};
|
//编辑用户账号
|
const Edit = (val) => {
|
console.log(val);
|
let obj = {
|
id: val.user_Id,
|
username: val.userName,
|
phoneno: val.phoneNo,
|
roleid: val.role_Id,
|
rolename: val.roleName,
|
enable: val.enable,
|
path: val.headImageUrl,
|
usertruename: val.userTrueName,
|
carnuber: val.cardNumber,
|
userteam: val.userteam,
|
dept_Id: val.dept_Id,
|
isLeader: val.isLeader,
|
userunit: val.unit,
|
};
|
formUser.value = {
|
...obj,
|
};
|
if (obj.headImageUrl != null) {
|
fileList.value = [
|
{
|
name: "1",
|
url: "http://192.168.1.103:9093" + obj.headImageUrl,
|
},
|
];
|
}
|
|
dialogVisible.value = true;
|
};
|
const newobj = ref({});
|
//修改密码
|
const Editpassword = (val) => {
|
let obj = Object.assign({}, val);
|
formUser.value = obj;
|
formpassword.value = val;
|
dialogVisible1.value = true;
|
};
|
//保存修改密码
|
const savePassword = async (formEl) => {
|
let obj = Object.assign({}, newobj);
|
// obj.password = formpassword.value.password;
|
|
let formdata = {
|
id: formUser.value.user_Id,
|
oldPwd: formUser.value.userPwd,
|
newPwd: newobj.value.newPwd,
|
};
|
if (!formEl) return;
|
await formEl.validate((valid, fields) => {
|
if (valid) {
|
UpdatePwd(formdata).then((res) => {
|
ElMessage({ message: "修改密码成功", type: "success" });
|
dialogVisible1.value = false;
|
initData();
|
});
|
} else {
|
console.log("error submit!", fields);
|
}
|
});
|
};
|
const formRoleRef = ref();
|
const roleRules = reactive({
|
roleName: {
|
required: true,
|
message: "请输入角色名称",
|
trigger: "blur",
|
},
|
description: {
|
required: true,
|
message: "请输入角色描述",
|
trigger: "blur",
|
},
|
teamName: {
|
required: true,
|
message: "请输入班组名称",
|
trigger: "blur",
|
},
|
unitName: {
|
required: true,
|
message: "请输入单位名称",
|
trigger: "blur",
|
},
|
});
|
const ipRules = reactive({
|
iPaddress: {
|
required: true,
|
message: "请输入IP地址",
|
trigger: "blur",
|
},
|
addressname: {
|
required: true,
|
message: "请输入检修道",
|
trigger: "blur",
|
},
|
});
|
|
const formRole = ref({
|
roleName: "",
|
description: "",
|
createDate: formatTime(new Date()), //创建时间
|
creater: JSON.parse(localStorage.getItem("user")).userName, //创建人
|
});
|
|
//新建角色
|
const AddRole = () => {
|
Roletype.value = "新建";
|
dialogVisible2.value = true;
|
};
|
const Roletype = ref("新建");
|
//保存角色
|
const saveRole = async (formEl) => {
|
if (!formEl) return;
|
await formEl.validate((valid, fields) => {
|
if (valid) {
|
if (Roletype.value == "修改") {
|
UpdateRoleApi(formRole.value).then((res) => {
|
ElMessage({ message: "修改成功", type: "success" });
|
dialogVisible2.value = false;
|
getRole();
|
});
|
} else {
|
AddRoleApi(formRole.value).then((res) => {
|
ElMessage({ message: "添加成功", type: "success" });
|
dialogVisible2.value = false;
|
getRole();
|
});
|
}
|
} else {
|
console.log("error submit!", fields);
|
}
|
});
|
};
|
//编辑角色
|
const EditRole = (val) => {
|
Roletype.value = "修改";
|
let obj = Object.assign({}, val);
|
formRole.value = obj;
|
dialogVisible2.value = true;
|
};
|
//编辑班组
|
const EditTream = (val) => {
|
Treamtype.value = "修改";
|
let obj = Object.assign({}, val);
|
formTeam.value = obj;
|
TreamdialogVisible.value = true;
|
};
|
//编辑单位
|
const EditUnit = (val) => {
|
Unittype.value = "修改";
|
let obj = Object.assign({}, val);
|
formUnit.value = obj;
|
UnitdialogVisible.value = true;
|
};
|
//获取角色
|
const getRole = () => {
|
const startTime = formatTime(queryForm.value.selectTime[0]);
|
const endTime = formatTime(queryForm.value.selectTime[1]);
|
const filter = [
|
{
|
name: queryForm.value.selectType,
|
value: queryForm.value.selectInput,
|
displayType: "like",
|
},
|
{ name: "createDate", value: startTime, displayType: "ThanOrEqual" },
|
{ name: "createDate", value: endTime, displayType: "LessOrEqual" },
|
];
|
GetPageDataApi({ ...pageQuery.value, filter }).then((res) => {
|
grideData.value = res.rows;
|
pageTotal.value = res.total;
|
groupOptions.value = res.rows;
|
});
|
};
|
//打印数据
|
const printExcel = () => {
|
// 查询条件
|
const startTime = formatTime(queryForm.value.selectTime[0]);
|
const endTime = formatTime(queryForm.value.selectTime[1]);
|
const filter = [
|
{
|
name: queryForm.value.selectType,
|
value: queryForm.value.selectInput,
|
displayType: "like",
|
},
|
{
|
name: "pustatus",
|
value: queryForm.value.selectName,
|
displayType: "String",
|
},
|
{ name: "createDate", value: startTime, displayType: "ThanOrEqual" },
|
{ name: "createDate", value: endTime, displayType: "LessOrEqual" },
|
];
|
if (isactive.value == 1) {
|
ExportApi({
|
...pageQuery.value,
|
filter,
|
});
|
}
|
if (isactive.value == 2) {
|
ExportApi1({
|
...pageQuery.value,
|
filter,
|
});
|
}
|
};
|
//获取用户班组
|
const getGroup = () => {
|
const startTime = formatTime(queryForm.value.selectTime[0]);
|
const endTime = formatTime(queryForm.value.selectTime[1]);
|
const filter = [
|
{
|
name: queryForm.value.selectType,
|
value: queryForm.value.selectInput,
|
displayType: "like",
|
},
|
{ name: "createDate", value: startTime, displayType: "ThanOrEqual" },
|
{ name: "createDate", value: endTime, displayType: "LessOrEqual" },
|
];
|
GetUserTeam({ ...pageQuery.value, filter }).then((res) => {
|
departmentData.value = res.rows;
|
pageTotal.value = res.total;
|
});
|
};
|
const formTeam = ref({});
|
const TreamdialogVisible = ref(false);
|
//新建用户班组
|
const AddGroup = () => {
|
Treamtype.value = "新建";
|
TreamdialogVisible.value = true;
|
};
|
const Treamtype = ref("新建");
|
const formTreamdRef = ref(null);
|
const saveTream = async (formEl) => {
|
if (!formEl) return;
|
await formEl.validate((valid, fields) => {
|
if (valid) {
|
if (Treamtype.value == "修改") {
|
EditUserTeam(formTeam.value).then((res) => {
|
ElMessage({ message: "修改成功", type: "success" });
|
TreamdialogVisible.value = false;
|
getGroup();
|
});
|
} else {
|
AddUserTeam(formTeam.value).then((res) => {
|
ElMessage({ message: "添加成功", type: "success" });
|
TreamdialogVisible.value = false;
|
getGroup();
|
});
|
}
|
} else {
|
console.log("error submit!", fields);
|
}
|
});
|
};
|
const formUnit = ref({});
|
const UnitdialogVisible = ref(false);
|
const Unittype = ref("新建");
|
const formUnitRef = ref(null);
|
const AddUnit = () => {
|
Unittype.value = "新建";
|
UnitdialogVisible.value = true;
|
};
|
const Addip = () => {
|
ipType.value = "新建";
|
dialogipVisible.value = true;
|
};
|
//获取用户单位
|
const getUnit = () => {
|
const startTime = formatTime(queryForm.value.selectTime[0]);
|
const endTime = formatTime(queryForm.value.selectTime[1]);
|
const filter = [
|
{
|
name: queryForm.value.selectType,
|
value: queryForm.value.selectInput,
|
displayType: "like",
|
},
|
{ name: "createDate", value: startTime, displayType: "ThanOrEqual" },
|
{ name: "createDate", value: endTime, displayType: "LessOrEqual" },
|
];
|
GetUserUnit({ ...pageQuery.value, filter }).then((res) => {
|
unitData.value = res.rows;
|
pageTotal.value = res.total;
|
});
|
};
|
//保存单位
|
const saveUnit = async (formEl) => {
|
if (!formEl) return;
|
await formEl.validate((valid, fields) => {
|
if (valid) {
|
if (Unittype.value == "修改") {
|
EditUserUnit(formUnit.value).then((res) => {
|
ElMessage({ message: "修改成功", type: "success" });
|
UnitdialogVisible.value = false;
|
getUnit();
|
});
|
} else {
|
AddUserUnit(formUnit.value).then((res) => {
|
ElMessage({ message: "添加成功", type: "success" });
|
UnitdialogVisible.value = false;
|
getUnit();
|
});
|
}
|
} else {
|
console.log("error submit!", fields);
|
}
|
});
|
};
|
//切换页面
|
const changeactive = (index) => {
|
isactive.value = index;
|
if (isactive.value == 1) {
|
selectoptions.value = userOptions;
|
initData();
|
} else if (isactive.value == 2) {
|
selectoptions.value = roleOptions;
|
getRole();
|
} else if (isactive.value == 3) {
|
selectoptions.value = treamOptions;
|
getGroup();
|
} else if (isactive.value == 4) {
|
selectoptions.value = unitOptions;
|
getUnit();
|
} else if ((isactive.value = 5)) {
|
getIpData();
|
}
|
};
|
|
//批量删除
|
const ids = ref([]);
|
const UserSelectionChange = (val) => {
|
ids.value = [];
|
ids.value = val.map((item) => item.user_Id);
|
console.log(val, ids.value);
|
};
|
const RoleSelectionChange = (val) => {
|
ids.value = [];
|
ids.value = val.map((item) => item.roleId);
|
};
|
const TreamSelectionChange = (val) => {
|
ids.value = [];
|
ids.value = val.map((item) => item.id);
|
};
|
const UnitSelectionChange = (val) => {
|
ids.value = [];
|
ids.value = val.map((item) => item.id);
|
};
|
const IpSelectionChange = (val) => {
|
ids.value = [];
|
ids.value = val.map((item) => item.id);
|
};
|
const deleteAll = () => {
|
if (ids.value.includes(1)) {
|
ElMessage({ message: "超级管理员不能删除", type: "error" });
|
return;
|
}
|
if (ids.value.length == 0) {
|
ElMessage({ message: "请选择要删除的数据", type: "error" });
|
return;
|
}
|
if (isactive.value == 1) {
|
DelApi(ids.value).then((res) => {
|
ElMessage({ message: "删除成功", type: "success" });
|
initData();
|
});
|
} else if (isactive.value == 2) {
|
DeleteRoleApi(ids.value).then((res) => {
|
ElMessage({ message: "删除成功", type: "success" });
|
getRole();
|
});
|
} else if (isactive.value == 3) {
|
DeleteUserTeam(ids.value).then((res) => {
|
ElMessage({ message: "删除成功", type: "success" });
|
getGroup();
|
});
|
} else if (isactive.value == 4) {
|
DeleteUserUnit(ids.value).then((res) => {
|
ElMessage({ message: "删除成功", type: "success" });
|
getUnit();
|
});
|
} else if (isactive.value == 5) {
|
DeleteIP(ids.value).then((res) => {
|
ElMessage({ message: "删除成功", type: "success" });
|
getIpData();
|
});
|
}
|
};
|
// 管理 路由跳转
|
const toDetail = (row) => {
|
router.push({ name: "permission", state: { info: JSON.stringify(row) } });
|
};
|
const interval = ref(null);
|
const onloading = ref(null);
|
const baseUrl = "http://192.168.1.103:9093";
|
const token = ref("");
|
const imgbase64 = ref("");
|
let urlPlugin = baseUrl + "/api/UserFace/DownlodaFacePlugin";
|
let urlPReg = baseUrl + "/api/UserFace/DownloadRegFile";
|
|
const getData = (flag) => {
|
let url = "http://localhost:9298";
|
let xmlResquest = new XMLHttpRequest();
|
xmlResquest.open("post", url, true);
|
xmlResquest.onload = function (e) {
|
if (xmlResquest.status == 200) {
|
clearTimeout(interval.value);
|
imgbase64.value = xmlResquest.response;
|
if (flag == 2) {
|
const faceContainer = document.getElementById("face-recognition");
|
const faceIcon = faceContainer.querySelector(".face-icon");
|
const capturedFace = document.getElementById("captured-face");
|
capturedFace.src = "data:image/png;base64," + xmlResquest.response;
|
faceIcon.style.display = "none";
|
capturedFace.style.display = "block";
|
window.URL.revokeObjectURL(url);
|
faceRecognitionEvent();
|
return;
|
} else {
|
let img = document.getElementById("img");
|
img.src = "data:image/png;base64," + xmlResquest.response;
|
window.URL.revokeObjectURL(url);
|
// hideLoading();
|
onloading.value.close();
|
return;
|
}
|
}
|
// hideLoading();
|
onloading.value.close();
|
};
|
|
xmlResquest.send();
|
};
|
|
const begin = (flag) => {
|
if (interval.value) {
|
clearTimeout(interval.value);
|
}
|
onloading.value = ElLoading.service({
|
lock: true,
|
text: "正在处理中,请稍后...",
|
background: "rgba(0, 0, 0, 0.7)",
|
});
|
interval.value = setInterval(() => {
|
getData(flag);
|
}, 10000);
|
};
|
|
function faceEnter() {
|
token.value = JSON.parse(localStorage.getItem("user")).token;
|
console.log(token.value);
|
|
let url = baseUrl + "/api/UserFace/faceEnter";
|
let xmlResquest = new XMLHttpRequest();
|
xmlResquest.open("post", url, true);
|
xmlResquest.setRequestHeader("Content-Type", "application/json");
|
xmlResquest.setRequestHeader("Authorization", "Bearer " + token.value);
|
xmlResquest.onload = function (e) {
|
img.src = "headimg.jpg";
|
if (xmlResquest.status == 200) {
|
let response = JSON.parse(xmlResquest.response);
|
if (response.status) {
|
ElMessage.success("人脸录入成功,图片名称:" + response.data);
|
onloading.value.close();
|
registerdialogVisible.value = false;
|
// hideLoading();
|
} else {
|
ElMessage.error("人脸录入失败,错误信息:" + response.message);
|
onloading.value.close();
|
registerdialogVisible.value = false;
|
// hideLoading();
|
}
|
} else {
|
ElMessage.error("数据提交失败");
|
onloading.value.close();
|
registerdialogVisible.value = false;
|
}
|
};
|
xmlResquest.send(JSON.stringify({ Base64Image: imgbase64.value }));
|
}
|
const ipData = ref([]);
|
const dialogipVisible = ref(false);
|
const ipType = ref("新建");
|
const formip = ref({
|
creater: "",
|
createDate: "",
|
modifier: "",
|
modifyDate: "",
|
id: 0,
|
iPaddress: "",
|
addressname: "",
|
});
|
const formipRef = ref(null);
|
//获取ip数据
|
const getIpData = () => {
|
// 查询条件
|
const startTime = formatTime(queryForm.value.selectTime[0]);
|
const endTime = formatTime(queryForm.value.selectTime[1]);
|
const filter = [
|
{
|
name: queryForm.value.selectType,
|
value: queryForm.value.selectInput,
|
displayType: "like",
|
},
|
{ name: "createDate", value: startTime, displayType: "ThanOrEqual" },
|
{ name: "createDate", value: endTime, displayType: "LessOrEqual" },
|
];
|
GetIPData({
|
...pageQuery.value,
|
filter,
|
}).then((res) => {
|
ipData.value = res.rows;
|
pageTotal.value = res.total;
|
});
|
};
|
const Editip = (val) => {
|
ipType.value = "修改";
|
let obj = Object.assign({}, val);
|
formip.value = obj;
|
dialogipVisible.value = true;
|
};
|
//保存ip
|
const saveIp = async (formEl) => {
|
if (!formEl) return;
|
await formEl.validate((valid, fields) => {
|
if (valid) {
|
if (ipType.value == "修改") {
|
EditIP(formip.value).then((res) => {
|
ElMessage({ message: "修改成功", type: "success" });
|
dialogipVisible.value = false;
|
getIpData();
|
});
|
} else {
|
AddIP(formip.value).then((res) => {
|
ElMessage({ message: "添加成功", type: "success" });
|
dialogipVisible.value = false;
|
getIpData();
|
});
|
}
|
} else {
|
console.log("error submit!", fields);
|
}
|
});
|
};
|
|
onMounted(() => {
|
if (window.innerWidth <= 1080) {
|
isMin.value = true;
|
}
|
//打印当前屏幕宽度
|
initData();
|
getRole();
|
getUnit();
|
getGroup();
|
userInfo.value = JSON.parse(localStorage.getItem("user"));
|
});
|
</script>
|
<style lang="scss" scoped>
|
.Usermanagement {
|
display: flex;
|
background-color: #fff;
|
|
.content {
|
width: 100%;
|
display: flex;
|
flex-direction: column;
|
|
.checkbox {
|
width: 25rem;
|
display: flex;
|
justify-content: space-between;
|
margin-top: 1rem;
|
margin-left: 1.31rem;
|
|
.item {
|
width: 5rem;
|
height: 1.88rem;
|
border-radius: 0.25rem;
|
background-color: rgba(190, 199, 209, 1);
|
color: rgba(255, 255, 255, 1);
|
font-size: 0.88rem;
|
text-align: center;
|
line-height: 1.88rem;
|
cursor: pointer;
|
}
|
|
.isactive {
|
background-color: rgba(16, 16, 16, 1);
|
color: rgba(255, 255, 255, 1);
|
}
|
}
|
|
.serch {
|
display: flex;
|
margin-top: 1.31rem;
|
align-items: center;
|
|
.time_box {
|
display: flex;
|
align-items: center;
|
text-align: center;
|
margin-left: 0.98rem;
|
|
.time {
|
box-sizing: border-box;
|
width: 6.88rem;
|
height: 2rem;
|
text-align: center;
|
border: 0.06rem solid rgba(222, 222, 222, 1);
|
border-radius: 0.25rem 0 0 0.25rem;
|
font-size: 0.75rem;
|
display: flex;
|
align-items: center;
|
justify-content: center;
|
}
|
}
|
|
.serch_box {
|
display: flex;
|
align-items: center;
|
text-align: center;
|
margin-left: 0.98rem;
|
border-radius: 0.38rem;
|
|
.serchb {
|
box-sizing: border-box;
|
width: 9rem;
|
height: 2rem;
|
text-align: center;
|
font-size: 0.75rem;
|
display: flex;
|
align-items: center;
|
justify-content: center;
|
}
|
|
input {
|
box-sizing: border-box;
|
outline: none;
|
width: 19rem;
|
height: 2rem;
|
border: 0.06rem solid rgba(222, 222, 222, 1);
|
border-radius: 0 0.25rem 0.25rem 0;
|
padding-left: 0.3125rem;
|
font-size: 1rem;
|
}
|
}
|
}
|
|
.btns {
|
display: flex;
|
justify-content: space-between;
|
align-items: center;
|
margin-top: 1.31rem;
|
margin-left: 1.13rem;
|
padding-right: 2rem;
|
box-sizing: border-box;
|
}
|
}
|
|
.my-header {
|
height: 3.84rem;
|
display: flex;
|
justify-content: space-between;
|
border-bottom: 0.06rem solid rgba(233, 233, 233, 1);
|
}
|
|
.avatar-uploader .avatar {
|
width: 7rem;
|
height: 7rem;
|
display: block;
|
}
|
|
:deep(.avatar-uploader .el-upload) {
|
width: 7rem;
|
height: 7rem;
|
border: 0.0625rem dashed var(--el-border-color);
|
border-radius: 0.0375rem;
|
cursor: pointer;
|
position: relative;
|
overflow: hidden;
|
transition: var(--el-transition-duration-fast);
|
}
|
|
:deep(.el-upload-list__item) {
|
width: 7rem;
|
height: 7rem;
|
}
|
|
.avatar-uploader .el-upload:hover {
|
border-color: var(--el-color-primary);
|
}
|
|
.el-icon .avatar-uploader-icon {
|
font-size: 0.5rem;
|
color: #8c939d;
|
width: 0.81rem;
|
height: 0.81rem;
|
text-align: center;
|
}
|
}
|
@media screen and (max-width: 1080px) {
|
.Usermanagement {
|
display: flex;
|
background-color: #fff;
|
|
.content {
|
width: 100%;
|
display: flex;
|
flex-direction: column;
|
|
.checkbox {
|
width: 45rem;
|
display: flex;
|
justify-content: space-between;
|
margin-top: 1rem;
|
margin-left: 1.31rem;
|
|
.item {
|
width: 8rem;
|
height: 2.88rem;
|
border-radius: 0.25rem;
|
background-color: rgba(190, 199, 209, 1);
|
color: rgba(255, 255, 255, 1);
|
font-size: 1.25rem;
|
text-align: center;
|
line-height: 2.88rem;
|
cursor: pointer;
|
}
|
|
.isactive {
|
background-color: rgba(16, 16, 16, 1);
|
color: rgba(255, 255, 255, 1);
|
}
|
}
|
|
.serch {
|
display: flex;
|
margin-top: 1.31rem;
|
align-items: center;
|
|
.time_box {
|
display: flex;
|
align-items: center;
|
text-align: center;
|
margin-left: 0.98rem;
|
|
.time {
|
box-sizing: border-box;
|
width: 6.88rem;
|
height: 3rem;
|
text-align: center;
|
border: 0.06rem solid rgba(222, 222, 222, 1);
|
border-radius: 0.25rem 0 0 0.25rem;
|
font-size: 1.25rem;
|
display: flex;
|
align-items: center;
|
justify-content: center;
|
}
|
:deep(.el-input__wrapper) {
|
height: 3rem !important;
|
font-size: 1.25rem !important;
|
}
|
}
|
|
.serch_box {
|
display: flex;
|
align-items: center;
|
text-align: center;
|
margin-left: 0.98rem;
|
border-radius: 0.38rem;
|
|
.serchb {
|
box-sizing: border-box;
|
width: 9rem;
|
height: 3rem !important;
|
text-align: center;
|
font-size: 2rem !important;
|
display: flex;
|
align-items: center;
|
justify-content: center;
|
.select {
|
height: 3rem !important;
|
:deep(.el-select__wrapper) {
|
height: 3rem !important;
|
font-size: 1.5rem !important;
|
}
|
}
|
}
|
|
input {
|
box-sizing: border-box;
|
outline: none;
|
width: 19rem;
|
height: 3rem;
|
border: 0.06rem solid rgba(222, 222, 222, 1);
|
border-radius: 0 0.25rem 0.25rem 0;
|
padding-left: 0.3125rem;
|
font-size: 2rem;
|
}
|
}
|
.text_btn {
|
width: 10rem !important;
|
height: 3.5rem !important;
|
font-size: 2rem !important;
|
display: flex;
|
align-items: center;
|
}
|
}
|
|
.btns {
|
display: flex;
|
justify-content: space-between;
|
align-items: center;
|
margin-top: 1.31rem;
|
margin-left: 1.13rem;
|
padding-right: 2rem;
|
box-sizing: border-box;
|
.text_btn {
|
width: 10rem !important;
|
height: 3.5rem !important;
|
font-size: 2rem !important;
|
display: flex;
|
align-items: center;
|
}
|
}
|
}
|
.formpassword {
|
font-size: 1.5rem !important;
|
}
|
.my-header {
|
height: 3.84rem;
|
display: flex;
|
justify-content: space-between;
|
border-bottom: 0.06rem solid rgba(233, 233, 233, 1);
|
}
|
|
.avatar-uploader .avatar {
|
width: 7rem;
|
height: 7rem;
|
display: block;
|
}
|
|
:deep(.avatar-uploader .el-upload) {
|
width: 7rem;
|
height: 7rem;
|
border: 0.0625rem dashed var(--el-border-color);
|
border-radius: 0.0375rem;
|
cursor: pointer;
|
position: relative;
|
overflow: hidden;
|
transition: var(--el-transition-duration-fast);
|
}
|
|
:deep(.el-upload-list__item) {
|
width: 7rem;
|
height: 7rem;
|
}
|
|
.avatar-uploader .el-upload:hover {
|
border-color: var(--el-color-primary);
|
}
|
|
.el-icon .avatar-uploader-icon {
|
font-size: 0.5rem;
|
color: #8c939d;
|
width: 0.81rem;
|
height: 0.81rem;
|
text-align: center;
|
}
|
.font-title {
|
font-size: 2rem !important;
|
}
|
.from_title {
|
font-size: 2rem !important;
|
}
|
.el-form-item__content {
|
.el-input {
|
height: 3rem !important;
|
font-size: 2rem !important;
|
}
|
.el-select--small :deep(.el-select__wrapper) {
|
font-size: 2rem;
|
line-height: 3rem;
|
min-height: 3rem;
|
}
|
}
|
}
|
}
|
/* 添加字体图标库 */
|
.content_register {
|
flex-direction: column;
|
align-items: center;
|
justify-content: center;
|
padding: 30px;
|
background-color: #f8f9fa;
|
border-radius: 12px;
|
box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
|
max-width: 800px;
|
margin: 0 auto;
|
.image-container {
|
margin-bottom: 25px;
|
border: 3px solid #e9ecef;
|
border-radius: 8px;
|
overflow: hidden;
|
}
|
|
.profile-image {
|
display: block;
|
width: 200px;
|
height: 360px;
|
object-fit: cover;
|
}
|
|
.action-buttons {
|
display: flex;
|
gap: 20px;
|
}
|
|
.btn,
|
a.btn {
|
padding: 12px 25px;
|
border: none;
|
border-radius: 50px;
|
font-size: 16px;
|
font-weight: 600;
|
cursor: pointer;
|
display: inline-flex;
|
align-items: center;
|
gap: 10px;
|
text-decoration: none;
|
color: white;
|
}
|
|
.face-register {
|
background-color: #4e73df;
|
}
|
|
.submit-data {
|
background-color: #1cc88a;
|
}
|
|
/* 确保a标签可点击区域 */
|
.btn {
|
position: relative;
|
z-index: 1;
|
}
|
|
/* 添加点击反馈 */
|
.btn:active {
|
transform: scale(0.98);
|
}
|
}
|
</style>
|
<style>
|
.confirmButtonClass {
|
margin-right: 10px;
|
}
|
|
.el-message-box .el-message-box__btns {
|
flex-direction: row-reverse !important;
|
justify-content: normal !important;
|
}
|
|
:deep(.el-select .el-select__wrapper) {
|
height: 2rem;
|
}
|
</style>
|