Browse Source

feat: 接口对接;

pull/6/head
Fox-33 6 months ago
parent
commit
5634701bb0
7 changed files with 164 additions and 31 deletions
  1. +21
    -0
      api/userTeacher.js
  2. +6
    -2
      otherPages/authentication/components/questionCard.vue
  3. +13
    -5
      otherPages/authentication/examination/trainCompleted/index.vue
  4. +3
    -1
      otherPages/authentication/examination/trainCompleted/waiting.vue
  5. +94
    -12
      otherPages/authentication/list/index.vue
  6. +20
    -5
      pages/login/index.vue
  7. +7
    -6
      pages/workbenchManage/index.vue

+ 21
- 0
api/userTeacher.js View File

@ -9,4 +9,25 @@ export const insertUser = (data) => {
method: 'post', method: 'post',
data data
}) })
}
export const udpateUser = (data) => {
return request({
url: '/applet/UserTeacher/udpateUser',
headers: {
isToken: true
},
method: 'post',
data
})
}
// 伴宠师工作台-查询专业执照列表
export const getUserOne = (appUserId) => {
return request({
url: `/applet/UserTeacher/getUserOne/${appUserId}`,
method: "get"
}).then(res => {
return res.data
})
} }

+ 6
- 2
otherPages/authentication/components/questionCard.vue View File

