editUser.vue 14 KB

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