| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688 |
- <!-- 用户编辑弹窗 -->
- <template>
- <ele-modal width="60%" :visible="visible" :close-on-click-modal="false" custom-class="ele-dialog-form"
- :title="isUpdate ? '基本信息' : '基本信息'" @update:visible="updateVisible">
- <el-form ref="form" :model="form" class="el-form-box" :rules="rules" label-width="82px">
- <el-row :gutter="15">
- <el-col v-bind="styleResponsive ? { sm: 12 } : { span: 12 }">
- <el-form-item label="所属机构:" prop="groupId">
- <org-select :data="institutionList" placeholder="请选择所属机构" v-model="form.groupId"
- @checkedKeys="checkedKeys"/>
- </el-form-item>
- <el-form-item label="负责部门:">
- <el-cascader class="ele-block" :options="organizationList" placeholder="请选择负责部门"
- :props="defaultProps"
- ref="deptRef"
- :show-all-levels="false"
- @change="handleChange"
- collapse-tags v-model="form.deptIds" clearable></el-cascader>
- </el-form-item>
- <el-form-item label="所属工厂:">
- <el-select style="width: 100%" clearable v-model="form.factoryId" filterable
- placeholder="请选择所属工厂">
- <el-option
- v-for="item in factoryList"
- :label="item.name"
- :value="item.id"
- :key="item.id"
- ></el-option>
- </el-select>
- </el-form-item>
- <el-form-item label="性别:" prop="sex">
- <el-select
- clearable
- class="ele-block"
- v-model="form.sex"
- placeholder="请选择性别"
- >
- <el-option label="男" :value="1" />
- <el-option label="女" :value="2" />
- </el-select>
- </el-form-item>
- <el-form-item label="员工状态:" prop="status">
- <el-select
- clearable
- class="ele-block"
- v-model="form.status"
- placeholder="请选择员工状态"
- >
- <el-option
- v-for="item in statusOptions"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- >
- </el-option>
- </el-select>
- </el-form-item>
- <el-form-item label="岗位:" prop="postName">
- <el-input
- clearable
- :maxlength="100"
- v-model="form.postName"
- placeholder="请输入岗位"
- />
- </el-form-item>
- <el-form-item label="工种:" prop="workTypeId">
- <DictSelection
- dictName="工种"
- clearable
- filterable
- v-model="form.workTypeId"
- >
- </DictSelection>
- </el-form-item>
- <el-form-item label="籍贯:" prop="city">
- <regions-select
- style="width: 100%"
- v-model="city"
- placeholder="请选择省市区"
- />
- </el-form-item>
- <el-form-item label="生日:" prop="age">
- <el-date-picker
- style="width: 100%"
- clearable
- v-model="form.birthday"
- type="date"
- value-format="yyyy-MM-dd"
- placeholder="请选择日期"
- >
- </el-date-picker>
- </el-form-item>
- <el-form-item label="审批签名:" prop="signature">
- <WithView :assetName="''" v-model="form.signature"></WithView>
- </el-form-item>
- </el-col>
- <el-col v-bind="styleResponsive ? { sm: 12 } : { span: 12 }">
- <el-form-item label="工号:" prop="jobNumber">
- <el-input
- clearable
- type="text"
- :maxlength="10"
- v-model="form.jobNumber"
- placeholder="请输入工号"
- onkeyup="value=value.replace(/[^\x00-\xff]/g, '')"
- />
- </el-form-item>
- <el-form-item label="姓名:" prop="name">
- <el-input
- clearable
- :maxlength="20"
- v-model="form.name"
- placeholder="请输入姓名"
- />
- </el-form-item>
- <el-form-item label="用户账号:">
- <el-input
- :disabled="true"
- :maxlength="11"
- v-model="form.loginName"
-
- />
- <!-- <el-select
- clearable
- class="ele-block"
- v-model="form.accountId"
- filterable
- placeholder="请选择用户账号"
- v-else
- >
- <el-option
- v-for="item in accountList"
- :key="item.id"
- :label="item.loginName"
- :value="item.id"
- >
- </el-option>
- </el-select> -->
- </el-form-item>
- <el-form-item label="手机号:" prop="phone">
- <el-input
- clearable
- :maxlength="11"
- v-model="form.phone"
- placeholder="请输入手机号"
- />
- </el-form-item>
- <el-form-item label="邮箱:" prop="email">
- <el-input
- clearable
- :maxlength="100"
- v-model="form.email"
- placeholder="请输入邮箱"
- />
- </el-form-item>
- <el-form-item label="年龄:" prop="age">
- <el-input
- type="number"
- clearable
- :maxlength="100"
- v-model="form.age"
- placeholder="请输入年龄"
- onkeyup="value=value.replace(/[^\d.]/g,'')"
- />
- </el-form-item>
- <el-form-item label="入职时间:" prop="joinDate">
- <el-date-picker
- style="width: 100%"
- clearable
- v-model="form.joinDate"
- type="date"
- value-format="yyyy-MM-dd"
- placeholder="请选择日期"
- >
- </el-date-picker>
- </el-form-item>
- <el-form-item label="毕业院校:" prop="school">
- <el-input
- clearable
- :maxlength="100"
- v-model="form.school"
- placeholder="请输入毕业院校"
- />
- </el-form-item>
- <el-form-item label="微信号:" prop="wxId">
- <el-input
- clearable
- :maxlength="100"
- v-model="form.wxId"
- placeholder="请输入微信号"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-tabs v-model="activeName">
- <el-tab-pane label="证照列表" name="identityPhotos">
- <ele-pro-table
- ref="table"
- :columns="identityPhotosColumns"
- :datasource="form.identityPhotos"
- max-height="350px"
- :toolkit="[]"
- class="el-form-box"
- :need-page="false"
- >
- <!-- 表头工具栏 -->
- <template v-slot:toolbar>
- <el-button type="primary" @click="addIdentityPhotos">添加</el-button>
- </template>
- <template v-slot:action="{ row, $index }">
- <el-link type="danger"
- :underline="false"
- icon="el-icon-delete" @click="handleIdentityPhotosDel(row, $index)">删除
- </el-link>
- </template>
- <template v-slot:categoryLevelId="{ row, $index }">
- </template>
- <template v-slot:type="{ row, $index }">
- <el-form-item label-width="0px" :prop="'identityPhotos.' + $index + '.type'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <DictSelection
- clearable
- v-model="row.type"
- dictName="证件类型"
- ></DictSelection>
- </el-form-item>
- </template>
- <template v-slot:code="{ row, $index }">
- <el-form-item label-width="0px" :prop="'identityPhotos.' + $index + '.code'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-input v-model="row.code" clearable></el-input>
- </el-form-item>
- </template>
- <template v-slot:level="{ row, $index }">
- <el-form-item label-width="0px" :prop="'identityPhotos.' + $index + '.level'">
- <el-select style="width: 100%" v-model="row.level" clearable filterable>
- <el-option
- :label="item.label"
- :value="item.value"
- v-for="(item, index) in levelOptions"
- :key="index"
- >
- </el-option>
- </el-select>
- </el-form-item>
- </template>
- <template v-slot:validityStartTime="{ row, $index }">
- <el-form-item label-width="0" :prop="'identityPhotos.' + $index + '.validityStartTime'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-date-picker
- style="width: 100%"
- v-model="row.validityStartTime"
- type="date"
- value-format="yyyy-MM-dd"
- placeholder="选择日期">
- </el-date-picker>
- </el-form-item>
- </template>
- <template v-slot:validityEndTime="{ row, $index }">
- <el-form-item label-width="0px" :prop="'identityPhotos.' + $index + '.validityEndTime'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-date-picker
- style="width: 100%"
- v-model="row.validityEndTime"
- value-format="yyyy-MM-dd"
- type="date"
- placeholder="选择日期">
- </el-date-picker>
- </el-form-item>
- </template>
- <template v-slot:enactorTime="{ row, $index }">
- <el-form-item label-width="0px" :prop="'identityPhotos.' + $index + '.enactorTime'">
- <el-date-picker
- style="width: 100%"
- v-model="row.enactorTime"
- value-format="yyyy-MM-dd"
- type="date"
- placeholder="选择日期">
- </el-date-picker>
- </el-form-item>
- </template>
- <template v-slot:fileObj="{ row, $index }">
- <el-form-item
- label-width="0"
- :prop="'identityPhotos.' + $index + '.fileObj'">
- <fileUpload
- v-model="row.fileObj"
- module="main"
- :showLib="false"
- :limit="5"/>
- </el-form-item>
- </template>
- <template v-slot:status="{ row, $index }">
- <el-form-item label-width="0px" :prop="'identityPhotos.' + $index + '.status'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <DictSelection
- clearable
- v-model="row.status"
- dictName="规则状态"
- ></DictSelection>
- </el-form-item>
- </template>
- <template v-slot:remark="{ row, $index }">
- <el-form-item label-width="0px">
- <el-input v-model="row.remark" type="textarea"></el-input>
- </el-form-item>
- </template>
- <template v-slot:isRequired="{ column }">
- <span class="is-required">{{ column.label }}</span>
- </template>
- </ele-pro-table>
- </el-tab-pane>
- <el-tab-pane label="技能列表" name="skills">
- <ele-pro-table
- ref="table"
- :columns="skillsColumns"
- :datasource="form.skills"
- max-height="350px"
- :toolkit="[]"
- class="el-form-box"
- :need-page="false"
- >
- <!-- 表头工具栏 -->
- <template v-slot:toolbar>
- <el-button type="primary" @click="addSkills">添加</el-button>
- </template>
- <template v-slot:action="{ row, $index }">
- <el-link type="danger"
- :underline="false"
- icon="el-icon-delete" @click="handleSkillsDel(row, $index)">删除
- </el-link>
- </template>
- <template v-slot:categoryLevelId="{ row, $index }">
- </template>
- <template v-slot:name="{ row, $index }">
- <el-form-item label-width="0px" :prop="'skills.' + $index + '.name'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-input v-model="row.name" clearable></el-input>
- </el-form-item>
- </template>
- <template v-slot:level="{ row, $index }">
- <el-form-item label-width="0" :prop="'skills.' + $index + '.level'">
- <el-select v-model="row.level" clearable filterable placeholder="请选择">
- <el-option
- v-for="item in []"
- :key="item.value"
- :label="item.label"
- :value="item.value">
- </el-option>
- </el-select>
- </el-form-item>
- </template>
- <template v-slot:years="{ row, $index }">
- <el-form-item label-width="0px" :prop="'skills.' + $index + '.years'">
- <el-input v-model="row.years" clearable></el-input>
- </el-form-item>
- </template>
- <template v-slot:fileAttach="{ row, $index }">
- <el-form-item
- label-width="0"
- :prop="'skills.' + $index + '.fileAttach'">
- <fileUpload
- v-model="row.fileAttach"
- module="main"
- :showLib="false"
- :limit="5"/>
- </el-form-item>
- </template>
- <template v-slot:remark="{ row, $index }">
- <el-form-item label-width="0px">
- <el-input v-model="row.remark" type="textarea"></el-input>
- </el-form-item>
- </template>
- <template v-slot:isRequired="{ column }">
- <span class="is-required">{{ column.label }}</span>
- </template>
- </ele-pro-table>
- </el-tab-pane>
- <el-tab-pane label="奖惩记录" name="RPRecords">
- <ele-pro-table
- ref="table"
- :columns="RPRecordsColumns"
- :datasource="form.rewardsPunishments"
- max-height="350px"
- :toolkit="[]"
- class="el-form-box"
- :need-page="false"
- >
- <!-- 表头工具栏 -->
- <template v-slot:toolbar>
- <el-button type="primary" @click="addRPRecords">添加</el-button>
- </template>
- <template v-slot:action="{ row, $index }">
- <el-link type="danger"
- :underline="false"
- icon="el-icon-delete" @click="handleRPRecordsDel(row, $index)">删除
- </el-link>
- </template>
- <template v-slot:type="{ row, $index }">
- <el-form-item label-width="0" :prop="'rewardsPunishments.' + $index + '.type'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-select v-model="row.type" clearable filterable placeholder="请选择">
- <el-option
- v-for="item in RPRecordsType"
- :key="item.value"
- :label="item.label"
- :value="item.value">
- </el-option>
- </el-select>
- </el-form-item>
- </template>
- <template v-slot:desce="{ row, $index }">
- <el-form-item label-width="0px">
- <el-input v-model="row.desce" type="textarea" clearable></el-input>
- </el-form-item>
- </template>
- <template v-slot:startTime="{ row, $index }">
- <el-form-item label-width="0" :prop="'rewardsPunishments.' + $index + '.startTime'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-date-picker
- style="width: 100%"
- v-model="row.startTime"
- type="date"
- value-format="yyyy-MM-dd"
- placeholder="选择日期">
- </el-date-picker>
- </el-form-item>
- </template>
- <template v-slot:endTime="{ row, $index }">
- <el-form-item label-width="0" :prop="'rewardsPunishments.' + $index + '.endTime'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-date-picker
- style="width: 100%"
- v-model="row.endTime"
- type="date"
- value-format="yyyy-MM-dd"
- placeholder="选择日期">
- </el-date-picker>
- </el-form-item>
- </template>
- <template v-slot:status="{ row, $index }">
- <el-form-item label-width="0px" :prop="'rewardsPunishments.' + $index + '.status'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-select v-model="row.status" clearable filterable placeholder="请选择">
- <el-option
- v-for="item in RPRecordsStatus"
- :key="item.value"
- :label="item.label"
- :value="item.value">
- </el-option>
- </el-select>
- </el-form-item>
- </template>
- <template v-slot:fileAttach="{ row, $index }">
- <el-form-item
- label-width="0"
- :prop="'rewardsPunishments.' + $index + '.fileAttach'">
- <fileUpload
- v-model="row.fileAttach"
- module="main"
- :showLib="false"
- :limit="5"/>
- </el-form-item>
- </template>
- <template v-slot:remark="{ row, $index }">
- <el-form-item label-width="0px">
- <el-input v-model="row.remark" type="textarea"></el-input>
- </el-form-item>
- </template>
- <template v-slot:isRequired="{ column }">
- <span class="is-required">{{ column.label }}</span>
- </template>
- </ele-pro-table>
- </el-tab-pane>
- <el-tab-pane label="培训记录" name="training">
- <ele-pro-table
- ref="table"
- :columns="trainingColumns"
- :datasource="form.trainRecords"
- max-height="350px"
- :toolkit="[]"
- class="el-form-box"
- :need-page="false"
- >
- <!-- 表头工具栏 -->
- <template v-slot:toolbar>
- <el-button type="primary" @click="addTraining">添加</el-button>
- </template>
- <template v-slot:action="{ row, $index }">
- <el-link type="danger"
- :underline="false"
- icon="el-icon-delete" @click="handleTrainingDel(row, $index)">删除
- </el-link>
- </template>
- <template v-slot:categoryLevelId="{ row, $index }">
- </template>
- <template v-slot:title="{ row, $index }">
- <el-form-item label-width="0" :prop="'trainRecords.' + $index + '.title'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-input v-model="row.title" clearable></el-input>
- </el-form-item>
- </template>
- <template v-slot:desce="{ row, $index }">
- <el-form-item label-width="0px" :prop="'trainRecords.' + $index + '.desce'">
- <el-input v-model="row.desce" type="textarea" clearable></el-input>
- </el-form-item>
- </template>
- <template v-slot:startTime="{ row, $index }">
- <el-form-item label-width="0" :prop="'trainRecords.' + $index + '.startTime'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-date-picker
- style="width: 100%"
- v-model="row.startTime"
- type="datetime"
- value-format="yyyy-MM-dd HH:mm:ss"
- placeholder="选择日期">
- </el-date-picker>
- </el-form-item>
- </template>
- <template v-slot:endTime="{ row, $index }">
- <el-form-item label-width="0" :prop="'trainRecords.' + $index + '.endTime'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-date-picker
- style="width: 100%"
- v-model="row.endTime"
- type="datetime"
- value-format="yyyy-MM-dd HH:mm:ss"
- placeholder="选择日期">
- </el-date-picker>
- </el-form-item>
- </template>
- <template v-slot:status="{ row, $index }">
- <el-form-item label-width="0px" :prop="'trainRecords.' + $index + '.status'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-select v-model="row.status" clearable filterable placeholder="请选择">
- <el-option
- v-for="item in trainingStatus"
- :key="item.value"
- :label="item.label"
- :value="item.value">
- </el-option>
- </el-select>
- </el-form-item>
- </template>
- <template v-slot:fileAttach="{ row, $index }">
- <el-form-item
- label-width="0"
- :prop="'trainRecords.' + $index + '.fileAttach'">
- <fileUpload
- v-model="row.fileAttach"
- module="main"
- :showLib="false"
- :limit="5"/>
- </el-form-item>
- </template>
- <template v-slot:remark="{ row, $index }">
- <el-form-item label-width="0px">
- <el-input v-model="row.remark" type="textarea"></el-input>
- </el-form-item>
- </template>
- <template v-slot:isRequired="{ column }">
- <span class="is-required">{{ column.label }}</span>
- </template>
- </ele-pro-table>
- </el-tab-pane>
- <el-tab-pane label="考勤记录" name="attendance">
- <ele-pro-table
- ref="table"
- :columns="attendanceColumns"
- :datasource="form.attendanceRecords"
- max-height="350px"
- :toolkit="[]"
- class="el-form-box"
- :need-page="false"
- >
- <!-- 表头工具栏 -->
- <template v-slot:toolbar>
- <el-button type="primary" @click="addAttendance">添加</el-button>
- </template>
- <template v-slot:action="{ row, $index }">
- <el-link type="danger"
- :underline="false"
- icon="el-icon-delete" @click="handleAttendanceDel(row, $index)">删除
- </el-link>
- </template>
- <template v-slot:type="{ row, $index }">
- <el-form-item label-width="0" :prop="'attendanceRecords.' + $index + '.type'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-select v-model="row.type" clearable filterable placeholder="请选择">
- <el-option
- v-for="item in attendanceType"
- :key="item.value"
- :label="item.label"
- :value="item.value">
- </el-option>
- </el-select>
- </el-form-item>
- </template>
- <template v-slot:checkTime="{ row, $index }">
- <el-form-item label-width="0" :prop="'attendanceRecords.' + $index + '.checkTime'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-date-picker
- style="width: 100%"
- v-model="row.checkTime"
- type="datetime"
- value-format="yyyy-MM-dd HH:mm:ss"
- placeholder="选择日期">
- </el-date-picker>
- </el-form-item>
- </template>
- <template v-slot:belateTime="{ row, $index }">
- <el-form-item label-width="0" :prop="'attendanceRecords.' + $index + '.belateTime'">
- <el-date-picker
- style="width: 100%"
- v-model="row.belateTime"
- type="datetime"
- value-format="yyyy-MM-dd HH:mm:ss"
- placeholder="选择日期">
- </el-date-picker>
- </el-form-item>
- </template>
- <template v-slot:leaveEarlyTime="{ row, $index }">
- <el-form-item label-width="0" :prop="'attendanceRecords.' + $index + '.leaveEarlyTime'">
- <el-date-picker
- style="width: 100%"
- v-model="row.leaveEarlyTime"
- type="datetime"
- value-format="yyyy-MM-dd HH:mm:ss"
- placeholder="选择日期">
- </el-date-picker>
- </el-form-item>
- </template>
- <template v-slot:fileAttach="{ row, $index }">
- <el-form-item
- label-width="0"
- :prop="'attendanceRecords.' + $index + '.fileAttach'">
- <fileUpload
- v-model="row.fileAttach"
- module="main"
- :showLib="false"
- :limit="5"/>
- </el-form-item>
- </template>
- <template v-slot:isRequired="{ column }">
- <span class="is-required">{{ column.label }}</span>
- </template>
- </ele-pro-table>
- </el-tab-pane>
- <el-tab-pane label="劳动合同" name="contracts">
- <ele-pro-table
- ref="table"
- :columns="contractsColumns"
- :datasource="form.contracts"
- max-height="350px"
- :toolkit="[]"
- class="el-form-box"
- :need-page="false"
- >
- <!-- 表头工具栏 -->
- <template v-slot:toolbar>
- <el-button type="primary" @click="addcontracts">添加</el-button>
- </template>
- <template v-slot:action="{ row, $index }">
- <el-link type="danger"
- :underline="false"
- icon="el-icon-delete" @click="handleContractsDel(row, $index)">删除
- </el-link>
- </template>
- <template v-slot:categoryLevelId="{ row, $index }">
- <el-form-item label-width="0" :prop="'contracts.' + $index + '.categoryLevelId'">
- </el-form-item>
- </template>
- <template v-slot:name="{ row, $index }">
- <el-form-item label-width="0px" :prop="'contracts.' + $index + '.name'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-input v-model="row.name" clearable></el-input>
- </el-form-item>
- </template>
- <template v-slot:signTime="{ row, $index }">
- <el-form-item label-width="0" :prop="'contracts.' + $index + '.signTime'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-date-picker
- style="width: 100%"
- v-model="row.signTime"
- type="date"
- value-format="yyyy-MM-dd"
- placeholder="选择日期">
- </el-date-picker>
- </el-form-item>
- </template>
- <template v-slot:startTime="{ row, $index }">
- <el-form-item label-width="0" :prop="'contracts.' + $index + '.startTime'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-date-picker
- style="width: 100%"
- v-model="row.startTime"
- type="date"
- value-format="yyyy-MM-dd"
- placeholder="选择日期">
- </el-date-picker>
- </el-form-item>
- </template>
- <template v-slot:endTime="{ row, $index }">
- <el-form-item label-width="0" :prop="'contracts.' + $index + '.endTime'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-date-picker
- style="width: 100%"
- v-model="row.endTime"
- type="date"
- value-format="yyyy-MM-dd"
- placeholder="选择日期">
- </el-date-picker>
- </el-form-item>
- </template>
- <template v-slot:status="{ row, $index }">
- <el-form-item label-width="0px" :prop="'contracts.' + $index + '.status'" :rules="{
- required: true,
- message: '',
- trigger: ['blur','change']
- }">
- <el-select v-model="row.status" clearable filterable placeholder="请选择" >
- <el-option
- v-for="item in contractsStatus"
- :key="item.value"
- :label="item.label"
- :value="item.value">
- </el-option>
- </el-select>
- </el-form-item>
- </template>
- <template v-slot:fileAttach="{ row, $index }">
- <el-form-item
- label-width="0"
- :prop="'contracts.' + $index + '.fileAttach'">
- <fileUpload
- v-model="row.fileAttach"
- module="main"
- :showLib="false"
- :limit="5"/>
- </el-form-item>
- </template>
- <template v-slot:remark="{ row, $index }">
- <el-form-item label-width="0px">
- <el-input v-model="row.remark" type="textarea"></el-input>
- </el-form-item>
- </template>
- <template v-slot:isRequired="{ column }">
- <span class="is-required">{{ column.label }}</span>
- </template>
- </ele-pro-table>
- </el-tab-pane>
- </el-tabs>
- </el-form>
- <template v-slot:footer>
- <el-button @click="updateVisible(false)">取消</el-button>
- <el-button type="primary" :loading="loading" @click="save">
- 保存
- </el-button>
- </template>
- </ele-modal>
- </template>
- <script>
- import { emailReg, phoneReg } from 'ele-admin';
- import OrgSelect from './org-select.vue';
- import RoleSelect from '@/views/system/user/components/role-select.vue';
- import RegionsSelect from '@/components/RegionsSelect/index.vue';
- import { getNotBoundAccount } from '@/api/system/user';
- import {
- getUserDetail,
- saveOrUpdateUser,
- checkExistence
- } from '@/api/system/organization';
- import { getFactoryarea } from '@/api/factoryModel';
- import WithView from '@/components/upload/WithView.vue';
- import FileUpload from "@/components/upload/fileUpload.vue";
- export default {
- components: {OrgSelect, RoleSelect, RegionsSelect,WithView,FileUpload},
- props: {
- // 弹窗是否打开
- visible: Boolean,
- // 修改回显的数据
- data: Object,
- // 全部机构
- organizationList: Array,
- //
- institutionList: Array,
- // 机构id
- organizationId: [Number, String]
- },
- data() {
- const defaultForm = {
- id: null,
- identityPhotos: [],
- skills: [],
- rewardsPunishments: [],
- trainRecords: [],
- attendanceRecords: [],
- contracts: [],
- deptIds: [],
- deptName: '',
- groupId: null,
- groupName: null,
- name: '',
- sex: null,
- email: '',
- phone: '',
- age: '',
- accountId: '',
- factoryId: '',
- workTypeId: '',
- signature: {}
- };
- return {
- defaultForm,
- // 表单数据
- form: {...defaultForm},
- activeName: 'identityPhotos',
- // 表单验证规则
- rules: {
- groupId: [
- { required: true, message: '请选择所属机构', trigger: 'blur' }
- ],
- name: [{ required: true, message: '请输入姓名', trigger: 'blur' }],
- sex: [{ required: true, message: '请选择性别', trigger: 'blur' }],
- email: [
- { pattern: emailReg, message: '邮箱格式不正确', trigger: 'blur' }
- ],
- phone: [
- { required: true, message: '请输入手机号', trigger: 'blur' },
- { pattern: phoneReg, message: '手机号格式不正确', trigger: 'blur' }
- ],
- jobNumber: [
- {
- required: false,
- trigger: 'blur',
- validator: (_rule, value, callback) => {
- if (!value) {
- return callback(new Error('请输入工号'));
- }
- checkExistence(this.form.jobNumber)
- .then((res) => {
- if (res != true && res != this.form.id) {
- callback(new Error('工号已经存在'));
- } else {
- callback();
- }
- })
- .catch(() => {
- callback();
- });
- }
- }
- ],
- status: [{ required: true, message: '请选择员工状态', trigger: 'blur' }]
- },
- // 提交状态
- loading: false,
- // 是否是修改
- isUpdate: false,
- city: '',
- factoryList: [],
- levelOptions: [
- {
- label: '初级',
- value: 1
- },
- {
- label: '中级',
- value: 2
- },
- {
- label: '高级',
- value: 3
- }
- ],
- RPRecordsStatus: [
- {
- label: '未生效',
- value: 0
- },
- {
- label: '审核中',
- value: 1
- },
- {
- label: '生效中',
- value: 2
- },
- {
- label: '已过期',
- value: 3
- },
- {
- label: '无效',
- value: 4
- },
- ],
- RPRecordsType: [
- {
- label: '未分类',
- value: 0
- },
- {
- label: '奖励',
- value: 1
- },
- {
- label: '惩罚',
- value: 2
- },
- ],
- trainingStatus: [
- {
- label: '未开始',
- value: 0
- },
- {
- label: '进行中',
- value: 1
- },
- {
- label: '已完成',
- value: 2
- },
- {
- label: '取消',
- value: 4
- },
- ],
- contractsStatus: [
- {
- label: '未生效',
- value: 0
- },
- {
- label: '审核中',
- value: 1
- },
- {
- label: '生效中',
- value: 2
- },
- {
- label: '过期',
- value: 3
- },
- {
- label: '转续签',
- value: 4
- },
- ],
- attendanceType: [
- {
- label: '未分类',
- value: 0
- },
- {
- label: '上班打卡',
- value: 1
- },
- {
- label: '下班打卡',
- value: 2
- },
- ],
- statusOptions: [
- { value: 1, label: '全职' },
- { value: 2, label: '兼职' },
- { value: 3, label: '实习' },
- { value: 4, label: '正式' },
- { value: 5, label: '试用' },
- { value: 6, label: '离职' }
- ],
- accountList: [],
- deptTree: [],
- defaultProps: {
- multiple: true,
- checkStrictly: true,
- emitPath: false,
- children: 'children',
- value: 'id',
- label: 'name'
- }
- };
- },
- computed: {
- // 是否开启响应式布局
- styleResponsive() {
- return this.$store.state.theme.styleResponsive;
- },
- identityPhotosColumns() {
- return [
- {
- label: '序号',
- type: 'index',
- width: 55,
- align: 'center'
- },
- {
- label: '证照类型',
- prop: 'type',
- slot: 'type',
- headerSlot: 'isRequired',
- minWidth: 120,
- align: "center"
- },
- {
- label: '证照编号',
- prop: 'code',
- slot: 'code',
- headerSlot: 'isRequired',
- minWidth: 120,
- align: "center"
- },
- {
- label: '等级',
- prop: 'level',
- slot: 'level',
- minWidth: 120,
- align: "center"
- },
- {
- label: '有效期开始时间',
- prop: 'validityStartTime',
- slot: 'validityStartTime',
- headerSlot: 'isRequired',
- minWidth: 150,
- align: "center"
- },
- {
- label: '有效期结束时间',
- prop: 'validityEndTime',
- slot: 'validityEndTime',
- headerSlot: 'isRequired',
- minWidth: 150,
- align: "center"
- },
- {
- label: '颁布日期',
- prop: 'enactorTime',
- slot: 'enactorTime',
- minWidth: 150,
- align: "center"
- },
- {
- label: '证照附件',
- prop: 'fileObj',
- slot: 'fileObj',
- minWidth: 200,
- align: "center"
- },
- {
- label: '状态',
- prop: 'status',
- slot: 'status',
- headerSlot: 'isRequired',
- minWidth: 100,
- align: "center"
- },
- {
- label: '备注',
- prop: 'remark',
- slot: 'remark',
- minWidth: 120,
- align: "center"
- },
- {
- action: 'action',
- slot: 'action',
- label: '操作',
- align: "center"
- }
- ]
- },
- skillsColumns() {
- return [
- {
- label: '序号',
- type: 'index',
- width: 55,
- align: 'center'
- },
- {
- label: '分类',
- prop: 'categoryLevelId',
- slot: 'categoryLevelId',
- minWidth: 120,
- align: "center"
- },
- {
- label: '技能名称',
- prop: 'name',
- slot: 'name',
- headerSlot: 'isRequired',
- minWidth: 120,
- align: "center"
- },
- {
- label: '技能等级',
- prop: 'level',
- slot: 'level',
- minWidth: 130,
- align: "center"
- },
- {
- label: '技能经验(年限)',
- prop: 'years',
- slot: 'years',
- minWidth: 130,
- align: "center"
- },
- {
- label: '证照附件',
- prop: 'fileAttach',
- slot: 'fileAttach',
- minWidth: 130,
- align: "center"
- },
- {
- label: '备注',
- prop: 'remark',
- slot: 'remark',
- minWidth: 120,
- align: "center"
- },
- {
- action: 'action',
- slot: 'action',
- label: '操作',
- align: "center"
- }
- ]
- },
- RPRecordsColumns() {
- return [
- {
- label: '序号',
- type: 'index',
- width: 55,
- align: 'center'
- },
- {
- label: '奖惩类型',
- prop: 'type',
- slot: 'type',
- headerSlot: 'isRequired',
- minWidth: 120,
- align: "center"
- },
- {
- label: '奖惩说明',
- prop: 'desce',
- slot: 'desce',
- minWidth: 120,
- align: "center"
- },
- {
- label: '开始时间',
- prop: 'startTime',
- slot: 'startTime',
- headerSlot: 'isRequired',
- minWidth: 130,
- align: "center"
- },
- {
- label: '结束时间',
- prop: 'endTime',
- slot: 'endTime',
- headerSlot: 'isRequired',
- minWidth: 130,
- align: "center"
- },
- {
- label: '证照附件',
- prop: 'fileAttach',
- slot: 'fileAttach',
- minWidth: 130,
- align: "center"
- },
- {
- label: '生效状态',
- prop: 'status',
- slot: 'status',
- headerSlot: 'isRequired',
- minWidth: 120,
- align: "center"
- },
- {
- label: '备注',
- prop: 'remark',
- slot: 'remark',
- minWidth: 120,
- align: "center"
- },
- {
- action: 'action',
- slot: 'action',
- label: '操作',
- align: "center"
- }
- ]
- },
- trainingColumns() {
- return [
- {
- label: '序号',
- type: 'index',
- width: 55,
- align: 'center'
- },
- {
- label: '分类',
- prop: 'categoryLevelId',
- slot: 'categoryLevelId',
- minWidth: 120,
- align: "center"
- },
- {
- label: '培训标题',
- prop: 'title',
- slot: 'title',
- headerSlot: 'isRequired',
- minWidth: 120,
- align: "center"
- },
- {
- label: '培训说明',
- prop: 'desce',
- slot: 'desce',
- minWidth: 120,
- align: "center"
- },
- {
- label: '开始时间',
- prop: 'startTime',
- slot: 'startTime',
- headerSlot: 'isRequired',
- minWidth: 130,
- align: "center"
- },
- {
- label: '结束时间',
- prop: 'endTime',
- slot: 'endTime',
- headerSlot: 'isRequired',
- minWidth: 130,
- align: "center"
- },
- {
- label: '附件',
- prop: 'fileAttach',
- slot: 'fileAttach',
- minWidth: 130,
- align: "center"
- },
- {
- label: '生效状态',
- prop: 'status',
- slot: 'status',
- headerSlot: 'isRequired',
- minWidth: 120,
- align: "center"
- },
- {
- label: '备注',
- prop: 'remark',
- slot: 'remark',
- minWidth: 120,
- align: "center"
- },
- {
- action: 'action',
- slot: 'action',
- label: '操作',
- align: "center"
- }
- ]
- },
- attendanceColumns() {
- return [
- {
- label: '序号',
- type: 'index',
- width: 55,
- align: 'center'
- },
- {
- label: '考勤类型',
- prop: 'type',
- slot: 'type',
- headerSlot: 'isRequired',
- minWidth: 120,
- align: "center"
- },
- {
- label: '签到时间',
- prop: 'checkTime',
- slot: 'checkTime',
- headerSlot: 'isRequired',
- minWidth: 120,
- align: "center"
- },
- // {
- // label: '迟到时间偏差值',
- // prop: 'belateTime',
- // minWidth: 120,
- // align: "center"
- // },
- // {
- // label: '早退时间偏差值',
- // prop: 'leaveEarlyTime',
- // minWidth: 130,
- // align: "center"
- // },
- {
- label: '附件',
- prop: 'fileAttach',
- slot: 'fileAttach',
- minWidth: 130,
- align: "center"
- },
- {
- action: 'action',
- slot: 'action',
- label: '操作',
- align: "center"
- }
- ]
- },
- contractsColumns() {
- return [
- {
- label: '序号',
- type: 'index',
- width: 55,
- align: 'center'
- },
- {
- label: '分类',
- prop: 'categoryLevelId',
- slot: 'categoryLevelId',
- minWidth: 120,
- align: "center"
- },
- {
- label: '合同名称',
- prop: 'name',
- slot: 'name',
- headerSlot: 'isRequired',
- minWidth: 120,
- align: "center"
- },
- {
- label: '签订时间',
- prop: 'signTime',
- slot: 'startTime',
- headerSlot: 'isRequired',
- minWidth: 130,
- align: "center"
- },
- {
- label: '开始时间',
- prop: 'startTime',
- slot: 'startTime',
- headerSlot: 'isRequired',
- minWidth: 130,
- align: "center"
- },
- {
- label: '结束时间',
- prop: 'endTime',
- slot: 'endTime',
- headerSlot: 'isRequired',
- minWidth: 130,
- align: "center"
- },
- {
- label: '合同附件',
- prop: 'fileAttach',
- slot: 'fileAttach',
- minWidth: 130,
- align: "center"
- },
- {
- label: '生效状态',
- prop: 'status',
- slot: 'status',
- headerSlot: 'isRequired',
- minWidth: 120,
- align: "center"
- },
- {
- label: '备注',
- prop: 'remark',
- slot: 'remark',
- minWidth: 120,
- align: "center"
- },
- {
- action: 'action',
- slot: 'action',
- label: '操作',
- align: "center"
- }
- ]
- },
- },
- created() {
- this.getFactoryList();
- console.log(this.institutionList, '========');
- },
- methods: {
- addIdentityPhotos() {
- this.form.identityPhotos.push({
- holder:this.form.name
- });
- },
- handleIdentityPhotosDel(row,index){
- this.form.identityPhotos.splice(index,1)
- },
- addSkills() {
- this.form.skills.push({});
- },
- handleSkillsDel(row,index){
- this.form.skills.splice(index,1)
- },
- addRPRecords() {
- this.form.rewardsPunishments.push({});
- },
- handleRPRecordsDel(row,index){
- this.form.rewardsPunishments.splice(index,1)
- },
- addTraining() {
- this.form.trainRecords.push({});
- },
- handleTrainingDel(row,index){
- this.form.trainRecords.splice(index,1)
- },
- addAttendance() {
- this.form.attendanceRecords.push({});
- },
- handleAttendanceDel(row,index) {
- this.form.attendanceRecords.splice(index,1)
- },
- addcontracts() {
- this.form.contracts.push({});
- },
- handleContractsDel(row,index) {
- this.form.contracts.splice(index,1)
- },
- getAccountList() {
- getNotBoundAccount().then((res) => {
- this.accountList = res;
- });
- },
- async getFactoryList() {
- const { list } = await getFactoryarea({
- pageNum: 1,
- size: 999,
- type: 1
- });
- this.factoryList = list || [];
- },
- /* 保存编辑 */
- save() {
- this.$refs.form.validate((valid) => {
- if (!valid) {
- return false;
- }
- this.loading = true;
- this.form.addressId = this.city ? this.city[this.city.length - 1] : '';
- // if (this.deptTree.length > 0) {
- // this.deptTree.forEach(i => {
- // this.form.deptIds.push(i[i.length - 1])
- // })
- //
- // this.form['deptTree'] = JSON.stringify(this.deptTree)
- // }
- const data = {
- ...this.form
- };
- if (!this.isUpdate) {
- delete data.id;
- }
- if (!Array.isArray(data.signature)) {
- data.signature = [data.signature].filter(item=>Boolean(item) && Object.keys(item).length!==0);
- }
- saveOrUpdateUser(data)
- .then((msg) => {
- this.loading = false;
- if (this.isUpdate) {
- this.$message.success('人员信息编辑成功');
- } else {
- this.$message.success('人员新增成功');
- }
- this.updateVisible(false);
- this.$emit('done');
- })
- .catch((e) => {
- this.loading = false;
- // this.$message.error(e.message);
- });
- });
- },
- /* 更新visible */
- updateVisible(value) {
- this.$emit('update:visible', value);
- },
- handleChange() {
- let arr = Array.from(this.$refs.deptRef.getCheckedNodes());
- this.form.deptName = arr.map((i) => i.label).join('/') || '';
- this.form.deptIds = this.form.deptIds || [];
- },
- checkedKeys(value) {
- this.getLabelName(this.institutionList, (i) => {
- if (i.id == this.form.groupId) {
- return (this.form.groupName = i.name);
- }
- });
- },
- getLabelName(data, callback) {
- data.some((i) => {
- callback(i);
- if (i.children) {
- this.getLabelName(i.children, callback);
- }
- });
- }
- },
- watch: {
- visible(visible) {
- if (visible) {
- this.getAccountList();
- if (this.data) {
- getUserDetail(this.data.id).then((res) => {
- this.form = { ...res };
- if (Array.isArray( this.form.signature)) {
- this.form.signature = this.form.signature[0];
- }
- // this.deptTree = []
- // this.form.deptIds = []
- // if (this.form.deptTree) {
- // this.deptTree = JSON.parse(this.form.deptTree)
- // }
- this.city = res.addressId ? res.addressId.toString() : null;
- this.isUpdate = true;
- });
- // this.$util.assignObject(this.form, {
- // ...this.data,
- // password: ''
- // });
- // this.form = {...this.data}
- // this.form.address = ["130000","130300","130304"]
- // this.form.address = "130304"
- // console.log('this.form',this.form)
- } else {
- this.city = null;
- this.form.groupId = this.organizationId;
- this.isUpdate = false;
- }
- } else {
- this.city = null;
- this.$refs.form.clearValidate();
- this.form = { ...this.defaultForm };
- }
- }
- }
- };
- </script>
- <style scoped lang="scss">
- ::v-deep .el-tabs__header {
- margin-bottom: 10px;
- }
- </style>
|