| <template> | |
|     <view class="page"> | |
|         <!-- 导航栏 --> | |
|         <navbar :title="`${ !identity ? '团长申请' : '团长信息' }`" leftClick @leftClick="$utils.navigateBack" bgColor="#019245" | |
|             color="#fff" /> | |
| 
 | |
|         <!-- 顶部图片区域 --> | |
|         <view class="banner" v-if="!identity"> | |
|             <image src="/static/image/红烧肉.webp" mode="aspectFill" class="banner-image"></image> | |
|         </view> | |
| 
 | |
|         <view class="content-area"> | |
|             <!-- 送餐点照片上传区域 --> | |
|             <view class="section-title">送餐点照片</view> | |
|             <view class="section-block"> | |
|                 <view class="upload-container"> | |
|                     <view class="upload-area" @tap="chooseImage" v-if="!formData.spotImage"> | |
|                         <view class="plus">+</view> | |
|                         <view class="upload-text">添加图片</view> | |
|                     </view> | |
|                     <image v-else :src="formData.spotImage" mode="aspectFill" class="upload-area" | |
|                         @tap="chooseImage" /> | |
|                 </view> | |
|             </view> | |
| 
 | |
|             <!-- 送餐点信息填写区域 --> | |
|             <view class="section-title">送餐点信息</view> | |
|             <view class="section-block"> | |
| 
 | |
|                 <view class="form-item"> | |
|                     <text class="label">送餐点名称</text> | |
|                     <input class="input" type="text" v-model="formData.spotName" placeholder="请输入送餐点名称" | |
|                         placeholder-class="placeholder" /> | |
|                 </view> | |
|                 <view class="form-item"> | |
|                     <text class="label">您的姓名</text> | |
|                     <input class="input" type="nickname" v-model="formData.name" placeholder="请输入您的姓名" | |
|                         placeholder-class="placeholder" /> | |
|                 </view> | |
|                 <view class="form-item"> | |
|                     <text class="label">联系手机号</text> | |
|                     <input class="input" type="number" v-model="formData.phone" placeholder="请输入您的手机号" | |
|                         placeholder-class="placeholder" /> | |
|                 </view> | |
|  | |
|                 <view class="form-item region-item"> | |
|                     <text class="label">所在地区</text> | |
|  | |
|                     <picker mode="region" @change="regionSelect"> | |
|                         <text style="font-size: 30rpx;">{{ formData.area || '请选择' }}</text> | |
|                     </picker> | |
|                     <uv-icon name="arrow-right" color="#000"  style="margin-left: 2rpx;"/> | |
|                 </view> | |
|                 <view class="address-item"> | |
|                     <text class="label">详细地址</text> | |
|                     <view class="address-box"> | |
|                         <textarea class="address-input" v-model="formData.address" placeholder="请输入详细地址" | |
|                             placeholder-class="placeholder" /> | |
|                     </view> | |
|                 </view> | |
|             </view> | |
|             <!-- 提交按钮 --> | |
|             <view v-if="!this.beModify" class="submit-btn" @tap="submitApplication"> | |
|                 {{ !identity ? '提交申请' : '提交保存' }} | |
|             </view> | |
|             <view v-else class="submit-btn-container"> | |
|                 <view class="submit-btn-modify" @tap="submitApplication">修改</view> | |
|                 <view class="submit-btn-save" @tap="submitApplication">保存</view> | |
|             </view> | |
|         </view> | |
|     </view> | |
| </template> | |
| 
 | |
| <script> | |
| import navbar from '@/components/base/navbar.vue' | |
| import shareConfig from '@/mixins/configList.js' | |
| 
 | |