@ -58,6 +58,11 @@
<script setup> <script setup>
import { computed, watch } from 'vue' import { computed, watch } from 'vue'
import { addBaseAnswer, addTrainAnswer } from '@/api/examination' import { addBaseAnswer, addTrainAnswer } from '@/api/examination'
import { store } from '@/store'
const userId = computed(() => {
return store.state.user.userInfo.userId
})
const props = defineProps({ const props = defineProps({
index: { index: {
@ -98,9 +103,8 @@ const value = computed({
const onChange = (val) => { const onChange = (val) => {
value.value = val value.value = val
console.log('--onChange', val)
const data = { const data = {
userId: userId.value,
questionId: props.data.id, questionId: props.data.id,
} }


+ 13
- 5
otherPages/authentication/examination/trainCompleted/index.vue View File

@ -15,7 +15,7 @@
<script setup> <script setup>
import { ref } from 'vue' import { ref } from 'vue'
import { onShow } from '@dcloudio/uni-app'
import { onLoad } from '@dcloudio/uni-app'
import stepProgress from '../../components/stepProgress.vue'; import stepProgress from '../../components/stepProgress.vue';
import waitingView from './waiting.vue' import waitingView from './waiting.vue'
@ -24,10 +24,18 @@
const status = ref('waiting') const status = ref('waiting')
onShow(() => {
// todo: fetch audit status
status.value = 'pass'
onLoad((option) => {
switch(option?.status) {
case '1':
status.value = 'pass'
break
case '2':
status.value = 'fail'
break
default:
status.value = 'waiting'
break
}
}) })
</script> </script>


+ 3
- 1
otherPages/authentication/examination/trainCompleted/waiting.vue View File

@ -18,7 +18,9 @@
const configList = store.state.system.configList const configList = store.state.system.configList
const onClick = () => { const onClick = () => {
// todo
uni.reLaunch({
url: "/pages/workbenchManage/index"
})
} }
</script> </script>


+ 94
- 12
otherPages/authentication/list/index.vue View File

@ -13,7 +13,7 @@
<dForm ref="formRef" :list="state.list" labelWidth="220rpx" :isFooter="false" @input="onFormInput"></dForm> <dForm ref="formRef" :list="state.list" labelWidth="220rpx" :isFooter="false" @input="onFormInput"></dForm>
</view> </view>
<view class="license__view" v-if="form.license">
<view class="license__view" v-if="form.isHave">
<view class="license"> <view class="license">
<up-checkbox-group <up-checkbox-group
v-model="licenseData.selected" v-model="licenseData.selected"
@ -75,11 +75,11 @@
</template> </template>
<script setup> <script setup>
import { ref, reactive } from "vue";
import { onShow } from '@dcloudio/uni-app'
import { ref, reactive, computed } from "vue";
import { onLoad } from '@dcloudio/uni-app'
import { ossUpload } from '@/utils/oss-upload/oss/index.js' import { ossUpload } from '@/utils/oss-upload/oss/index.js'
import { getLicenseList, getPetTypeList } from '@/api/examination' import { getLicenseList, getPetTypeList } from '@/api/examination'
import { insertUser } from '@/api/userTeacher'
import { insertUser, udpateUser, getUserOne } from '@/api/userTeacher'
import { store } from '@/store' import { store } from '@/store'
import dForm from "@/components/dForm/index.vue" import dForm from "@/components/dForm/index.vue"
@ -87,6 +87,12 @@
const configList = store.state.system.configList const configList = store.state.system.configList
const userId = computed(() => {
return store.state.user.userInfo.userId
})
const id = ref(null)
const state = reactive({ const state = reactive({
list: [{ list: [{
type: "input", type: "input",
@ -120,6 +126,12 @@
key: "age", key: "age",
placeholder: "请输入您的年龄", placeholder: "请输入您的年龄",
}, },
{
type: "input",
label: "手机号",
key: "phone",
placeholder: "请输入您的手机号",
},
{ {
type: "input", type: "input",
label: "养宠经验", label: "养宠经验",
@ -130,7 +142,7 @@
{ {
type: "radio", type: "radio",
label: "是否有专业执照", label: "是否有专业执照",
key: "license",
key: "isHave",
placeholder: "请选择", placeholder: "请选择",
options: [{ options: [{
name: "是", name: "是",
@ -149,6 +161,66 @@
form.value = e form.value = e
} }
const fetchUserInfo = async () => {
try {
const { userTelephone } = store.state.user.userInfo
const data = await getUserOne(userId.value)
if (data) {
const {
id: _id,
status,
name,
idCard,
sex,
age,
phone,
experience,
isHave,
license,
images,
petType: _petType,
} = data
if ([1,2].includes(status)) { // status: 0- 1- 2-
uni.navigateTo({
url: `/otherPages/authentication/examination/trainCompleted/index?status=${status}`
})
return
}
id.value = _id
formRef.value.setData({
name,
idCard,
sex,
age,
phone: phone || userTelephone,
experience,
isHave,
})
licenseData.selected = license?.split?.(';').map(str => parseInt(str)) || []
licenseData.fileList = images?.split?.(';').map(url => ({ url })) || []
petType.value = _petType
} else {
formRef.value.setData({
phone: userTelephone,
})
}
fetchPetTypeOptions()
fetchLicenseOptions()
} catch (err) {
console.log('--err', err)
}
}
const licenseData = reactive({ const licenseData = reactive({
selected: [], selected: [],
fileList: [] fileList: []
@ -195,27 +267,36 @@
idCard, idCard,
sex, sex,
age, age,
phone,
experience, experience,
license,
isHave,
} = form.value } = form.value
const data = { const data = {
userId: userId.value,
name, name,
idCard, idCard,
sex, sex,
age, age,
phone,
experience, experience,
isHave,
petType: petType.value, petType: petType.value,
} }
if (license) {
if (isHave) {
const { selected, fileList } = licenseData const { selected, fileList } = licenseData
data.license = selected.join(';') data.license = selected.join(';')
data.images = fileList.join(';')
data.images = fileList.map(item => item.url).join(';')
} }
await insertUser(data)
if (id.value) {
data.id = id.value
await udpateUser(data)
} else {
await insertUser(data)
}
uni.setStorageSync('petTypeData', petTypeOptions.value.find(item => item.id === petType.value)) uni.setStorageSync('petTypeData', petTypeOptions.value.find(item => item.id === petType.value))
@ -227,9 +308,10 @@
} }
} }
onShow(() => {
fetchPetTypeOptions()
fetchLicenseOptions()
onLoad(() => {
fetchUserInfo()
}) })
</script> </script>


+ 20
- 5
pages/login/index.vue View File

@ -7,8 +7,6 @@
<view class="login-submit"> <view class="login-submit">
<up-button class="mt24" type="primary" text="微信授权登陆" @click="loginWx" shape="circle" <up-button class="mt24" type="primary" text="微信授权登陆" @click="loginWx" shape="circle"
color="#FFBF60"></up-button> color="#FFBF60"></up-button>
<up-button @click="cancelLogin" class="mt24" type="primary" text="取消登录" shape="circle"
color="#FFBF60"></up-button>
</view> </view>
<view class="flex-rowc"> <view class="flex-rowc">
<view> <view>
@ -23,13 +21,16 @@
> >
</up-checkbox> </up-checkbox>
</view> </view>
<view class="size-26">
<view class="size-26 agreement">
<text>我已阅读并同意猫爸狗妈</text> <text>我已阅读并同意猫爸狗妈</text>
<text @click="privacyPolicy('login_xy')" class="main-color">注册协议</text> <text @click="privacyPolicy('login_xy')" class="main-color">注册协议</text>
<text></text> <text></text>
<text @click="privacyPolicy('login_ys')" class="main-color">隐私政策</text> <text @click="privacyPolicy('login_ys')" class="main-color">隐私政策</text>
</view> </view>
</view> </view>
<view class="login-footer flex-rowc">
<button @click="cancelLogin" class="btn-cancel" plain >暂不登录</button>
</view>
</view> </view>
<up-popup :show="show" @close="close" :round="10"> <up-popup :show="show" @close="close" :round="10">
@ -166,10 +167,24 @@
@import "index"; @import "index";
@import "@/style/index.scss"; @import "@/style/index.scss";
.footer {
.agreement {
color: #C7C7C7; color: #C7C7C7;
font-size: 22rpx;
line-height: 29rpx;
}
.login-footer {
width: 100vw;
position: fixed; position: fixed;
bottom: 100rpx;
bottom: 127rpx;
.btn-cancel {
color: #C7C7C7;
font-size: 30rpx;
line-height: 40rpx;
border: none;
display: inline-block;
padding: 0;
}
} }
</style> </style>

+ 7
- 6
pages/workbenchManage/index.vue View File

@ -135,12 +135,13 @@
}).catch(() => {}) }).catch(() => {})
} else { } else {
// //
joiBcs({
appUserId: baseInfo.userId
}).then(res => {
isoOpen.value = true
changeBaseInfo(baseInfo.userId)
})
handleBc()
// joiBcs({
// appUserId: baseInfo.userId
// }).then(res => {
// isoOpen.value = true
// changeBaseInfo(baseInfo.userId)
// })
} }
} }
// //


Loading…
Cancel
Save