feat: 表单过期
This commit is contained in:
BIN
src/assets/images/award/expired.png
Normal file
BIN
src/assets/images/award/expired.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 35 KiB |
@@ -7,16 +7,16 @@
|
|||||||
<div class="title poppins-medium">Application Form</div>
|
<div class="title poppins-medium">Application Form</div>
|
||||||
<div
|
<div
|
||||||
class="form-header"
|
class="form-header"
|
||||||
v-if="!isCompleted"
|
v-if="!isCompleted && !isExpired"
|
||||||
>
|
>
|
||||||
<div class="form-title poppins-bold">Email Verification</div>
|
<div class="form-title poppins-bold">Email Verification</div>
|
||||||
<div class="desc">AiDA Users Only</div>
|
<div class="desc">AiDA Users Only</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<Success v-if="isCompleted" />
|
<Success :isExpired="isExpired" v-if="isCompleted || isExpired" />
|
||||||
<div
|
<div
|
||||||
class="form-container"
|
class="form-container"
|
||||||
v-if="!isCompleted"
|
v-if="!isCompleted && !isExpired"
|
||||||
>
|
>
|
||||||
<div class="form-content">
|
<div class="form-content">
|
||||||
<a-form
|
<a-form
|
||||||
@@ -154,6 +154,7 @@
|
|||||||
class="full-row"
|
class="full-row"
|
||||||
name="pdfPath"
|
name="pdfPath"
|
||||||
required
|
required
|
||||||
|
:validate-trigger="[]"
|
||||||
label="How will you use AiDA in your design process?"
|
label="How will you use AiDA in your design process?"
|
||||||
>
|
>
|
||||||
<div
|
<div
|
||||||
@@ -205,6 +206,7 @@
|
|||||||
class="full-row"
|
class="full-row"
|
||||||
name="videoPath"
|
name="videoPath"
|
||||||
required
|
required
|
||||||
|
:validate-trigger="[]"
|
||||||
label="How will you use AiDA in your design process?"
|
label="How will you use AiDA in your design process?"
|
||||||
>
|
>
|
||||||
<div
|
<div
|
||||||
@@ -348,6 +350,13 @@
|
|||||||
import UploadStatus from './components/UploadStatus.vue'
|
import UploadStatus from './components/UploadStatus.vue'
|
||||||
import Success from './components/Success.vue'
|
import Success from './components/Success.vue'
|
||||||
|
|
||||||
|
// 是否晚于2026年7月22日
|
||||||
|
const isExpired = computed(() => {
|
||||||
|
const now = new Date()
|
||||||
|
const targetDate = new Date('2026-03-15')
|
||||||
|
return now > targetDate
|
||||||
|
})
|
||||||
|
|
||||||
const route = useRoute()
|
const route = useRoute()
|
||||||
const isCompleted = ref(false)
|
const isCompleted = ref(false)
|
||||||
const hasValidEmail = ref(false)
|
const hasValidEmail = ref(false)
|
||||||
@@ -432,6 +441,36 @@
|
|||||||
],
|
],
|
||||||
lastName: [
|
lastName: [
|
||||||
{ required: true, message: 'Please input your last name', trigger: 'blur' }
|
{ required: true, message: 'Please input your last name', trigger: 'blur' }
|
||||||
|
],
|
||||||
|
gender: [
|
||||||
|
{ required: true, message: 'Please select your gender', trigger: 'blur' }
|
||||||
|
],
|
||||||
|
occupation: [
|
||||||
|
{ required: true, message: 'Please input your occupation', trigger: 'blur' }
|
||||||
|
],
|
||||||
|
age: [{ required: true, message: 'Please input your age', trigger: 'blur' }],
|
||||||
|
countryRegionCity: [
|
||||||
|
{
|
||||||
|
required: true,
|
||||||
|
message: 'Please input your country/region and city',
|
||||||
|
trigger: 'blur'
|
||||||
|
}
|
||||||
|
],
|
||||||
|
phoneNumber: [{ required: true, validator: validatePhone, trigger: 'blur' }],
|
||||||
|
|
||||||
|
designTitle: [
|
||||||
|
{ required: true, message: 'Please input your design title', trigger: 'blur' }
|
||||||
|
],
|
||||||
|
designDescription: [
|
||||||
|
{
|
||||||
|
required: true,
|
||||||
|
message: 'Please input your design description',
|
||||||
|
trigger: 'blur'
|
||||||
|
}
|
||||||
|
],
|
||||||
|
pdfPath: [{ required: true, message: 'Please upload your PDF', trigger: 'null' }],
|
||||||
|
videoPath: [
|
||||||
|
{ required: true, message: 'Please upload your video', trigger: 'null' }
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -962,8 +1001,9 @@
|
|||||||
height: 1rem;
|
height: 1rem;
|
||||||
}
|
}
|
||||||
.apply-container {
|
.apply-container {
|
||||||
min-height: calc(100% -18rem);
|
min-height: calc(100% - 18rem);
|
||||||
background-color: #f5f5f5;
|
background-color: #f5f5f5;
|
||||||
|
box-sizing: border-box;
|
||||||
}
|
}
|
||||||
|
|
||||||
.banner {
|
.banner {
|
||||||
|
|||||||
@@ -1,24 +1,51 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="success-container flex flex-col align-center">
|
<div class="success-container flex flex-col align-center">
|
||||||
<img
|
<img
|
||||||
src="@/assets/images/award/successful.png"
|
:src="info.icon"
|
||||||
alt=""
|
alt=""
|
||||||
class="icon-img"
|
class="icon-img"
|
||||||
/>
|
/>
|
||||||
<div class="title">Submission Successful</div>
|
<div class="title">{{ info.title }}</div>
|
||||||
<div class="desc">
|
<div class="desc">
|
||||||
<div>
|
{{ info.desc }}
|
||||||
|
<!-- <div>
|
||||||
Please review your submitted information in the AiDA in-platform message.
|
Please review your submitted information in the AiDA in-platform message.
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div>
|
||||||
You may edit it if needed. Competition updates and results will be sent
|
You may edit it if needed. Competition updates and results will be sent
|
||||||
via email.
|
via email.
|
||||||
</div>
|
</div> -->
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup lang="ts"></script>
|
<script setup lang="ts">
|
||||||
|
import { computed } from 'vue'
|
||||||
|
import successIcon from '@/assets/images/award/successful.png'
|
||||||
|
import expiredIcon from '@/assets/images/award/expired.png'
|
||||||
|
const props = defineProps({
|
||||||
|
isExpired: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
const info = computed(() => {
|
||||||
|
if (props.isExpired) {
|
||||||
|
return {
|
||||||
|
icon: expiredIcon,
|
||||||
|
title: 'Application Deadline Passed',
|
||||||
|
desc: 'The submission deadline for AIDA Global Fashion Award 2026 has ended.\nWe are no longer accepting new applications. '
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return {
|
||||||
|
icon: successIcon,
|
||||||
|
title: 'Submission Successful',
|
||||||
|
desc: 'Please review your submitted information in the AiDA in-platform message.\nYou may edit it if needed. Competition updates and results will be sent via email.'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
</script>
|
||||||
<style lang="less" scoped>
|
<style lang="less" scoped>
|
||||||
.success-container {
|
.success-container {
|
||||||
margin: 0 21.5rem;
|
margin: 0 21.5rem;
|
||||||
|
|||||||
@@ -141,6 +141,7 @@
|
|||||||
overflow: auto;
|
overflow: auto;
|
||||||
height: 100vh;
|
height: 100vh;
|
||||||
// 隐藏滚动条箭头,只显示滚动条本体
|
// 隐藏滚动条箭头,只显示滚动条本体
|
||||||
|
box-sizing: border-box;
|
||||||
&::-webkit-scrollbar {
|
&::-webkit-scrollbar {
|
||||||
display: none;
|
display: none;
|
||||||
width: 0;
|
width: 0;
|
||||||
@@ -154,6 +155,7 @@
|
|||||||
background-color: #232323;
|
background-color: #232323;
|
||||||
padding-left: 21.5rem;
|
padding-left: 21.5rem;
|
||||||
padding-right: 8.6rem;
|
padding-right: 8.6rem;
|
||||||
|
box-sizing: border-box;
|
||||||
.header-left {
|
.header-left {
|
||||||
.logo {
|
.logo {
|
||||||
width: 13rem;
|
width: 13rem;
|
||||||
@@ -176,6 +178,7 @@
|
|||||||
.footer {
|
.footer {
|
||||||
height: 10rem;
|
height: 10rem;
|
||||||
padding-left: 21.5rem;
|
padding-left: 21.5rem;
|
||||||
|
box-sizing: border-box;
|
||||||
padding-right: 22rem;
|
padding-right: 22rem;
|
||||||
background-color: #232323;
|
background-color: #232323;
|
||||||
.social-list {
|
.social-list {
|
||||||
|
|||||||
@@ -55,7 +55,7 @@
|
|||||||
.banner {
|
.banner {
|
||||||
height: 108rem;
|
height: 108rem;
|
||||||
background: url('@/assets/images/award/banner.png') no-repeat;
|
background: url('@/assets/images/award/banner.png') no-repeat;
|
||||||
background-size: 100% 100%;
|
background-size: cover;
|
||||||
position: relative;
|
position: relative;
|
||||||
.submit-btn {
|
.submit-btn {
|
||||||
width: 41rem;
|
width: 41rem;
|
||||||
@@ -63,6 +63,7 @@
|
|||||||
line-height: 6.394rem;
|
line-height: 6.394rem;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
border-radius: 3.2rem;
|
border-radius: 3.2rem;
|
||||||
|
background-color: rgba(35, 35, 35, 0.7);
|
||||||
box-shadow: inset 0 0 1119px 0 rgba(255, 255, 255, 0.3),
|
box-shadow: inset 0 0 1119px 0 rgba(255, 255, 255, 0.3),
|
||||||
inset -0.8px -2.4px 1.6px 0.4px rgba(255, 255, 255, 0.1),
|
inset -0.8px -2.4px 1.6px 0.4px rgba(255, 255, 255, 0.1),
|
||||||
inset 0.8px 2.4px 1.6px 0 rgba(255, 255, 255, 0.3);
|
inset 0.8px 2.4px 1.6px 0 rgba(255, 255, 255, 0.3);
|
||||||
@@ -72,8 +73,8 @@
|
|||||||
font-size: 2.4rem;
|
font-size: 2.4rem;
|
||||||
column-gap: 3.2rem;
|
column-gap: 3.2rem;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
top: 23.88rem;
|
left: 42.1rem;
|
||||||
left: 51rem;
|
bottom: 15.7rem;
|
||||||
backdrop-filter: blur(5px);
|
backdrop-filter: blur(5px);
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
.arrow {
|
.arrow {
|
||||||
@@ -90,6 +91,7 @@
|
|||||||
font-weight: 400;
|
font-weight: 400;
|
||||||
font-size: 2rem;
|
font-size: 2rem;
|
||||||
line-height: 2.2rem;
|
line-height: 2.2rem;
|
||||||
|
color: #232323E5;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user