editUser.vue 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313
  1. <template>
  2. <div class="sys-user-container">
  3. <el-dialog v-model="state.isShowDialog" draggable :close-on-click-modal="false" width="769px">
  4. <template #header>
  5. <div style="color: #fff">
  6. <el-icon size="16" style="margin-right: 3px; display: inline; vertical-align: middle"> <ele-Edit /> </el-icon>
  7. <span>{{ props.title }}</span>
  8. </div>
  9. </template>
  10. <el-tabs v-loading="state.loading">
  11. <el-tab-pane label="基础信息">
  12. <el-form :model="state.ruleForm" ref="ruleFormRef" size="default" label-width="100px">
  13. <el-row :gutter="35">
  14. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  15. <el-form-item label="账号名称" prop="account" :rules="[{ required: true, message: '账号名称不能为空', trigger: 'blur' }]">
  16. <el-input v-model="state.ruleForm.account" placeholder="账号名称" clearable />
  17. </el-form-item>
  18. </el-col>
  19. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  20. <el-form-item label="真实姓名" prop="realName" :rules="[{ required: true, message: '真实姓名不能为空', trigger: 'blur' }]">
  21. <el-input v-model="state.ruleForm.realName" placeholder="真实姓名" clearable />
  22. </el-form-item>
  23. </el-col>
  24. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  25. <el-form-item label="昵称" prop="nickName">
  26. <el-input v-model="state.ruleForm.nickName" placeholder="昵称" clearable />
  27. </el-form-item>
  28. </el-col>
  29. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  30. <el-form-item label="手机号码" prop="phone" :rules="[{ required: true, message: '手机号码不能为空', trigger: 'blur' }]">
  31. <el-input v-model="state.ruleForm.phone" placeholder="手机号码" clearable />
  32. </el-form-item>
  33. </el-col>
  34. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  35. <el-form-item label="出生日期" prop="birthday" :rules="[{ required: true, message: '出生日期不能为空', trigger: 'blur' }]">
  36. <el-date-picker v-model="state.ruleForm.birthday" type="date" placeholder="出生日期" format="YYYY-MM-DD" value-format="YYYY-MM-DD" style="width: 100%" />
  37. </el-form-item>
  38. </el-col>
  39. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  40. <el-form-item label="性别" prop="sex">
  41. <el-radio-group v-model="state.ruleForm.sex">
  42. <el-radio :label="1">男</el-radio>
  43. <el-radio :label="2">女</el-radio>
  44. </el-radio-group>
  45. </el-form-item>
  46. </el-col>
  47. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
  48. <el-form-item label="角色" prop="roleIdList" :rules="[{ required: true, message: '角色集合不能为空', trigger: 'blur' }]">
  49. <el-select v-model="state.ruleForm.roleIdList" multiple value-key="id" clearable placeholder="角色集合" collapse-tags collapse-tags-tooltip class="w100" filterable>
  50. <el-option v-for="item in state.roleData" :key="item.id" :label="item.name" :value="item.id" />
  51. </el-select>
  52. </el-form-item>
  53. </el-col>
  54. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb5">
  55. <el-form-item label="排序">
  56. <el-input-number v-model="state.ruleForm.orderNo" placeholder="排序" class="w100" />
  57. </el-form-item>
  58. </el-col>
  59. <el-divider border-style="dashed" content-position="center">
  60. <div style="color: #b1b3b8">机构组织</div>
  61. </el-divider>
  62. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  63. <el-form-item label="所属机构" prop="orgId" :rules="[{ required: true, message: '所属机构不能为空', trigger: 'blur' }]">
  64. <el-cascader :options="props.orgData" :props="{ checkStrictly: true, emitPath: false, value: 'id', label: 'name' }" placeholder="所属机构" clearable class="w100" v-model="state.ruleForm.orgId">
  65. <template #default="{ node, data }">
  66. <span>{{ data.name }}</span>
  67. <span v-if="!node.isLeaf"> ({{ data.children.length }}) </span>
  68. </template>
  69. </el-cascader>
  70. </el-form-item>
  71. </el-col>
  72. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  73. <el-form-item label="职位" prop="posId" :rules="[{ required: true, message: '职位名称不能为空', trigger: 'blur' }]">
  74. <el-select v-model="state.ruleForm.posId" placeholder="职位" style="width: 100%">
  75. <el-option v-for="d in state.posData" :key="d.id" :label="d.name" :value="d.id" />
  76. </el-select>
  77. </el-form-item>
  78. </el-col>
  79. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  80. <el-form-item label="工号" prop="jobNum">
  81. <el-input v-model="state.ruleForm.jobNum" placeholder="工号" clearable />
  82. </el-form-item>
  83. </el-col>
  84. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  85. <el-form-item label="入职日期" prop="joinDate">
  86. <el-date-picker v-model="state.ruleForm.joinDate" type="date" placeholder="入职日期" format="YYYY-MM-DD" value-format="YYYY-MM-DD" style="width: 100%" />
  87. </el-form-item>
  88. </el-col>
  89. <el-divider border-style="dashed" content-position="center">
  90. <div style="color: #b1b3b8">附属机构</div>
  91. </el-divider>
  92. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" class="mb20">
  93. <el-button icon="ele-Plus" type="primary" plain @click="addExtOrgRow"> 增加附属机构 </el-button>
  94. <span style="font-size: 12px; color: gray; padding-left: 5px"> 具有相应组织机构的数据权限 </span>
  95. </el-col>
  96. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" class="mb20">
  97. <template v-if="state.ruleForm.extOrgIdList != undefined && state.ruleForm.extOrgIdList.length > 0">
  98. <el-row :gutter="35" v-for="(v, k) in state.ruleForm.extOrgIdList" :key="k">
  99. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  100. <el-form-item label="机构" :prop="`extOrgIdList[${k}].orgId`" :rules="[{ required: true, message: `机构不能为空`, trigger: 'blur' }]">
  101. <template #label>
  102. <el-button icon="ele-Delete" type="danger" circle plain size="small" @click="deleteExtOrgRow(k)" />
  103. <span class="ml5">机构</span>
  104. </template>
  105. <el-cascader
  106. :options="props.orgData"
  107. :props="{ checkStrictly: true, emitPath: false, value: 'id', label: 'name' }"
  108. placeholder="机构组织"
  109. clearable
  110. class="w100"
  111. v-model="state.ruleForm.extOrgIdList[k].orgId"
  112. >
  113. <template #default="{ node, data }">
  114. <span>{{ data.name }}</span>
  115. <span v-if="!node.isLeaf"> ({{ data.children.length }}) </span>
  116. </template>
  117. </el-cascader>
  118. </el-form-item>
  119. </el-col>
  120. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  121. <el-form-item label="职位" :prop="`extOrgIdList[${k}].posId`" :rules="[{ required: true, message: `职位不能为空`, trigger: 'blur' }]">
  122. <el-select v-model="state.ruleForm.extOrgIdList[k].posId" placeholder="职位名称" style="width: 100%">
  123. <el-option v-for="d in state.posData" :key="d.id" :label="d.name" :value="d.id" />
  124. </el-select>
  125. </el-form-item>
  126. </el-col>
  127. </el-row>
  128. </template>
  129. <el-empty description="空" v-else></el-empty>
  130. </el-col>
  131. </el-row>
  132. </el-form>
  133. </el-tab-pane>
  134. <el-tab-pane label="档案信息">
  135. <el-form :model="state.ruleForm" size="default" label-width="100px">
  136. <el-row :gutter="35">
  137. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  138. <el-form-item label="证件类型" prop="cardType">
  139. <el-select v-model="state.ruleForm.cardType" placeholder="证件类型" style="width: 100%">
  140. <el-option label="身份证" :value="0" />
  141. <el-option label="护照" :value="1" />
  142. <el-option label="出生证" :value="2" />
  143. <el-option label="港澳台通行证" :value="3" />
  144. <el-option label="外国人居留证" :value="4" />
  145. </el-select>
  146. </el-form-item>
  147. </el-col>
  148. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  149. <el-form-item label="证件号码" prop="idCardNum">
  150. <el-input v-model="state.ruleForm.idCardNum" placeholder="证件号码" clearable />
  151. </el-form-item>
  152. </el-col>
  153. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  154. <el-form-item label="民族" prop="nation">
  155. <el-input v-model="state.ruleForm.nation" placeholder="民族" clearable />
  156. </el-form-item>
  157. </el-col>
  158. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  159. <el-form-item label="邮箱" prop="email">
  160. <el-input v-model="state.ruleForm.email" placeholder="邮箱" clearable />
  161. </el-form-item>
  162. </el-col>
  163. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" class="mb20">
  164. <el-form-item label="地址" prop="nation">
  165. <el-input v-model="state.ruleForm.address" placeholder="地址" clearable type="textarea" />
  166. </el-form-item>
  167. </el-col>
  168. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  169. <el-form-item label="毕业学校" prop="college">
  170. <el-input v-model="state.ruleForm.college" placeholder="毕业学校" clearable />
  171. </el-form-item>
  172. </el-col>
  173. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  174. <el-form-item label="文化程度" prop="cultureLevel">
  175. <el-select v-model="state.ruleForm.cultureLevel" placeholder="文化程度" style="width: 100%">
  176. <el-option label="小学" :value="0" />
  177. <el-option label="初中" :value="1" />
  178. <el-option label="高中" :value="2" />
  179. <el-option label="中专" :value="3" />
  180. <el-option label="大专" :value="4" />
  181. <el-option label="本科" :value="5" />
  182. <el-option label="硕士研究生" :value="6" />
  183. <el-option label="博士研究生" :value="7" />
  184. </el-select>
  185. </el-form-item>
  186. </el-col>
  187. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  188. <el-form-item label="政治面貌" prop="politicalOutlook">
  189. <el-input v-model="state.ruleForm.politicalOutlook" placeholder="政治面貌" clearable />
  190. </el-form-item>
  191. </el-col>
  192. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  193. <el-form-item label="办公电话" prop="officePhone">
  194. <el-input v-model="state.ruleForm.officePhone" placeholder="办公电话" clearable />
  195. </el-form-item>
  196. </el-col>
  197. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  198. <el-form-item label="紧急联系人" prop="emergencyContact">
  199. <el-input v-model="state.ruleForm.emergencyContact" placeholder="紧急联系人" clearable />
  200. </el-form-item>
  201. </el-col>
  202. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  203. <el-form-item label="联系人电话" prop="emergencyPhone">
  204. <el-input v-model="state.ruleForm.emergencyPhone" placeholder="联系人电话" clearable />
  205. </el-form-item>
  206. </el-col>
  207. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" class="mb20">
  208. <el-form-item label="联系人地址" prop="emergencyAddress">
  209. <el-input v-model="state.ruleForm.emergencyAddress" placeholder="紧急联系人" clearable type="textarea" />
  210. </el-form-item>
  211. </el-col>
  212. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" class="mb20">
  213. <el-form-item label="备注" prop="remark">
  214. <el-input v-model="state.ruleForm.remark" placeholder="备注" clearable type="textarea" />
  215. </el-form-item>
  216. </el-col>
  217. </el-row>
  218. </el-form>
  219. </el-tab-pane>
  220. </el-tabs>
  221. <template #footer>
  222. <span class="dialog-footer">
  223. <el-button @click="cancel" size="default">取 消</el-button>
  224. <el-button type="primary" @click="submit" size="default">确 定</el-button>
  225. </span>
  226. </template>
  227. </el-dialog>
  228. </div>
  229. </template>
  230. <script lang="ts" setup name="sysEditUser">
  231. import { onMounted, reactive, ref } from 'vue';
  232. import mittBus from '/@/utils/mitt';
  233. import { getAPI } from '/@/utils/axios-utils';
  234. import { SysPosApi, SysRoleApi, SysUserApi } from '/@/api-services/api';
  235. import { RoleOutput, SysOrg, SysPos, UpdateUserInput } from '/@/api-services/models';
  236. const props = defineProps({
  237. title: String,
  238. orgData: Array<SysOrg>,
  239. });
  240. const ruleFormRef = ref();
  241. const state = reactive({
  242. loading: false,
  243. isShowDialog: false,
  244. ruleForm: {} as UpdateUserInput,
  245. posData: [] as Array<SysPos>, // 职位数据
  246. roleData: [] as Array<RoleOutput>, // 角色数据
  247. });
  248. onMounted(async () => {
  249. state.loading = true;
  250. var res = await getAPI(SysPosApi).apiSysPosListGet();
  251. state.posData = res.data.result ?? [];
  252. var res1 = await getAPI(SysRoleApi).apiSysRoleListGet();
  253. state.roleData = res1.data.result ?? [];
  254. state.loading = false;
  255. });
  256. // 打开弹窗
  257. const openDialog = async (row: any) => {
  258. state.ruleForm = JSON.parse(JSON.stringify(row));
  259. if (JSON.stringify(row) !== '{}') {
  260. var resRole = await getAPI(SysUserApi).apiSysUserOwnRoleListUserIdGet(row.id);
  261. state.ruleForm.roleIdList = resRole.data.result;
  262. var resExtOrg = await getAPI(SysUserApi).apiSysUserExtOrgListUserIdGet(row.id);
  263. state.ruleForm.extOrgIdList = resExtOrg.data.result;
  264. state.isShowDialog = true;
  265. } else state.isShowDialog = true;
  266. };
  267. // 关闭弹窗
  268. const closeDialog = () => {
  269. mittBus.emit('submitRefresh');
  270. state.isShowDialog = false;
  271. };
  272. // 取消
  273. const cancel = () => {
  274. state.isShowDialog = false;
  275. };
  276. // 提交
  277. const submit = () => {
  278. ruleFormRef.value.validate(async (valid: boolean) => {
  279. if (!valid) return;
  280. if (state.ruleForm.id != undefined && state.ruleForm.id > 0) {
  281. await getAPI(SysUserApi).apiSysUserUpdatePut(state.ruleForm);
  282. } else {
  283. await getAPI(SysUserApi).apiSysUserAddPost(state.ruleForm);
  284. }
  285. closeDialog();
  286. });
  287. };
  288. // 增加附属机构行
  289. const addExtOrgRow = () => {
  290. if (state.ruleForm.extOrgIdList == undefined) state.ruleForm.extOrgIdList = [];
  291. state.ruleForm.extOrgIdList?.push({});
  292. };
  293. // 删除附属机构行
  294. const deleteExtOrgRow = (k: number) => {
  295. state.ruleForm.extOrgIdList?.splice(k, 1);
  296. };
  297. // 暴露给父组件的数据或对象
  298. defineExpose({
  299. openDialog,
  300. });
  301. </script>