This commit is contained in:
aaron 2025-03-04 11:52:11 +08:00
parent 07aa07bbb7
commit ce3fed4040
2 changed files with 305 additions and 147 deletions

View File

@ -32,13 +32,16 @@
</form> </form>
</div> </div>
<!-- 提交成功弹窗 --> <!-- 将成功弹窗改为通用模态弹窗 -->
<div class="success-modal" v-if="showSuccessModal"> <div class="modal" v-if="showModal">
<div class="modal-content"> <div class="modal-content">
<div class="success-icon"></div> <div class="modal-icon" :class="{ 'success-icon': isSuccess, 'error-icon': !isSuccess }">
<h3>申请提交成功</h3> <span v-if="isSuccess"></span>
<p>我们将尽快处理您的小区开通申请</p> <span v-else>!</span>
<button @click="closeSuccessModal" class="btn-confirm">确定</button> </div>
<h3>{{ modalTitle }}</h3>
<p>{{ modalMessage }}</p>
<button @click="closeModal" class="btn-confirm">确定</button>
</div> </div>
</div> </div>
</div> </div>
@ -55,7 +58,12 @@ export default {
const router = useRouter() const router = useRouter()
const route = useRoute() const route = useRoute()
const isSubmitting = ref(false) const isSubmitting = ref(false)
const showSuccessModal = ref(false) // showSuccessModal showModal
const showModal = ref(false)
//
const isSuccess = ref(true)
const modalTitle = ref('')
const modalMessage = ref('')
const userId = ref('') const userId = ref('')
const lastTouchEnd = ref(0) const lastTouchEnd = ref(0)
@ -128,41 +136,67 @@ export default {
} }
const submitRequest = async () => { const submitRequest = async () => {
if (isSubmitting.value) return
isSubmitting.value = true
try { try {
if (!userId.value) { // - 使
alert('缺少用户ID无法提交申请') const requestData = {
return user_id: userId.value || 0,
}
isSubmitting.value = true
// user_id
const submitData = {
user_id: userId.value,
community_name: formData.communityName, community_name: formData.communityName,
community_address: formData.address community_address: formData.address
} }
// 使 apiClient axios //
const response = await apiClient.post('/api/feedback/community-apply', submitData) const response = await apiClient.post('/api/feedback/community-apply', requestData)
console.log('提交成功:', response.data) //
if (response.data && response.data.code === 200) {
// console.log('申请提交成功:', response.data)
showSuccessModal.value = true
//
isSuccess.value = true
modalTitle.value = '申请提交成功'
modalMessage.value = '我们将尽快审核您的小区开通申请'
showModal.value = true
//
formData.communityName = ''
formData.address = ''
} else {
//
const errorMessage = response.data?.message || '提交失败,请稍后重试'
console.error('提交申请失败:', errorMessage)
isSuccess.value = false
modalTitle.value = '提交失败'
modalMessage.value = errorMessage
showModal.value = true
}
} catch (error) { } catch (error) {
console.error('提交失败:', error) console.error('提交申请失败:', error)
alert('提交失败,请稍后重试')
//
const errorMessage = error.response?.data?.message || '提交失败,请稍后重试'
isSuccess.value = false
modalTitle.value = '提交失败'
modalMessage.value = errorMessage
showModal.value = true
} finally { } finally {
isSubmitting.value = false isSubmitting.value = false
} }
} }
const closeSuccessModal = () => { // closeSuccessModal closeModal
showSuccessModal.value = false const closeModal = () => {
showModal.value = false
// //
goBack() if (isSuccess.value) {
goBack()
}
} }
const goBack = () => { const goBack = () => {
@ -178,9 +212,12 @@ export default {
return { return {
formData, formData,
isSubmitting, isSubmitting,
showSuccessModal, showModal,
isSuccess,
modalTitle,
modalMessage,
submitRequest, submitRequest,
closeSuccessModal, closeModal,
goBack, goBack,
handleTouchStart handleTouchStart
} }
@ -307,13 +344,13 @@ export default {
background-color: #FFD633; background-color: #FFD633;
} }
/* 成功弹窗样式 */ /* 添加模态弹窗样式 */
.success-modal { .modal {
position: fixed; position: fixed;
top: 0; top: 0;
left: 0; left: 0;
right: 0; width: 100%;
bottom: 0; height: 100%;
background-color: rgba(0, 0, 0, 0.5); background-color: rgba(0, 0, 0, 0.5);
display: flex; display: flex;
justify-content: center; justify-content: center;
@ -333,10 +370,9 @@ export default {
align-items: center; align-items: center;
} }
.success-icon { .modal-icon {
width: 60px; width: 60px;
height: 60px; height: 60px;
background-color: #FFCC00;
border-radius: 50%; border-radius: 50%;
display: flex; display: flex;
justify-content: center; justify-content: center;
@ -346,6 +382,14 @@ export default {
margin-bottom: 20px; margin-bottom: 20px;
} }
.success-icon {
background-color: #FFCC00;
}
.error-icon {
background-color: #FF6B6B;
}
.modal-content h3 { .modal-content h3 {
font-size: 20px; font-size: 20px;
margin-bottom: 10px; margin-bottom: 10px;
@ -361,7 +405,13 @@ export default {
background-color: #FFCC00; background-color: #FFCC00;
color: #333333; color: #333333;
border: none; border: none;
border-radius: 8px;
padding: 12px 15px;
width: 100%; width: 100%;
font-size: 16px;
font-weight: 500;
cursor: pointer;
transition: background-color 0.3s;
} }
.btn-confirm:hover { .btn-confirm:hover {

View File

@ -15,13 +15,34 @@
<div class="form-group"> <div class="form-group">
<label for="phone">您的电话</label> <label for="phone">您的电话</label>
<div class="phone-input-group">
<input
type="tel"
id="phone"
v-model="formData.phone"
placeholder="请输入您的联系电话"
required
pattern="[0-9]{11}"
/>
<button
type="button"
class="btn-send-code"
@click="sendVerificationCode"
:disabled="cooldown > 0"
>
{{ cooldown > 0 ? `${cooldown}秒后重发` : '发送验证码' }}
</button>
</div>
</div>
<div class="form-group">
<label for="phoneCode">验证码</label>
<input <input
type="tel" type="text"
id="phone" id="phoneCode"
v-model="formData.phone" v-model="formData.phone_code"
placeholder="请输入您的联系电话" placeholder="请输入短信验证码"
required required
pattern="[0-9]{11}"
/> />
</div> </div>
@ -74,13 +95,16 @@
</form> </form>
</div> </div>
<!-- 提交成功弹窗 --> <!-- 成功弹窗 -->
<div class="success-modal" v-if="showSuccessModal"> <div class="modal" v-if="showModal">
<div class="modal-content"> <div class="modal-content">
<div class="success-icon"></div> <div class="modal-icon" :class="{ 'success-icon': isSuccess, 'error-icon': !isSuccess }">
<h3>申请提交成功</h3> <span v-if="isSuccess"></span>
<p>我们将尽快审核您的合伙人申请</p> <span v-else>!</span>
<button @click="closeSuccessModal" class="btn-confirm">确定</button> </div>
<h3>{{ modalTitle }}</h3>
<p>{{ modalMessage }}</p>
<button @click="closeModal" class="btn-confirm">确定</button>
</div> </div>
</div> </div>
</div> </div>
@ -97,14 +121,19 @@ export default {
const router = useRouter() const router = useRouter()
const route = useRoute() const route = useRoute()
const isSubmitting = ref(false) const isSubmitting = ref(false)
const showSuccessModal = ref(false) const showModal = ref(false)
const isSuccess = ref(true)
const modalTitle = ref('')
const modalMessage = ref('')
const userId = ref('') const userId = ref('')
const lastTouchEnd = ref(0) const lastTouchEnd = ref(0)
const cooldown = ref(0)
const formData = reactive({ const formData = reactive({
name: '', name: '',
phone: '', phone: '',
partnerType: 'community', // phone_code: '',
partnerType: 'community',
serviceArea: '' serviceArea: ''
}) })
@ -130,90 +159,121 @@ export default {
lastTouchEnd.value = now lastTouchEnd.value = now
} }
const handleTouchMove = (event) => { document.addEventListener('touchend', handleTouchEnd)
if (event.touches.length > 1) {
event.preventDefault()
}
}
document.addEventListener('touchend', handleTouchEnd, { passive: false }) onBeforeUnmount(() => {
document.addEventListener('touchmove', handleTouchMove, { passive: false }) document.removeEventListener('touchend', handleTouchEnd)
document.title = '蜂快到家'
// 便 })
window._partnerRequestTouchHandlers = {
handleTouchEnd,
handleTouchMove
}
}) })
onBeforeUnmount(() => {
//
if (window._partnerRequestTouchHandlers) {
document.removeEventListener('touchend', window._partnerRequestTouchHandlers.handleTouchEnd)
document.removeEventListener('touchmove', window._partnerRequestTouchHandlers.handleTouchMove)
delete window._partnerRequestTouchHandlers
}
})
const handleTouchStart = (event) => {
//
if (event.touches.length > 1) {
event.preventDefault()
}
}
const checkMiniProgramEnvironment = () => { const checkMiniProgramEnvironment = () => {
// //
const ua = navigator.userAgent.toLowerCase() const userAgent = navigator.userAgent.toLowerCase()
const isMiniProgram = ua.indexOf('miniprogram') > -1 || window.__wxjs_environment === 'miniprogram' const isWechatMiniProgram = /miniprogram/.test(userAgent) || window.__wxjs_environment === 'miniprogram'
console.log('Is Mini Program:', isMiniProgram) console.log('是否在小程序环境中:', isWechatMiniProgram)
} }
const selectPartnerType = (type) => { const selectPartnerType = (type) => {
formData.partnerType = type formData.partnerType = type
// }
formData.serviceArea = ''
const sendVerificationCode = async () => {
//
if (!/^1[3-9]\d{9}$/.test(formData.phone)) {
alert('请输入正确的手机号码')
return
}
try {
//
await apiClient.post('/api/user/send-code', {
phone: formData.phone
})
//
cooldown.value = 60
const timer = setInterval(() => {
cooldown.value--
if (cooldown.value <= 0) {
clearInterval(timer)
}
}, 1000)
alert('验证码已发送,请注意查收')
} catch (error) {
console.error('发送验证码失败:', error)
alert('发送验证码失败,请稍后重试')
}
} }
const submitRequest = async () => { const submitRequest = async () => {
if (isSubmitting.value) return
isSubmitting.value = true
try { try {
if (!userId.value) { //
alert('缺少用户ID无法提交申请') const requestData = {
return user_id: userId.value || 0,
}
isSubmitting.value = true
// user_id
const submitData = {
user_id: userId.value,
name: formData.name, name: formData.name,
phone: formData.phone, phone: formData.phone,
phone_code: formData.phone_code,
type: formData.partnerType, type: formData.partnerType,
service_target: formData.serviceArea service_target: formData.serviceArea
} }
// 使 apiClient axios //
const response = await apiClient.post('/api/feedback/partner-apply', submitData) const response = await apiClient.post('/api/feedback/partner-apply', requestData)
console.log('提交成功:', response.data) //
if (response.data && response.data.code === 200) {
// console.log('申请提交成功:', response.data)
showSuccessModal.value = true
//
isSuccess.value = true
modalTitle.value = '申请提交成功'
modalMessage.value = '我们将尽快处理您的合伙人申请'
showModal.value = true
//
formData.name = ''
formData.phone = ''
formData.phone_code = ''
formData.serviceArea = ''
} else {
//
const errorMessage = response.data?.message || '提交失败,请稍后重试'
console.error('提交申请失败:', errorMessage)
isSuccess.value = false
modalTitle.value = '提交失败'
modalMessage.value = errorMessage
showModal.value = true
}
} catch (error) { } catch (error) {
console.error('提交失败:', error) console.error('提交申请失败:', error)
alert('提交失败,请稍后重试')
//
const errorMessage = error.response?.data?.message || '提交失败,请稍后重试'
isSuccess.value = false
modalTitle.value = '提交失败'
modalMessage.value = errorMessage
showModal.value = true
} finally { } finally {
isSubmitting.value = false isSubmitting.value = false
} }
} }
const closeSuccessModal = () => { const closeModal = () => {
showSuccessModal.value = false showModal.value = false
// //
goBack() if (isSuccess.value) {
goBack()
}
} }
const goBack = () => { const goBack = () => {
@ -226,15 +286,27 @@ export default {
} }
} }
const handleTouchStart = (event) => {
// iOS
if (event.touches.length > 1) {
event.preventDefault()
}
}
return { return {
formData, formData,
isSubmitting, isSubmitting,
showSuccessModal, showModal,
isSuccess,
modalTitle,
modalMessage,
selectPartnerType,
submitRequest, submitRequest,
closeSuccessModal, closeModal,
goBack, goBack,
handleTouchStart, handleTouchStart,
selectPartnerType sendVerificationCode,
cooldown
} }
} }
} }
@ -242,21 +314,15 @@ export default {
<style scoped> <style scoped>
.partner-request-container { .partner-request-container {
/* 添加触摸相关样式 */
-webkit-touch-callout: none;
-webkit-user-select: none;
-khtml-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
touch-action: manipulation;
min-height: 100vh; min-height: 100vh;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
align-items: center; align-items: center;
padding: 20px 15px; justify-content: flex-start;
padding: 20px 15px 30px;
background: linear-gradient(to bottom, #FFCC00, #FFFFFF); background: linear-gradient(to bottom, #FFCC00, #FFFFFF);
position: relative;
overflow: hidden;
} }
.request-card { .request-card {
@ -269,11 +335,11 @@ export default {
} }
.page-title { .page-title {
font-size: 22px; font-size: 24px;
font-weight: bold; font-weight: bold;
color: #333333; color: #333333;
text-align: center;
margin-bottom: 25px; margin-bottom: 25px;
text-align: center;
} }
.request-form { .request-form {
@ -310,6 +376,39 @@ export default {
outline: none; outline: none;
} }
/* 手机号输入组样式 */
.phone-input-group {
display: flex;
gap: 10px;
}
.phone-input-group input {
flex: 1;
}
.btn-send-code {
padding: 0 15px;
background-color: #FFCC00;
color: #333333;
border: none;
border-radius: 8px;
font-size: 14px;
font-weight: 500;
cursor: pointer;
white-space: nowrap;
transition: background-color 0.3s;
}
.btn-send-code:hover {
background-color: #FFD633;
}
.btn-send-code:disabled {
background-color: #DDDDDD;
color: #999999;
cursor: not-allowed;
}
/* 合伙类型选择器样式 */ /* 合伙类型选择器样式 */
.partner-type-selector { .partner-type-selector {
display: flex; display: flex;
@ -363,25 +462,25 @@ export default {
.form-actions { .form-actions {
display: flex; display: flex;
justify-content: space-between; gap: 15px;
margin-top: 10px; margin-top: 10px;
} }
.btn-cancel, .btn-cancel, .btn-submit {
.btn-submit, flex: 1;
.btn-confirm { padding: 12px 15px;
padding: 12px 25px;
border-radius: 8px; border-radius: 8px;
font-size: 16px; font-size: 16px;
font-weight: 500; font-weight: 500;
cursor: pointer; cursor: pointer;
transition: all 0.3s; transition: all 0.3s;
text-align: center;
} }
.btn-cancel { .btn-cancel {
background-color: #F5F5F5; background-color: #F2F2F2;
color: #666666; color: #666666;
border: 1px solid #DDDDDD; border: none;
} }
.btn-submit { .btn-submit {
@ -390,26 +489,27 @@ export default {
border: none; border: none;
} }
.btn-submit:disabled {
background-color: #FFE580;
cursor: not-allowed;
}
.btn-cancel:hover { .btn-cancel:hover {
background-color: #EEEEEE; background-color: #E6E6E6;
} }
.btn-submit:hover:not(:disabled) { .btn-submit:hover {
background-color: #FFD633; background-color: #FFD633;
} }
.btn-submit:disabled {
background-color: #DDDDDD;
color: #999999;
cursor: not-allowed;
}
/* 成功弹窗样式 */ /* 成功弹窗样式 */
.success-modal { .modal {
position: fixed; position: fixed;
top: 0; top: 0;
left: 0; left: 0;
right: 0; width: 100%;
bottom: 0; height: 100%;
background-color: rgba(0, 0, 0, 0.5); background-color: rgba(0, 0, 0, 0.5);
display: flex; display: flex;
justify-content: center; justify-content: center;
@ -429,10 +529,9 @@ export default {
align-items: center; align-items: center;
} }
.success-icon { .modal-icon {
width: 60px; width: 60px;
height: 60px; height: 60px;
background-color: #FFCC00;
border-radius: 50%; border-radius: 50%;
display: flex; display: flex;
justify-content: center; justify-content: center;
@ -442,6 +541,14 @@ export default {
margin-bottom: 20px; margin-bottom: 20px;
} }
.success-icon {
background-color: #FFCC00;
}
.error-icon {
background-color: #FF6B6B;
}
.modal-content h3 { .modal-content h3 {
font-size: 20px; font-size: 20px;
margin-bottom: 10px; margin-bottom: 10px;
@ -457,7 +564,13 @@ export default {
background-color: #FFCC00; background-color: #FFCC00;
color: #333333; color: #333333;
border: none; border: none;
border-radius: 8px;
padding: 12px 15px;
width: 100%; width: 100%;
font-size: 16px;
font-weight: 500;
cursor: pointer;
transition: background-color 0.3s;
} }
.btn-confirm:hover { .btn-confirm:hover {
@ -486,17 +599,12 @@ export default {
font-size: 15px; font-size: 15px;
} }
.partner-type-selector {
flex-direction: column;
gap: 10px;
}
.partner-type-option { .partner-type-option {
padding: 10px 12px; padding: 10px 12px;
} }
.option-label { .option-label {
font-size: 15px; font-size: 14px;
} }
} }
</style> </style>