register.vue 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279
  1. <template>
  2. <div id="register" class="w_1200">
  3. <div style="height:90vh;overflow-y:auto">
  4. <el-form ref="forms" :model="forms" :rules="rules" label-width="140px">
  5. <el-form-item label="用户名称" prop="name">
  6. <el-input v-model="forms.name" placeholder="请输入用户名称"></el-input>
  7. </el-form-item>
  8. <el-form-item label="手机号" prop="phone">
  9. <el-input v-model="forms.phone" placeholder="请输入手机号"></el-input>
  10. </el-form-item>
  11. <el-form-item label="登录密码" prop="password">
  12. <el-input v-model="forms.password" placeholder="请输入登录密码" show-password></el-input>
  13. </el-form-item>
  14. <el-form-item label="机构代码或邀请码" prop="code" class="cs">
  15. <el-input v-model="forms.code" placeholder="请输入邀请码"></el-input>
  16. </el-form-item>
  17. <el-form-item label="用户类别" prop="role">
  18. <el-radio-group v-model="forms.role">
  19. <el-radio label="4">个人</el-radio>
  20. <el-radio label="5">机构管理员</el-radio>
  21. <el-radio label="6">专家</el-radio>
  22. </el-radio-group>
  23. </el-form-item>
  24. <span v-if="forms.role == '4' || forms.role == '5'">
  25. <el-form-item label="电子邮箱" prop="email">
  26. <el-input v-model="forms.email" placeholder="请输入电子邮箱"></el-input>
  27. </el-form-item>
  28. <el-form-item label="联系地址" prop="addr">
  29. <el-input v-model="forms.addr" placeholder="请输入联系地址"></el-input>
  30. </el-form-item>
  31. <el-form-item label="办公电话" prop="office_phone">
  32. <el-input v-model="forms.office_phone" placeholder="请输入办公电话"></el-input>
  33. </el-form-item>
  34. <el-form-item label="所属行业" prop="profession">
  35. <el-input v-model="forms.profession" placeholder="请输入所属行业"></el-input>
  36. </el-form-item>
  37. </span>
  38. <span v-if="forms.role == '5'">
  39. <el-form-item label="统一社会信用代码" prop="institution_code">
  40. <el-input v-model="forms.institution_code" placeholder="请输入统一社会信用代码"></el-input>
  41. <el-link type="danger" :underline="false">统一社会信用代码作为机构用户登录平台唯一凭证</el-link>
  42. </el-form-item>
  43. <el-form-item label="注册类型">
  44. <el-input v-model="forms.companytype" placeholder="请输入注册类型"></el-input>
  45. </el-form-item>
  46. <el-form-item label="注册时间">
  47. <el-date-picker v-model="forms.companydate" placeholder="请选择" value-format="yyyy-MM-dd" format="yyyy-MM-dd" type="date"> </el-date-picker>
  48. </el-form-item>
  49. <el-form-item label="注册资金">
  50. <el-input v-model="forms.companycapital" placeholder="请输入注册资金"></el-input>
  51. </el-form-item>
  52. <el-form-item label="企业法人">
  53. <el-input v-model="forms.companyperson" placeholder="请输入企业法人"></el-input>
  54. </el-form-item>
  55. <el-form-item label="上年度企业总收入">
  56. <el-input v-model="forms.sndqyzsr" placeholder="请输入上年度企业总收入"></el-input>
  57. </el-form-item>
  58. <el-form-item label="上年度研发费用">
  59. <el-input v-model="forms.sndyffy" placeholder="请输入上年度研发费用"></el-input>
  60. </el-form-item>
  61. <el-form-item label="企业总人数">
  62. <el-input v-model="forms.companytotal" placeholder="请输入企业总人数"></el-input>
  63. </el-form-item>
  64. <el-form-item label="企业简介">
  65. <el-input
  66. v-model="forms.companybrief"
  67. type="textarea"
  68. maxlength="300"
  69. show-word-limit
  70. :autosize="{ minRows: 4, maxRows: 5 }"
  71. placeholder="请输入企业简介"
  72. ></el-input>
  73. </el-form-item>
  74. <el-form-item label="主要产品">
  75. <el-input
  76. v-model="forms.mainproduct"
  77. type="textarea"
  78. maxlength="300"
  79. show-word-limit
  80. :autosize="{ minRows: 4, maxRows: 5 }"
  81. placeholder="请输入主要产品"
  82. ></el-input>
  83. </el-form-item>
  84. <el-form-item label="企业资质/荣誉">
  85. <el-input
  86. v-model="forms.qualifications"
  87. type="textarea"
  88. maxlength="300"
  89. show-word-limit
  90. :autosize="{ minRows: 4, maxRows: 5 }"
  91. placeholder="请输入企业资质/荣誉"
  92. ></el-input>
  93. </el-form-item>
  94. </span>
  95. <span v-else-if="forms.role == '6'">
  96. <el-form-item label="头像">
  97. <upload :limit="1" :data="forms.expertimage" type="expertimage" :url="'/files/userjuriscms_user/upload'" @upload="uploadSuccess"></upload>
  98. </el-form-item>
  99. <el-form-item label="最高学历">
  100. <el-input v-model="forms.education" placeholder="请输入最高学历"></el-input>
  101. </el-form-item>
  102. <el-form-item label="毕业院校">
  103. <el-input v-model="forms.school" placeholder="请输入毕业院校"></el-input>
  104. </el-form-item>
  105. <el-form-item label="出生日期">
  106. <el-date-picker v-model="forms.birthDate" type="date" placeholder="选择日期" value-format="yyyy-MM-dd"> </el-date-picker>
  107. </el-form-item>
  108. <el-form-item label="QQ/微信">
  109. <el-input v-model="forms.qqwx" placeholder="请输入QQ/微信"></el-input>
  110. </el-form-item>
  111. <el-form-item label="电子邮箱">
  112. <el-input v-model="forms.email" placeholder="请输入电子邮箱"></el-input>
  113. </el-form-item>
  114. <el-form-item label="工作单位">
  115. <el-input v-model="forms.company" placeholder="请输入工作单位"></el-input>
  116. </el-form-item>
  117. <el-form-item label="职务职称">
  118. <el-input v-model="forms.zwzc" placeholder="请输入职务职称"></el-input>
  119. </el-form-item>
  120. <el-form-item label="擅长领域">
  121. <el-input v-model="forms.expertise" placeholder="请输入擅长领域"></el-input>
  122. </el-form-item>
  123. <el-form-item label="工作经历">
  124. <el-input
  125. v-model="forms.workexperience"
  126. type="textarea"
  127. maxlength="300"
  128. show-word-limit
  129. :autosize="{ minRows: 2, maxRows: 5 }"
  130. placeholder="请输入工作经历"
  131. ></el-input>
  132. </el-form-item>
  133. <el-form-item label="科研综述">
  134. <el-input
  135. v-model="forms.scientific"
  136. type="textarea"
  137. maxlength="300"
  138. show-word-limit
  139. :autosize="{ minRows: 2, maxRows: 5 }"
  140. placeholder="请输入科研综述"
  141. ></el-input>
  142. </el-form-item>
  143. <el-form-item label="承担项目">
  144. <el-input
  145. v-model="forms.undertakingproject"
  146. type="textarea"
  147. maxlength="300"
  148. show-word-limit
  149. :autosize="{ minRows: 2, maxRows: 5 }"
  150. placeholder="请输入承担项目"
  151. ></el-input>
  152. </el-form-item>
  153. <el-form-item label="科技奖励">
  154. <el-input
  155. v-model="forms.scienceaward"
  156. type="textarea"
  157. maxlength="300"
  158. show-word-limit
  159. :autosize="{ minRows: 2, maxRows: 5 }"
  160. placeholder="请输入科技奖励"
  161. ></el-input>
  162. </el-form-item>
  163. <el-form-item label="社会任职">
  164. <el-input
  165. v-model="forms.social"
  166. type="textarea"
  167. maxlength="300"
  168. show-word-limit
  169. :autosize="{ minRows: 2, maxRows: 5 }"
  170. placeholder="请输入社会任职"
  171. ></el-input>
  172. </el-form-item>
  173. </span>
  174. <el-col :span="24" class="loginSubmit"><el-button type="primary" @click="registerSubmit()">注册</el-button></el-col>
  175. </el-form>
  176. </div>
  177. </div>
  178. </template>
  179. <script>
  180. import upload from '@/components/frame/uploadone.vue';
  181. import { mapState, createNamespacedHelpers } from 'vuex';
  182. // const { mapActions: user } = createNamespacedHelpers('user');
  183. export default {
  184. name: 'register',
  185. props: {},
  186. components: { upload },
  187. data: function() {
  188. return {
  189. forms: {},
  190. rules: {
  191. name: [{ required: true, message: '请输入用户名称', trigger: 'blur' }],
  192. phone: [{ required: true, message: '请输入手机号/统一社会信用代码', trigger: 'blur' }],
  193. password: [{ required: true, message: '请输入密码', trigger: 'blur' }],
  194. code: [{ required: true, message: '请输入邀请码', trigger: 'blur' }],
  195. institution_code: [{ required: true, message: '请输入统一社会信用代码', trigger: 'blur' }],
  196. },
  197. };
  198. },
  199. created() {},
  200. methods: {
  201. // ...user(['create']),
  202. async toSave() {
  203. let duplicate = _.cloneDeep(this.forms);
  204. const res = await this.create(duplicate);
  205. if (this.$checkRes(res, '注册成功', res.errmsg || '注册失败')) {
  206. // TODO 跳转路由
  207. }
  208. },
  209. registerSubmit() {
  210. this.$refs['forms'].validate(valid => {
  211. if (valid) {
  212. this.toSave();
  213. } else {
  214. console.log('error submit!!');
  215. return false;
  216. }
  217. });
  218. },
  219. uploadSuccess({ type, data }) {
  220. this.$set(this.forms, `${type}`, data.uri);
  221. },
  222. },
  223. computed: {
  224. pageTitle() {
  225. return `${this.$route.meta.title}`;
  226. },
  227. },
  228. metaInfo() {
  229. return { title: this.$route.meta.title };
  230. },
  231. };
  232. </script>
  233. <style lang="less" scoped>
  234. .w_1200 {
  235. width: 1200px;
  236. margin: 0 auto;
  237. }
  238. </style>