| export default { | |
|     components: { | |
|         navbar | |
|     }, | |
|     mixins: [shareConfig], | |
|     data() { | |
|         return { | |
|             formData: { | |
|                 spotImage: '', // 上传的送餐点照片 | |
|                 spotName: '', // 送餐点名称 | |
|                 name: '', // 联系人姓名 | |
|                 phone: '', // 联系电话 | |
|                 area: '', // 所在地区 | |
|                 address: '' // 详细地址 | |
|             }, | |
|             identity: uni.getStorageSync('identity'), | |
|             beModify: false // 为团员并且可以修改的模式 | |
|         } | |
|     }, | |
|     methods: { | |
|         // 选择图片 | |
|         chooseImage() { | |
|             uni.chooseImage({ | |
|                 count: 1, | |
|                 sizeType: ['compressed'], | |
|                 sourceType: ['album', 'camera'], | |
|                 success: (res) => { | |
|                     // 这里可以添加图片上传到服务器的逻辑 | |
|                     // 暂时只展示选择的图片 | |
|                     this.formData.spotImage = res.tempFilePaths[0] | |
|                 } | |
|             }) | |
|         }, | |
| 
 | |
|         // 显示地区选择器(当前只是一个简单的点击反应) | |
|         regionSelect(e) { | |
|             this.formData.area = e.detail.value[1] + e.detail.value[2] | |
|         }, | |
| 
 | |
|         // 提交申请 | |
|         submitApplication() { | |
|             // 表单验证 | |
|             if (!this.formData.spotImage) { | |
|                 return uni.showToast({ | |
|                     title: '请上传送餐点照片', | |
|                     icon: 'none' | |
|                 }) | |
|             } | |
| 
 | |
|             if (!this.formData.spotName) { | |
|                 return uni.showToast({ | |
|                     title: '请输入送餐点名称', | |
|                     icon: 'none' | |
|                 }) | |
|             } | |
| 
 | |
|             if (!this.formData.name) { | |
|                 return uni.showToast({ | |
|                     title: '请输入您的姓名', | |
|                     icon: 'none' | |
|                 }) | |
|             } | |
| 
 | |
|             if (!this.formData.phone) { | |
|                 return uni.showToast({ | |
|                     title: '请输入联系手机号', | |
|                     icon: 'none' | |
|                 }) | |
|             } | |
| 
 | |
|             if (!this.$utils.verificationPhone(this.formData.phone)) { | |
|                 return uni.showToast({ | |
|                     title: '请输入正确的手机号', | |
|                     icon: 'none' | |
|                 }) | |
|             } | |
| 
 | |
|             if (!this.formData.area) { | |
|                 return uni.showToast({ | |
|                     title: '请选择所在地区', | |
|                     icon: 'none' | |
|                 }) | |
|             } | |
| 
 | |
|             if (!this.formData.address) { | |
|                 return uni.showToast({ | |
|                     title: '请输入详细地址', | |
|                     icon: 'none' | |
|                 }) | |
|             } | |
| 
 | |
|             // 显示提交中 | |
|             uni.showLoading({ | |
|                 title: '提交中...' | |
|             }) | |
| 
 | |
|             // 模拟提交申请的过程 | |
|             setTimeout(() => { | |
|                 uni.hideLoading() | |
| 
 | |
|                 if (this.identity) { | |
|                     // 如果是团长 保存表单信息 直接返回了 | |
|                     this.saveInfo()  | |
|                     return | |
|                 } | |
| 
 | |
|                 console.log(this.formData); | |
|                  | |
| 
 | |
|                 // 如果是团员 提交申请 | |
|                 this.$api('addLeader', { | |
|                     ...this.formData, | |
|                 }, res => { | |
|                     if (res.code == 200) { | |
|                         uni.showModal({ | |
|                             title: '提交成功!', | |
|                             content: '我们的工作人员会及时与您联系,\n请保持电话畅通!', | |
|                             showCancel: false, | |
|                             confirmColor: '#019245', | |
|                             success: (res) => { | |
|                                 if (res.confirm) { | |
|                                     // 如果是团员 延迟返回上一页 | |
|                                     setTimeout(() => { | |
|                                         this.$utils.navigateBack() | |
|                                     }, 500) | |
|                                 } | |
|                             } | |
|                         }) | |
|                     } | |
|                 }) | |
| 
 | |
|             }, 1000) | |
|         }, | |
| 
 | |
|         // 保存信息 针对团长端 | |
|         saveInfo() { | |
|             uni.setStorageSync('team_form_data', JSON.stringify(this.formData)) | |
|             uni.showToast({ | |
|                 title: '保存成功!', | |
|                 icon: 'none', | |
|                 duration: 2000 | |
|             }) | |
| 
 | |
|         } | |
|     }, | |
|     onLoad() { | |
|         if (this.identity) { | |
|             // 如果是团员 才去获取团长信息 | |
|             const addData = uni.getStorageSync('team_form_data') | |
|             if (addData) { | |
|                 this.beModify = true | |
|                 this.formData = JSON.parse(addData) | |
|             } | |
|         } | |
|     } | |
| } | |
| </script> | |
| 
 | |
| <style lang="scss" scoped> | |
| .page { | |
|     background-color: #f5f5f5; | |
|     min-height: 100vh; | |
| } | |
| 
 | |
