editUser.vue 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  1. <template>
  2. <div class="sys-user-container">
  3. <el-dialog v-model="isShowDialog" width="769px">
  4. <template #header>
  5. <div style="font-size: large" v-drag="['.el-dialog','.el-dialog__header']">
  6. {{ title }}
  7. </div>
  8. </template>
  9. <el-form :model="ruleForm" :rules="ruleRules" ref="ruleFormRef" size="default" label-width="80px">
  10. <el-row :gutter="35">
  11. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  12. <el-form-item label="账号名称" prop="userName">
  13. <el-input v-model="ruleForm.userName" placeholder="账号名称" clearable></el-input>
  14. </el-form-item>
  15. </el-col>
  16. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  17. <el-form-item label="手机号码" prop="phone">
  18. <el-input v-model="ruleForm.phone" placeholder="手机号码" clearable></el-input>
  19. </el-form-item>
  20. </el-col>
  21. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  22. <el-form-item label="真实姓名" prop="realName">
  23. <el-input v-model="ruleForm.realName" placeholder="真实姓名" clearable></el-input>
  24. </el-form-item>
  25. </el-col>
  26. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  27. <el-form-item label="昵称" prop="nickName">
  28. <el-input v-model="ruleForm.nickName" placeholder="昵称" clearable></el-input>
  29. </el-form-item>
  30. </el-col>
  31. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  32. <el-form-item label="出生日期" prop="birthday">
  33. <el-date-picker v-model="ruleForm.birthday" type="date" placeholder="出生日期"
  34. format="YYYY-MM-DD" value-format="YYYY-MM-DD" style="width: 100%" />
  35. </el-form-item>
  36. </el-col>
  37. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  38. <el-form-item label="性别" prop="sex">
  39. <el-radio-group v-model="ruleForm.sex">
  40. <el-radio :label="1">男</el-radio>
  41. <el-radio :label="2">女</el-radio>
  42. </el-radio-group>
  43. </el-form-item>
  44. </el-col>
  45. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  46. <el-form-item label="证件号码" prop="idCard">
  47. <el-input v-model="ruleForm.idCard" placeholder="证件号码" clearable></el-input>
  48. </el-form-item>
  49. </el-col>
  50. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  51. <el-form-item label="邮箱" prop="email">
  52. <el-input v-model="ruleForm.email" placeholder="邮箱" clearable></el-input>
  53. </el-form-item>
  54. </el-col>
  55. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb5">
  56. <el-form-item label="排序">
  57. <el-input-number v-model="ruleForm.order" controls-position="right" placeholder="排序"
  58. class="w100" />
  59. </el-form-item>
  60. </el-col>
  61. <el-divider border-style="dashed" content-position="center">
  62. <div style="color: #b1b3b8">其他</div>
  63. </el-divider>
  64. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  65. <el-form-item label="所属机构">
  66. <el-cascader :options="orgData" :props="{ checkStrictly: true, value: 'id', label: 'name' }"
  67. placeholder="所属机构" clearable class="w100" v-model="ruleForm.orgId">
  68. <template #default="{ node, data }">
  69. <span>{{ data.name }}</span>
  70. <span v-if="!node.isLeaf"> ({{ data.children.length }}) </span>
  71. </template>
  72. </el-cascader>
  73. </el-form-item>
  74. </el-col>
  75. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  76. <el-form-item label="职位" prop="posId">
  77. <el-select v-model="ruleForm.posId" placeholder="职位" style="width: 100%">
  78. <el-option v-for="d in posData" :key="d.id" :label="d.name" :value="d.id" />
  79. </el-select>
  80. </el-form-item>
  81. </el-col>
  82. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  83. <el-form-item label="工号" prop="jobNum">
  84. <el-input v-model="ruleForm.jobNum" placeholder="所属机构" clearable></el-input>
  85. </el-form-item>
  86. </el-col>
  87. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class="mb20">
  88. <el-form-item label="岗位状态" prop="jobStatus">
  89. <el-select v-model="ruleForm.jobStatus" placeholder="岗位状态" style="width: 100%">
  90. <el-option v-for="dict in jobStatusType" :key="dict.value" :label="dict.label"
  91. :value="dict.value" />
  92. </el-select>
  93. </el-form-item>
  94. </el-col>
  95. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" class="mb20">
  96. <el-form-item label="个性签名" prop="signature">
  97. <el-input v-model="ruleForm.signature" placeholder="个性签名" clearable></el-input>
  98. </el-form-item>
  99. </el-col>
  100. <!-- <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" class="mb20">
  101. <el-form-item label="本人简介" prop="introduction">
  102. <el-input v-model="ruleForm.introduction" placeholder="本人简介" clearable></el-input>
  103. </el-form-item>
  104. </el-col> -->
  105. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" class="mb20">
  106. <el-form-item label="备注">
  107. <el-input v-model="ruleForm.remark" placeholder="请输入备注内容" clearable type="textarea">
  108. </el-input>
  109. </el-form-item>
  110. </el-col>
  111. </el-row>
  112. </el-form>
  113. <template #footer>
  114. <span class="dialog-footer">
  115. <el-button @click="cancel" size="default">取 消</el-button>
  116. <el-button type="primary" @click="submit" size="default">确 定</el-button>
  117. </span>
  118. </template>
  119. </el-dialog>
  120. </div>
  121. </template>
  122. <script lang="ts">
  123. import { reactive, toRefs, defineComponent, getCurrentInstance, ref, unref, onMounted } from 'vue';
  124. import { getAPI } from '/@/utils/axios-utils';
  125. import { SysPosApi, SysUserApi } from '/@/api-services/api';
  126. export default defineComponent({
  127. name: 'sysEditUser',
  128. components: {},
  129. props: {
  130. // 弹窗标题
  131. title: {
  132. type: String,
  133. default: () => "",
  134. },
  135. // 机构数据
  136. orgData: {
  137. type: Array,
  138. default: () => [],
  139. }
  140. },
  141. setup() {
  142. const { proxy } = getCurrentInstance() as any;
  143. const ruleFormRef = ref<HTMLElement | null>(null);
  144. const state = reactive({
  145. isShowDialog: false,
  146. ruleForm: {
  147. id: 0,
  148. userName: '',
  149. nickName: '',
  150. realName: '',
  151. birthday: undefined,
  152. sex: 1,
  153. phone: '',
  154. idCard: '',
  155. email: '',
  156. orgId: 0,
  157. posId: 0,
  158. jobNum: '',
  159. jobStatus: 1,
  160. signature: '',
  161. introduction: '',
  162. order: 10, // 排序
  163. remark: '', // 备注
  164. },
  165. jobStatusType: [{ value: 1, label: "在职" }, { value: 2, label: "离职" }, { value: 3, label: "请假" }], // 岗位状态
  166. posData: [] as any, // 职位数据
  167. ruleRules: {
  168. userName: [{ required: true, message: "账号名称不能为空", trigger: "blur" }],
  169. phone: [{ required: true, message: "手机号码不能为空", trigger: "blur" }],
  170. realName: [{ required: true, message: "真实姓名不能为空", trigger: "blur" }],
  171. },
  172. });
  173. onMounted(async () => {
  174. var res = await getAPI(SysPosApi).sysPosListGet();
  175. state.posData = res.data.result;
  176. });
  177. // 打开弹窗
  178. const openDialog = (row: any) => {
  179. state.ruleForm = row;
  180. state.isShowDialog = true;
  181. };
  182. // 关闭弹窗
  183. const closeDialog = () => {
  184. proxy.mittBus.emit("submitRefresh");
  185. state.isShowDialog = false;
  186. };
  187. // 取消
  188. const cancel = () => {
  189. state.isShowDialog = false;
  190. };
  191. // 提交
  192. const submit = () => {
  193. const formWrap = unref(ruleFormRef) as any;
  194. if (!formWrap) return;
  195. // 取父节点Id
  196. if (Array.isArray(state.ruleForm.orgId))
  197. state.ruleForm.orgId = state.ruleForm.orgId[state.ruleForm.orgId.length - 1];
  198. formWrap.validate(async () => {
  199. if (state.ruleForm.id != undefined && state.ruleForm.id > 0) {
  200. await getAPI(SysUserApi).sysUserUpdatePost(state.ruleForm);
  201. }
  202. else {
  203. await getAPI(SysUserApi).sysUserAddPost(state.ruleForm);
  204. }
  205. closeDialog();
  206. })
  207. };
  208. return {
  209. ruleFormRef,
  210. openDialog,
  211. closeDialog,
  212. cancel,
  213. submit,
  214. ...toRefs(state),
  215. };
  216. },
  217. });
  218. </script>