org-user-edit.vue 63 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103
  1. <!-- 用户编辑弹窗 -->
  2. <template>
  3. <ele-modal
  4. width="60%"
  5. :visible="visible"
  6. :close-on-click-modal="false"
  7. custom-class="ele-dialog-form"
  8. :title="isUpdate ? '基本信息' : '基本信息'"
  9. @update:visible="updateVisible"
  10. :maxable="true"
  11. >
  12. <el-form
  13. ref="form"
  14. :model="form"
  15. class="el-form-box"
  16. :rules="rules"
  17. label-width="82px"
  18. :disabled="disabled"
  19. >
  20. <el-row :gutter="15">
  21. <el-col v-bind="styleResponsive ? { sm: 12 } : { span: 12 }">
  22. <el-form-item label="所属机构:" prop="groupId">
  23. <org-select
  24. :data="institutionList"
  25. placeholder="请选择所属机构"
  26. v-model="form.groupId"
  27. :disabled="!!form.loginName"
  28. @checkedKeys="checkedKeys"
  29. />
  30. </el-form-item>
  31. <el-form-item label="隶属部门:">
  32. <el-cascader
  33. class="ele-block"
  34. :options="organization"
  35. placeholder="请选择隶属部门"
  36. :props="defaultProps"
  37. ref="deptRef"
  38. :show-all-levels="true"
  39. @change="handleChange"
  40. :disabled="!!form.loginName"
  41. v-model="form.deptIds"
  42. clearable
  43. ></el-cascader>
  44. </el-form-item>
  45. <el-form-item label="所属工厂:">
  46. <el-select
  47. style="width: 100%"
  48. clearable
  49. v-model="form.factoryId"
  50. filterable
  51. :disabled="!!form.loginName"
  52. placeholder="请选择所属工厂"
  53. >
  54. <el-option
  55. v-for="item in factoryList"
  56. :label="item.name"
  57. :value="item.id"
  58. :key="item.id"
  59. ></el-option>
  60. </el-select>
  61. </el-form-item>
  62. <el-form-item label="性别:" prop="sex">
  63. <el-select
  64. clearable
  65. class="ele-block"
  66. v-model="form.sex"
  67. placeholder="请选择性别"
  68. >
  69. <el-option label="男" :value="1" />
  70. <el-option label="女" :value="2" />
  71. </el-select>
  72. </el-form-item>
  73. <el-form-item label="员工状态:" prop="status">
  74. <el-select
  75. clearable
  76. class="ele-block"
  77. v-model="form.status"
  78. placeholder="请选择员工状态"
  79. >
  80. <el-option
  81. v-for="item in statusOptions"
  82. :key="item.value"
  83. :label="item.label"
  84. :value="item.value"
  85. >
  86. </el-option>
  87. </el-select>
  88. </el-form-item>
  89. <el-form-item label="岗位:" prop="postId">
  90. <!-- <el-input
  91. clearable
  92. :maxlength="100"
  93. v-model="form.postName"
  94. placeholder="请输入岗位"
  95. /> -->
  96. <DictSelection
  97. dictName="岗位"
  98. clearable
  99. filterable
  100. v-model="form.postId"
  101. multiple
  102. >
  103. </DictSelection>
  104. </el-form-item>
  105. <el-form-item label="身份证号:" prop="idCard">
  106. <el-input
  107. clearable
  108. :maxlength="18"
  109. v-model="form.idCard"
  110. placeholder="请输入身份证号"
  111. @change="idCardChange"
  112. />
  113. </el-form-item>
  114. <!-- <el-form-item label="工种:" prop="workTypeId"> -->
  115. <!-- <DictSelection
  116. dictName="工种类型"
  117. clearable
  118. filterable
  119. v-model="form.workTypeId"
  120. >
  121. </DictSelection> -->
  122. <!-- <el-select style="width: 100%" clearable v-model="form.workTypeId" filterable placeholder="请选择工种类型">
  123. <el-option v-for="item in professionList" :key="item.id" :label="item.name" :value="item.id"></el-option>
  124. </el-select>
  125. </el-form-item> -->
  126. <el-form-item label="籍贯:" prop="city">
  127. <regions-select
  128. style="width: 100%"
  129. v-model="city"
  130. placeholder="请选择省市区"
  131. />
  132. </el-form-item>
  133. <el-form-item label="生日:" prop="age">
  134. <el-date-picker
  135. style="width: 100%"
  136. clearable
  137. v-model="form.birthday"
  138. type="date"
  139. value-format="yyyy-MM-dd"
  140. placeholder="请选择日期"
  141. >
  142. </el-date-picker>
  143. </el-form-item>
  144. <el-form-item label="是否启用">
  145. <el-switch
  146. v-model="form.isEnabled"
  147. :active-text="form.isEnabled == 1 ? '启用' : '停用'"
  148. :active-value="1"
  149. :inactive-value="0"
  150. >
  151. </el-switch>
  152. </el-form-item>
  153. <el-form-item label="审批签名:" prop="signature">
  154. <WithView :assetName="''" v-model="form.signature"></WithView>
  155. </el-form-item>
  156. </el-col>
  157. <el-col v-bind="styleResponsive ? { sm: 12 } : { span: 12 }">
  158. <el-form-item label="工号:" prop="jobNumber">
  159. <el-input
  160. clearable
  161. type="text"
  162. :maxlength="10"
  163. v-model="form.jobNumber"
  164. placeholder="请输入工号"
  165. onkeyup="value=value.replace(/[^\x00-\xff]/g, '')"
  166. />
  167. </el-form-item>
  168. <el-form-item label="姓名:" prop="name">
  169. <el-input
  170. clearable
  171. :maxlength="20"
  172. v-model="form.name"
  173. placeholder="请输入姓名"
  174. />
  175. </el-form-item>
  176. <el-form-item label="用户账号:">
  177. <el-input
  178. :disabled="true"
  179. :maxlength="11"
  180. v-model="form.loginName"
  181. />
  182. </el-form-item>
  183. <el-form-item label="手机号:" prop="phone">
  184. <el-input
  185. clearable
  186. :maxlength="11"
  187. v-model="form.phone"
  188. placeholder="请输入手机号"
  189. />
  190. </el-form-item>
  191. <el-form-item label="邮箱:" prop="email">
  192. <el-input
  193. clearable
  194. :maxlength="100"
  195. v-model="form.email"
  196. placeholder="请输入邮箱"
  197. />
  198. </el-form-item>
  199. <el-form-item label="年龄:" prop="age">
  200. <el-input
  201. type="number"
  202. clearable
  203. :maxlength="100"
  204. v-model="form.age"
  205. placeholder="请输入年龄"
  206. onkeyup="value=value.replace(/[^\d.]/g,'')"
  207. />
  208. </el-form-item>
  209. <el-form-item label="入职时间:" prop="joinDate">
  210. <el-date-picker
  211. style="width: 100%"
  212. clearable
  213. v-model="form.joinDate"
  214. type="date"
  215. value-format="yyyy-MM-dd"
  216. placeholder="请选择日期"
  217. >
  218. </el-date-picker>
  219. </el-form-item>
  220. <el-form-item label="毕业院校:" prop="school">
  221. <el-input
  222. clearable
  223. :maxlength="100"
  224. v-model="form.school"
  225. placeholder="请输入毕业院校"
  226. />
  227. </el-form-item>
  228. <el-form-item label="微信号:" prop="wxId">
  229. <el-input
  230. clearable
  231. :maxlength="100"
  232. v-model="form.wxId"
  233. placeholder="请输入微信号"
  234. />
  235. </el-form-item>
  236. </el-col>
  237. </el-row>
  238. <el-tabs v-model="activeName">
  239. <el-tab-pane label="证照列表" name="identityPhotos">
  240. <ele-pro-table
  241. ref="table"
  242. :columns="identityPhotosColumns"
  243. :datasource="form.identityPhotos"
  244. max-height="350px"
  245. :toolkit="[]"
  246. class="el-form-box"
  247. :need-page="false"
  248. >
  249. <!-- 表头工具栏 -->
  250. <template v-slot:toolbar>
  251. <el-button type="primary" @click="addIdentityPhotos"
  252. >添加</el-button
  253. >
  254. </template>
  255. <template v-slot:action="{ row, $index }">
  256. <el-link
  257. type="danger"
  258. :underline="false"
  259. icon="el-icon-delete"
  260. @click="handleIdentityPhotosDel(row, $index)"
  261. >删除
  262. </el-link>
  263. </template>
  264. <template v-slot:categoryLevelId="{ row, $index }"> </template>
  265. <template v-slot:type="{ row, $index }">
  266. <el-form-item
  267. label-width="0px"
  268. :prop="'identityPhotos.' + $index + '.type'"
  269. :rules="{
  270. required: true,
  271. message: '',
  272. trigger: ['blur', 'change']
  273. }"
  274. >
  275. <DictSelection
  276. clearable
  277. v-model="row.type"
  278. dictName="证件类型"
  279. ></DictSelection>
  280. </el-form-item>
  281. </template>
  282. <template v-slot:code="{ row, $index }">
  283. <el-form-item
  284. label-width="0px"
  285. :prop="'identityPhotos.' + $index + '.code'"
  286. :rules="{
  287. required: true,
  288. message: '',
  289. trigger: ['blur', 'change']
  290. }"
  291. >
  292. <el-input v-model="row.code" clearable></el-input>
  293. </el-form-item>
  294. </template>
  295. <template v-slot:level="{ row, $index }">
  296. <el-form-item
  297. label-width="0px"
  298. :prop="'identityPhotos.' + $index + '.level'"
  299. >
  300. <el-select
  301. style="width: 100%"
  302. v-model="row.level"
  303. clearable
  304. filterable
  305. >
  306. <el-option
  307. :label="item.label"
  308. :value="item.value"
  309. v-for="(item, index) in levelOptions"
  310. :key="index"
  311. >
  312. </el-option>
  313. </el-select>
  314. </el-form-item>
  315. </template>
  316. <template v-slot:validityStartTime="{ row, $index }">
  317. <el-form-item
  318. label-width="0"
  319. :prop="'identityPhotos.' + $index + '.validityStartTime'"
  320. :rules="{
  321. required: true,
  322. message: '',
  323. trigger: ['blur', 'change']
  324. }"
  325. >
  326. <el-date-picker
  327. style="width: 100%"
  328. v-model="row.validityStartTime"
  329. type="date"
  330. value-format="yyyy-MM-dd"
  331. placeholder="选择日期"
  332. >
  333. </el-date-picker>
  334. </el-form-item>
  335. </template>
  336. <template v-slot:validityEndTime="{ row, $index }">
  337. <el-form-item
  338. label-width="0px"
  339. :prop="'identityPhotos.' + $index + '.validityEndTime'"
  340. :rules="{
  341. required: true,
  342. message: '',
  343. trigger: ['blur', 'change']
  344. }"
  345. >
  346. <el-date-picker
  347. style="width: 100%"
  348. v-model="row.validityEndTime"
  349. value-format="yyyy-MM-dd"
  350. type="date"
  351. placeholder="选择日期"
  352. >
  353. </el-date-picker>
  354. </el-form-item>
  355. </template>
  356. <template v-slot:enactorTime="{ row, $index }">
  357. <el-form-item
  358. label-width="0px"
  359. :prop="'identityPhotos.' + $index + '.enactorTime'"
  360. >
  361. <el-date-picker
  362. style="width: 100%"
  363. v-model="row.enactorTime"
  364. value-format="yyyy-MM-dd"
  365. type="date"
  366. placeholder="选择日期"
  367. >
  368. </el-date-picker>
  369. </el-form-item>
  370. </template>
  371. <template v-slot:fileObj="{ row, $index }">
  372. <el-form-item
  373. label-width="0"
  374. :prop="'identityPhotos.' + $index + '.fileObj'"
  375. >
  376. <fileUpload
  377. v-model="row.fileObj"
  378. module="main"
  379. :showLib="false"
  380. :limit="5"
  381. />
  382. </el-form-item>
  383. </template>
  384. <template v-slot:status="{ row, $index }">
  385. <el-form-item
  386. label-width="0px"
  387. :prop="'identityPhotos.' + $index + '.status'"
  388. :rules="{
  389. required: true,
  390. message: '',
  391. trigger: ['blur', 'change']
  392. }"
  393. >
  394. <DictSelection
  395. clearable
  396. v-model="row.status"
  397. dictName="规则状态"
  398. ></DictSelection>
  399. </el-form-item>
  400. </template>
  401. <template v-slot:remark="{ row, $index }">
  402. <el-form-item label-width="0px">
  403. <el-input v-model="row.remark" type="textarea"></el-input>
  404. </el-form-item>
  405. </template>
  406. <template v-slot:isRequired="{ column }">
  407. <span class="is-required">{{ column.label }}</span>
  408. </template>
  409. </ele-pro-table>
  410. </el-tab-pane>
  411. <el-tab-pane label="技能列表" name="skills">
  412. <ele-pro-table
  413. ref="table"
  414. :columns="skillsColumns"
  415. :datasource="form.skills"
  416. max-height="350px"
  417. :toolkit="[]"
  418. class="el-form-box"
  419. :need-page="false"
  420. >
  421. <!-- 表头工具栏 -->
  422. <template v-slot:toolbar>
  423. <el-button type="primary" @click="addSkills">添加</el-button>
  424. </template>
  425. <template v-slot:action="{ row, $index }">
  426. <el-link
  427. type="danger"
  428. :underline="false"
  429. icon="el-icon-delete"
  430. @click="handleSkillsDel(row, $index)"
  431. >删除
  432. </el-link>
  433. </template>
  434. <template v-slot:categoryLevelId="{ row, $index }"> </template>
  435. <template v-slot:name="{ row, $index }">
  436. <el-form-item
  437. label-width="0px"
  438. :prop="'skills.' + $index + '.name'"
  439. :rules="{
  440. required: true,
  441. message: '',
  442. trigger: ['blur', 'change']
  443. }"
  444. >
  445. <el-input v-model="row.name" clearable></el-input>
  446. </el-form-item>
  447. </template>
  448. <template v-slot:level="{ row, $index }">
  449. <el-form-item
  450. label-width="0"
  451. :prop="'skills.' + $index + '.level'"
  452. >
  453. <el-select
  454. v-model="row.level"
  455. clearable
  456. filterable
  457. placeholder="请选择"
  458. >
  459. <el-option
  460. v-for="item in []"
  461. :key="item.value"
  462. :label="item.label"
  463. :value="item.value"
  464. >
  465. </el-option>
  466. </el-select>
  467. </el-form-item>
  468. </template>
  469. <template v-slot:years="{ row, $index }">
  470. <el-form-item
  471. label-width="0px"
  472. :prop="'skills.' + $index + '.years'"
  473. >
  474. <el-input v-model="row.years" clearable></el-input>
  475. </el-form-item>
  476. </template>
  477. <template v-slot:fileAttach="{ row, $index }">
  478. <el-form-item
  479. label-width="0"
  480. :prop="'skills.' + $index + '.fileAttach'"
  481. >
  482. <fileUpload
  483. v-model="row.fileAttach"
  484. module="main"
  485. :showLib="false"
  486. :limit="5"
  487. />
  488. </el-form-item>
  489. </template>
  490. <template v-slot:remark="{ row, $index }">
  491. <el-form-item label-width="0px">
  492. <el-input v-model="row.remark" type="textarea"></el-input>
  493. </el-form-item>
  494. </template>
  495. <template v-slot:isRequired="{ column }">
  496. <span class="is-required">{{ column.label }}</span>
  497. </template>
  498. </ele-pro-table>
  499. </el-tab-pane>
  500. <el-tab-pane label="奖惩记录" name="RPRecords">
  501. <ele-pro-table
  502. ref="table"
  503. :columns="RPRecordsColumns"
  504. :datasource="form.rewardsPunishments"
  505. max-height="350px"
  506. :toolkit="[]"
  507. class="el-form-box"
  508. :need-page="false"
  509. >
  510. <!-- 表头工具栏 -->
  511. <template v-slot:toolbar>
  512. <el-button type="primary" @click="addRPRecords">添加</el-button>
  513. </template>
  514. <template v-slot:action="{ row, $index }">
  515. <el-link
  516. type="danger"
  517. :underline="false"
  518. icon="el-icon-delete"
  519. @click="handleRPRecordsDel(row, $index)"
  520. >删除
  521. </el-link>
  522. </template>
  523. <template v-slot:type="{ row, $index }">
  524. <el-form-item
  525. label-width="0"
  526. :prop="'rewardsPunishments.' + $index + '.type'"
  527. :rules="{
  528. required: true,
  529. message: '',
  530. trigger: ['blur', 'change']
  531. }"
  532. >
  533. <el-select
  534. v-model="row.type"
  535. clearable
  536. filterable
  537. placeholder="请选择"
  538. >
  539. <el-option
  540. v-for="item in RPRecordsType"
  541. :key="item.value"
  542. :label="item.label"
  543. :value="item.value"
  544. >
  545. </el-option>
  546. </el-select>
  547. </el-form-item>
  548. </template>
  549. <template v-slot:desce="{ row, $index }">
  550. <el-form-item label-width="0px">
  551. <el-input
  552. v-model="row.desce"
  553. type="textarea"
  554. clearable
  555. ></el-input>
  556. </el-form-item>
  557. </template>
  558. <template v-slot:startTime="{ row, $index }">
  559. <el-form-item
  560. label-width="0"
  561. :prop="'rewardsPunishments.' + $index + '.startTime'"
  562. :rules="{
  563. required: true,
  564. message: '',
  565. trigger: ['blur', 'change']
  566. }"
  567. >
  568. <el-date-picker
  569. style="width: 100%"
  570. v-model="row.startTime"
  571. type="date"
  572. value-format="yyyy-MM-dd"
  573. placeholder="选择日期"
  574. >
  575. </el-date-picker>
  576. </el-form-item>
  577. </template>
  578. <template v-slot:endTime="{ row, $index }">
  579. <el-form-item
  580. label-width="0"
  581. :prop="'rewardsPunishments.' + $index + '.endTime'"
  582. :rules="{
  583. required: true,
  584. message: '',
  585. trigger: ['blur', 'change']
  586. }"
  587. >
  588. <el-date-picker
  589. style="width: 100%"
  590. v-model="row.endTime"
  591. type="date"
  592. value-format="yyyy-MM-dd"
  593. placeholder="选择日期"
  594. >
  595. </el-date-picker>
  596. </el-form-item>
  597. </template>
  598. <template v-slot:status="{ row, $index }">
  599. <el-form-item
  600. label-width="0px"
  601. :prop="'rewardsPunishments.' + $index + '.status'"
  602. :rules="{
  603. required: true,
  604. message: '',
  605. trigger: ['blur', 'change']
  606. }"
  607. >
  608. <el-select
  609. v-model="row.status"
  610. clearable
  611. filterable
  612. placeholder="请选择"
  613. >
  614. <el-option
  615. v-for="item in RPRecordsStatus"
  616. :key="item.value"
  617. :label="item.label"
  618. :value="item.value"
  619. >
  620. </el-option>
  621. </el-select>
  622. </el-form-item>
  623. </template>
  624. <template v-slot:fileAttach="{ row, $index }">
  625. <el-form-item
  626. label-width="0"
  627. :prop="'rewardsPunishments.' + $index + '.fileAttach'"
  628. >
  629. <fileUpload
  630. v-model="row.fileAttach"
  631. module="main"
  632. :showLib="false"
  633. :limit="5"
  634. />
  635. </el-form-item>
  636. </template>
  637. <template v-slot:remark="{ row, $index }">
  638. <el-form-item label-width="0px">
  639. <el-input v-model="row.remark" type="textarea"></el-input>
  640. </el-form-item>
  641. </template>
  642. <template v-slot:isRequired="{ column }">
  643. <span class="is-required">{{ column.label }}</span>
  644. </template>
  645. </ele-pro-table>
  646. </el-tab-pane>
  647. <el-tab-pane label="培训记录" name="training">
  648. <ele-pro-table
  649. ref="table"
  650. :columns="trainingColumns"
  651. :datasource="form.trainRecords"
  652. max-height="350px"
  653. :toolkit="[]"
  654. class="el-form-box"
  655. :need-page="false"
  656. >
  657. <!-- 表头工具栏 -->
  658. <template v-slot:toolbar>
  659. <el-button type="primary" @click="addTraining">添加</el-button>
  660. </template>
  661. <template v-slot:action="{ row, $index }">
  662. <el-link
  663. type="danger"
  664. :underline="false"
  665. icon="el-icon-delete"
  666. @click="handleTrainingDel(row, $index)"
  667. >删除
  668. </el-link>
  669. </template>
  670. <template v-slot:categoryLevelId="{ row, $index }"> </template>
  671. <template v-slot:title="{ row, $index }">
  672. <el-form-item
  673. label-width="0"
  674. :prop="'trainRecords.' + $index + '.title'"
  675. :rules="{
  676. required: true,
  677. message: '',
  678. trigger: ['blur', 'change']
  679. }"
  680. >
  681. <el-input v-model="row.title" clearable></el-input>
  682. </el-form-item>
  683. </template>
  684. <template v-slot:desce="{ row, $index }">
  685. <el-form-item
  686. label-width="0px"
  687. :prop="'trainRecords.' + $index + '.desce'"
  688. >
  689. <el-input
  690. v-model="row.desce"
  691. type="textarea"
  692. clearable
  693. ></el-input>
  694. </el-form-item>
  695. </template>
  696. <template v-slot:startTime="{ row, $index }">
  697. <el-form-item
  698. label-width="0"
  699. :prop="'trainRecords.' + $index + '.startTime'"
  700. :rules="{
  701. required: true,
  702. message: '',
  703. trigger: ['blur', 'change']
  704. }"
  705. >
  706. <el-date-picker
  707. style="width: 100%"
  708. v-model="row.startTime"
  709. type="datetime"
  710. value-format="yyyy-MM-dd HH:mm:ss"
  711. placeholder="选择日期"
  712. >
  713. </el-date-picker>
  714. </el-form-item>
  715. </template>
  716. <template v-slot:endTime="{ row, $index }">
  717. <el-form-item
  718. label-width="0"
  719. :prop="'trainRecords.' + $index + '.endTime'"
  720. :rules="{
  721. required: true,
  722. message: '',
  723. trigger: ['blur', 'change']
  724. }"
  725. >
  726. <el-date-picker
  727. style="width: 100%"
  728. v-model="row.endTime"
  729. type="datetime"
  730. value-format="yyyy-MM-dd HH:mm:ss"
  731. placeholder="选择日期"
  732. >
  733. </el-date-picker>
  734. </el-form-item>
  735. </template>
  736. <template v-slot:status="{ row, $index }">
  737. <el-form-item
  738. label-width="0px"
  739. :prop="'trainRecords.' + $index + '.status'"
  740. :rules="{
  741. required: true,
  742. message: '',
  743. trigger: ['blur', 'change']
  744. }"
  745. >
  746. <el-select
  747. v-model="row.status"
  748. clearable
  749. filterable
  750. placeholder="请选择"
  751. >
  752. <el-option
  753. v-for="item in trainingStatus"
  754. :key="item.value"
  755. :label="item.label"
  756. :value="item.value"
  757. >
  758. </el-option>
  759. </el-select>
  760. </el-form-item>
  761. </template>
  762. <template v-slot:fileAttach="{ row, $index }">
  763. <el-form-item
  764. label-width="0"
  765. :prop="'trainRecords.' + $index + '.fileAttach'"
  766. >
  767. <fileUpload
  768. v-model="row.fileAttach"
  769. module="main"
  770. :showLib="false"
  771. :limit="5"
  772. />
  773. </el-form-item>
  774. </template>
  775. <template v-slot:remark="{ row, $index }">
  776. <el-form-item label-width="0px">
  777. <el-input v-model="row.remark" type="textarea"></el-input>
  778. </el-form-item>
  779. </template>
  780. <template v-slot:isRequired="{ column }">
  781. <span class="is-required">{{ column.label }}</span>
  782. </template>
  783. </ele-pro-table>
  784. </el-tab-pane>
  785. <el-tab-pane label="考勤记录" name="attendance">
  786. <ele-pro-table
  787. ref="table"
  788. :columns="attendanceColumns"
  789. :datasource="form.attendanceRecords"
  790. max-height="350px"
  791. :toolkit="[]"
  792. class="el-form-box"
  793. :need-page="false"
  794. >
  795. <!-- 表头工具栏 -->
  796. <template v-slot:toolbar>
  797. <el-button type="primary" @click="addAttendance">添加</el-button>
  798. </template>
  799. <template v-slot:action="{ row, $index }">
  800. <el-link
  801. type="danger"
  802. :underline="false"
  803. icon="el-icon-delete"
  804. @click="handleAttendanceDel(row, $index)"
  805. >删除
  806. </el-link>
  807. </template>
  808. <template v-slot:type="{ row, $index }">
  809. <el-form-item
  810. label-width="0"
  811. :prop="'attendanceRecords.' + $index + '.type'"
  812. :rules="{
  813. required: true,
  814. message: '',
  815. trigger: ['blur', 'change']
  816. }"
  817. >
  818. <el-select
  819. v-model="row.type"
  820. clearable
  821. filterable
  822. placeholder="请选择"
  823. >
  824. <el-option
  825. v-for="item in attendanceType"
  826. :key="item.value"
  827. :label="item.label"
  828. :value="item.value"
  829. >
  830. </el-option>
  831. </el-select>
  832. </el-form-item>
  833. </template>
  834. <template v-slot:checkTime="{ row, $index }">
  835. <el-form-item
  836. label-width="0"
  837. :prop="'attendanceRecords.' + $index + '.checkTime'"
  838. :rules="{
  839. required: true,
  840. message: '',
  841. trigger: ['blur', 'change']
  842. }"
  843. >
  844. <el-date-picker
  845. style="width: 100%"
  846. v-model="row.checkTime"
  847. type="datetime"
  848. value-format="yyyy-MM-dd HH:mm:ss"
  849. placeholder="选择日期"
  850. >
  851. </el-date-picker>
  852. </el-form-item>
  853. </template>
  854. <template v-slot:belateTime="{ row, $index }">
  855. <el-form-item
  856. label-width="0"
  857. :prop="'attendanceRecords.' + $index + '.belateTime'"
  858. >
  859. <el-date-picker
  860. style="width: 100%"
  861. v-model="row.belateTime"
  862. type="datetime"
  863. value-format="yyyy-MM-dd HH:mm:ss"
  864. placeholder="选择日期"
  865. >
  866. </el-date-picker>
  867. </el-form-item>
  868. </template>
  869. <template v-slot:leaveEarlyTime="{ row, $index }">
  870. <el-form-item
  871. label-width="0"
  872. :prop="'attendanceRecords.' + $index + '.leaveEarlyTime'"
  873. >
  874. <el-date-picker
  875. style="width: 100%"
  876. v-model="row.leaveEarlyTime"
  877. type="datetime"
  878. value-format="yyyy-MM-dd HH:mm:ss"
  879. placeholder="选择日期"
  880. >
  881. </el-date-picker>
  882. </el-form-item>
  883. </template>
  884. <template v-slot:fileAttach="{ row, $index }">
  885. <el-form-item
  886. label-width="0"
  887. :prop="'attendanceRecords.' + $index + '.fileAttach'"
  888. >
  889. <fileUpload
  890. v-model="row.fileAttach"
  891. module="main"
  892. :showLib="false"
  893. :limit="5"
  894. />
  895. </el-form-item>
  896. </template>
  897. <template v-slot:isRequired="{ column }">
  898. <span class="is-required">{{ column.label }}</span>
  899. </template>
  900. </ele-pro-table>
  901. </el-tab-pane>
  902. <el-tab-pane label="劳动合同" name="contracts">
  903. <ele-pro-table
  904. ref="table"
  905. :columns="contractsColumns"
  906. :datasource="form.contracts"
  907. max-height="350px"
  908. :toolkit="[]"
  909. class="el-form-box"
  910. :need-page="false"
  911. >
  912. <!-- 表头工具栏 -->
  913. <template v-slot:toolbar>
  914. <el-button type="primary" @click="addcontracts">添加</el-button>
  915. </template>
  916. <template v-slot:action="{ row, $index }">
  917. <el-link
  918. type="danger"
  919. :underline="false"
  920. icon="el-icon-delete"
  921. @click="handleContractsDel(row, $index)"
  922. >删除
  923. </el-link>
  924. </template>
  925. <template v-slot:categoryLevelId="{ row, $index }">
  926. <el-form-item
  927. label-width="0"
  928. :prop="'contracts.' + $index + '.categoryLevelId'"
  929. >
  930. </el-form-item>
  931. </template>
  932. <template v-slot:name="{ row, $index }">
  933. <el-form-item
  934. label-width="0px"
  935. :prop="'contracts.' + $index + '.name'"
  936. :rules="{
  937. required: true,
  938. message: '',
  939. trigger: ['blur', 'change']
  940. }"
  941. >
  942. <el-input v-model="row.name" clearable></el-input>
  943. </el-form-item>
  944. </template>
  945. <template v-slot:signTime="{ row, $index }">
  946. <el-form-item
  947. label-width="0"
  948. :prop="'contracts.' + $index + '.signTime'"
  949. :rules="{
  950. required: true,
  951. message: '',
  952. trigger: ['blur', 'change']
  953. }"
  954. >
  955. <el-date-picker
  956. style="width: 100%"
  957. v-model="row.signTime"
  958. type="date"
  959. value-format="yyyy-MM-dd"
  960. placeholder="选择日期"
  961. >
  962. </el-date-picker>
  963. </el-form-item>
  964. </template>
  965. <template v-slot:startTime="{ row, $index }">
  966. <el-form-item
  967. label-width="0"
  968. :prop="'contracts.' + $index + '.startTime'"
  969. :rules="{
  970. required: true,
  971. message: '',
  972. trigger: ['blur', 'change']
  973. }"
  974. >
  975. <el-date-picker
  976. style="width: 100%"
  977. v-model="row.startTime"
  978. type="date"
  979. value-format="yyyy-MM-dd"
  980. placeholder="选择日期"
  981. >
  982. </el-date-picker>
  983. </el-form-item>
  984. </template>
  985. <template v-slot:endTime="{ row, $index }">
  986. <el-form-item
  987. label-width="0"
  988. :prop="'contracts.' + $index + '.endTime'"
  989. :rules="{
  990. required: true,
  991. message: '',
  992. trigger: ['blur', 'change']
  993. }"
  994. >
  995. <el-date-picker
  996. style="width: 100%"
  997. v-model="row.endTime"
  998. type="date"
  999. value-format="yyyy-MM-dd"
  1000. placeholder="选择日期"
  1001. >
  1002. </el-date-picker>
  1003. </el-form-item>
  1004. </template>
  1005. <template v-slot:status="{ row, $index }">
  1006. <el-form-item
  1007. label-width="0px"
  1008. :prop="'contracts.' + $index + '.status'"
  1009. :rules="{
  1010. required: true,
  1011. message: '',
  1012. trigger: ['blur', 'change']
  1013. }"
  1014. >
  1015. <el-select
  1016. v-model="row.status"
  1017. clearable
  1018. filterable
  1019. placeholder="请选择"
  1020. >
  1021. <el-option
  1022. v-for="item in contractsStatus"
  1023. :key="item.value"
  1024. :label="item.label"
  1025. :value="item.value"
  1026. >
  1027. </el-option>
  1028. </el-select>
  1029. </el-form-item>
  1030. </template>
  1031. <template v-slot:fileAttach="{ row, $index }">
  1032. <el-form-item
  1033. label-width="0"
  1034. :prop="'contracts.' + $index + '.fileAttach'"
  1035. >
  1036. <fileUpload
  1037. v-model="row.fileAttach"
  1038. module="main"
  1039. :showLib="false"
  1040. :limit="5"
  1041. />
  1042. </el-form-item>
  1043. </template>
  1044. <template v-slot:remark="{ row, $index }">
  1045. <el-form-item label-width="0px">
  1046. <el-input v-model="row.remark" type="textarea"></el-input>
  1047. </el-form-item>
  1048. </template>
  1049. <template v-slot:isRequired="{ column }">
  1050. <span class="is-required">{{ column.label }}</span>
  1051. </template>
  1052. </ele-pro-table>
  1053. </el-tab-pane>
  1054. <el-tab-pane label="工种" name="jobManagement">
  1055. <ele-pro-table
  1056. ref="table"
  1057. :columns="jobColumns"
  1058. :datasource="form.professions"
  1059. max-height="350px"
  1060. :toolkit="[]"
  1061. class="el-form-box"
  1062. :need-page="false"
  1063. >
  1064. <!-- 表头工具栏 -->
  1065. <template v-slot:toolbar>
  1066. <el-button type="primary" @click="$refs.aptitudeDialogRef.open()"
  1067. >添加</el-button
  1068. >
  1069. </template>
  1070. <template v-slot:action="{ row, $index }">
  1071. <el-link
  1072. type="danger"
  1073. :underline="false"
  1074. icon="el-icon-delete"
  1075. @click="deleteJob($index)"
  1076. >删除
  1077. </el-link>
  1078. </template>
  1079. </ele-pro-table>
  1080. </el-tab-pane>
  1081. </el-tabs>
  1082. </el-form>
  1083. <template v-slot:footer>
  1084. <el-button @click="updateVisible(false)">取消</el-button>
  1085. <el-button
  1086. type="primary"
  1087. :loading="loading"
  1088. @click="save"
  1089. v-if="!disabled"
  1090. >
  1091. 保存
  1092. </el-button>
  1093. </template>
  1094. <aptitudeDialog
  1095. ref="aptitudeDialogRef"
  1096. @success="chooseAptitude"
  1097. :disabledIds="form.professions?.map(item => item.id)"
  1098. ></aptitudeDialog>
  1099. </ele-modal>
  1100. </template>
  1101. <script>
  1102. import { emailReg, phoneReg } from 'ele-admin';
  1103. import OrgSelect from './org-select.vue';
  1104. import RoleSelect from '@/views/system/user/components/role-select.vue';
  1105. import RegionsSelect from '@/components/RegionsSelect/index.vue';
  1106. import { getNotBoundAccount } from '@/api/system/user';
  1107. import {
  1108. getUserDetail,
  1109. saveOrUpdateUser,
  1110. checkExistence
  1111. } from '@/api/system/organization';
  1112. import { getFactoryarea, getProfessionPageList } from '@/api/factoryModel';
  1113. import WithView from '@/components/upload/WithView.vue';
  1114. import FileUpload from '@/components/upload/fileUpload.vue';
  1115. import dictMixins from '@/mixins/dictMixins';
  1116. import aptitudeDialog from '@/views/factoryModel/jobManagement/components/aptitudeDialog.vue';
  1117. import { del } from 'vue';
  1118. // D:\中赢\kd-aiot-frontend\src\views\system\user
  1119. export default {
  1120. mixins: [dictMixins],
  1121. components: {
  1122. OrgSelect,
  1123. RoleSelect,
  1124. RegionsSelect,
  1125. WithView,
  1126. FileUpload,
  1127. aptitudeDialog
  1128. },
  1129. props: {
  1130. // 弹窗是否打开
  1131. visible: Boolean,
  1132. // 修改回显的数据
  1133. data: Object,
  1134. // 全部机构
  1135. organizationList: Array,
  1136. //
  1137. institutionList: Array,
  1138. // 机构id
  1139. organizationId: [Number, String]
  1140. },
  1141. data() {
  1142. const defaultForm = {
  1143. id: null,
  1144. identityPhotos: [],
  1145. skills: [],
  1146. rewardsPunishments: [],
  1147. trainRecords: [],
  1148. attendanceRecords: [],
  1149. contracts: [],
  1150. deptIds: [],
  1151. deptName: '',
  1152. isEnabled: 1,
  1153. groupId: null,
  1154. groupName: null,
  1155. name: '',
  1156. sex: null,
  1157. email: '',
  1158. phone: '',
  1159. age: '',
  1160. accountId: '',
  1161. factoryId: '',
  1162. idCard: '',
  1163. workTypeId: '',
  1164. birthday: '',
  1165. signature: {},
  1166. postName: '',
  1167. professions: []
  1168. };
  1169. return {
  1170. defaultForm,
  1171. // 表单数据
  1172. form: { ...defaultForm },
  1173. disabled: false,
  1174. activeName: 'identityPhotos',
  1175. // 表单验证规则
  1176. rules: {
  1177. groupId: [
  1178. { required: true, message: '请选择所属机构', trigger: 'blur' }
  1179. ],
  1180. name: [{ required: true, message: '请输入姓名', trigger: 'blur' }],
  1181. sex: [{ required: true, message: '请选择性别', trigger: 'blur' }],
  1182. email: [
  1183. { pattern: emailReg, message: '邮箱格式不正确', trigger: 'blur' }
  1184. ],
  1185. phone: [
  1186. { required: true, message: '请输入手机号', trigger: 'blur' },
  1187. { pattern: phoneReg, message: '手机号格式不正确', trigger: 'blur' }
  1188. ],
  1189. jobNumber: [
  1190. {
  1191. required: true,
  1192. trigger: 'blur'
  1193. }
  1194. ],
  1195. status: [
  1196. { required: true, message: '请选择员工状态', trigger: 'blur' }
  1197. ]
  1198. },
  1199. // 提交状态
  1200. loading: false,
  1201. // 是否是修改
  1202. isUpdate: false,
  1203. city: '',
  1204. factoryList: [],
  1205. levelOptions: [
  1206. {
  1207. label: '初级',
  1208. value: '1'
  1209. },
  1210. {
  1211. label: '中级',
  1212. value: '2'
  1213. },
  1214. {
  1215. label: '高级',
  1216. value: '3'
  1217. }
  1218. ],
  1219. RPRecordsStatus: [
  1220. {
  1221. label: '未生效',
  1222. value: 0
  1223. },
  1224. {
  1225. label: '审核中',
  1226. value: 1
  1227. },
  1228. {
  1229. label: '生效中',
  1230. value: 2
  1231. },
  1232. {
  1233. label: '已过期',
  1234. value: 3
  1235. },
  1236. {
  1237. label: '无效',
  1238. value: 4
  1239. }
  1240. ],
  1241. RPRecordsType: [
  1242. {
  1243. label: '未分类',
  1244. value: 0
  1245. },
  1246. {
  1247. label: '奖励',
  1248. value: 1
  1249. },
  1250. {
  1251. label: '惩罚',
  1252. value: 2
  1253. }
  1254. ],
  1255. trainingStatus: [
  1256. {
  1257. label: '未开始',
  1258. value: 0
  1259. },
  1260. {
  1261. label: '进行中',
  1262. value: 1
  1263. },
  1264. {
  1265. label: '已完成',
  1266. value: 2
  1267. },
  1268. {
  1269. label: '取消',
  1270. value: 4
  1271. }
  1272. ],
  1273. contractsStatus: [
  1274. {
  1275. label: '未生效',
  1276. value: 0
  1277. },
  1278. {
  1279. label: '审核中',
  1280. value: 1
  1281. },
  1282. {
  1283. label: '生效中',
  1284. value: 2
  1285. },
  1286. {
  1287. label: '过期',
  1288. value: 3
  1289. },
  1290. {
  1291. label: '转续签',
  1292. value: 4
  1293. }
  1294. ],
  1295. attendanceType: [
  1296. {
  1297. label: '未分类',
  1298. value: 0
  1299. },
  1300. {
  1301. label: '上班打卡',
  1302. value: 1
  1303. },
  1304. {
  1305. label: '下班打卡',
  1306. value: 2
  1307. }
  1308. ],
  1309. statusOptions: [
  1310. { value: 1, label: '全职' },
  1311. { value: 2, label: '兼职' },
  1312. { value: 3, label: '实习' },
  1313. { value: 4, label: '正式' },
  1314. { value: 5, label: '试用' },
  1315. { value: 6, label: '离职' }
  1316. ],
  1317. accountList: [],
  1318. levelOptions: [
  1319. {
  1320. label: '初级',
  1321. value: '1'
  1322. },
  1323. {
  1324. label: '中级',
  1325. value: '2'
  1326. },
  1327. {
  1328. label: '高级',
  1329. value: '3'
  1330. }
  1331. ],
  1332. deptTree: [],
  1333. defaultProps: {
  1334. multiple: true,
  1335. checkStrictly: true,
  1336. emitPath: false,
  1337. children: 'children',
  1338. value: 'id',
  1339. label: 'name'
  1340. },
  1341. professionList: []
  1342. };
  1343. },
  1344. computed: {
  1345. // 是否开启响应式布局
  1346. styleResponsive() {
  1347. return this.$store.state.theme.styleResponsive;
  1348. },
  1349. organization() {
  1350. return this.setList(this.organizationList);
  1351. },
  1352. identityPhotosColumns() {
  1353. return [
  1354. {
  1355. label: '序号',
  1356. type: 'index',
  1357. width: 55,
  1358. align: 'center'
  1359. },
  1360. {
  1361. label: '证照类型',
  1362. prop: 'type',
  1363. slot: 'type',
  1364. headerSlot: 'isRequired',
  1365. minWidth: 120,
  1366. align: 'center'
  1367. },
  1368. {
  1369. label: '证照编号',
  1370. prop: 'code',
  1371. slot: 'code',
  1372. headerSlot: 'isRequired',
  1373. minWidth: 120,
  1374. align: 'center'
  1375. },
  1376. {
  1377. label: '等级',
  1378. prop: 'level',
  1379. slot: 'level',
  1380. minWidth: 120,
  1381. align: 'center'
  1382. },
  1383. {
  1384. label: '有效期开始时间',
  1385. prop: 'validityStartTime',
  1386. slot: 'validityStartTime',
  1387. headerSlot: 'isRequired',
  1388. minWidth: 150,
  1389. align: 'center'
  1390. },
  1391. {
  1392. label: '有效期结束时间',
  1393. prop: 'validityEndTime',
  1394. slot: 'validityEndTime',
  1395. headerSlot: 'isRequired',
  1396. minWidth: 150,
  1397. align: 'center'
  1398. },
  1399. {
  1400. label: '颁布日期',
  1401. prop: 'enactorTime',
  1402. slot: 'enactorTime',
  1403. minWidth: 150,
  1404. align: 'center'
  1405. },
  1406. {
  1407. label: '证照附件',
  1408. prop: 'fileObj',
  1409. slot: 'fileObj',
  1410. minWidth: 200,
  1411. align: 'center'
  1412. },
  1413. {
  1414. label: '状态',
  1415. prop: 'status',
  1416. slot: 'status',
  1417. headerSlot: 'isRequired',
  1418. minWidth: 100,
  1419. align: 'center'
  1420. },
  1421. {
  1422. label: '备注',
  1423. prop: 'remark',
  1424. slot: 'remark',
  1425. minWidth: 120,
  1426. align: 'center'
  1427. },
  1428. {
  1429. action: 'action',
  1430. slot: 'action',
  1431. label: '操作',
  1432. align: 'center'
  1433. }
  1434. ];
  1435. },
  1436. skillsColumns() {
  1437. return [
  1438. {
  1439. label: '序号',
  1440. type: 'index',
  1441. width: 55,
  1442. align: 'center'
  1443. },
  1444. {
  1445. label: '分类',
  1446. prop: 'categoryLevelId',
  1447. slot: 'categoryLevelId',
  1448. minWidth: 120,
  1449. align: 'center'
  1450. },
  1451. {
  1452. label: '技能名称',
  1453. prop: 'name',
  1454. slot: 'name',
  1455. headerSlot: 'isRequired',
  1456. minWidth: 120,
  1457. align: 'center'
  1458. },
  1459. {
  1460. label: '技能等级',
  1461. prop: 'level',
  1462. slot: 'level',
  1463. minWidth: 130,
  1464. align: 'center'
  1465. },
  1466. {
  1467. label: '技能经验(年限)',
  1468. prop: 'years',
  1469. slot: 'years',
  1470. minWidth: 130,
  1471. align: 'center'
  1472. },
  1473. {
  1474. label: '证照附件',
  1475. prop: 'fileAttach',
  1476. slot: 'fileAttach',
  1477. minWidth: 130,
  1478. align: 'center'
  1479. },
  1480. {
  1481. label: '备注',
  1482. prop: 'remark',
  1483. slot: 'remark',
  1484. minWidth: 120,
  1485. align: 'center'
  1486. },
  1487. {
  1488. action: 'action',
  1489. slot: 'action',
  1490. label: '操作',
  1491. align: 'center'
  1492. }
  1493. ];
  1494. },
  1495. RPRecordsColumns() {
  1496. return [
  1497. {
  1498. label: '序号',
  1499. type: 'index',
  1500. width: 55,
  1501. align: 'center'
  1502. },
  1503. {
  1504. label: '奖惩类型',
  1505. prop: 'type',
  1506. slot: 'type',
  1507. headerSlot: 'isRequired',
  1508. minWidth: 120,
  1509. align: 'center'
  1510. },
  1511. {
  1512. label: '奖惩说明',
  1513. prop: 'desce',
  1514. slot: 'desce',
  1515. minWidth: 120,
  1516. align: 'center'
  1517. },
  1518. {
  1519. label: '开始时间',
  1520. prop: 'startTime',
  1521. slot: 'startTime',
  1522. headerSlot: 'isRequired',
  1523. minWidth: 130,
  1524. align: 'center'
  1525. },
  1526. {
  1527. label: '结束时间',
  1528. prop: 'endTime',
  1529. slot: 'endTime',
  1530. headerSlot: 'isRequired',
  1531. minWidth: 130,
  1532. align: 'center'
  1533. },
  1534. {
  1535. label: '证照附件',
  1536. prop: 'fileAttach',
  1537. slot: 'fileAttach',
  1538. minWidth: 130,
  1539. align: 'center'
  1540. },
  1541. {
  1542. label: '生效状态',
  1543. prop: 'status',
  1544. slot: 'status',
  1545. headerSlot: 'isRequired',
  1546. minWidth: 120,
  1547. align: 'center'
  1548. },
  1549. {
  1550. label: '备注',
  1551. prop: 'remark',
  1552. slot: 'remark',
  1553. minWidth: 120,
  1554. align: 'center'
  1555. },
  1556. {
  1557. action: 'action',
  1558. slot: 'action',
  1559. label: '操作',
  1560. align: 'center'
  1561. }
  1562. ];
  1563. },
  1564. trainingColumns() {
  1565. return [
  1566. {
  1567. label: '序号',
  1568. type: 'index',
  1569. width: 55,
  1570. align: 'center'
  1571. },
  1572. {
  1573. label: '分类',
  1574. prop: 'categoryLevelId',
  1575. slot: 'categoryLevelId',
  1576. minWidth: 120,
  1577. align: 'center'
  1578. },
  1579. {
  1580. label: '培训标题',
  1581. prop: 'title',
  1582. slot: 'title',
  1583. headerSlot: 'isRequired',
  1584. minWidth: 120,
  1585. align: 'center'
  1586. },
  1587. {
  1588. label: '培训说明',
  1589. prop: 'desce',
  1590. slot: 'desce',
  1591. minWidth: 120,
  1592. align: 'center'
  1593. },
  1594. {
  1595. label: '开始时间',
  1596. prop: 'startTime',
  1597. slot: 'startTime',
  1598. headerSlot: 'isRequired',
  1599. minWidth: 130,
  1600. align: 'center'
  1601. },
  1602. {
  1603. label: '结束时间',
  1604. prop: 'endTime',
  1605. slot: 'endTime',
  1606. headerSlot: 'isRequired',
  1607. minWidth: 130,
  1608. align: 'center'
  1609. },
  1610. {
  1611. label: '附件',
  1612. prop: 'fileAttach',
  1613. slot: 'fileAttach',
  1614. minWidth: 130,
  1615. align: 'center'
  1616. },
  1617. {
  1618. label: '生效状态',
  1619. prop: 'status',
  1620. slot: 'status',
  1621. headerSlot: 'isRequired',
  1622. minWidth: 120,
  1623. align: 'center'
  1624. },
  1625. {
  1626. label: '备注',
  1627. prop: 'remark',
  1628. slot: 'remark',
  1629. minWidth: 120,
  1630. align: 'center'
  1631. },
  1632. {
  1633. action: 'action',
  1634. slot: 'action',
  1635. label: '操作',
  1636. align: 'center'
  1637. }
  1638. ];
  1639. },
  1640. attendanceColumns() {
  1641. return [
  1642. {
  1643. label: '序号',
  1644. type: 'index',
  1645. width: 55,
  1646. align: 'center'
  1647. },
  1648. {
  1649. label: '考勤类型',
  1650. prop: 'type',
  1651. slot: 'type',
  1652. headerSlot: 'isRequired',
  1653. minWidth: 120,
  1654. align: 'center'
  1655. },
  1656. {
  1657. label: '签到时间',
  1658. prop: 'checkTime',
  1659. slot: 'checkTime',
  1660. headerSlot: 'isRequired',
  1661. minWidth: 120,
  1662. align: 'center'
  1663. },
  1664. // {
  1665. // label: '迟到时间偏差值',
  1666. // prop: 'belateTime',
  1667. // minWidth: 120,
  1668. // align: "center"
  1669. // },
  1670. // {
  1671. // label: '早退时间偏差值',
  1672. // prop: 'leaveEarlyTime',
  1673. // minWidth: 130,
  1674. // align: "center"
  1675. // },
  1676. {
  1677. label: '附件',
  1678. prop: 'fileAttach',
  1679. slot: 'fileAttach',
  1680. minWidth: 130,
  1681. align: 'center'
  1682. },
  1683. {
  1684. action: 'action',
  1685. slot: 'action',
  1686. label: '操作',
  1687. align: 'center'
  1688. }
  1689. ];
  1690. },
  1691. contractsColumns() {
  1692. return [
  1693. {
  1694. label: '序号',
  1695. type: 'index',
  1696. width: 55,
  1697. align: 'center'
  1698. },
  1699. {
  1700. label: '分类',
  1701. prop: 'categoryLevelId',
  1702. slot: 'categoryLevelId',
  1703. minWidth: 120,
  1704. align: 'center'
  1705. },
  1706. {
  1707. label: '合同名称',
  1708. prop: 'name',
  1709. slot: 'name',
  1710. headerSlot: 'isRequired',
  1711. minWidth: 120,
  1712. align: 'center'
  1713. },
  1714. {
  1715. label: '签订时间',
  1716. prop: 'signTime',
  1717. slot: 'startTime',
  1718. headerSlot: 'isRequired',
  1719. minWidth: 130,
  1720. align: 'center'
  1721. },
  1722. {
  1723. label: '开始时间',
  1724. prop: 'startTime',
  1725. slot: 'startTime',
  1726. headerSlot: 'isRequired',
  1727. minWidth: 130,
  1728. align: 'center'
  1729. },
  1730. {
  1731. label: '结束时间',
  1732. prop: 'endTime',
  1733. slot: 'endTime',
  1734. headerSlot: 'isRequired',
  1735. minWidth: 130,
  1736. align: 'center'
  1737. },
  1738. {
  1739. label: '合同附件',
  1740. prop: 'fileAttach',
  1741. slot: 'fileAttach',
  1742. minWidth: 130,
  1743. align: 'center'
  1744. },
  1745. {
  1746. label: '生效状态',
  1747. prop: 'status',
  1748. slot: 'status',
  1749. headerSlot: 'isRequired',
  1750. minWidth: 120,
  1751. align: 'center'
  1752. },
  1753. {
  1754. label: '备注',
  1755. prop: 'remark',
  1756. slot: 'remark',
  1757. minWidth: 120,
  1758. align: 'center'
  1759. },
  1760. {
  1761. action: 'action',
  1762. slot: 'action',
  1763. label: '操作',
  1764. align: 'center'
  1765. }
  1766. ];
  1767. },
  1768. jobColumns() {
  1769. return [
  1770. {
  1771. label: '序号',
  1772. type: 'index',
  1773. width: 55,
  1774. align: 'center'
  1775. },
  1776. {
  1777. slot: 'type',
  1778. label: '类型',
  1779. showOverflowTooltip: true,
  1780. align: 'center',
  1781. minWidth: 110,
  1782. formatter: (_row) => {
  1783. return this.getDictValue('工种类型', _row.type);
  1784. }
  1785. },
  1786. {
  1787. align: 'center',
  1788. prop: 'code',
  1789. label: '编码',
  1790. showOverflowTooltip: true,
  1791. minWidth: 110
  1792. },
  1793. {
  1794. slot: 'name',
  1795. prop: 'name',
  1796. label: '名称',
  1797. showOverflowTooltip: true,
  1798. align: 'center',
  1799. minWidth: 110
  1800. },
  1801. {
  1802. slot: 'level',
  1803. prop: 'level',
  1804. label: '等级',
  1805. showOverflowTooltip: true,
  1806. align: 'center',
  1807. minWidth: 110,
  1808. formatter: (_row) => {
  1809. return this.levelOptions.filter(
  1810. (item) => _row.level == item.value
  1811. )[0].label;
  1812. }
  1813. },
  1814. {
  1815. slot: 'hourCost',
  1816. prop: 'hourCost',
  1817. label: '标准工时费',
  1818. showOverflowTooltip: true,
  1819. align: 'center',
  1820. minWidth: 110
  1821. },
  1822. {
  1823. slot: 'unit',
  1824. prop: 'unit',
  1825. label: '工时费单位',
  1826. showOverflowTooltip: true,
  1827. align: 'center',
  1828. minWidth: 110
  1829. },
  1830. {
  1831. columnKey: 'action',
  1832. label: '操作',
  1833. width: 260,
  1834. align: 'center',
  1835. resizable: false,
  1836. slot: 'action',
  1837. showOverflowTooltip: true
  1838. }
  1839. ];
  1840. }
  1841. },
  1842. created() {
  1843. this.getFactoryList();
  1844. console.log(this.institutionList, '========');
  1845. this.getProfessionList();
  1846. },
  1847. methods: {
  1848. chooseAptitude(data) {
  1849. console.log(data);
  1850. this.form.professions.push(...data);
  1851. },
  1852. deleteJob(index) {
  1853. this.form.professions.splice(index, 1);
  1854. },
  1855. idCardChange() {
  1856. // 检查身份证号是否为18位
  1857. if (this.form.idCard.length === 18) {
  1858. // 提取出生日期部分(YYYYMMDD)并转换为YYYY-MM-DD格式
  1859. const birthDatePart = this.form.idCard.substr(6, 8); // 获取YYYYMMDD部分
  1860. const year = birthDatePart.substr(0, 4); // 年份
  1861. const month = birthDatePart.substr(4, 2); // 月份
  1862. const day = birthDatePart.substr(6, 2); // 日期
  1863. this.form.birthday = `${year}-${month}-${day}`; // 格式化日期并存储到data中
  1864. const birthDate = new Date(year, month - 1, day); // 月份是从0开始的,所以要减1
  1865. const now = new Date();
  1866. this.form.age = now.getFullYear() - birthDate.getFullYear();
  1867. const monthDifference = now.getMonth() - birthDate.getMonth();
  1868. if (
  1869. monthDifference < 0 ||
  1870. (monthDifference === 0 && now.getDate() < birthDate.getDate())
  1871. ) {
  1872. this.form.age--;
  1873. }
  1874. }
  1875. },
  1876. async getProfessionList() {
  1877. const res = await getProfessionPageList({
  1878. pageNum: 1,
  1879. size: 9999
  1880. });
  1881. this.professionList = res.list || [];
  1882. },
  1883. setList(list) {
  1884. return list.map((val) => {
  1885. val['disabled'] = val.id == this.form.groupId;
  1886. if (val.children) {
  1887. val.children = this.setList(val.children);
  1888. }
  1889. return val;
  1890. });
  1891. },
  1892. addIdentityPhotos() {
  1893. this.form.identityPhotos.push({
  1894. holder: this.form.name,
  1895. holderType: '1'
  1896. });
  1897. },
  1898. handleIdentityPhotosDel(row, index) {
  1899. this.form.identityPhotos.splice(index, 1);
  1900. },
  1901. addSkills() {
  1902. this.form.skills.push({});
  1903. },
  1904. handleSkillsDel(row, index) {
  1905. this.form.skills.splice(index, 1);
  1906. },
  1907. addRPRecords() {
  1908. this.form.rewardsPunishments.push({});
  1909. },
  1910. handleRPRecordsDel(row, index) {
  1911. this.form.rewardsPunishments.splice(index, 1);
  1912. },
  1913. addTraining() {
  1914. this.form.trainRecords.push({});
  1915. },
  1916. handleTrainingDel(row, index) {
  1917. this.form.trainRecords.splice(index, 1);
  1918. },
  1919. addAttendance() {
  1920. this.form.attendanceRecords.push({});
  1921. },
  1922. handleAttendanceDel(row, index) {
  1923. this.form.attendanceRecords.splice(index, 1);
  1924. },
  1925. addcontracts() {
  1926. this.form.contracts.push({});
  1927. },
  1928. handleContractsDel(row, index) {
  1929. this.form.contracts.splice(index, 1);
  1930. },
  1931. getAccountList() {
  1932. getNotBoundAccount().then((res) => {
  1933. this.accountList = res;
  1934. });
  1935. },
  1936. setDisabled(disabled) {
  1937. this.disabled = disabled;
  1938. this.getProfessionList();
  1939. },
  1940. async getFactoryList() {
  1941. const { list } = await getFactoryarea({
  1942. pageNum: 1,
  1943. size: 999,
  1944. type: 1
  1945. });
  1946. this.factoryList = list || [];
  1947. },
  1948. /* 保存编辑 */
  1949. save() {
  1950. this.$refs.form.validate((valid) => {
  1951. if (!valid) {
  1952. return false;
  1953. }
  1954. this.loading = true;
  1955. this.form.addressId = this.city
  1956. ? this.city[this.city.length - 1]
  1957. : '';
  1958. // if (this.deptTree.length > 0) {
  1959. // this.deptTree.forEach(i => {
  1960. // this.form.deptIds.push(i[i.length - 1])
  1961. // })
  1962. //
  1963. // this.form['deptTree'] = JSON.stringify(this.deptTree)
  1964. // }
  1965. let formData = JSON.parse(JSON.stringify(this.form));
  1966. if (formData.postId) {
  1967. formData.postName = formData.postId
  1968. .map((item) => this.getDictValue('岗位', item))
  1969. .toString();
  1970. formData.postId = formData.postId.toString();
  1971. }
  1972. if (formData.professions?.length) {
  1973. formData.professionId = formData.professions.map(item=>item.id).toString();
  1974. }
  1975. const data = {
  1976. ...formData
  1977. };
  1978. if (!this.isUpdate) {
  1979. delete data.id;
  1980. }
  1981. if (!Array.isArray(data.signature)) {
  1982. data.signature = [data.signature].filter(
  1983. (item) => Boolean(item) && Object.keys(item).length !== 0
  1984. );
  1985. }
  1986. saveOrUpdateUser(data)
  1987. .then((msg) => {
  1988. this.loading = false;
  1989. if (this.isUpdate) {
  1990. this.$message.success('人员信息编辑成功');
  1991. } else {
  1992. this.$message.success('人员新增成功');
  1993. }
  1994. this.updateVisible(false);
  1995. this.$emit('done');
  1996. })
  1997. .catch((e) => {
  1998. this.loading = false;
  1999. // this.$message.error(e.message);
  2000. });
  2001. });
  2002. },
  2003. /* 更新visible */
  2004. updateVisible(value) {
  2005. this.$emit('update:visible', value);
  2006. },
  2007. handleChange() {
  2008. let arr = Array.from(this.$refs.deptRef.getCheckedNodes());
  2009. this.form.deptName = arr.map((i) => i.label).join('/') || '';
  2010. this.form.deptIds = this.form.deptIds || [];
  2011. },
  2012. checkedKeys(value) {
  2013. this.getLabelName(this.institutionList, (i) => {
  2014. if (i.id == this.form.groupId) {
  2015. return (this.form.groupName = i.name);
  2016. }
  2017. });
  2018. this.form.deptIds = this.form.deptIds.filter(
  2019. (item) => item != this.form.groupId
  2020. );
  2021. console.log(this.form.groupName);
  2022. },
  2023. getLabelName(data, callback) {
  2024. data.some((i) => {
  2025. callback(i);
  2026. if (i.children) {
  2027. this.getLabelName(i.children, callback);
  2028. }
  2029. });
  2030. }
  2031. },
  2032. watch: {
  2033. visible(visible) {
  2034. if (visible) {
  2035. this.getAccountList();
  2036. if (this.data) {
  2037. getUserDetail(this.data.id).then((res) => {
  2038. if (res.postId) {
  2039. res.postId = res.postId.split(',');
  2040. }
  2041. this.form = { ...res };
  2042. if (Array.isArray(this.form.signature)) {
  2043. this.form.signature = this.form.signature[0];
  2044. }
  2045. // this.deptTree = []
  2046. // this.form.deptIds = []
  2047. // if (this.form.deptTree) {
  2048. // this.deptTree = JSON.parse(this.form.deptTree)
  2049. // }
  2050. // this.form.workTypeId = this.form.workTypeId + '';
  2051. // this.form.postName = this.form.postName + '';
  2052. this.city = res.addressId ? res.addressId.toString() : null;
  2053. this.isUpdate = true;
  2054. });
  2055. // this.$util.assignObject(this.form, {
  2056. // ...this.data,
  2057. // password: ''
  2058. // });
  2059. // this.form = {...this.data}
  2060. // this.form.address = ["130000","130300","130304"]
  2061. // this.form.address = "130304"
  2062. // console.log('this.form',this.form)
  2063. } else {
  2064. this.city = null;
  2065. this.form.groupId = this.organizationId;
  2066. this.isUpdate = false;
  2067. }
  2068. } else {
  2069. this.city = null;
  2070. this.$refs.form.clearValidate();
  2071. this.form = { ...this.defaultForm };
  2072. }
  2073. }
  2074. }
  2075. };
  2076. </script>
  2077. <style scoped lang="scss">
  2078. ::v-deep .el-tabs__header {
  2079. margin-bottom: 10px;
  2080. }
  2081. </style>