feat: survey vuex to pinia (#331)

* feat: survey vuex to pinia

* feat: fix ts type-check

* feat: fix lint error
This commit is contained in:
yoruponder 2024-07-10 14:41:36 +08:00 committed by GitHub
parent 1a15faad42
commit 2ad6a77740
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
6 changed files with 96 additions and 40 deletions

View File

@ -8,11 +8,13 @@ import { useRoute } from 'vue-router'
import { getPublishedSurveyInfo, getPreviewSchema } from '../api/survey'
import useCommandComponent from '../hooks/useCommandComponent'
import { useSurveyStore } from '../stores/survey'
import AlertDialog from '../components/AlertDialog.vue'
import { initRuleEngine } from '@/render/hooks/useRuleEngine.js'
const store = useStore()
const route = useRoute()
const surveyStore = useSurveyStore()
const loadData = (res: any, surveyPath: string) => {
if (res.code === 200) {
const data = res.data
@ -36,7 +38,7 @@ const loadData = (res: any, surveyPath: string) => {
document.title = data.title
store.commit('setSurveyPath', surveyPath)
surveyStore.setSurveyPath(surveyPath)
store.dispatch('init', questionData)
initRuleEngine(logicConf?.showLogicConf)
} else {
@ -46,7 +48,7 @@ const loadData = (res: any, surveyPath: string) => {
onMounted(() => {
const surveyId = route.params.surveyId
console.log({ surveyId })
store.commit('setSurveyPath', surveyId)
surveyStore.setSurveyPath(surveyId)
getDetail(surveyId as string)
})
@ -60,7 +62,7 @@ const getDetail = async (surveyPath: string) => {
} else {
const res: any = await getPublishedSurveyInfo({ surveyPath })
loadData(res, surveyPath)
store.dispatch('getEncryptInfo')
surveyStore.getEncryptInfo();
}
} catch (error: any) {
console.log(error)

View File

@ -29,6 +29,7 @@ import AlertDialog from '../components/AlertDialog.vue'
import ConfirmDialog from '../components/ConfirmDialog.vue'
import ProgressBar from '../components/ProgressBar.vue'
import { useSurveyStore } from '../stores/survey'
import { submitForm } from '../api/survey'
import encrypt from '../utils/encrypt'
@ -57,12 +58,13 @@ const confirm = useCommandComponent(ConfirmDialog)
const store = useStore()
const router = useRouter()
const surveyStore = useSurveyStore()
const bannerConf = computed(() => store.state?.bannerConf || {})
const renderData = computed(() => store.getters.renderData)
const submitConf = computed(() => store.state?.submitConf || {})
const logoConf = computed(() => store.state?.bottomConf || {})
const surveyPath = computed(() => store.state?.surveyPath || '')
const surveyPath = computed(() => surveyStore.surveyPath || '')
const validate = (cbk: (v: boolean) => void) => {
const index = 0
@ -70,8 +72,8 @@ const validate = (cbk: (v: boolean) => void) => {
}
const normalizationRequestBody = () => {
const enterTime = store.state.enterTime
const encryptInfo = store.state.encryptInfo
const enterTime = surveyStore.enterTime
const encryptInfo = surveyStore.encryptInfo as any;
const formValues = store.state.formValues
const result: any = {
@ -82,7 +84,7 @@ const normalizationRequestBody = () => {
}
if (encryptInfo?.encryptType) {
result.encryptType = encryptInfo?.encryptType
result.encryptType = encryptInfo.encryptType
result.data = encrypt[result.encryptType as 'rsa']({
data: result.data,
secretKey: encryptInfo?.data?.secretKey

View File

@ -4,16 +4,17 @@ import 'moment/locale/zh-cn'
// 设置中文
moment.locale('zh-cn')
import adapter from '../adapter'
import { queryVote, getEncryptInfo } from '@/render/api/survey'
import { queryVote } from '@/render/api/survey'
import { RuleMatch } from '@/common/logicEngine/RulesMatch'
import { useSurveyStore } from '@/render/stores/survey'
/**
* CODE_MAP不从management引入在dev阶段会导致B端 router被加载进而导致C端路由被添加 baseUrl: /management
*/
const CODE_MAP = {
SUCCESS: 200,
ERROR: 500,
NO_AUTH: 403
}
// const CODE_MAP = {
// SUCCESS: 200,
// ERROR: 500,
// NO_AUTH: 403
// }
const VOTE_INFO_KEY = 'voteinfo'
import router from '../router'
export default {
@ -22,7 +23,8 @@ export default {
{ commit, dispatch },
{ bannerConf, baseConf, bottomConf, dataConf, skinConf, submitConf }
) {
commit('setEnterTime')
const surveyStore = useSurveyStore()
surveyStore.setEnterTime();
const { begTime, endTime, answerBegTime, answerEndTime } = baseConf
const { msgContent } = submitConf
const now = Date.now()
@ -90,8 +92,9 @@ export default {
},
// 初始化投票题的数据
async initVoteData({ state, commit }) {
const surveyStore = useSurveyStore()
const questionData = state.questionData
const surveyPath = state.surveyPath
const surveyPath = surveyStore.surveyPath
const fieldList = []
@ -163,16 +166,16 @@ export default {
commit('updateVoteMapByKey', totalPayload)
})
},
async getEncryptInfo({ commit }) {
try {
const res = await getEncryptInfo()
if (res.code === CODE_MAP.SUCCESS) {
commit('setEncryptInfo', res.data)
}
} catch (error) {
console.log(error)
}
},
// async getEncryptInfo({ commit }) {
// try {
// const res = await getEncryptInfo()
// if (res.code === CODE_MAP.SUCCESS) {
// commit('setEncryptInfo', res.data)
// }
// } catch (error) {
// console.log(error)
// }
// },
async initRuleEngine({ commit }, ruleConf) {
const ruleEngine = new RuleMatch(ruleConf)
commit('setRuleEgine', ruleEngine)

View File

@ -24,12 +24,12 @@ export default {
const { key, value, field } = data
set(state, `questionData.${field}.othersValue.${key}`, value)
},
setEnterTime(state) {
state.enterTime = Date.now()
},
setSurveyPath(state, data) {
state.surveyPath = data
},
// setEnterTime(state) {
// state.enterTime = Date.now()
// },
// setSurveyPath(state, data) {
// state.surveyPath = data
// },
setVoteMap(state, data) {
state.voteMap = data
},
@ -44,9 +44,9 @@ export default {
setQuestionSeq(state, data) {
state.questionSeq = data
},
setEncryptInfo(state, data) {
state.encryptInfo = data
},
// setEncryptInfo(state, data) {
// state.encryptInfo = data
// },
setRuleEgine(state, ruleEngine) {
state.ruleEngine = ruleEngine
}

View File

@ -1,16 +1,16 @@
import { isMobile } from '../utils/index'
// import { isMobile } from '../utils/index'
export default {
surveyPath: '',
// surveyPath: '',
questionData: null,
isMobile: isMobile(),
// isMobile: isMobile(),
errorInfo: {
errorType: '',
errorMsg: ''
},
enterTime: null,
// enterTime: null,
questionSeq: [], // 题目的顺序,因为可能会有分页的情况,所以是一个二维数组[[qid1, qid2], [qid3,qid4]]
voteMap: {},
encryptInfo: null,
// encryptInfo: null,
ruleEngine: null
}

View File

@ -1 +1,50 @@
// 问卷相关的Pinia Store
import { defineStore } from 'pinia'
import { ref } from 'vue'
import { isMobile as isInMobile } from '@/render/utils/index'
import { getEncryptInfo as getEncryptInfoApi } from '@/render/api/survey'
/**
* CODE_MAP不从management引入在dev阶段会导致B端 router被加载进而导致C端路由被添加 baseUrl: /management
*/
const CODE_MAP = {
SUCCESS: 200,
ERROR: 500,
NO_AUTH: 403
}
export const useSurveyStore = defineStore('survey', () => {
const surveyPath = ref('');
const isMobile = ref(isInMobile())
const enterTime = ref(0)
const encryptInfo = ref(null)
const setSurveyPath = ( data) => {
surveyPath.value = data
}
const setEnterTime = () => {
enterTime.value = Date.now()
}
const getEncryptInfo = async() => {
try {
const res = await getEncryptInfoApi()
if (res.code === CODE_MAP.SUCCESS) {
encryptInfo.value = res.data
}
} catch (error) {
console.log(error)
}
}
return {
surveyPath,
isMobile,
enterTime,
encryptInfo,
setSurveyPath,
setEnterTime,
getEncryptInfo
}
})