合并
This commit is contained in:
		| @ -7,12 +7,13 @@ VITE_APP_ENV = 'development' | ||||
| # 开发环境 | ||||
| VITE_APP_BASE_API = 'http://192.168.110.180:8899' | ||||
| # 李陈杰 209 | ||||
| # VITE_APP_BASE_API = 'http://192.168.110.209:8899' | ||||
| # 曾涛 | ||||
| # VITE_APP_BASE_API = 'http://192.168.110.180:8899' | ||||
| # 罗成 | ||||
| # VITE_APP_BASE_API = 'http://192.168.110.188:8899' | ||||
| # 朱银 | ||||
| # VITE_APP_BASE_API = 'http://192.168.110.180:8899' | ||||
| # VITE_APP_BASE_API = 'http://192.168.110.149:8899' | ||||
| #曾涛 | ||||
| # VITE_APP_BASE_API = 'http://192.168.110.171:8899' | ||||
|  | ||||
|  | ||||
| @ -8,10 +8,11 @@ import { ProgressCategoryVO, ProgressCategoryForm, ProgressCategoryQuery } from | ||||
|  * @returns {*} | ||||
|  */ | ||||
|  | ||||
| export const listProgressCategory = (id?: string | number): AxiosPromise<any[]> => { | ||||
| export const listProgressCategory = (parentId?: string | number,name?:string): AxiosPromise<any[]> => { | ||||
|   return request({ | ||||
|     url: '/progress/progressCategory/listByParent/' + id, | ||||
|     method: 'get' | ||||
|     url: '/progress/progressCategory/listByParent', | ||||
|     method: 'get', | ||||
|     params:{parentId,name} | ||||
|   }); | ||||
| }; | ||||
|  | ||||
|  | ||||
| @ -78,9 +78,10 @@ export const getTabList = (id: string) => { | ||||
|  * @param parentId | ||||
|  * @returns {*} | ||||
|  */ | ||||
| export const listProgressCategoryTemplateByParent = (parentId: string | number): AxiosPromise<ProgressCategoryTemplateVO[]> => { | ||||
| export const listProgressCategoryTemplateByParent = (parentId: string | number,name:string): AxiosPromise<ProgressCategoryTemplateVO[]> => { | ||||
|   return request({ | ||||
|     url: '/progress/progressCategoryTemplate/listByParent/' + parentId, | ||||
|     method: 'get' | ||||
|     url: '/progress/progressCategoryTemplate/listByParent' , | ||||
|     method: 'get', | ||||
|     params:{parentId,name} | ||||
|   }); | ||||
| }; | ||||
|  | ||||
| @ -164,7 +164,7 @@ export const updateConstructionUserSalary = (data: ConstructionUserSalaryForm) = | ||||
|  */ | ||||
| export const getConstructionUserExit = (query: ConstructionUserExitForm) => { | ||||
|   return request({ | ||||
|     url: '/contractor/constructionUserExit/list', | ||||
|     url: '/project/constructionUserExit/list', | ||||
|     method: 'get', | ||||
|     params: query | ||||
|   }); | ||||
| @ -204,7 +204,6 @@ export const importConstructionUserInfo = (file: string) => { | ||||
|   }); | ||||
| }; | ||||
|  | ||||
|  | ||||
| // 获取项目列表 | ||||
| export const ProjectList = (query) => { | ||||
|   return request({ | ||||
| @ -216,7 +215,7 @@ export const ProjectList = (query) => { | ||||
|  | ||||
| // 获取班组列表 | ||||
| export const TeamList = (query) => { | ||||
|   return request({     | ||||
|   return request({ | ||||
|     url: '/contractor/constructionUser/teamList', | ||||
|     method: 'get', | ||||
|     params: query | ||||
| @ -230,4 +229,4 @@ export const TeamDistribution = (data) => { | ||||
|     method: 'post', | ||||
|     data: data | ||||
|   }); | ||||
| }; | ||||
| }; | ||||
|  | ||||
| @ -10,7 +10,7 @@ import { ConstructionUserFileVO, ConstructionUserFileForm, ConstructionUserFileQ | ||||
|  | ||||
| export const listConstructionUserFile = (query?: ConstructionUserFileQuery): AxiosPromise<ConstructionUserFileVO[]> => { | ||||
|   return request({ | ||||
|     url: '/project/constructionUserFile/list', | ||||
|     url: '/contractor/constructionUserFile/list', | ||||
|     method: 'get', | ||||
|     params: query | ||||
|   }); | ||||
| @ -22,7 +22,7 @@ export const listConstructionUserFile = (query?: ConstructionUserFileQuery): Axi | ||||
|  */ | ||||
| export const setConstructionUserFile = (data: ConstructionUserFileForm): AxiosPromise<string | number> => { | ||||
|   return request({ | ||||
|     url: '/project/constructionUserFile/save', | ||||
|     url: '/contractor/constructionUserFile/save', | ||||
|     method: 'post', | ||||
|     data | ||||
|   }); | ||||
| @ -34,7 +34,7 @@ export const setConstructionUserFile = (data: ConstructionUserFileForm): AxiosPr | ||||
|  */ | ||||
| export const delConstructionUserFile = (id: string | number | Array<string | number>) => { | ||||
|   return request({ | ||||
|     url: '/project/constructionUserFile/' + id, | ||||
|     url: '/contractor/constructionUserFile/' + id, | ||||
|     method: 'delete' | ||||
|   }); | ||||
| }; | ||||
|  | ||||
| @ -203,6 +203,7 @@ watch( | ||||
|       }); | ||||
|     } else { | ||||
|       fileList.value = []; | ||||
|  | ||||
|       return []; | ||||
|     } | ||||
|   }, | ||||
| @ -293,7 +294,7 @@ const handleChange = (file: any, filelist: any) => { | ||||
|     } | ||||
|   } | ||||
|   // 记录 status = 'ready' 的文件 | ||||
|   if (file.status === 'ready') { | ||||
|   if (file.status === 'ready' && !props.isConstruction) { | ||||
|     pendingFiles.value.push(file); | ||||
|     fileList.value = pendingFiles.value; | ||||
|   } | ||||
|  | ||||
| @ -47,9 +47,9 @@ | ||||
|             <el-row :gutter="8" class="mb-3 font-medium text-gray-700 whitespace-nowrap"> | ||||
|               <el-col :span="4">专业</el-col> | ||||
|               <el-col :span="5">设计人员(可多选)</el-col> | ||||
|               <el-col :span="5">校审人员</el-col> | ||||
|               <el-col :span="5">校审人员</el-col> <el-col :span="4">审核人员</el-col> | ||||
|               <el-col :span="5">审定人员</el-col> | ||||
|               <el-col :span="4">审核人员</el-col> | ||||
|               | ||||
|               <el-col :span="3"></el-col> | ||||
|             </el-row> | ||||
|  | ||||
| @ -209,61 +209,7 @@ | ||||
|                 </el-col> | ||||
|  | ||||
|                 <!-- 4. 审定人员 --> | ||||
|                 <el-col :span="5" class="mb-4 sm:mb-0"> | ||||
|                   <div class="pl-2 border-l-2 border-orange-200 py-2"> | ||||
|                     <div class="space-y-3"> | ||||
|                       <div | ||||
|                         v-for="(person, personIndex) in majorConfig.approvedPersons" | ||||
|                         :key="`approved-${configIndex}-${personIndex}`" | ||||
|                         class="flex items-center" | ||||
|                       > | ||||
|                         <el-form-item | ||||
|                           :prop="`approved.${configIndex}.persons.${personIndex}.userId`" | ||||
|                           :rules="{ required: true, message: '请选择审定人员', trigger: 'change' }" | ||||
|                           class="flex-1 mr-2 mb-0" | ||||
|                           label="审定" | ||||
|                           label-width="50px" | ||||
|                         > | ||||
|                           <el-select | ||||
|                             filterable | ||||
|                             v-model="person.userId" | ||||
|                             placeholder="选择人员" | ||||
|                             class="w-full transition-all duration-300 border-gray-300" | ||||
|                             @change="() => checkDuplicate(person, 'approved', configIndex, personIndex)" | ||||
|                           > | ||||
|                             <el-option v-for="item in userList" :key="`user-${item.userId}`" :label="item.nickName" :value="item.userId" /> | ||||
|                           </el-select> | ||||
|                         </el-form-item> | ||||
|                         <!-- <div class="flex gap-1"> | ||||
|                           <el-button | ||||
|                             type="danger" | ||||
|                             size="small" | ||||
|                             @click="removePerson('approved', configIndex, personIndex)" | ||||
|                             class="transition-all duration-300 hover:bg-red-600" | ||||
|                             :disabled="majorConfig.approvedPersons.length <= 1 || disabledForm" | ||||
|                           > | ||||
|                             <el-icon :size="14"><Delete /></el-icon> | ||||
|                           </el-button> | ||||
|                           <el-button | ||||
|                             type="success" | ||||
|                             size="small" | ||||
|                             @click="addPerson('approved', configIndex)" | ||||
|                             class="transition-all duration-300 transform hover:scale-105" | ||||
|                             :disabled="!form.designers[configIndex].userMajor || disabledForm" | ||||
|                           > | ||||
|                             <el-icon :size="14"><Plus /></el-icon> | ||||
|                           </el-button> | ||||
|                         </div> --> | ||||
|                       </div> | ||||
|                     </div> | ||||
|                     <div | ||||
|                       v-if="majorConfig.approvedPersons.length == 0" | ||||
|                       class="text-gray-500 text-xs py-2 bg-gray-100 rounded border border-dashed border-gray-200" | ||||
|                     > | ||||
|                       点击"添加" | ||||
|                     </div> | ||||
|                   </div> | ||||
|                 </el-col> | ||||
|                  | ||||
|  | ||||
|                 <!-- 5. 审核人员 --> | ||||
|                 <el-col :span="5" class="mb-4 sm:mb-0"> | ||||
| @ -321,6 +267,61 @@ | ||||
|                     </div> | ||||
|                   </div> | ||||
|                 </el-col> | ||||
| <el-col :span="5" class="mb-4 sm:mb-0"> | ||||
|                   <div class="pl-2 border-l-2 border-orange-200 py-2"> | ||||
|                     <div class="space-y-3"> | ||||
|                       <div | ||||
|                         v-for="(person, personIndex) in majorConfig.approvedPersons" | ||||
|                         :key="`approved-${configIndex}-${personIndex}`" | ||||
|                         class="flex items-center" | ||||
|                       > | ||||
|                         <el-form-item | ||||
|                           :prop="`approved.${configIndex}.persons.${personIndex}.userId`" | ||||
|                           :rules="{ required: true, message: '请选择审定人员', trigger: 'change' }" | ||||
|                           class="flex-1 mr-2 mb-0" | ||||
|                           label="审定" | ||||
|                           label-width="50px" | ||||
|                         > | ||||
|                           <el-select | ||||
|                             filterable | ||||
|                             v-model="person.userId" | ||||
|                             placeholder="选择人员" | ||||
|                             class="w-full transition-all duration-300 border-gray-300" | ||||
|                             @change="() => checkDuplicate(person, 'approved', configIndex, personIndex)" | ||||
|                           > | ||||
|                             <el-option v-for="item in userList" :key="`user-${item.userId}`" :label="item.nickName" :value="item.userId" /> | ||||
|                           </el-select> | ||||
|                         </el-form-item> | ||||
|                         <!-- <div class="flex gap-1"> | ||||
|                           <el-button | ||||
|                             type="danger" | ||||
|                             size="small" | ||||
|                             @click="removePerson('approved', configIndex, personIndex)" | ||||
|                             class="transition-all duration-300 hover:bg-red-600" | ||||
|                             :disabled="majorConfig.approvedPersons.length <= 1 || disabledForm" | ||||
|                           > | ||||
|                             <el-icon :size="14"><Delete /></el-icon> | ||||
|                           </el-button> | ||||
|                           <el-button | ||||
|                             type="success" | ||||
|                             size="small" | ||||
|                             @click="addPerson('approved', configIndex)" | ||||
|                             class="transition-all duration-300 transform hover:scale-105" | ||||
|                             :disabled="!form.designers[configIndex].userMajor || disabledForm" | ||||
|                           > | ||||
|                             <el-icon :size="14"><Plus /></el-icon> | ||||
|                           </el-button> | ||||
|                         </div> --> | ||||
|                       </div> | ||||
|                     </div> | ||||
|                     <div | ||||
|                       v-if="majorConfig.approvedPersons.length == 0" | ||||
|                       class="text-gray-500 text-xs py-2 bg-gray-100 rounded border border-dashed border-gray-200" | ||||
|                     > | ||||
|                       点击"添加" | ||||
|                     </div> | ||||
|                   </div> | ||||
|                 </el-col> | ||||
|  | ||||
|                 <!-- 操作列 --> | ||||
|                 <el-col :span="2" class="pr-4 mt-2 text-right"> | ||||
|  | ||||
| @ -85,7 +85,7 @@ const handleQuery = () => { | ||||
|  | ||||
| /** 重置按钮操作 */ | ||||
| const resetQuery = () => { | ||||
|   queryParams.value.month = ''; | ||||
|   resetMonth(); | ||||
|   handleQuery(); | ||||
| }; | ||||
| // 获取列表 | ||||
| @ -102,14 +102,17 @@ const getList = async () => { | ||||
|     total.value = res.total; | ||||
|   } | ||||
| }; | ||||
| onMounted(() => { | ||||
|   const currentDate = new Date(); | ||||
| const resetMonth=()=>{ | ||||
| 	const currentDate = new Date(); | ||||
|   const year = currentDate.getFullYear(); | ||||
|   const month = currentDate.getMonth() + 1; // 月份从0开始,所以需要加1 | ||||
|  | ||||
|   // 形成"YYYY-M"格式 | ||||
|   const formattedDate = `${year}-${String(month).padStart(2, '0')}`; | ||||
|   queryParams.value.month = formattedDate; | ||||
| } | ||||
| onMounted(() => { | ||||
|   resetMonth(); | ||||
|  | ||||
|   getList(); | ||||
| }); | ||||
|  | ||||
| @ -120,17 +120,17 @@ | ||||
|           <!-- <el-input v-model="form.projectStructure" placeholder="请输入对应项目结构" /> --> | ||||
|         </el-form-item> | ||||
|         <el-form-item label="预计开始时间" prop="planStartDate"> | ||||
|           <el-date-picker clearable v-model="form.planStartDate" type="datetime" value-format="YYYY-MM-DD HH:mm:ss" placeholder="选择预计开始时间" /> | ||||
|           <el-date-picker clearable v-model="form.planStartDate" type="date" value-format="YYYY-MM-DD" placeholder="选择预计开始时间" /> | ||||
|         </el-form-item> | ||||
|         <el-form-item label="预计结束时间" prop="planEndDate"> | ||||
|           <el-date-picker clearable v-model="form.planEndDate" type="datetime" value-format="YYYY-MM-DD HH:mm:ss" placeholder="选择预计结束时间" /> | ||||
|           <el-date-picker clearable v-model="form.planEndDate" type="date" value-format="YYYY-MM-DD" placeholder="选择预计结束时间" /> | ||||
|         </el-form-item> | ||||
|         <el-form-item label="实际开始时间" prop="practicalStartDate"> | ||||
|           <el-date-picker | ||||
|             clearable | ||||
|             v-model="form.practicalStartDate" | ||||
|             type="datetime" | ||||
|             value-format="YYYY-MM-DD HH:mm:ss" | ||||
|             type="date" | ||||
|             value-format="YYYY-MM-DD" | ||||
|             placeholder="选择实际开始时间" | ||||
|           /> | ||||
|         </el-form-item> | ||||
| @ -138,8 +138,8 @@ | ||||
|           <el-date-picker | ||||
|             clearable | ||||
|             v-model="form.practicalEndDate" | ||||
|             type="datetime" | ||||
|             value-format="YYYY-MM-DD HH:mm:ss" | ||||
|             type="date" | ||||
|             value-format="YYYY-MM-DD" | ||||
|             placeholder="选择实际结束时间" | ||||
|           /> | ||||
|         </el-form-item> | ||||
|  | ||||
| @ -216,7 +216,7 @@ const { queryParams, form, rules } = toRefs(data); | ||||
| /** 查询进度类别模版列表 */ | ||||
| const getList = async () => { | ||||
|   loading.value = true; | ||||
|   const res = await listProgressCategoryTemplateByParent(activeTab.value); | ||||
|   const res = await listProgressCategoryTemplateByParent(activeTab.value,queryParams.value.name); | ||||
|   const data = proxy?.handleTree<ProgressCategoryTemplateVO>(res.data, 'id', 'parentId'); | ||||
|   if (data) { | ||||
|     progressCategoryTemplateList.value = data; | ||||
|  | ||||
| @ -44,11 +44,11 @@ | ||||
|               {{ userDetail?.sfzNumber }} | ||||
|             </el-form-item> | ||||
|           </el-col> | ||||
|           <el-col :span="12"> | ||||
|           <!-- <el-col :span="12"> | ||||
|             <el-form-item label="身份证号码"> | ||||
|               {{ userDetail?.sfzNumber }} | ||||
|             </el-form-item> | ||||
|           </el-col> | ||||
|           </el-col> --> | ||||
|           <el-col :span="12"> | ||||
|             <el-form-item label="身份证有效开始期"> | ||||
|               {{ dayjs(userDetail?.sfzStart).format('YYYY 年 MM 月 DD 日') }} | ||||
| @ -59,7 +59,7 @@ | ||||
|               {{ dayjs(userDetail?.sfzEnd).format('YYYY 年 MM 月 DD 日') }} | ||||
|             </el-form-item> | ||||
|           </el-col> | ||||
|           <el-col :span="12"> | ||||
|           <el-col :span="24"> | ||||
|             <el-form-item label="身份证地址"> | ||||
|               {{ userDetail?.sfzSite }} | ||||
|             </el-form-item> | ||||
|  | ||||
| @ -44,14 +44,14 @@ | ||||
|               {{ userDetail?.sfzNumber }} | ||||
|             </el-form-item> | ||||
|           </el-col> | ||||
|           <el-col :span="12"> | ||||
|           <!-- <el-col :span="12"> | ||||
|             <el-form-item label="身份证号码"> | ||||
|               {{ userDetail?.sfzNumber }} | ||||
|             </el-form-item> | ||||
|           </el-col> | ||||
|           </el-col> --> | ||||
|           <el-col :span="12"> | ||||
|             <el-form-item label="身份证有效开始期"> | ||||
|               {{ dayjs(userDetail?.sfzStart).format('YYYY 年 MM 月 DD 日') }} | ||||
|               {{ dayjs(userDetail?.sfzStart).format('YYYY年 MM 月 DD 日') }} | ||||
|             </el-form-item> | ||||
|           </el-col> | ||||
|           <el-col :span="12"> | ||||
|  | ||||
| @ -1,7 +1,6 @@ | ||||
| <template> | ||||
|   <div class="p-2"> | ||||
|     <transition :enter-active-class="proxy?.animate.searchAnimate.enter" | ||||
|       :leave-active-class="proxy?.animate.searchAnimate.leave"> | ||||
|     <transition :enter-active-class="proxy?.animate.searchAnimate.enter" :leave-active-class="proxy?.animate.searchAnimate.leave"> | ||||
|       <div v-show="showSearch" class="mb-[10px]"> | ||||
|         <el-card shadow="hover"> | ||||
|           <el-form ref="queryFormRef" :model="queryParams" :inline="true"> | ||||
| @ -46,43 +45,59 @@ | ||||
|       <template #header> | ||||
|         <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-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 | ||||
|               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 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-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-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 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 | ||||
|                 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> | ||||
| @ -120,9 +135,18 @@ | ||||
|         </el-table-column> | ||||
|         <el-table-column label="打卡状态" align="center" prop="clock"> | ||||
|           <template #default="scope"> | ||||
|             <el-switch v-model="scope.row.clock" class="ml-2" inline-prompt | ||||
|               style="--el-switch-on-color: #13ce66; --el-switch-off-color: #ff4949" active-text="开启" inactive-text="禁用" | ||||
|               :loading="playCardLoding" active-value="0" inactive-value="1" @change="handleClockStatus(scope.row)" /> | ||||
|             <el-switch | ||||
|               v-model="scope.row.clock" | ||||
|               class="ml-2" | ||||
|               inline-prompt | ||||
|               style="--el-switch-on-color: #13ce66; --el-switch-off-color: #ff4949" | ||||
|               active-text="开启" | ||||
|               inactive-text="禁用" | ||||
|               :loading="playCardLoding" | ||||
|               active-value="0" | ||||
|               inactive-value="1" | ||||
|               @change="handleClockStatus(scope.row)" | ||||
|             /> | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|         <el-table-column label="薪水" align="center" min-width="180"> | ||||
| @ -131,8 +155,7 @@ | ||||
|               {{ scope.row.salary ? scope.row.salary : scope.row.standardSalary }} | ||||
|               (<dict-tag :options="wage_measure_unit_type" :value="scope.row.wageMeasureUnit"></dict-tag>) | ||||
|             </span> | ||||
|             <div class="text-blue text-sm cursor-pointer" @click="openSalaryDialog(scope.row)">{{ scope.row.salary ? | ||||
|               '取消变更' : '变更' }}</div> | ||||
|             <div class="text-blue text-sm cursor-pointer" @click="openSalaryDialog(scope.row)">{{ scope.row.salary ? '取消变更' : '变更' }}</div> | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|         <el-table-column label="入场时间" align="center" prop="entryDate" min-width="180" /> | ||||
| @ -146,30 +169,31 @@ | ||||
|         <el-table-column label="操作" align="center" class-name="small-padding fixed-width" fixed="right" min-width="300"> | ||||
|           <template #default="scope"> | ||||
|             <el-space wrap> | ||||
|               <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 link type="success" icon="Edit" @click="handleUpdate(scope.row)" | ||||
|                 v-hasPermi="['contractor:constructionUser:edit']"> | ||||
|               <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 | ||||
|                 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="Switch" @click="handleAssign(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 link type="danger" icon="Delete" @click="handleDelete(scope.row)" v-hasPermi="['contractor:constructionUser:remove']"> | ||||
|                 删除 | ||||
|               </el-button> | ||||
|               <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-badge> | ||||
|               </el-tooltip> | ||||
| @ -178,8 +202,7 @@ | ||||
|         </el-table-column> | ||||
|       </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-dialog draggable :title="dialog.title" v-model="dialog.visible" width="930px" append-to-body> | ||||
| @ -231,14 +254,12 @@ | ||||
|             </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-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-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"> | ||||
| @ -248,8 +269,7 @@ | ||||
|             </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-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"> | ||||
| @ -302,16 +322,14 @@ | ||||
|             <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-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-option v-for="item in wage_measure_unit_type" :key="item.value" :label="item.label" :value="item.value" /> | ||||
|                 </el-select> | ||||
|               </el-form-item> | ||||
|             </div> | ||||
| @ -340,8 +358,7 @@ | ||||
|         </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-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> | ||||
| @ -356,8 +373,7 @@ | ||||
|       <div class="image_upload" v-for="(item, index) in uploadPath" :key="item.value"> | ||||
|         <div class="title">{{ item.label }}</div> | ||||
|         <div class="file_upload_all" v-if="item.value != 7"> | ||||
|           <file-upload v-model="item.path" isConstruction :isShowTip="false" :limit="10" :file-type="['pdf']" | ||||
|             :file-size="50" /> | ||||
|           <file-upload v-model="item.path" isConstruction show-file-list :isShowTip="false" :limit="10" :file-type="['pdf']" :file-size="50" /> | ||||
|         </div> | ||||
|       </div> | ||||
|       <template #footer> | ||||
| @ -376,7 +392,8 @@ | ||||
|         </el-form> | ||||
|       </div> | ||||
|       <template #footer> | ||||
|         <span><el-button type="primary" @click="submitForm">保存</el-button> | ||||
|         <span | ||||
|           ><el-button type="primary" @click="submitForm">保存</el-button> | ||||
|           <el-button @click="showFaceDrawer = false">取消</el-button> | ||||
|         </span> | ||||
|       </template> | ||||
| @ -388,7 +405,8 @@ | ||||
|         </el-select> | ||||
|       </el-form-item> | ||||
|       <template #footer> | ||||
|         <span><el-button type="primary" @click="handleEdit">保存</el-button> | ||||
|         <span | ||||
|           ><el-button type="primary" @click="handleEdit">保存</el-button> | ||||
|           <el-button @click="statusDialog = false">取消</el-button> | ||||
|         </span> | ||||
|       </template> | ||||
| @ -412,8 +430,8 @@ | ||||
|           <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 /> | ||||
|               <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> | ||||
| @ -441,8 +459,11 @@ | ||||
|           <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)"> | ||||
|           <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> | ||||
| @ -461,8 +482,12 @@ | ||||
|         </el-select> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="班组" label-width="130px"> | ||||
|         <el-select v-model="personnelAllocationObject.teamId" :disabled="!personnelAllocationObject.projectId" placeholder="请选择分包单位" | ||||
|           style="width: 240px"> | ||||
|         <el-select | ||||
|           v-model="personnelAllocationObject.teamId" | ||||
|           :disabled="!personnelAllocationObject.projectId" | ||||
|           placeholder="请选择班组" | ||||
|           style="width: 240px" | ||||
|         > | ||||
|           <el-option v-for="item in teamList" :key="item.id" :label="item.teamName" :value="item.id" /> | ||||
|         </el-select> | ||||
|       </el-form-item> | ||||
| @ -527,8 +552,8 @@ import { parseTime } from '@/utils/ruoyi'; | ||||
|  | ||||
| const calendar = ref<CalendarInstance>(); | ||||
| const { proxy } = getCurrentInstance() as ComponentInternalInstance; | ||||
| const { type_of_work, user_sex_type, user_clock_type, user_file_type, user_status_type, wage_measure_unit_type,user_post_type } = toRefs<any>( | ||||
|   proxy?.useDict('type_of_work', 'user_sex_type', 'user_clock_type', 'user_file_type', 'user_status_type', 'wage_measure_unit_type','user_post_type') | ||||
| const { type_of_work, user_sex_type, user_clock_type, user_file_type, user_status_type, wage_measure_unit_type, user_post_type } = toRefs<any>( | ||||
|   proxy?.useDict('type_of_work', 'user_sex_type', 'user_clock_type', 'user_file_type', 'user_status_type', 'wage_measure_unit_type', 'user_post_type') | ||||
| ); | ||||
| // 获取用户 store | ||||
| const userStore = useUserStoreHook(); | ||||
| @ -586,7 +611,7 @@ const personnelAllocationObject = reactive({ | ||||
|   memberId: null, | ||||
|   projectId: '', | ||||
|   teamId: '', | ||||
|   postId: '', | ||||
|   postId: '' | ||||
| }); | ||||
|  | ||||
| const contractorList = ref<Array<skipTeamType>>([]); | ||||
| @ -942,7 +967,7 @@ const downloadTemplate = async () => { | ||||
| }; | ||||
|  | ||||
| //导入资料 | ||||
| const importInformation = async () => { }; | ||||
| const importInformation = async () => {}; | ||||
|  | ||||
| /** 人员迁移 */ | ||||
| const handleChange = async (row: ConstructionUserVO) => { | ||||
| @ -974,7 +999,7 @@ const handleExit = async (row: ConstructionUserVO) => { | ||||
|  | ||||
| //上传按钮 | ||||
| const handleUpload = async (row: ConstructionUserVO) => { | ||||
|   const _id = row?.id || ids.value[0]; | ||||
|   const _id = row?.sysUserId; | ||||
|   currentUserId.value = _id; | ||||
|   const res = await listConstructionUserFile({ userId: _id }); | ||||
|   fileList.value = res.data; | ||||
| @ -1110,14 +1135,17 @@ const listeningProject = watch( | ||||
| const handleAssign = async (row: ConstructionUserVO) => { | ||||
|   const _id = row?.id || ids.value[0]; | ||||
|   currentUserId.value = _id; | ||||
|   personnelAllocationObject.projectId = ''; | ||||
|   personnelAllocationObject.postId = ''; | ||||
|   personnelAllocationObject.teamId = ''; | ||||
|   personnelAllocationObject.memberId = row?.sysUserId; | ||||
|   skipName.value = row?.userName; | ||||
|   personnelAllocation.value = true; | ||||
| }; | ||||
| // 选择项目1 | ||||
| const selectProject1 = (e: any) => { | ||||
|   // 请求班组 | ||||
|   getTeamList(personnelAllocationObject.projectId); | ||||
|    | ||||
| }; | ||||
| const getTeamList = async (projectId) => { | ||||
|   const res = await TeamList({ | ||||
| @ -1152,7 +1180,7 @@ onMounted(() => { | ||||
|   position: relative; | ||||
|   font-size: 12px; | ||||
|  | ||||
|   >div { | ||||
|   > div { | ||||
|     margin: 0 15px; | ||||
|     position: relative; | ||||
|     font-size: 12px; | ||||
| @ -1197,7 +1225,7 @@ onMounted(() => { | ||||
| .monthDay { | ||||
|   padding: 8px; | ||||
|  | ||||
|   >div { | ||||
|   > div { | ||||
|     position: absolute; | ||||
|     width: 20px; | ||||
|     height: 20px; | ||||
|  | ||||
		Reference in New Issue
	
	Block a user