| 
									
										
										
										
											2025-03-13 18:01:21 +08:00
										 |  |  | <template> | 
					
						
							|  |  |  |   <view class="contact-container"> | 
					
						
							|  |  |  |     <u-card title="Contact Us" class="card"> | 
					
						
							|  |  |  |       <view class="info"> | 
					
						
							| 
									
										
										
										
											2025-03-14 09:51:29 +08:00
										 |  |  |         <u-icon name="map" size="28" color="#2E7D32"/> | 
					
						
							| 
									
										
										
										
											2025-03-13 18:01:21 +08:00
										 |  |  |         <text class="info-text">123 Main Street, New York, NY 10001</text> | 
					
						
							|  |  |  |       </view> | 
					
						
							|  |  |  |       <view class="info"> | 
					
						
							| 
									
										
										
										
											2025-03-14 09:51:29 +08:00
										 |  |  |         <u-icon name="phone" size="28" color="#2E7D32"/> | 
					
						
							| 
									
										
										
										
											2025-03-13 18:01:21 +08:00
										 |  |  |         <text class="info-text">+1 (123) 456-7890</text> | 
					
						
							|  |  |  |       </view> | 
					
						
							|  |  |  |       <view class="info"> | 
					
						
							| 
									
										
										
										
											2025-03-14 09:51:29 +08:00
										 |  |  |         <u-icon name="email" size="28" color="#2E7D32"/> | 
					
						
							| 
									
										
										
										
											2025-03-13 18:01:21 +08:00
										 |  |  |         <text class="info-text">contact@company.com</text> | 
					
						
							|  |  |  |       </view> | 
					
						
							|  |  |  |     </u-card> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-14 09:51:29 +08:00
										 |  |  |     <u-form labelPosition="top" :rules="rules" :model="form" ref="formRef"> | 
					
						
							|  |  |  |       <u-form-item label="Name" prop="name" borderBottom> | 
					
						
							|  |  |  |         <u-input v-model="form.name" placeholder="Enter your name" font-size="18"/> | 
					
						
							| 
									
										
										
										
											2025-03-13 18:01:21 +08:00
										 |  |  |       </u-form-item> | 
					
						
							|  |  |  |       <u-form-item label="Email" prop="email" borderBottom> | 
					
						
							| 
									
										
										
										
											2025-03-14 09:51:29 +08:00
										 |  |  |         <u-input v-model="form.email" placeholder="Enter your email" font-size="18"/> | 
					
						
							| 
									
										
										
										
											2025-03-13 18:01:21 +08:00
										 |  |  |       </u-form-item> | 
					
						
							|  |  |  |       <u-form-item label="Message" prop="message" borderBottom> | 
					
						
							| 
									
										
										
										
											2025-03-14 09:51:29 +08:00
										 |  |  |         <u-textarea v-model="form.message" font-size="18" placeholder="Enter your message"></u-textarea> | 
					
						
							| 
									
										
										
										
											2025-03-13 18:01:21 +08:00
										 |  |  |       </u-form-item> | 
					
						
							|  |  |  |       <view class="button-container"> | 
					
						
							|  |  |  |         <u-button @click="submitForm" class="submit-button" text="Submit"></u-button> | 
					
						
							|  |  |  |       </view> | 
					
						
							|  |  |  |     </u-form> | 
					
						
							|  |  |  |   </view> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  | export default { | 
					
						
							|  |  |  |   data() { | 
					
						
							|  |  |  |     return { | 
					
						
							|  |  |  |       form: { | 
					
						
							|  |  |  |         name: '', | 
					
						
							|  |  |  |         email: '', | 
					
						
							|  |  |  |         message: '' | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       rules: { | 
					
						
							|  |  |  |         name: [ | 
					
						
							|  |  |  |           { | 
					
						
							|  |  |  |             required: true, | 
					
						
							| 
									
										
										
										
											2025-03-14 09:51:29 +08:00
										 |  |  |             message: 'Please enter your name', | 
					
						
							|  |  |  |             trigger: ['blur', 'change'] | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         ], | 
					
						
							|  |  |  |         email: [ | 
					
						
							|  |  |  |           { | 
					
						
							|  |  |  |             required: true, | 
					
						
							|  |  |  |             message: 'Please enter your email address', | 
					
						
							|  |  |  |             trigger: ['blur', 'change'] | 
					
						
							|  |  |  |           }, | 
					
						
							|  |  |  |           { | 
					
						
							|  |  |  |             pattern: /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/, | 
					
						
							|  |  |  |             message: 'Please enter a valid email address', | 
					
						
							|  |  |  |             trigger: ['blur', 'change'] | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         ], | 
					
						
							|  |  |  |         message: [ | 
					
						
							|  |  |  |           { | 
					
						
							|  |  |  |             required: true, | 
					
						
							|  |  |  |             message: 'Please enter your feedback', | 
					
						
							| 
									
										
										
										
											2025-03-13 18:01:21 +08:00
										 |  |  |             trigger: ['blur', 'change'] | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         ] | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   methods: { | 
					
						
							|  |  |  |     submitForm() { | 
					
						
							|  |  |  |       this.$refs.formRef.validate().then(res => { | 
					
						
							| 
									
										
										
										
											2025-03-14 09:51:29 +08:00
										 |  |  |         uni.showToast({title: 'Successfully', icon: 'success'}); | 
					
						
							|  |  |  |         this.form = {name: '', email: '', message: ''}; | 
					
						
							| 
									
										
										
										
											2025-03-13 18:01:21 +08:00
										 |  |  |       }).catch(errors => { | 
					
						
							| 
									
										
										
										
											2025-03-14 09:51:29 +08:00
										 |  |  |         uni.$u.toast('Validation failed') | 
					
						
							| 
									
										
										
										
											2025-03-13 18:01:21 +08:00
										 |  |  |       }) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <style lang="scss" scoped> | 
					
						
							|  |  |  | .contact-container { | 
					
						
							|  |  |  |   padding: 40rpx; | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  |   flex-direction: column; | 
					
						
							|  |  |  |   //align-items: center;
 | 
					
						
							|  |  |  |   //text-align: center;
 | 
					
						
							|  |  |  |   height: 100vh; | 
					
						
							|  |  |  |   font-size: 20rpx; | 
					
						
							|  |  |  |   background-color: #FFFFFF; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2025-03-14 09:51:29 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-13 18:01:21 +08:00
										 |  |  | .card { | 
					
						
							|  |  |  |   width: 90%; | 
					
						
							|  |  |  |   padding: 30rpx; | 
					
						
							|  |  |  |   font-size: 22rpx; | 
					
						
							|  |  |  |   background-color: #1B5E20; | 
					
						
							|  |  |  |   color: #FFFFFF; | 
					
						
							|  |  |  |   border-radius: 20rpx; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2025-03-14 09:51:29 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-13 18:01:21 +08:00
										 |  |  | .info { | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  |   align-items: center; | 
					
						
							|  |  |  |   justify-content: center; | 
					
						
							|  |  |  |   margin-bottom: 20rpx; | 
					
						
							|  |  |  |   color: #FFFFFF; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2025-03-14 09:51:29 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-13 18:01:21 +08:00
										 |  |  | .info-text { | 
					
						
							|  |  |  |   margin-left: 15rpx; | 
					
						
							|  |  |  |   font-size: 22rpx; | 
					
						
							|  |  |  |   color: #FFFFFF; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2025-03-14 09:51:29 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-13 18:01:21 +08:00
										 |  |  | .form-container { | 
					
						
							|  |  |  |   width: 90%; | 
					
						
							|  |  |  |   //display: flex;
 | 
					
						
							|  |  |  |   flex-direction: column; | 
					
						
							|  |  |  |   align-items: center; | 
					
						
							|  |  |  |   font-size: 22rpx; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2025-03-14 09:51:29 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-13 18:01:21 +08:00
										 |  |  | .button-container { | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  |   justify-content: center; | 
					
						
							|  |  |  |   width: 100%; | 
					
						
							|  |  |  |   margin-top: 20rpx; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2025-03-14 09:51:29 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-13 18:01:21 +08:00
										 |  |  | .submit-button { | 
					
						
							|  |  |  |   font-size: 22rpx; | 
					
						
							|  |  |  |   padding: 15rpx 30rpx; | 
					
						
							|  |  |  |   background-color: #2E7D32; | 
					
						
							|  |  |  |   color: #FFFFFF; | 
					
						
							|  |  |  |   border-radius: 10rpx; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | </style> |