Index.vue 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. <template>
  2. <app-view class="g-form">
  3. <template #header>
  4. <app-navbar :title="$t('user.avater.title')" />
  5. </template>
  6. <Form ref="formRef" class="g-form__container" @submit="onSubmit">
  7. <CellGroup inset>
  8. <Field :label="$t('user.avater.cardbackphotourl')" :rules="formRules.headurl">
  9. <template #input>
  10. <app-uploader @success="onUploadSuccess" />
  11. </template>
  12. </Field>
  13. </CellGroup>
  14. </Form>
  15. <template #footer>
  16. <div class="g-form__footer inset">
  17. <Button round block type="danger" @click="formRef?.submit">{{ $t('operation.confirm') }}</Button>
  18. </div>
  19. </template>
  20. </app-view>
  21. </template>
  22. <script lang="ts" setup>
  23. import { shallowRef, reactive } from 'vue'
  24. import { CellGroup, Button, Field, Form, FormInstance, FieldRule, showFailToast } from 'vant'
  25. import { fullloading } from '@/utils/vant'
  26. import { useNavigation } from '@mobile/router/navigation'
  27. import { updateUserHeadUrl } from '@/services/api/user'
  28. import { useLoginStore, useUserStore, i18n } from '@/stores'
  29. import AppUploader from '@mobile/components/base/uploader/index.vue'
  30. const { router } = useNavigation()
  31. const loginStore = useLoginStore()
  32. const userStore = useUserStore()
  33. const { global: { t } } = i18n
  34. const formRef = shallowRef<FormInstance>()
  35. const formData = reactive<Model.UserHeadUrlReq>({
  36. userid: loginStore.userId, // 用户ID
  37. headurl: '', // 头像地址
  38. })
  39. // 表单验证规则
  40. const formRules: { [key: string]: FieldRule[] } = {
  41. headurl: [{
  42. message: t('user.avater.tips1'),
  43. validator: () => {
  44. return !!formData.headurl
  45. }
  46. }],
  47. }
  48. const onUploadSuccess = (filePath: string) => {
  49. formData.headurl = filePath
  50. }
  51. const onSubmit = () => {
  52. fullloading((hideLoading) => {
  53. updateUserHeadUrl({
  54. data: formData
  55. }).then(() => {
  56. hideLoading()
  57. userStore.getUserData()
  58. router.back()
  59. }).catch((err) => {
  60. showFailToast(err)
  61. })
  62. })
  63. }
  64. </script>