Compare commits
3 Commits
7e7e51853d
...
496adee0b4
Author | SHA1 | Date | |
---|---|---|---|
496adee0b4 | |||
78c13c4131 | |||
c069b53636 |
@ -5,8 +5,10 @@ VITE_APP_TITLE = 新能源项目管理平台
|
|||||||
VITE_APP_ENV = 'development'
|
VITE_APP_ENV = 'development'
|
||||||
|
|
||||||
# 开发环境
|
# 开发环境
|
||||||
# VITE_APP_BASE_API = 'http://192.168.110.119:8899'
|
VITE_APP_BASE_API = 'http://192.168.110.119:8899'
|
||||||
VITE_APP_BASE_API = 'http://58.17.134.85:8899'
|
# VITE_APP_BASE_API = 'http://58.17.134.85:8899'
|
||||||
|
# GO开发环境
|
||||||
|
VITE_APP_BASE_API_GO = 'http://192.168.110.159:8919'
|
||||||
|
|
||||||
# 无人机接口地址
|
# 无人机接口地址
|
||||||
|
|
||||||
|
@ -2,6 +2,7 @@ import request from '@/utils/request';
|
|||||||
import { AxiosPromise } from 'axios';
|
import { AxiosPromise } from 'axios';
|
||||||
import { LoginData, LoginResult, TenantInfo, UserProject, VerifyCodeResult } from './types';
|
import { LoginData, LoginResult, TenantInfo, UserProject, VerifyCodeResult } from './types';
|
||||||
import { UserInfo } from '@/api/system/user/types';
|
import { UserInfo } from '@/api/system/user/types';
|
||||||
|
import requestGo from '@/utils/request-go';
|
||||||
|
|
||||||
// pc端固定客户端授权id
|
// pc端固定客户端授权id
|
||||||
const clientId = import.meta.env.VITE_APP_CLIENT_ID;
|
const clientId = import.meta.env.VITE_APP_CLIENT_ID;
|
||||||
@ -119,3 +120,17 @@ export function getUserProject(): AxiosPromise<UserProject[]> {
|
|||||||
method: 'get'
|
method: 'get'
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//获取Go服务Token
|
||||||
|
export function getGoToken(): AxiosPromise<any> {
|
||||||
|
return requestGo({
|
||||||
|
url: '/zm/api/v1/system/login',
|
||||||
|
method: 'post',
|
||||||
|
data: {
|
||||||
|
status: 'yjdsj',
|
||||||
|
verifyCode: '1111',
|
||||||
|
username: 'admin',
|
||||||
|
password: 'zmkg@2023A'
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
@ -10,7 +10,7 @@ import { ConstructionUserFileVO, ConstructionUserFileForm, ConstructionUserFileQ
|
|||||||
|
|
||||||
export const listConstructionUserFile = (query?: ConstructionUserFileQuery): AxiosPromise<ConstructionUserFileVO[]> => {
|
export const listConstructionUserFile = (query?: ConstructionUserFileQuery): AxiosPromise<ConstructionUserFileVO[]> => {
|
||||||
return request({
|
return request({
|
||||||
url: '/project/constructionUserFile/list',
|
url: '/contractor/constructionUserFile/list',
|
||||||
method: 'get',
|
method: 'get',
|
||||||
params: query
|
params: query
|
||||||
});
|
});
|
||||||
|
52
src/api/project/goUser/index.ts
Normal file
52
src/api/project/goUser/index.ts
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
import request from '@/utils/request';
|
||||||
|
// 人员 考勤 补卡 请假接口 对接go 后台
|
||||||
|
// 获取施工人员列表
|
||||||
|
export const getBusConstructionUser = (params) => {
|
||||||
|
return request({
|
||||||
|
url: '/zm/api/wxApplet/wxApplet/busConstructionUser/list',
|
||||||
|
method: 'get',
|
||||||
|
params
|
||||||
|
});
|
||||||
|
};
|
||||||
|
// 获取人员详情
|
||||||
|
export const getDetails = (id) => {
|
||||||
|
return request({
|
||||||
|
url: '/zm/api/wxApplet/wxApplet/busConstructionUser/getDetails',
|
||||||
|
method: 'get',
|
||||||
|
params: {
|
||||||
|
id: id
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
// 获取考勤列表数据
|
||||||
|
export const pcSelectBelowProjectOfPersonnel = (params) => {
|
||||||
|
return request({
|
||||||
|
url: '/zm/api/v1/system/busConstructionUser/pcSelectBelowProjectOfPersonnel',
|
||||||
|
method: 'get',
|
||||||
|
params
|
||||||
|
});
|
||||||
|
};
|
||||||
|
// 获取考勤图表数据
|
||||||
|
export const pcCollectDataForTwoWeeks = (params) => {
|
||||||
|
return request({
|
||||||
|
url: '/api/v1/system/busConstructionUser/pcCollectDataForTwoWeeks',
|
||||||
|
method: 'get',
|
||||||
|
params
|
||||||
|
});
|
||||||
|
};
|
||||||
|
// 获取补卡申请
|
||||||
|
export const busReissueACardList = (params) => {
|
||||||
|
return request({
|
||||||
|
url: '/zm/api/v1/system/busReissueACard/list',
|
||||||
|
method: 'get',
|
||||||
|
params
|
||||||
|
});
|
||||||
|
};
|
||||||
|
// 获取请假列表
|
||||||
|
export const busAskforleaveList = (params) => {
|
||||||
|
return request({
|
||||||
|
url: '/zm/api/v1/system/busAskforleave/list',
|
||||||
|
method: 'get',
|
||||||
|
params
|
||||||
|
});
|
||||||
|
};
|
@ -1,8 +1,8 @@
|
|||||||
import request from '@/utils/request';
|
// import request from '@/utils/request';
|
||||||
import { AxiosPromise } from 'axios';
|
import { AxiosPromise } from 'axios';
|
||||||
import { LeaveVO, LeaveForm, LeaveQuery } from '@/api/project/leave/types';
|
import { LeaveVO, LeaveForm, LeaveQuery } from '@/api/project/leave/types';
|
||||||
import { AuditReissueCardForm } from '../reissueCard/types';
|
import { AuditReissueCardForm } from '../reissueCard/types';
|
||||||
|
import request from '@/utils/request-go';
|
||||||
/**
|
/**
|
||||||
* 查询施工人员请假申请列表
|
* 查询施工人员请假申请列表
|
||||||
* @param query
|
* @param query
|
||||||
@ -11,7 +11,7 @@ import { AuditReissueCardForm } from '../reissueCard/types';
|
|||||||
|
|
||||||
export const listLeave = (query?: LeaveQuery): AxiosPromise<LeaveVO[]> => {
|
export const listLeave = (query?: LeaveQuery): AxiosPromise<LeaveVO[]> => {
|
||||||
return request({
|
return request({
|
||||||
url: '/project/leave/list',
|
url: '/zm/api/v1/system/busAskforleave/list',
|
||||||
method: 'get',
|
method: 'get',
|
||||||
params: query
|
params: query
|
||||||
});
|
});
|
||||||
|
@ -115,6 +115,7 @@ export const useUserStore = defineStore('user', () => {
|
|||||||
roles.value = [];
|
roles.value = [];
|
||||||
permissions.value = [];
|
permissions.value = [];
|
||||||
removeToken();
|
removeToken();
|
||||||
|
$cache.local.remove('goToken'); // 清除Go服务Token缓存
|
||||||
// 清除项目缓存
|
// 清除项目缓存
|
||||||
$cache.local.remove('selectedProject');
|
$cache.local.remove('selectedProject');
|
||||||
$cache.local.remove('ProjectTeamList');
|
$cache.local.remove('ProjectTeamList');
|
||||||
|
19
src/utils/request-go.ts
Normal file
19
src/utils/request-go.ts
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
import $cache from '@/plugins/cache';
|
||||||
|
// src/utils/request-go.ts
|
||||||
|
import request from '@/utils/request';
|
||||||
|
|
||||||
|
const BASE_GO_URL = import.meta.env.VITE_APP_BASE_API_GO;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 包装 request 请求,统一使用 Go 服务地址作为 baseURL
|
||||||
|
* @param config 原始请求配置
|
||||||
|
*/
|
||||||
|
export default function requestGo(config: any) {
|
||||||
|
return request({
|
||||||
|
baseURL: BASE_GO_URL,
|
||||||
|
...config,
|
||||||
|
headers: {
|
||||||
|
'Authorization': `Bearer ${$cache.local.get('goToken') || ''}`
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
@ -45,7 +45,7 @@ service.interceptors.request.use(
|
|||||||
// 是否需要加密
|
// 是否需要加密
|
||||||
const isEncrypt = config.headers?.isEncrypt === 'true';
|
const isEncrypt = config.headers?.isEncrypt === 'true';
|
||||||
|
|
||||||
if (getToken() && !isToken) {
|
if (getToken() && !isToken && !config.headers?.Authorization) {
|
||||||
config.headers['Authorization'] = 'Bearer ' + getToken(); // 让每个请求携带自定义token 请根据实际情况自行修改
|
config.headers['Authorization'] = 'Bearer ' + getToken(); // 让每个请求携带自定义token 请根据实际情况自行修改
|
||||||
}
|
}
|
||||||
// get请求映射params参数
|
// get请求映射params参数
|
||||||
|
@ -79,7 +79,7 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { getCodeImg, getTenantList } from '@/api/login';
|
import { getCodeImg, getGoToken, getTenantList } from '@/api/login';
|
||||||
import { authBinding } from '@/api/system/social/auth';
|
import { authBinding } from '@/api/system/social/auth';
|
||||||
import { useUserStore } from '@/store/modules/user';
|
import { useUserStore } from '@/store/modules/user';
|
||||||
import { LoginData, TenantVO } from '@/api/types';
|
import { LoginData, TenantVO } from '@/api/types';
|
||||||
@ -151,8 +151,12 @@ const handleLogin = () => {
|
|||||||
// 调用action的登录方法
|
// 调用action的登录方法
|
||||||
const [err] = await to(userStore.login(loginForm.value));
|
const [err] = await to(userStore.login(loginForm.value));
|
||||||
if (!err) {
|
if (!err) {
|
||||||
|
//获取Go服务Token保存本地
|
||||||
|
const goToken = await getGoToken();
|
||||||
|
proxy.$cache.local.set('goToken', goToken.data.token);
|
||||||
const redirectUrl = redirect.value || '/';
|
const redirectUrl = redirect.value || '/';
|
||||||
await router.push(redirectUrl);
|
await router.push(redirectUrl);
|
||||||
|
|
||||||
loading.value = false;
|
loading.value = false;
|
||||||
} else {
|
} else {
|
||||||
loading.value = false;
|
loading.value = false;
|
||||||
|
@ -63,7 +63,7 @@
|
|||||||
<el-table-column type="selection" width="55" align="center" />
|
<el-table-column type="selection" width="55" align="center" />
|
||||||
<el-table-column label="序号" align="center" type="index" width="50" />
|
<el-table-column label="序号" align="center" type="index" width="50" />
|
||||||
<el-table-column label="申请人" align="center" prop="userName" />
|
<el-table-column label="申请人" align="center" prop="userName" />
|
||||||
<el-table-column label="申请请假说明" align="center" prop="userExplain" />
|
<el-table-column label="申请请假说明" align="center" prop="argument" />
|
||||||
<!-- <el-table-column label="请假申请时间" align="center" prop="userTime" width="180">
|
<!-- <el-table-column label="请假申请时间" align="center" prop="userTime" width="180">
|
||||||
<template #default="scope">
|
<template #default="scope">
|
||||||
<span>{{ parseTime(scope.row.userTime, '{y}-{m}-{d}') }}</span>
|
<span>{{ parseTime(scope.row.userTime, '{y}-{m}-{d}') }}</span>
|
||||||
@ -74,9 +74,9 @@
|
|||||||
<dict-tag :options="user_leave_type" :value="scope.row.teamName" />
|
<dict-tag :options="user_leave_type" :value="scope.row.teamName" />
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column label="状态" align="center" prop="status">
|
<el-table-column label="状态" align="center" prop="cardNumber">
|
||||||
<template #default="scope">
|
<template #default="scope">
|
||||||
<dict-tag :options="user_review_status_type" :value="scope.row.status" />
|
<dict-tag :options="user_review_status_type" :value="scope.row.cardNumber" />
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<!-- <el-table-column label="班组长意见" align="center" prop="gangerOpinion">
|
<!-- <el-table-column label="班组长意见" align="center" prop="gangerOpinion">
|
||||||
@ -189,7 +189,7 @@
|
|||||||
</el-step>
|
</el-step>
|
||||||
<el-step title="结果" :status="resultsStatus">
|
<el-step title="结果" :status="resultsStatus">
|
||||||
<template #description>
|
<template #description>
|
||||||
<div>{{ user_review_status_type[parseInt(detailObj.status) - 1].label }}</div>
|
<div>{{ user_review_status_type[parseInt(detailObj.cardNumber) - 1].label }}</div>
|
||||||
</template>
|
</template>
|
||||||
</el-step>
|
</el-step>
|
||||||
</el-steps>
|
</el-steps>
|
||||||
@ -346,8 +346,8 @@ const resultsStatus = computed(() => {
|
|||||||
const getList = async () => {
|
const getList = async () => {
|
||||||
loading.value = true;
|
loading.value = true;
|
||||||
const res = await listLeave(queryParams.value);
|
const res = await listLeave(queryParams.value);
|
||||||
leaveList.value = res.rows;
|
leaveList.value = res.data.list;
|
||||||
total.value = res.total;
|
total.value = res.data.total;
|
||||||
loading.value = false;
|
loading.value = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -35,72 +35,12 @@
|
|||||||
</el-card>
|
</el-card>
|
||||||
</div>
|
</div>
|
||||||
</transition>
|
</transition>
|
||||||
|
|
||||||
<el-card shadow="never">
|
<el-card shadow="never">
|
||||||
<template #header>
|
<template #header>
|
||||||
<el-row :gutter="10" class="mb8">
|
<el-row :gutter="10" class="mb8">
|
||||||
<el-col :span="1.5">
|
|
||||||
<el-button type="primary" plain icon="Plus" @click="handleAdd" v-hasPermi="['contractor:constructionUser:add']">新增 </el-button>
|
|
||||||
</el-col>
|
|
||||||
<el-col :span="1.5">
|
|
||||||
<el-button
|
|
||||||
type="danger"
|
|
||||||
plain
|
|
||||||
icon="Delete"
|
|
||||||
:disabled="multiple"
|
|
||||||
@click="handleDelete()"
|
|
||||||
v-hasPermi="['contractor:constructionUser:remove']"
|
|
||||||
>
|
|
||||||
删除
|
|
||||||
</el-button>
|
|
||||||
</el-col>
|
|
||||||
<el-col :span="1.5">
|
|
||||||
<el-button type="warning" plain icon="Download" @click="handleExport" v-hasPermi="['contractor:constructionUser:export']"
|
|
||||||
>导出
|
|
||||||
</el-button>
|
|
||||||
</el-col>
|
|
||||||
<el-col :span="1.5">
|
|
||||||
<el-button type="warning" plain icon="Edit" :disabled="multiple" @click="statusDialog = true">用户状态编辑 </el-button>
|
|
||||||
</el-col>
|
|
||||||
<el-col :span="1.5">
|
|
||||||
<el-switch
|
|
||||||
v-model="playCardStatus"
|
|
||||||
class="ml-2"
|
|
||||||
inline-prompt
|
|
||||||
style="--el-switch-on-color: #13ce66; --el-switch-off-color: #ff4949"
|
|
||||||
:loading="playCardLoding"
|
|
||||||
@change="handlePlayCardStatus"
|
|
||||||
inactive-text="一键关闭打卡"
|
|
||||||
active-text="一键开启打卡"
|
|
||||||
/>
|
|
||||||
</el-col>
|
|
||||||
<el-row @mouseover="informationStatus = true" :gutter="10" @mouseout="informationStatus = false">
|
|
||||||
<el-col :span="1.5">
|
|
||||||
<el-button type="success" plain>员工资料 </el-button>
|
|
||||||
</el-col>
|
|
||||||
<el-col :span="1.5" v-show="informationStatus">
|
|
||||||
<el-button type="primary" plain icon="Edit" @click="downloadTemplate" v-hasPermi="['contractor:constructionUserFile:download']"
|
|
||||||
>下载资料模板
|
|
||||||
</el-button>
|
|
||||||
</el-col>
|
|
||||||
<el-col :span="1.5" v-show="informationStatus">
|
|
||||||
<file-upload
|
|
||||||
v-model="filePath"
|
|
||||||
isImportInfo
|
|
||||||
:isShowTip="false"
|
|
||||||
uploadUrl="/project/constructionUserFile/upload/zip"
|
|
||||||
:limit="1"
|
|
||||||
:file-size="50"
|
|
||||||
>
|
|
||||||
<el-button type="warning" plain icon="Edit" v-hasPermi="['contractor:constructionUserFile:upload']">导入员工资料 </el-button>
|
|
||||||
</file-upload>
|
|
||||||
</el-col>
|
|
||||||
</el-row>
|
|
||||||
|
|
||||||
<right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar>
|
<right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar>
|
||||||
</el-row>
|
</el-row>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<el-table v-loading="loading" :data="constructionUserList" @selection-change="handleSelectionChange" v-cloak>
|
<el-table v-loading="loading" :data="constructionUserList" @selection-change="handleSelectionChange" v-cloak>
|
||||||
<el-table-column type="selection" width="55" align="center" />
|
<el-table-column type="selection" width="55" align="center" />
|
||||||
<el-table-column label="序号" type="index" width="60" align="center" />
|
<el-table-column label="序号" type="index" width="60" align="center" />
|
||||||
@ -167,25 +107,6 @@
|
|||||||
<el-button link type="primary" icon="View" @click="handleShowDrawer(scope.row)" v-hasPermi="['contractor:constructionUser:query']">
|
<el-button link type="primary" icon="View" @click="handleShowDrawer(scope.row)" v-hasPermi="['contractor:constructionUser:query']">
|
||||||
详情
|
详情
|
||||||
</el-button>
|
</el-button>
|
||||||
<el-button link type="success" icon="Edit" @click="handleUpdate(scope.row)" v-hasPermi="['contractor:constructionUser:edit']">
|
|
||||||
修改
|
|
||||||
</el-button>
|
|
||||||
<el-button link type="warning" icon="Female" @click="handlePlayCard(scope.row)"> 打卡 </el-button>
|
|
||||||
<el-button
|
|
||||||
link
|
|
||||||
type="danger"
|
|
||||||
icon="Avatar"
|
|
||||||
@click="handleJoinBlacklist(scope.row)"
|
|
||||||
v-hasPermi="['contractor:constructionBlacklist:add']"
|
|
||||||
>
|
|
||||||
黑名单
|
|
||||||
</el-button>
|
|
||||||
<!-- <el-button link type="primary" icon="Switch" @click="handleToggle(scope.row)"> 切换人脸 </el-button> -->
|
|
||||||
<el-button link type="primary" icon="Switch" @click="handleChange(scope.row)"> 人员迁移 </el-button>
|
|
||||||
<el-button link type="primary" icon="ChatLineSquare" @click="handleExit(scope.row)"> 入退场记录 </el-button>
|
|
||||||
<el-button link type="danger" icon="Delete" @click="handleDelete(scope.row)" v-hasPermi="['contractor:constructionUser:remove']">
|
|
||||||
删除
|
|
||||||
</el-button>
|
|
||||||
<el-tooltip content="红点:部分上传,绿点:已上传,无点:未上传" placement="right" effect="dark">
|
<el-tooltip content="红点:部分上传,绿点:已上传,无点:未上传" placement="right" effect="dark">
|
||||||
<el-badge :is-dot="scope.row.fileUploadStatus != '1'" :type="uploadStatusColor(scope.row.fileUploadStatus)">
|
<el-badge :is-dot="scope.row.fileUploadStatus != '1'" :type="uploadStatusColor(scope.row.fileUploadStatus)">
|
||||||
<el-button link type="primary" icon="FolderAdd" @click="handleUpload(scope.row)">文件上传 </el-button>
|
<el-button link type="primary" icon="FolderAdd" @click="handleUpload(scope.row)">文件上传 </el-button>
|
||||||
@ -195,174 +116,11 @@
|
|||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
</el-table>
|
</el-table>
|
||||||
|
|
||||||
<pagination v-show="total > 0" :total="total" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize" @pagination="getList" />
|
<pagination v-show="total > 0" :total="total" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize" @pagination="getList" />
|
||||||
</el-card>
|
</el-card>
|
||||||
<!-- 添加或修改施工人员对话框 -->
|
|
||||||
<el-dialog draggable :title="dialog.title" v-model="dialog.visible" width="930px" append-to-body>
|
|
||||||
<el-form ref="constructionUserFormRef" :model="form" :rules="rules" label-width="130px" :inline="true">
|
|
||||||
<div class="block_box">
|
|
||||||
<div class="msg">用户信息</div>
|
|
||||||
<div class="el-row">
|
|
||||||
<div class="el-col el-col-24">
|
|
||||||
<el-form-item label="人脸照" prop="facePic">
|
|
||||||
<image-upload v-model="form.facePic" :limit="1" :is-show-tip="false" />
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="身份证正面图片" prop="sfzFrontPic">
|
|
||||||
<image-upload v-model="form.sfzFrontPic" :limit="1" :is-show-tip="false" />
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="身份证背面图片" prop="sfzBackPic">
|
|
||||||
<image-upload v-model="form.sfzBackPic" :limit="1" :is-show-tip="false" />
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="人员姓名" prop="userName">
|
|
||||||
<el-input v-model="form.userName" placeholder="请输入人员姓名" />
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="分包公司" prop="contractorId">
|
|
||||||
<el-select v-model="form.contractorId" clearable placeholder="请选择分包公司">
|
|
||||||
<el-option v-for="item in contractorOpt" :key="item.value" :label="item.label" :value="item.value" />
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="联系电话" prop="phone">
|
|
||||||
<el-input v-model="form.phone" placeholder="请输入联系电话" />
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="民族" prop="nation">
|
|
||||||
<el-input v-model="form.nation" placeholder="请输入民族" />
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="身份证号码" prop="sfzNumber">
|
|
||||||
<el-input v-model="form.sfzNumber" placeholder="请输入身份证号码" />
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="身份证有效开始期" prop="sfzStart">
|
|
||||||
<el-date-picker clearable v-model="form.sfzStart" type="date" value-format="YYYY-MM-DD" placeholder="请输入身份证有效开始期" />
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="身份证有效结束期" prop="sfzEnd">
|
|
||||||
<el-date-picker clearable v-model="form.sfzEnd" type="date" value-format="YYYY-MM-DD" placeholder="请输入身份证有效结束期" />
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="身份证地址" prop="sfzSite">
|
|
||||||
<el-input v-model="form.sfzSite" placeholder="请输入身份证地址" />
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="身份证出生日期" prop="sfzBirth">
|
|
||||||
<el-date-picker clearable v-model="form.sfzBirth" type="date" value-format="YYYY-MM-DD" placeholder="请输入身份证出生日期" />
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="籍贯" prop="nativePlace">
|
|
||||||
<el-input v-model="form.nativePlace" placeholder="请输入籍贯" />
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="block_box">
|
|
||||||
<div class="msg">银行卡</div>
|
|
||||||
<div class="el-row">
|
|
||||||
<div class="el-col el-col-24">
|
|
||||||
<el-form-item label="银行图片" prop="yhkPic">
|
|
||||||
<image-upload v-model="form.yhkPic" :limit="1" :is-show-tip="false" />
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="银行卡号" prop="yhkNumber">
|
|
||||||
<el-input v-model="form.yhkNumber" placeholder="请输入银行卡号" />
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="开户行" prop="yhkOpeningBank">
|
|
||||||
<el-input v-model="form.yhkOpeningBank" placeholder="请输入开户行" />
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="持卡人" prop="yhkCardholder">
|
|
||||||
<el-input v-model="form.yhkCardholder" placeholder="请输入持卡人" />
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="block_box">
|
|
||||||
<div class="msg">单位信息</div>
|
|
||||||
<div class="el-row">
|
|
||||||
<div class="el-col el-col-24">
|
|
||||||
<el-form-item label="特种作业证图片" prop="specialWorkPic">
|
|
||||||
<image-upload v-model="form.specialWorkPic" :limit="1" :is-show-tip="false" />
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="工种" prop="typeOfWork">
|
|
||||||
<el-select v-model="form.typeOfWork" clearable placeholder="请选择工种">
|
|
||||||
<el-option v-for="item in type_of_work" :key="item.value" :label="item.label" :value="item.value" />
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="打卡" prop="clock">
|
|
||||||
<el-select v-model="form.clock" clearable placeholder="请选择打卡状态">
|
|
||||||
<el-option v-for="item in user_clock_type" :key="item.value" :label="item.label" :value="item.value" />
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="结算方式" prop="wageMeasureUnit">
|
|
||||||
<el-select v-model="form.wageMeasureUnit" clearable placeholder="请选择结算方式">
|
|
||||||
<el-option v-for="item in wage_measure_unit_type" :key="item.value" :label="item.label" :value="item.value" />
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
<div class="el-col el-col-12">
|
|
||||||
<el-form-item label="备注" prop="remark">
|
|
||||||
<el-input v-model="form.remark" type="textarea" placeholder="请输入内容" style="width: 240px" />
|
|
||||||
</el-form-item>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</el-form>
|
|
||||||
<template #footer>
|
|
||||||
<div class="dialog-footer">
|
|
||||||
<el-button :loading="buttonLoading" type="primary" @click="submitForm">确 定</el-button>
|
|
||||||
<el-button @click="cancel">取 消</el-button>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
</el-dialog>
|
|
||||||
<el-dialog draggable title="施工人员详情" v-model="showDetailDrawer" width="800px">
|
<el-dialog draggable title="施工人员详情" v-model="showDetailDrawer" width="800px">
|
||||||
<construction-user-detail :user-id="currentUserId" />
|
<construction-user-detail :user-id="currentUserId" />
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
<el-dialog draggable :title="skipName + '-人员迁移'" v-model="skip" width="500px">
|
|
||||||
<el-form-item label="所属项目" label-width="130px">
|
|
||||||
<el-select v-model="skipObject.projectId" @change="selectProject" placeholder="请选择所属项目" style="width: 240px">
|
|
||||||
<el-option v-for="item in skipOptions" :key="item.id" :label="item.projectName" :value="item.id" />
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item label="分包单位" label-width="130px">
|
|
||||||
<el-select v-model="skipObject.contractorId" :disabled="!skipObject.projectId" placeholder="请选择分包单位" style="width: 240px">
|
|
||||||
<el-option v-for="item in contractorList" :key="item.id" :label="item.name" :value="item.id" />
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
<template #footer>
|
|
||||||
<div class="dialog-footer">
|
|
||||||
<el-button type="primary" @click="setUnits">确认</el-button>
|
|
||||||
<el-button @click="skip = false"> 取消 </el-button>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
</el-dialog>
|
|
||||||
<el-dialog draggable title="上传文件" v-model="fileStatus" width="770px">
|
<el-dialog draggable title="上传文件" v-model="fileStatus" width="770px">
|
||||||
<div class="image_upload" v-for="(item, index) in uploadPath" :key="item.value">
|
<div class="image_upload" v-for="(item, index) in uploadPath" :key="item.value">
|
||||||
<div class="title">{{ item.label }}</div>
|
<div class="title">{{ item.label }}</div>
|
||||||
@ -392,78 +150,6 @@
|
|||||||
</span>
|
</span>
|
||||||
</template>
|
</template>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
<el-dialog draggable title="修改在职状态" v-model="statusDialog" width="30%">
|
|
||||||
<el-form-item label="在职状态">
|
|
||||||
<el-select v-model="vocationalStatus" placeholder="请选择状态">
|
|
||||||
<el-option v-for="item in user_status_type" :key="item.value" :label="item.label" :value="item.value" />
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
<template #footer>
|
|
||||||
<span
|
|
||||||
><el-button type="primary" @click="handleEdit">保存</el-button>
|
|
||||||
<el-button @click="statusDialog = false">取消</el-button>
|
|
||||||
</span>
|
|
||||||
</template>
|
|
||||||
</el-dialog>
|
|
||||||
<el-dialog draggable title="温馨提示" v-model="salaryStatus" width="30%">
|
|
||||||
<span>请输入薪资</span>
|
|
||||||
<el-input class="mt-xl" v-model="changeSalary" placeholder="" clearable @change=""></el-input>
|
|
||||||
<template #footer>
|
|
||||||
<span>
|
|
||||||
<el-button type="primary" @click="handleSalary">确认</el-button>
|
|
||||||
<el-button @click="salaryStatus = false">取消</el-button>
|
|
||||||
</span>
|
|
||||||
</template>
|
|
||||||
</el-dialog>
|
|
||||||
<el-dialog draggable title="入场退场记录" v-model="exitStatus" width="600px">
|
|
||||||
<div v-for="(item, index) in exitList">
|
|
||||||
<el-timeline>
|
|
||||||
<el-timeline-item color="#0bbd87" class="mb">
|
|
||||||
{{ '入场时间:' + item.entryDate }}
|
|
||||||
</el-timeline-item>
|
|
||||||
<el-timeline-item color="rgb(255, 73, 73)">
|
|
||||||
<div class="mb">{{ '退场时间:' + item.entryDate }}</div>
|
|
||||||
<div class="pl-xl">
|
|
||||||
<span class="text-coolgray font-bold">退场文件:<image-preview v-for="itm in item.pathUrl" :src="itm" width="100px" class="mr" /></span
|
|
||||||
><br />
|
|
||||||
<p class="mt text-coolgray">
|
|
||||||
备注:<span class="text-blue">{{ item.remark }}</span>
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
</el-timeline-item>
|
|
||||||
</el-timeline>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<template #footer>
|
|
||||||
<span>
|
|
||||||
<el-button @click="exitStatus = false">关闭</el-button>
|
|
||||||
</span>
|
|
||||||
</template>
|
|
||||||
</el-dialog>
|
|
||||||
<el-dialog draggable :title="`打卡记录`" v-model="playCardCalendar" width="770px" :close-on-click-modal="false">
|
|
||||||
<el-calendar ref="calendar" v-model="calendarDay">
|
|
||||||
<template #header="{ date }">
|
|
||||||
<span>{{ date }}</span>
|
|
||||||
<div class="status-detail flex items-center justify-between">
|
|
||||||
<div class="green">全天考勤正常</div>
|
|
||||||
<div class="orange">半勤</div>
|
|
||||||
<div class="red">缺卡</div>
|
|
||||||
<div class="gray">请假</div>
|
|
||||||
</div>
|
|
||||||
<el-date-picker v-model="monthValue" type="month" placeholder="请选择月份" @change="handleMonth" />
|
|
||||||
</template>
|
|
||||||
<template #date-cell="{ data }">
|
|
||||||
<div
|
|
||||||
class="w100% h100% position-relative m-0 monthDay"
|
|
||||||
:class="data.isSelected ? 'is-selected' : ''"
|
|
||||||
@click="handleViewPlayCard(playCardIdx(data), data)"
|
|
||||||
>
|
|
||||||
{{ data.day.split('-').slice(1).join('-') }}
|
|
||||||
<div :style="{ background: playCardColor(data) }" v-if="playCardIdx(data) != -1"></div>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
</el-calendar>
|
|
||||||
</el-dialog>
|
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
@ -495,7 +181,6 @@ import {
|
|||||||
} from '@/api/project/constructionUser/types';
|
} from '@/api/project/constructionUser/types';
|
||||||
import { useUserStoreHook } from '@/store/modules/user';
|
import { useUserStoreHook } from '@/store/modules/user';
|
||||||
import { listContractor } from '@/api/project/contractor';
|
import { listContractor } from '@/api/project/contractor';
|
||||||
import { listProjectTeam } from '@/api/project/projectTeam';
|
|
||||||
import { ContractorVO } from '@/api/project/contractor/types';
|
import { ContractorVO } from '@/api/project/contractor/types';
|
||||||
import { ProjectTeamVO } from '@/api/project/projectTeam/types';
|
import { ProjectTeamVO } from '@/api/project/projectTeam/types';
|
||||||
import ConstructionUserDetail from '@/views/project/constructionUser/component/ConstructionUserDetail.vue';
|
import ConstructionUserDetail from '@/views/project/constructionUser/component/ConstructionUserDetail.vue';
|
||||||
@ -556,7 +241,6 @@ const dialog = reactive<DialogOption>({
|
|||||||
title: '',
|
title: '',
|
||||||
id: undefined
|
id: undefined
|
||||||
});
|
});
|
||||||
const baseUrl = import.meta.env.VITE_APP_BASE_API;
|
|
||||||
//人员迁移条件
|
//人员迁移条件
|
||||||
const skipObject: skipType = reactive({
|
const skipObject: skipType = reactive({
|
||||||
id: '',
|
id: '',
|
||||||
|
@ -53,6 +53,12 @@ export default defineConfig(({ mode, command }: ConfigEnv): UserConfig => {
|
|||||||
changeOrigin: true,
|
changeOrigin: true,
|
||||||
ws: true,
|
ws: true,
|
||||||
rewrite: (path) => path.replace(new RegExp('^' + env.VITE_APP_BASE_API), '')
|
rewrite: (path) => path.replace(new RegExp('^' + env.VITE_APP_BASE_API), '')
|
||||||
|
},
|
||||||
|
[env.VITE_APP_BASE_API_GO]: {
|
||||||
|
target: 'http://192.168.110.159:8919',
|
||||||
|
changeOrigin: true,
|
||||||
|
ws: true,
|
||||||
|
rewrite: (path) => path.replace(new RegExp('^' + env.VITE_APP_BASE_API_GO), '')
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
Reference in New Issue
Block a user