refactor: 重构 render/pages 目录下三个文件, 使用 Vue3 组合式 API 写法 (#113)

This commit is contained in:
alwayrun 2024-05-15 20:32:57 +08:00 committed by sudoooooo
parent 2560f0af3d
commit f9af6219ab
3 changed files with 121 additions and 142 deletions

View File

@ -8,29 +8,23 @@
</div> </div>
</div> </div>
</template> </template>
<script> <script setup lang="ts">
export default { import { computed } from 'vue'
name: 'errorPage', import { useStore } from 'vuex'
data() {
return { const store = useStore()
imageMap: {
overTime: '/imgs/icons/overtime.webp' const errorImageUrl = computed(() => {
} const errorType = store.state?.errorInfo?.errorType
} const imageMap = {
}, overTime: '/imgs/icons/overtime.webp',
computed: { default: '/imgs/icons/error.webp',
errorImageUrl() { }
return this.imageMap[this.errorType] || this.imageMap.default
}, return imageMap[errorType as 'overTime'] || imageMap.default
errorType() { })
return this.$store.state?.errorInfo?.errorType
}, const errorMsg = computed(() => store.state?.errorInfo?.errorMsg)
errorMsg() {
return this.$store.state?.errorInfo?.errorMsg
}
},
mounted() {}
}
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.result-page-wrap { .result-page-wrap {

View File

@ -1,19 +1,21 @@
<template> <template>
<div class="index"> <div class="index">
<progressBar /> <progressBar />
<div class="wrapper" ref="box"> <div class="wrapper" ref="boxRef">
<HeaderSetter></HeaderSetter> <HeaderSetter></HeaderSetter>
<div class="content"> <div class="content">
<MainTitle></MainTitle> <MainTitle></MainTitle>
<MainRenderer ref="main"></MainRenderer> <MainRenderer ref="mainRef"></MainRenderer>
<submit :validate="validate" :renderData="renderData" @submit="onSubmit"></submit> <submit :validate="validate" :renderData="renderData" @submit="handleSubmit"></submit>
<LogoIcon /> <LogoIcon />
</div> </div>
</div> </div>
</div> </div>
</template> </template>
<script setup lang="ts">
import { computed, ref } from 'vue'
import { useStore } from 'vuex'
<script>
import HeaderSetter from '../components/HeaderSetter.vue' import HeaderSetter from '../components/HeaderSetter.vue'
import MainTitle from '../components/MainTitle.vue' import MainTitle from '../components/MainTitle.vue'
import submit from '../components/SubmitSetter.vue' import submit from '../components/SubmitSetter.vue'
@ -28,115 +30,101 @@ import encrypt from '../utils/encrypt'
import useCommandComponent from '../hooks/useCommandComponent' import useCommandComponent from '../hooks/useCommandComponent'
export default { interface Props {
name: 'indexPage', questionInfo?: any,
props: { isMobile?: boolean,
questionInfo: { }
type: Object,
default: () => ({})
},
isMobile: {
type: Boolean,
default: false
}
},
components: {
HeaderSetter,
MainTitle,
submit,
MainRenderer,
progressBar,
LogoIcon
},
computed: {
formModel() {
return this.$store.getters.formModel
},
confirmAgain() {
return this.$store.state.submitConf.confirmAgain
},
surveyPath() {
return this.$store.state.surveyPath
},
renderData() {
return this.$store.getters.renderData
},
encryptInfo() {
return this.$store.state.encryptInfo
}
},
created() {
this.alert = useCommandComponent(AlertDialog)
this.confirm = useCommandComponent(ConfirmDialog)
},
methods: {
validate(cbk) {
const index = 0
this.$refs.main.$refs.formGroup[index].validate(cbk)
},
onSubmit() {
const { again_text, is_again } = this.confirmAgain
if (is_again) {
this.confirm({
title: again_text,
onConfirm: async () => {
try {
await this.submitForm()
} catch (error) {
console.error(error)
} finally {
this.confirm.close()
}
}
})
} else {
this.submitForm()
}
},
getSubmitData() {
const result = {
surveyPath: this.surveyPath,
data: JSON.stringify(this.formModel),
difTime: Date.now() - this.$store.state.enterTime,
clientTime: Date.now()
}
if (this.encryptInfo?.encryptType) {
result.encryptType = this.encryptInfo?.encryptType
result.data = encrypt[result.encryptType]({
data: result.data,
secretKey: this.encryptInfo?.data?.secretKey
})
if (this.encryptInfo?.data?.sessionId) {
result.sessionId = this.encryptInfo.data.sessionId
}
} else {
result.data = JSON.stringify(result.data)
}
return result withDefaults(defineProps<Props>(), {
}, questionInfo: {},
async submitForm() { isMobile: false,
try { })
const submitData = this.getSubmitData()
const res = await submitForm(submitData) const mainRef = ref<any>()
if (res.code === 200) { const boxRef = ref<HTMLElement>()
this.$store.commit('setRouter', 'successPage')
} else { const alert = useCommandComponent(AlertDialog)
this.alert({ const confirm = useCommandComponent(ConfirmDialog)
title: res.errmsg || '提交失败'
}) const store = useStore()
}
} catch (error) { const renderData = computed(() => store.getters.renderData)
console.log(error)
} const validate = (cbk: (v: boolean) => void) => {
const index = 0
mainRef.value.$refs.formGroup[index].validate(cbk)
}
const normalizationRequestBody = () => {
const enterTime = store.state.enterTime
const encryptInfo = store.state.encryptInfo
const formModel = store.getters.formModel
const surveyPath = store.state.surveyPath
const result: any = {
surveyPath,
data: JSON.stringify(formModel),
difTime: Date.now() - enterTime,
clientTime: Date.now()
}
if (encryptInfo?.encryptType) {
result.encryptType = encryptInfo?.encryptType
result.data = encrypt[result.encryptType as 'rsa']({
data: result.data,
secretKey: encryptInfo?.data?.secretKey
})
if (encryptInfo?.data?.sessionId) {
result.sessionId = encryptInfo.data.sessionId
} }
} else {
result.data = JSON.stringify(result.data)
}
return result
}
const submitSurver = async () => {
try {
const params = normalizationRequestBody()
console.log(params)
const res: any = await submitForm(params)
if (res.code === 200) {
store.commit('setRouter', 'successPage')
} else {
alert({
title: res.errmsg || '提交失败'
})
}
} catch (error) {
console.log(error)
}
}
const handleSubmit = () => {
const confirmAgain = store.state.submitConf.confirmAgain
const { again_text, is_again } = confirmAgain
if (is_again) {
confirm({
title: again_text,
onConfirm: async () => {
try {
submitSurver()
} catch(error) {
console.log(error)
} finally {
confirm.close()
}
}
})
} else {
submitSurver()
} }
} }
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">
.index { .index {
// padding-bottom: 0.8rem;
min-height: 100%; min-height: 100%;
.wrapper { .wrapper {
min-height: 100%; min-height: 100%;

View File

@ -9,20 +9,17 @@
</div> </div>
</div> </div>
</template> </template>
<script> <script setup lang="ts">
import { computed } from 'vue'
import { useStore } from 'vuex'
import LogoIcon from '../components/LogoIcon.vue' import LogoIcon from '../components/LogoIcon.vue'
export default {
name: 'resultPage', const store = useStore()
components: { LogoIcon },
computed: { const successMsg = computed(() => {
submitConf() { const msgContent = store.state?.submitConf?.msgContent || {}
return this.$store?.state?.submitConf || {} return msgContent?.msg_200 || '提交成功'
}, })
successMsg() {
return this.submitConf?.msgContent?.msg_200 || '提交成功'
}
}
}
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
@import '@/render/styles/variable.scss'; @import '@/render/styles/variable.scss';