| .banner { | |
|     width: 100%; | |
|     height: 240rpx; | |
|     background-color: #019245; | |
| 
 | |
|     .banner-image { | |
|         width: 100%; | |
|         height: 100%; | |
|         display: block; | |
|     } | |
| } | |
| 
 | |
| .content-area { | |
|     padding: 20rpx; | |
| } | |
| 
 | |
| .section-block { | |
|     margin-bottom: 20rpx; | |
|     background-color: #fff; | |
|     border-radius: 20rpx; | |
|     padding: 10rpx 20rpx; | |
| 
 | |
|     overflow: hidden; | |
| } | |
| 
 | |
| .section-title { | |
|     font-size: 28rpx; | |
|     color: #333; | |
|     padding: 20rpx; | |
|     // border-bottom: 1rpx solid #f5f5f5; | |
| } | |
| 
 | |
| .upload-container { | |
|     padding: 20rpx; | |
|     min-height: 140rpx; | |
| } | |
| 
 | |
| .upload-area { | |
|     width: 150rpx; | |
|     height: 150rpx; | |
|     border: 3rpx dashed $uni-color; | |
|     // border-radius: 8rpx; | |
|     display: flex; | |
|     flex-direction: column; | |
|     justify-content: center; | |
|     align-items: center; | |
| 
 | |
|     .plus { | |
|         font-size: 80rpx; | |
|         color: $uni-color; | |
|         line-height: 1; | |
|         // margin-bottom: 5rpx; | |
|         font-weight: 100; | |
|     } | |
| 
 | |
|     .upload-text { | |
|         font-size: 24rpx; | |
|         color: $uni-color-third; | |
|     } | |
| } | |
| 
 | |
| 
 | |
| .form-item { | |
|     padding: 24rpx 0; | |
|     display: flex; | |
|     align-items: center; | |
|     border-bottom: 2rpx solid #C7C7C7; | |
| 
 | |
|     &:last-child { | |
|         border-bottom: none; | |
|     } | |
| } | |
| 
 | |
| .label { | |
|     flex: 3; | |
|     font-size: 28rpx; | |
|     color: #333; | |
|     padding-left: 10rpx; | |
| } | |
| 
 | |
| .input { | |
|     flex: 2; | |
|     font-size: 28rpx; | |
|     // height: 60rpx; | |
|     text-align: left; | |
| } | |
| 
 | |
| .placeholder, | |
| .region-item  text.placeholder { | |
|     // height: 60rpx; | |
|     color: #999; | |
| } | |
| 
 | |
| .region-item { | |
|     cursor: pointer; | |
| 
 | |
| } | |
| 
 | |
| .address-item { | |
|     padding: 24rpx 0; | |
|     display: flex; | |
|     flex-direction: column; | |
|     gap: 20rpx; | |
| 
 | |
|     .address-box {} | |
| 
 | |
|     .address-input { | |
|         padding: 20rpx; | |
|         background-color: #F5F5F5; | |
|         border-radius: 10rpx; | |
|         width: inherit; | |
|         height: 60rpx; | |
|         font-size: 28rpx; | |
|     } | |
| } | |
| 
 | |
| .submit-btn { | |
|     width: 80%; | |
|     margin: 40rpx auto 0; | |
|     height: 100rpx; | |
|     background-color: $uni-color; | |
|     color: #fff; | |
|     font-size: 32rpx; | |
|     display: flex; | |
|     justify-content: center; | |
|     align-items: center; | |
|     border-radius: 50rpx; | |
| } | |
| .submit-btn-container { | |
|     display: flex; | |
|     justify-content: space-between; | |
|     align-items: center; | |
|     margin: 40rpx auto 0; | |
|     width: 74%; | |
|     .submit-btn-modify { | |
|         width: 45%; | |
|         height: 90rpx; | |
|         background-color: #fff; | |
|         color: $uni-color; | |
|         font-size: 32rpx; | |
|         display: flex; | |
|         justify-content: center; | |
|         align-items: center; | |
|         border-radius: 50rpx; | |
|         border: 4rpx solid $uni-color; | |
|     } | |
|     .submit-btn-save { | |
|         width: 45%; | |
|         height: 90rpx; | |
|         background-color: $uni-color; | |
|         color: #fff; | |
|         font-size: 32rpx; | |
|         display: flex; | |
|         justify-content: center; | |
|         align-items: center; | |
|         border-radius: 50rpx; | |
|     } | |
| } | |
| </style> |