detailsModal.vue 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258
  1. <template>
  2. <BasicModal
  3. v-bind="$attrs"
  4. @cancel="resetFields"
  5. @register="register"
  6. :title="title"
  7. @ok="handleOk"
  8. >
  9. <div class="pt-3px pr-3px">
  10. <BasicForm @register="registerForm" :model="model" />
  11. </div>
  12. </BasicModal>
  13. </template>
  14. <script lang="ts">
  15. import { defineComponent, ref } from 'vue';
  16. import { checkUserApi, saveApi, updateApi, roleLIstApi } from '/@/api/staff/list';
  17. import { BasicModal, useModalInner } from '/@/components/Modal';
  18. import { BasicForm, FormSchema, useForm } from '/@/components/Form/index';
  19. import { ListAllCompanyApi } from '/@/api/corporation/list';
  20. import { useI18n } from '/@/hooks/web/useI18n';
  21. import { useMessage } from '/@/hooks/web/useMessage';
  22. import { useUserStore } from '/@/store/modules/user';
  23. const { t } = useI18n();
  24. export default defineComponent({
  25. components: { BasicModal, BasicForm },
  26. props: {
  27. userData: { type: Object },
  28. },
  29. emits: ['ok'],
  30. setup(_, context) {
  31. const modelRef = ref({});
  32. const userStore = useUserStore();
  33. const { getCheckRole } = userStore;
  34. const schemas: FormSchema[] = [
  35. {
  36. field: 'phone',
  37. component: 'Input',
  38. label: '手机号',
  39. colProps: {
  40. span: 18,
  41. },
  42. // helpMessage: '手机号需在指房宝APP注册后才可新增',
  43. required: false,
  44. rules: [
  45. {
  46. required: true,
  47. // @ts-ignore
  48. validator: async (rule, value) => {
  49. var reg_tel =
  50. /^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])\d{8}$/;
  51. // var reg = /\S+@\S+\.\S+/;
  52. if (!value) {
  53. return Promise.reject(t('common.phone'));
  54. }
  55. if (!reg_tel.test(value)) {
  56. /* eslint-disable-next-line */
  57. return Promise.reject(t('common.phoneError'));
  58. }
  59. try {
  60. let res = await checkUserApi({ phone: value });
  61. console.log('res', res);
  62. if (res == true) {
  63. return Promise.resolve();
  64. } else {
  65. return Promise.reject('手机号未在指房宝APP中进行注册');
  66. }
  67. } catch (err) {
  68. return Promise.reject(err);
  69. }
  70. },
  71. trigger: 'change',
  72. },
  73. ],
  74. },
  75. {
  76. field: 'nickName',
  77. component: 'Input',
  78. label: '员工名称',
  79. colProps: {
  80. span: 22,
  81. },
  82. componentProps: {
  83. maxLength: 15,
  84. },
  85. rules: [
  86. {
  87. required: true,
  88. // @ts-ignore
  89. validator: async (rule, value) => {
  90. var reg_tel = /^[a-zA-Z0-9\u4e00-\u9fa5()]+$/;
  91. // var reg = /\S+@\S+\.\S+/;
  92. if (!value) {
  93. return Promise.reject('请输入员工名称');
  94. }
  95. if (!reg_tel.test(value)) {
  96. /* eslint-disable-next-line */
  97. return Promise.reject('请输入正确的员工名称');
  98. }
  99. return Promise.resolve();
  100. },
  101. trigger: 'change',
  102. },
  103. ],
  104. },
  105. {
  106. field: 'companyId',
  107. label: '公司',
  108. component: 'ApiSelect',
  109. itemProps: {
  110. validateTrigger: 'blur',
  111. },
  112. colProps: {
  113. span: 22,
  114. },
  115. required: true,
  116. ifShow: getCheckRole('plat_admin'),
  117. componentProps: {
  118. api: ListAllCompanyApi,
  119. showSearch: true,
  120. resultField: 'list',
  121. labelField: 'name',
  122. valueField: 'id',
  123. immediate: true,
  124. params: {
  125. page: 1,
  126. limit: 1000,
  127. },
  128. required: true,
  129. },
  130. },
  131. {
  132. field: 'roleId',
  133. component: 'RadioGroup',
  134. label: '角色',
  135. required: true,
  136. itemProps: {
  137. validateTrigger: 'blur',
  138. },
  139. colProps: {
  140. span: 22,
  141. },
  142. defaultValue: 8,
  143. componentProps: {
  144. options: [
  145. {
  146. label: '公司员工',
  147. value: 8,
  148. key: 8,
  149. },
  150. ],
  151. },
  152. },
  153. // {
  154. // field: 'status',
  155. // label: '状态',
  156. // component: 'RadioButtonGroup',
  157. // required: true,
  158. // defaultValue: 1,
  159. // itemProps: {
  160. // validateTrigger: 'blur',
  161. // },
  162. // componentProps: {
  163. // options: [
  164. // { label: '是', value: 1 },
  165. // { label: '否', value: 0 },
  166. // ],
  167. // },
  168. // },
  169. {
  170. field: 'id',
  171. component: 'Input',
  172. label: 'id',
  173. show: false,
  174. },
  175. ];
  176. const title = ref('新 增');
  177. const { createMessage } = useMessage();
  178. const [registerForm, { setFieldsValue, validate, updateSchema, resetFields }] = useForm({
  179. labelWidth: 120,
  180. schemas,
  181. showActionButtonGroup: false,
  182. actionColOptions: {
  183. span: 24,
  184. },
  185. });
  186. const [register, { closeModal }] = useModalInner((data) => {
  187. data && onDataReceive(data);
  188. });
  189. function onDataReceive(data) {
  190. // 方式1;
  191. console.log('useModalInner', data);
  192. setFieldsValue({
  193. ...data,
  194. roleId: data.roleId != 2 ? data.roleId : '',
  195. });
  196. let setSchema = [
  197. {
  198. field: 'roleId',
  199. component: data.id && data.roleId != 2 ? 'Select' : 'ApiSelect',
  200. componentProps:
  201. data.id && data.roleId != 2
  202. ? {
  203. disabled: true,
  204. options: [
  205. {
  206. label: data.roleName,
  207. value: data.roleId,
  208. key: data.roleId,
  209. },
  210. ],
  211. }
  212. : {
  213. disabled: false,
  214. api: roleLIstApi,
  215. labelField: 'roleName',
  216. valueField: 'roleId',
  217. },
  218. },
  219. {
  220. field: 'phone',
  221. componentProps: {
  222. disabled: data.id ? true : false,
  223. },
  224. },
  225. {
  226. field: 'companyId',
  227. componentProps: {
  228. disabled: data.id ? (data.roleId != 2 ? true : false) : false,
  229. },
  230. },
  231. ];
  232. title.value = data.id ? '编辑' : '新增';
  233. updateSchema(setSchema);
  234. }
  235. async function handleOk() {
  236. let data = await validate();
  237. const requestApi = data.id ? updateApi : saveApi;
  238. let res = await requestApi({
  239. ...data,
  240. userName: data.phone,
  241. phone: data.phone,
  242. nickName: data.nickName,
  243. roleId: data.roleId,
  244. id: data.id,
  245. });
  246. console.log('res', res);
  247. context && context.emit('ok', res);
  248. createMessage.success(t('common.optSuccess'));
  249. closeModal();
  250. resetFields();
  251. }
  252. return { register, title, schemas, registerForm, model: modelRef, handleOk, resetFields };
  253. },
  254. });
  255. </script>