From 5dc62108ace3f3713ede3beea54f971b1285be1a Mon Sep 17 00:00:00 2001 From: Himit_ZH <372347736@qq.com> Date: Sun, 23 Jan 2022 21:51:39 +0800 Subject: [PATCH] update frontend --- hoj-vue/src/views/oj/Home.vue | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/hoj-vue/src/views/oj/Home.vue b/hoj-vue/src/views/oj/Home.vue index 81f93d08..b6ef4062 100644 --- a/hoj-vue/src/views/oj/Home.vue +++ b/hoj-vue/src/views/oj/Home.vue @@ -215,9 +215,10 @@ import time from '@/common/time'; import api from '@/common/api'; import { CONTEST_STATUS_REVERSE } from '@/common/constants'; -import { mapState } from 'vuex'; +import { mapState, mapGetters } from 'vuex'; import { addCodeBtn } from '@/common/codeblock'; import Avatar from 'vue-avatar'; +import myMessage from '@/common/message'; const Announcements = () => import('@/components/oj/common/Announcements.vue'); export default { name: 'home', @@ -313,10 +314,15 @@ export default { this.index = newIndex; }, goContest() { - this.$router.push({ - name: 'ContestDetails', - params: { contestID: this.contests[this.index].id }, - }); + if (!this.isAuthenticated) { + myMessage.warning(this.$i18n.t('m.Please_login_first')); + this.$store.dispatch('changeModalStatus', { visible: true }); + } else { + this.$router.push({ + name: 'ContestDetails', + params: { contestID: this.contests[this.index].id }, + }); + } }, goOtherOJContest(event) { window.open(event.row.url); @@ -341,6 +347,7 @@ export default { }, computed: { ...mapState(['websiteConfig']), + ...mapGetters(['isAuthenticated']), }, };