Bladeren bron

语言切换

pingan\平安 3 dagen geleden
bovenliggende
commit
d6363e8088
57 gewijzigde bestanden met toevoegingen van 822 en 776 verwijderingen
  1. 8 0
      app5.js
  2. 42 2
      output3.json
  3. 3 3
      pages/aboutMy/aboutMy.vue
  4. 29 29
      pages/activation/activation.vue
  5. 2 2
      pages/activity/activity.vue
  6. 4 4
      pages/addUser/addUser.vue
  7. 68 68
      pages/battery/battery.vue
  8. 5 5
      pages/batteryDetail/batteryDetail.vue
  9. 13 13
      pages/batteryPackage/batteryPackage.vue
  10. 14 14
      pages/batteryRecord/batteryRecord.vue
  11. 36 37
      pages/bluetoothUnlock/bluetoothPair.vue
  12. 11 11
      pages/bluetoothUnlock/unlockSet.vue
  13. 16 16
      pages/cabinetDetail/cabinetDetail.vue
  14. 13 13
      pages/carDetail/carDetail.vue
  15. 1 1
      pages/carFunctionSet/more.vue
  16. 5 5
      pages/carFunctionSet/unbind.vue
  17. 7 7
      pages/carList/carList.vue
  18. 12 12
      pages/carLocation/carLocation.vue
  19. 5 5
      pages/contract/contract.vue
  20. 5 5
      pages/dashboard/dashboard.vue
  21. 5 5
      pages/deviceInfo/deviceInfo.vue
  22. 14 14
      pages/feedback/index.vue
  23. 8 8
      pages/index/components/AndroidUnlockAuth.vue
  24. 12 12
      pages/index/components/IosUnlockAuth.vue
  25. 32 32
      pages/index/components/control/control.vue
  26. 3 3
      pages/index/components/mapCard/mapCard.vue
  27. 13 13
      pages/index/components/unleasedPages/unleasedPages.vue
  28. 1 1
      pages/index/homeNotRent.vue
  29. 8 8
      pages/index/index.vue
  30. 13 13
      pages/login/login.vue
  31. 1 1
      pages/loginRegister/changePassword.vue
  32. 1 1
      pages/loginRegister/forgetPassword.vue
  33. 3 3
      pages/loginRegister/login.vue
  34. 2 2
      pages/loginRegister/register.vue
  35. 16 16
      pages/manualInput/manualInput.vue
  36. 1 1
      pages/message/detail.vue
  37. 4 4
      pages/message/index.vue
  38. 5 5
      pages/message/location.vue
  39. 13 13
      pages/mileageStatistics/index.vue
  40. 9 9
      pages/modifyPhone/modifyPhone.vue
  41. 2 2
      pages/moreInfo/moreInfo.vue
  42. 18 18
      pages/my/my.vue
  43. 12 12
      pages/my/set.vue
  44. 17 17
      pages/openCabinet/openCabinet.vue
  45. 58 58
      pages/order/order.vue
  46. 119 120
      pages/orderStatus/orderStatus.vue
  47. 20 20
      pages/package/package.vue
  48. 13 13
      pages/phoneLogin/phoneLogin.vue
  49. 12 12
      pages/powerSetting/powerSetting.vue
  50. 27 27
      pages/purchaseOrder/purchaseOrder.vue
  51. 18 18
      pages/scanCar/scanCar.vue
  52. 6 6
      pages/service/components/carRentalList/carRentalList.vue
  53. 2 2
      pages/service/components/leaseType/leaseType.vue
  54. 10 10
      pages/service/service.vue
  55. 13 13
      pages/storeDetails/storeDetails.vue
  56. 8 8
      pages/travelingTrack/travelingTrack.vue
  57. 4 4
      pages/userManagement/userManagement.vue

+ 8 - 0
app5.js

@@ -27,6 +27,10 @@ function processFile(filePath) {
     // 替换 <template> 中的内容
     content = content.replace(templateRegex, (match, templateContent) => {
         return match.replace(chineseRegex, (text) => {
+            // 跳过已有的 $t()
+            if (templateContent.includes(`$t('${langData[text]}')`) || templateContent.includes(`$t("${langData[text]}")`)) {
+                return text; // 不替换
+            }
             return replaceText(text, '{{ $t(\'$1\') }}');
         });
     });
@@ -34,6 +38,10 @@ function processFile(filePath) {
     // 替换 <script> 中的内容
     content = content.replace(scriptRegex, (match, scriptContent) => {
         return match.replace(/(['"])([\u4e00-\u9fa5\u3000-\u303f\uff01-\uff5e\u201c-\u201d\u3008-\u3011]+)\1/g, (_, quote, text) => {
+            // 跳过已有的 $t()
+            if (scriptContent.includes(`this.$t('${langData[text]}')`) || scriptContent.includes(`this.$t("${langData[text]}")`)) {
+                return `${quote}${text}${quote}`; // 不替换
+            }
             return replaceText(text, 'this.$t(\'$1\')');
         });
     });

+ 42 - 2
output3.json

@@ -821,5 +821,45 @@
   "暂无骑行数据!": "No cycling data available!",
   "共享用户": "Shared User",
   "家人、朋友长期共用车辆,授权账户可以使用感应解锁,寻车定位,查看设置等功能;": "Family/Friends Share – Authorized accounts can use functions like unlock, locate, and settings.",
-  "您还未绑定车辆": "You have not bound a vehicle yet."
-}
+  "您还未绑定车辆": "You have not bound a vehicle yet.",
+  ",": "text_824",
+  "车辆激活": "text_825",
+  "车辆品牌:": "text_826",
+  "车辆颜色:": "text_827",
+  "车牌号:": "text_828",
+  "上传照片": "text_829",
+  "这里是关于激活车辆照片的文案描述,这里是关于激活车辆照片的文案描述": "text_830",
+  "+": "text_831",
+  "你确定要删除吗?": "text_832",
+  "还车成功!": "text_833",
+  "《小众电动车租赁用户协议》": "text_834",
+  "秒换电,瞬间满电,畅享骑行新体验!": "text_835",
+  "不限次数": "text_836",
+  "部分成功": "text_837",
+  "“": "text_838",
+  "”,请在系统弹窗中选择": "text_839",
+  "”,以完成功能开启。": "text_840",
+  "、": "text_841",
+  "是否切换到车辆": "text_842",
+  "滑动启动": "text_843",
+  "扫码失败,请重新扫码": "text_844",
+  "您还未购买换电套餐,是否前往购买换电套餐?": "text_845",
+  "当前车辆暂未绑定电池": "text_846",
+  "扫码的是机柜": "text_847",
+  "扫码的是车辆": "text_848",
+  "请扫描机柜二维码": "text_849",
+  "《": "text_850",
+  "电动车租赁用户协议》": "text_851",
+  "《隐私协议》": "text_852",
+  "》": "text_853",
+  "信息详情": "text_854",
+  "您还没有设备消息": "text_855",
+  "您还没有系统消息": "text_856",
+  "当前没有可更换的电池,购买车辆绑定电池后才可享受换电套餐": "text_857",
+  "仓门已打开": "text_858",
+  "完成弹窗": "text_859",
+  "祝您骑行愉快": "text_860",
+  "|重量": "text_861",
+  "车辆已被租售!": "text_862",
+  "全部": "text_863"
+}

+ 3 - 3
pages/aboutMy/aboutMy.vue

@@ -1,6 +1,6 @@
 <template>
 	<view class="container">
-		<navBar name="关于我们"></navBar>
+		<navBar :name="$t('关于我们')"></navBar>
 		<view class="header_view flex-row flex-column">
 			<image class="header_img" :src="app_logo" mode="aspectFit"></image>
 			<view class="header_title">{{appName}}</view>
@@ -8,8 +8,8 @@
 		</view>
 		
 		<view class="company-text-view">
-			<view class=" company-text" style="margin-bottom:16rpx;">弗兰克公司 版权所有</view>
-			<view class=" company-text">@2023 FULANKE CorporationAll Rights Reserved</view>
+			<view class=" company-text" style="margin-bottom:16rpx;">{{ $t('弗兰克公司') }} {{ $t('版权所有') }}</view>
+			<view class=" company-text">@2023 FULANKE Corporation All Rights Reserved</view>
 		</view>
 	</view>
 </template>

+ 29 - 29
pages/activation/activation.vue

@@ -1,41 +1,41 @@
 <template>
 	<view class="">
-		<navBar :name="typePage=='index'?'归还车辆':'车辆激活'" left="0"></navBar>
+		<navBar :name="typePage=='index'?$t('归还车辆'): $t('车辆激活')" left="0"></navBar>
 		<view class="container-view">
 			<view class="return-info">
-				<view class="h5">车辆信息</view>
+				<view class="h5">{{ $t('车辆信息') }}</view>
 				<view v-if="overdueMoney" class="return-top  flex-row flex-between">
-					<view style="align-items: baseline;" class="flex-row">逾期费用:
+					<view style="align-items: baseline;" class="flex-row">{{ $t('逾期费用:') }}
 						<allPrice :amount="(overdueMoney/100)" />
 					</view>
 				</view>
 				<view class="return-top  flex-row flex-between">
-					<view>车辆编号:{{car_sn}}</view>
+					<view>{{ $t('车辆编号:') }}{{car_sn}}</view>
 				</view>
 				<view class="return-top  flex-row flex-between">
-					<view>车辆品牌:{{carInfoData.brand_name}}</view>
+					<view>{{ $t('车辆品牌:') }}{{carInfoData.brand_name}}</view>
 				</view>
 				<view class="return-top  flex-row flex-between">
-					<view>车辆颜色:{{carInfoData.color_name}}</view>
+					<view>{{ $t('车辆颜色:') }}{{carInfoData.color_name}}</view>
 				</view>
 				<view v-if="carInfoData.license_plate_number" class="return-top  flex-row flex-between">
-					<view>车牌号:{{carInfoData.license_plate_number}}</view>
+					<view>{{ $t('车牌号:') }}{{carInfoData.license_plate_number}}</view>
 				</view>
 				<view class="return-top  flex-row flex-between">
-					<view>车辆名称:{{carInfoData.car_name}}</view>
+					<view>{{ $t('车辆名称:') }}{{carInfoData.car_name}}</view>
 				</view>
 				<view class="return-top  flex-row flex-between">
-					<view>车型:{{carInfoData.model_name}}</view>
+					<view>{{ $t('车型:') }}{{carInfoData.model_name}}</view>
 				</view>
 				<view class="return-top  flex-row flex-between">
-					<view>续航:{{(carInfoData.endurance / 1000).toFixed(2)}}km</view>
+					<view>{{ $t('续航:') }}{{(carInfoData.endurance / 1000).toFixed(2)}}km</view>
 				</view>
 				<view class="return-top  flex-row flex-between">
-					<view>重量:{{(carInfoData.weight / 1000).toFixed(2)}}kg</view>
+					<view>{{ $t('重量:') }}{{(carInfoData.weight / 1000).toFixed(2)}}kg</view>
 				</view>
 				
 				<view class="return-top  flex-row ">
-					<view>照片:</view>
+					<view>{{ $t('照片:') }}</view>
 					<view style="display: flex;align-items: center;" class="">
 						<image style="margin-right: 10rpx;" v-for="(item,index) of carInfoData.model_images"
 							:key="index" class="img" :src="item" mode="aspectFit"></image>
@@ -43,17 +43,17 @@
 				</view>
 			</view>
 			<view v-if="shopInfo.shop_name" class="return-info">
-				<view class="h5">门店信息</view>
+				<view class="h5">{{ $t('门店信息') }}</view>
 				<view class="return-top  flex-row flex-between">
-					<view>门店名称:{{shopInfo.shop_name}}</view>
+					<view>{{ $t('门店名称:') }}{{shopInfo.shop_name}}</view>
 				</view>
 				<view class="return-top  flex-row flex-between">
-					<view>门店地址:{{shopInfo.address}}</view>
+					<view>{{ $t('门店地址:') }}{{shopInfo.address}}</view>
 				</view>
 			</view>
 			<view class="pictures-info">
-				<view>上传照片</view>
-				<!-- <view>这里是关于激活车辆照片的文案描述,这里是关于激活车辆照片的文案描述</view> -->
+				<view>{{ $t('上传照片') }}</view>
+				<!-- <view>{{ $t('这里是关于激活车辆照片的文案描述,这里是关于激活车辆照片的文案描述') }}</view> -->
 				<!-- <uploaders :max="Number(shopList.flk_hire_car_img_num)" :car_info="car_imgs"
 					@update-car-images="handleCarImagesUpdate"></uploaders> -->
 				<view class="list-group">
@@ -61,12 +61,12 @@
 						:key="item.unique">
 						<image v-if="!item.imgUrl"  class="img-item-demo" :src="item.url"></image>
 						<image v-else class="img-item" :src="item.imgUrl" mode="aspectFit"></image>
-						<view class="img_text">{{ item.title? item.title : '车辆照片'}}</view>
-						<view v-if="!item.imgUrl" class="empity-item">+</view>
+						<view class="img_text">{{ item.title? item.title : $t('车辆照片')}}</view>
+						<view v-if="!item.imgUrl" class="empity-item">{{ $t('') }}</view>
 					</view>
 				</view>
-				<view v-if="isReturnCar" @tap="submitReturn" class="pictures-btn">归还车辆</view>
-				<view v-else @tap="submitEnabled" class="pictures-btn">激活车辆</view>
+				<view v-if="isReturnCar" @tap="submitReturn" class="pictures-btn">{{ $t('归还车辆') }}</view>
+				<view v-else @tap="submitEnabled" class="pictures-btn">{{ $t('激活车辆') }}</view>
 			</view>
 			<PayTypeModel @closeShow="()=>isShowToBuy=false" @payToOrder="payToOrder" :free_price="totalPrice"
 				:isShowToBuy="isShowToBuy" />
@@ -123,7 +123,7 @@
 			this.isReturnCar = options.isReturnCar
 			if (options.isReturnCar) {
 				uni.setNavigationBarTitle({
-					title: '归还车辆'
+					title: this.$t('归还车辆')
 				})
 				this.shopInfoFn()
 			}
@@ -157,8 +157,8 @@
 		methods: {
 			async bindDelImage(index){
 				let res = await uni.showModal({
-					title: '提示',
-					content: '你确定要删除吗?',
+					title: this.$t('提示'),
+					content: this.$t('你确定要删除吗?'),
 					showCancel: true,
 				})
 				if (res[1].confirm) {
@@ -199,7 +199,7 @@
 				})
 				if (data.code == 200) {
 					uni.removeStorageSync('car_info')
-					common.simpleToast('还车成功!')
+					common.simpleToast(this.$t('还车成功!'))
 					setTimeout(() => {
 						uni.switchTab({
 							url: `/pages/index/index`,
@@ -231,7 +231,7 @@
 						return item
 					}
 				})
-				if (this._image_list.length < this.shopList.flk_hire_return_car_img.length) return common.simpleToast('请上传车辆照片')
+				if (this._image_list.length < this.shopList.flk_hire_return_car_img.length) return common.simpleToast(this.$t('请上传车辆照片'))
 				if (this.totalPrice > 0) {
 					this.isShowToBuy = true
 				} else {
@@ -251,7 +251,7 @@
 					if (data.data.list.length > 0) {
 						this.shopInfo = data.data.list[0]
 					} else {
-						common.simpleToast('未获取到门店位置!')
+						common.simpleToast(this.$t('未获取到门店位置!'))
 					}
 				} else {
 					common.simpleToast(data.msg)
@@ -313,7 +313,7 @@
 						return item
 					}
 				})
-				if (_image_list.length < this.shopList.flk_hire_return_car_img.length) return common.simpleToast('请上传车辆照片')
+				if (_image_list.length < this.shopList.flk_hire_return_car_img.length) return common.simpleToast(this.$t('请上传车辆照片'))
 				const pData = {
 					car_sn: this.car_sn,
 					sub_sn: this.sub_sn,
@@ -321,7 +321,7 @@
 				}
 				http.postApi(config.API_FLK_CAR_ASSIGNMENT, pData, (resp) => {
 					if (resp.data.code === 200) {
-						common.simpleToast('车辆激活成功')
+						common.simpleToast(this.$t('车辆激活成功'))
 						setTimeout(function() {
 							uni.switchTab({
 								url: `/pages/index/index?plate_number=${me.car_sn}`,

+ 2 - 2
pages/activity/activity.vue

@@ -1,9 +1,9 @@
 <template>
 	<view class="">
-		<navBar name="活动中心" type="active" ></navBar>
+		<navBar :name="$t('活动中心')" type="active" ></navBar>
 		<view class="container-view flex-row">
 			<img style="width: 352rpx;height: 352rpx;" src="https://qiniu.bms16.com/Fn0mFwx4EHDzQiCypHM7HgiL4uuP" alt="">
-			<view class="active-text">暂无可参与的活动</view>
+			<view class="active-text">{{ $t('暂无可参与的活动') }}</view>
 			<CustomTabbar curt-tab="active"/>
 		</view>
 	</view>

+ 4 - 4
pages/addUser/addUser.vue

@@ -1,11 +1,11 @@
 <template>
 	<view class="add-user-view">
-		<navBar :name="'添加成员'" left="0"/>
+		<navBar :name="$t('添加成员')" left="0"/>
 		<view class="flex-row email-input-view">
-			<input class="email-input-style" type="email" v-model="email" placeholder="请输入被邀人邮箱号"  placeholder-style="font-size: 32rpx; font-weight: 400; color: #BAC1D0;">
+			<input class="email-input-style" type="email" v-model="email" :placeholder="$t('请输入被邀人邮箱号')"  placeholder-style="font-size: 32rpx; font-weight: 400; color: #BAC1D0;">
 			<img class="clear-btn" src="https://qiniu.bms16.com/Fjpf2YnHUK1_CFf20kKRvjX9YdC3" alt="">
 		</view>
-		<view @click="nextFn" class="next-btn" :class="{'next-btn-i':!isEmailFn(email)}">下一步</view>
+		<view @click="nextFn" class="next-btn" :class="{'next-btn-i':!isEmailFn(email)}">{{ $t('下一步') }}</view>
 	</view>
 </template>
 
@@ -40,7 +40,7 @@
 							url:`/pages/powerSetting/powerSetting?email=${this.email}&headimg=${data.data.headimg}&nickname=${data.data.nickname}&isSet=1`
 						})
 					}else{
-						msg('该用户不存在!')
+						msg(this.$t('该用户不存在!'))
 					}
 				}else{
 					msg(data.msg)

+ 68 - 68
pages/battery/battery.vue

@@ -22,23 +22,23 @@
 						data-url="/pages/exchangeCar/exchangeCar" data-index="1"
 						class="flex-column my_function position">
 						<view v-if="(orderInfo.order_info.gift_exchange_num - orderInfo.order_info.used_exchange_num)>0"
-							class="red_tip">免费 <text
+							class="red_tip">{{ $t('免费') }} <text
 								style="font-size: 28rpx;margin: 0 2rpx;">{{orderInfo.order_info.gift_exchange_num - orderInfo.order_info.used_exchange_num}}</text>
-							次</view>
+							{{ $t('') }}</view>
 						<image class="my_icon" src="https://qiniu.bms16.com/FgR9qwTgatlAzamYdcFngFU4_ydj"></image>
-						<view class="my_title">车辆换电</view>
+						<view class="my_title">{{ $t('车辆换电') }}</view>
 					</view>
 					<view v-if="orderInfo.third_device_type == 'TBTKC'" @tap="clickCarCommand" data-command="FINDCAR" class="flex-column my_function">
 						<image class="my_icon" src="https://zxappfile.bms16.com/zx_client/find_car.png"></image>
-						<view class="my_title">响铃找车</view>
+						<view class="my_title">{{ $t('响铃找车') }}</view>
 					</view>
 					<view  v-if="orderInfo.third_device_type == 'TBTKC'" @tap="clickCarCommand" data-command="OPENSEATLOCK" class="flex-column my_function">
 						<image class="my_icon" src="https://zxappfile.bms16.com/zx_client/seat_lock.png"></image>
-						<view class="my_title">开座桶锁</view>
+						<view class="my_title">{{ $t('开座桶锁') }}</view>
 					</view>
 					<!-- 	<view @tap="clickCarCommand" data-command="helmet" class="flex-column my_function">
 						<image class="my_icon_1" src="https://zxappfile.bms16.com/zx_client/helmet.png"></image>
-						<view class="my_title">关闭头盔锁</view>
+						<view class="my_title">{{ $t('关闭头盔锁') }}</view>
 					</view> -->
 					<view 
 						@tap="clickCarCommand($event, true)" 
@@ -47,22 +47,22 @@
 						class="flex-column my_function"
 					>
 						<image class="my_icon" :src="protect_state ? lockIcon : onLockIcon"></image>
-						<view class="my_title">{{ protect_state ? '解锁' : '上锁'}}</view>
+						<view class="my_title">{{ protect_state ? '{{ $t('解锁') }}' : '{{ $t('上锁') }}'}}</view>
 					</view>
 					<view @tap="navToPage" data-url="/pages/travelingTrack/travelingTrack" data-index="2"
 						class="flex-column my_function">
 						<image class="my_icon" src="https://qiniu.bms16.com/Fj61bkq6KYkfA9QdbLfpVUj3Nm5Q"></image>
-						<view class="my_title">行驶轨迹</view>
+						<view class="my_title">{{ $t('行驶轨迹') }}</view>
 					</view>
 					<view @tap="navToPage" data-url="/pages/carLocation/carLocation" data-index="3"
 						class="flex-column my_function">
 						<image class="my_icon" src="https://qiniu.bms16.com/Fg_eny6c-tiDVy1iTFyyWzmUj4ho"></image>
-						<view class="my_title">车辆位置</view>
+						<view class="my_title">{{ $t('车辆位置') }}</view>
 					</view>
 					<view v-if="orderInfo.drag_car_service" @tap="navToPage" data-url="/pages/towingCar/towingCar"
 						data-index="4" class="flex-column my_function">
 						<image class="my_icon" src="https://qiniu.bms16.com/FsG5bN2bg-MXLXZehQ33TsYPfrH8"></image>
-						<view class="my_title">拖车服务</view>
+						<view class="my_title">{{ $t('拖车服务') }}</view>
 					</view>
 				</view>
 
@@ -71,47 +71,47 @@
 				<view class="battery-btn flex-row">
 					<view v-if="orderInfo.is_on == 1" @tap="bindCarStatus" :data-car="orderInfo.is_on">
 						<!-- <img class="img_car_on" src="https://qiniu.bms16.com/FtoO8li2ncvlGsjggXY7gMtaIAWt" /> -->
-						关闭车辆
+						{{ $t('关闭车辆') }}
 					</view>
 					<view v-else-if="orderInfo.is_on == 0||orderInfo.is_on == 2" @tap="bindCarStatus"
 						:data-car="orderInfo.is_on">
 						<!-- <img class="lock_img" src="https://qiniu.bms16.com/Fq7SWg4flipex4HXuDxsxL88AN5s" /> -->
-						启动车辆
+						{{ $t('启动车辆') }}
 					</view>
 
-					<view @tap="bindReturnCar">我要还车</view>
+					<view @tap="bindReturnCar">{{ $t('我要还车') }}</view>
 				</view>
 			</view>
 			<view class="">
 				<view class="battery-second flex-row flex-between">
-					<view>剩余租期</view>
-					<view @tap="navToPage" data-url="/pages/orderStatus/orderStatus" data-index="5">查看订单</view>
+					<view>{{ $t('剩余租期') }}</view>
+					<view @tap="navToPage" data-url="/pages/orderStatus/orderStatus" data-index="5">{{ $t('查看订单') }}</view>
 				</view>
 			</view>
 			<view class="battery-bottom flex-row flex-between">
 				<view v-if="orderInfo.time" class="bottom-time flex-row">
 					{{orderInfo.time.day > 0 ? orderInfo.time.day :'' }}<text
-						v-if="orderInfo.time.day>0">日</text>{{orderInfo.time.hour > 0 ? orderInfo.time.hour :'' }}<text
-						v-if="orderInfo.time.hour>0">小时</text>{{orderInfo.time.minute > 0 ? orderInfo.time.minute :'' }}<text
-						v-if="orderInfo.time.minute>0">分</text>
-					<view style="font-weight: 400;">到期后将无法用车</view>
+						v-if="orderInfo.time.day>0">{{ $t('') }}</text>{{orderInfo.time.hour > 0 ? orderInfo.time.hour :'' }}<text
+						v-if="orderInfo.time.hour>0">{{ $t('小时') }}</text>{{orderInfo.time.minute > 0 ? orderInfo.time.minute :'' }}<text
+						v-if="orderInfo.time.minute>0">{{ $t('') }}</text>
+					<view style="font-weight: 400;">{{ $t('到期后将无法用车') }}</view>
 				</view>
 				<view v-else class="bottom-time flex-row">
-					已到期
-					<view>到期后将无法用车</view>
+					{{ $t('已到期') }}
+					<view>{{ $t('到期后将无法用车') }}</view>
 				</view>
-				<view @tap="bindRenewHire">续租</view>
+				<view @tap="bindRenewHire">{{ $t('续租') }}</view>
 			</view>
 			<view v-if="isShowReturnCar" class="return-box">
 				<view class="return-item">
 					<view class="return-title flex-row flex-between">
-						<view>还车到门店</view>
+						<view>{{ $t('还车到门店') }}</view>
 						<view @tap="isShowReturnCar = false" style="font-size: 60rpx;">×</view>
 					</view>
-					<view class="return-text">系统会根据您的定位判断您是否已到还车位置,如您已经到达门店,请点击「我已到店」按钮,待门店确认还车后,即可还车成功。</view>
+					<view class="return-text">{{ $t('系统会根据您的定位判断您是否已到还车位置,如您已经到达门店,请点击「我已到店」按钮,待门店确认还车后,即可还车成功。') }}</view>
 					<view class="return-btn flex-row">
-						<view @tap="toRurnCarPage">我已到店</view>
-						<view @tap="toNearbyStorePage">附近可还门店</view>
+						<view @tap="toRurnCarPage">{{ $t('我已到店') }}</view>
+						<view @tap="toNearbyStorePage">{{ $t('附近可还门店') }}</view>
 					</view>
 				</view>
 			</view>
@@ -119,35 +119,35 @@
 			<view v-if="isShowRenewHire" class="renew-box">
 				<scroll-view class="renew-item" scroll-y :show-scrollbar='true' :enhanced='true'>
 					<view class="renew-title flex-row flex-between">
-						<view>选择续租方案</view>
+						<view>{{ $t('选择续租方案') }}</view>
 						<view @tap="isShowRenewHire = false" style="font-size: 60rpx;">×</view>
 					</view>
 					<view class="plan-info">
 						<view class="plan-type flex-row flex-between">
 							<view @tap="bindChangeStatus" data-status="0"
 								:class="isSelectStatus == 0?'ptyped-item':'ptype-item'">
-								<view class="ptype-title">时租</view>
+								<view class="ptype-title">{{ $t('时租') }}</view>
 								<view :class="isSelectStatus == 0?'ptyped-text':'ptype-text'">
 									¥<text>8</text>
 								</view>
 							</view>
 							<view @tap="bindChangeStatus" data-status="1"
 								:class="isSelectStatus == 1?'ptyped-item':'ptype-item'">
-								<view class="ptype-title">日租</view>
+								<view class="ptype-title">{{ $t('日租') }}</view>
 								<view :class="isSelectStatus == 1?'ptyped-text':'ptype-text'">
 									¥<text>48</text>
 								</view>
 							</view>
 							<view @tap="bindChangeStatus" data-status="2"
 								:class="isSelectStatus == 2?'ptyped-item':'ptype-item'">
-								<view class="ptype-title">周租</view>
+								<view class="ptype-title">{{ $t('周租') }}</view>
 								<view :class="isSelectStatus == 2?'ptyped-text':'ptype-text'">
 									¥<text>208</text>
 								</view>
 							</view>
 						</view>
 						<view class="plan-time flex-row flex-between">
-							<view>租车时长/天</view>
+							<view>{{ $t('租车时长') }}/{{ $t('') }}</view>
 							<view class="quantity-count flex-row">
 								<view class="count-btn fbtn" @tap.stop.prevent="bindMinus">-</view>
 								<input @input="bindInput" @blur="bindBlur" type="number" :value="count" />
@@ -155,17 +155,17 @@
 							</view>
 						</view>
 						<view class="coupon-info flex-row flex-between">
-							<view>优惠券</view>
+							<view>{{ $t('优惠券') }}</view>
 							<view>
-								9.8 折
+								9.8 {{ $t('') }}
 								<img src="https://qiniu.bms16.com/Fjw9OKXT_2aZ1iPStF941RoawSy_" />
 							</view>
 						</view>
 					</view>
 					<view class="guarantee-info">
 						<view class="guarantee-title flex-row flex-between">
-							<view>骑行保障服务</view>
-							<view>保障须知</view>
+							<view>{{ $t('骑行保障服务') }}</view>
+							<view>{{ $t('保障须知') }}</view>
 						</view>
 						<view class="flex-row flex-between">
 							<view @tap="clickSelectGuarantee" v-for="(item,index) in guaranteeList" :key="index"
@@ -182,12 +182,12 @@
 										<view>{{items.price}}</view>
 									</view>
 									<view style="color: #828DA2;text-align: center;font-size: 24rpx;">
-										含行程延误保障
+										{{ $t('含行程延误保障') }}
 									</view>
 									<view class="guarantee-border"></view>
 									<view class="guarantee-bottom flex-row flex-column">
-										<view>1.3元/天</view>
-										<view v-if="index==0" :class="isSelectGuarantee==0?'blue-t':'black-t'">商家赠送
+										<view>1.3{{ $t('') }}/{{ $t('') }}</view>
+										<view v-if="index==0" :class="isSelectGuarantee==0?'blue-t':'black-t'">{{ $t('商家赠送') }}
 										</view>
 										<view v-if="index!=0">
 											<img
@@ -199,10 +199,10 @@
 						</view>
 					</view>
 					<view class="assort-info">
-						<view>配套服务</view>
+						<view>{{ $t('配套服务') }}</view>
 						<view class="assort-text flex-row">
-							<view>头盔×1</view>
-							<view>手机支架×1</view>
+							<view>{{ $t('头盔') }}×1</view>
+							<view>{{ $t('手机支架') }}×1</view>
 						</view>
 					</view>
 
@@ -210,22 +210,22 @@
 						<view class="payment-top flex-row">
 							<img
 								:src="isArgee?'https://qiniu.bms16.com/FhWimtmWybKlYMB6mgIReVWArbfq':'https://qiniu.bms16.com/FkmDjxBNZhFGFU5inza2usdtDlX8'" />
-							已阅读并同意
-							<text>《小众电动车租赁用户协议》</text>
+							{{ $t('已阅读并同意') }}
+							<text>{{ $t('《小众电动车租赁用户协议》') }}</text>
 						</view>
 						<view class="payment-bottom flex-row flex-between">
 							<view class="bottom-left flex-row">
 								<view>¥92.23</view>
-								<view>明细<img src="https://qiniu.bms16.com/FmEDQp82D5k9lkHMEcCoCeLO8ZQL" /></view>
+								<view>{{ $t('明细') }}<img src="https://qiniu.bms16.com/FmEDQp82D5k9lkHMEcCoCeLO8ZQL" /></view>
 							</view>
-							<view @tap="navToPage" data-url="/pages/orderStatus/orderStatus">支付·授权免押</view>
+							<view @tap="navToPage" data-url="/pages/orderStatus/orderStatus">{{ $t('支付') }}·{{ $t('授权免押') }}</view>
 						</view>
 					</view>
 				</scroll-view>
 			</view>
 
 		</view>
-		<view v-else class="no-car">暂无车辆</view>
+		<view v-else class="no-car">{{ $t('暂无车辆') }}</view>
 	</view>
 
 </template>
@@ -376,7 +376,7 @@
 						uni.setStorageSync('user_current_location', me.myLocation)
 					},
 					fail: function(res) {
-						common.simpleToast('获取地址失败,请授权重新打开')
+						common.simpleToast(this.$t('获取地址失败,请授权重新打开'))
 					}
 				})
 				// this.loadCarInfo()
@@ -514,26 +514,26 @@
 
 				const commandTips = {
 					FINDCAR: {
-						title: "响铃找车",
-						desc: "您确定开启响铃找车?",
-						success: "车辆已开始鸣笛"
+						title: this.$t('响铃找车'),
+						desc: this.$t('您确定开启响铃找车?'),
+						success: this.$t('车辆已开始鸣笛')
 					},
 					OPENSEATLOCK: {
-						title: "开座桶锁",
-						desc: "您确定打开座桶锁?",
-						success: "座桶锁已打开"
+						title: this.$t('开座桶锁'),
+						desc: this.$t('您确定打开座桶锁?'),
+						success: this.$t('座桶锁已打开')
 					},
 					SAFEON: {
-						title: "上锁",
-						desc: "您确定给车辆上锁?",
+						title: this.$t('上锁'),
+						desc: this.$t('您确定给车辆上锁?'),
 						optTxt: '正在上锁...',
-						success: "已上锁"
+						success: this.$t('已上锁')
 					},
 					SAFEOFF: {
-						title: "解锁",
-						desc: "您确定给车辆解锁?",
+						title: this.$t('解锁'),
+						desc: this.$t('您确定给车辆解锁?'),
 						optTxt: '正在解锁...',
-						success: "已解锁"
+						success: this.$t('已解锁')
 					}
 				}
 
@@ -546,8 +546,8 @@
 				uni.showModal({
 					title: tipTitle,
 					content: tipDesc,
-					cancelText: '取消',
-					confirmText: '确定',
+					cancelText: this.$t('取消'),
+					confirmText: this.$t('确定'),
 					success: function(res) {
 						if (res.confirm) {
 							const pData = {
@@ -571,7 +571,7 @@
 								}
 							})
 						} else if (res.cancel) {
-							// common.simpleToast('已取消')
+							// common.simpleToast(this.$t('已取消'))
 						}
 					},
 					fail: function(res) {
@@ -637,10 +637,10 @@
 				const CUR_IS_ON = (is_on - 0) == 1 
 				// is_on :0 2 :锁车  1 :启动
 				uni.showModal({
-					title: '车辆提示',
+					title: this.$t('车辆提示'),
 					content: CUR_IS_ON ? '确认关闭车辆?' : '确认需要启动车辆?',
-					cancelText: '取消',
-					confirmText: '确定',
+					cancelText: this.$t('取消'),
+					confirmText: this.$t('确定'),
 					success: function(res) {
 						if (res.confirm) {
 							const pData = {
@@ -650,12 +650,12 @@
 							http.postApi(config.API_DAYHIRE_CAR_LOCK, pData, function(resp) {
 								if (resp.data.code === 200) {
 									const text = CUR_IS_ON ? '正在关闭车辆...' : '正在启动车辆...';
-									const resultText = CUR_IS_ON ? '车辆已关闭' : '车辆已启动';
+									const resultText = CUR_IS_ON ? this.$t('车辆已关闭') : this.$t('车辆已启动');
 									common.simpleToast(text, 4000)
 									setTimeout(() => {
 										me.loadCarInfo().then(res => {
 											// console.log(me.initialIsOn, res.is_on)
-											// const TEXT = me.initialIsOn === res.is_on ? '操作超时' : resultText
+											// const TEXT = me.initialIsOn === res.is_on ? this.$t('操作超时') : resultText
 											// me.setData({
 											// 	initialIsOn: res.is_on
 											// })
@@ -667,7 +667,7 @@
 								}
 							})
 						} else if (res.cancel) {
-							common.simpleToast('已取消')
+							common.simpleToast(this.$t('已取消'))
 						}
 					},
 					fail: function(res) {

+ 5 - 5
pages/batteryDetail/batteryDetail.vue

@@ -1,24 +1,24 @@
 <template>
 	<view class="battery-detail-main">
-		<navBar name="电池信息"  bgColor="#CFD1DE"></navBar>
+		<navBar :name="$t('电池信息')"  bgColor="#CFD1DE"></navBar>
 		<view class=" quantity-count">{{electricQuantity || 0}}<text class="quantity-text">%</text></view>
 		<view v-for="(item,index) of list" :key="index" class="battery-list-view">
 			<view class="battery-list flex-row flex-between">
-				<view class="battery-name">No.{{index + 1}}电池</view>
+				<view class="battery-name">No.{{index + 1}}{{ $t('电池') }}</view>
 				<view class="battery-id">MAC ID:{{item.battery_sn}}</view>
 			</view>
 			<view class="flex-row flex-around">
 				<view class="battery-device-info">
 					<view class="quantity-info">{{item.electric_quantity || 0}} <text class="quantity-text-1">%</text></view>
-					<view class="battery-info-text">剩余电量</view>
+					<view class="battery-info-text">{{ $t('剩余电量') }}</view>
 				</view>
 				<view class="battery-device-info">
 					<view class="quantity-info">{{(item.voltage).toFixed(2) || 0}}<text class="quantity-text-1"></text></view>
-					<view class="battery-info-text">电压</view>
+					<view class="battery-info-text">{{ $t('电压') }}</view>
 				</view>
 				<view class="battery-device-info">
 					<view class="quantity-info">{{item.battery_temp[0] || 0}} <text class="quantity-text-1">℃</text></view>
-					<view class="battery-info-text">温度</view>
+					<view class="battery-info-text">{{ $t('温度') }}</view>
 				</view>
 			</view>
 		</view>

+ 13 - 13
pages/batteryPackage/batteryPackage.vue

@@ -1,18 +1,18 @@
 <template>
 	<view class="battery-package-main">
-		<navBar bgColor="#fff" name="换电套餐" />
+		<navBar bgColor="#fff" :name="$t('换电套餐')" />
 		
 		<view class="package-icon-view flex-row">
 			<img src="https://qiniu.bms16.com/FqF7erLOB8OutmFnre7-mbTkwpZr" alt="">
-			<view class="package-icon-text flex-row">5秒换电,瞬间满电,畅享骑行新体验!</view>
+			<view class="package-icon-text flex-row">5{{ $t('秒换电,瞬间满电,畅享骑行新体验!') }}</view>
 		</view>
 		<view v-for="(item,index) of list" @click="selectItem(item)" :key="index" class="package-list-view" :class="{'active' : item.package_code == form.package_code }">
-			<view class="package-num-view flex-row"><text class="package-num">{{item.total_day || 0}}</text> 天 <text
-					class="package-num">{{(item.total_num || 0)=== 0 ? '不限次数' : item.total_num + '次'}}</text></view>
+			<view class="package-num-view flex-row"><text class="package-num">{{item.total_day || 0}}</text> {{ $t('') }} <text
+					class="package-num">{{(item.total_num || 0)=== 0 ? $t('不限次数') : item.total_num + $t('次')}}</text></view>
 			<view class="flex-row flex-between align-baseline">
-				<view v-if="item.tag.child_tag_name" class="apply-battery">适用电池:<text class="apply-battery-num">{{ !!Number(item.tag.main_tag_name) ? item.tag.main_tag_name + "V" : item.tag.main_tag_name}}{{!!Number(item.tag.child_tag_name) ? item.tag.child_tag_name + "Ah" : item.tag.child_tag_name }}</text></view>
+				<view v-if="item.tag.child_tag_name" class="apply-battery">{{ $t('适用电池:') }}<text class="apply-battery-num">{{ !!Number(item.tag.main_tag_name) ? item.tag.main_tag_name + "V" : item.tag.main_tag_name}}{{!!Number(item.tag.child_tag_name) ? item.tag.child_tag_name + "Ah" : item.tag.child_tag_name }}</text></view>
 				
-				<view v-else class="apply-battery">适用电池:<text class="apply-battery-num">{{ item.tag.main_tag_name }}</text></view>
+				<view v-else class="apply-battery">{{ $t('适用电池:') }}<text class="apply-battery-num">{{ item.tag.main_tag_name }}</text></view>
 				<view class="flex-row align-baseline">
 					<!-- <text class="package-price">${{item.viewShowMoney || '0.00'}}</text> -->
 					<text class="symbol-style">
@@ -25,10 +25,10 @@
 			</view>
 		</view>
 <!-- 		<view class="package-list-view">
-			<view class="package-num-view flex-row"><text class="package-num">10</text> 天 <text
-					class="package-num">10</text> 次</view>
+			<view class="package-num-view flex-row"><text class="package-num">10</text> {{ $t('') }} <text
+					class="package-num">10</text> {{ $t('') }}</view>
 			<view class="flex-row flex-between align-baseline">
-				<view class="apply-battery">适用电池:<text class="apply-battery-num">48v20Ah</text></view>
+				<view class="apply-battery">{{ $t('适用电池:') }}<text class="apply-battery-num">48v20Ah</text></view>
 				<view class="flex-row align-baseline">
 					<text class="package-price">$35.9</text>
 					<text class="symbol-style">
@@ -41,13 +41,13 @@
 			</view>
 		</view> -->
 		<view class="flex-row package-tip" style="flex-direction: column;">
-			<view class="flex-row" style="margin-bottom: 16rpx;">当前购买为虚拟IC卡</view>
-			<view class="flex-row">如想要体验实体IC卡功能,前往最近的门店领取IC卡</view>
+			<view class="flex-row" style="margin-bottom: 16rpx;">{{ $t('当前购买为虚拟') }}IC{{ $t('') }}</view>
+			<view class="flex-row">{{ $t('如想要体验实体') }}IC{{ $t('卡功能,前往最近的门店领取') }}IC{{ $t('') }}</view>
 		</view>
 		<view style="height: 200rpx;">
 			
 		</view>
-		<view v-if="form.package_code" @click="isShowToBuy = true"  class="pay-btn">立即购买</view>
+		<view v-if="form.package_code" @click="isShowToBuy = true"  class="pay-btn">{{ $t('立即购买') }}</view>
 		<payTypeModel @closeShow='isShowToBuy = false' :free_price='form.price' :isShowToBuy='isShowToBuy' @payToOrder='submit'></payTypeModel>
 	</view>
 </template>
@@ -84,7 +84,7 @@ import { fenToYuan, msg } from '../../utils/util.js';
 			async submit(payType){
 				this.form.pay_type = payType
 				if(!this.form.car_sn){
-					msg('请先绑定车辆!')
+					msg(this.$t('请先绑定车辆!'))
 					return
 				}
 				uni.showLoading({

+ 14 - 14
pages/batteryRecord/batteryRecord.vue

@@ -1,6 +1,6 @@
 <template>
 	<view class="container-view">
-		<navBar name="换电记录" type="noBottom"></navBar>
+		<navBar :name="$t('换电记录')" type="noBottom"></navBar>
 		<view class="order-type-view flex-row flex-between">
 			<view v-if="car_info.car_sn" @click="srcFn(`/pages/carList/carList`)" class="car-model-list flex-row">
 				<view class="car-model-text">{{car_info.car_name}}</view><img class="right-corner-icon"
@@ -10,33 +10,33 @@
 		
 		<view v-for="(item,index) of list" :key="index" class="batteryList">
 			<view class="header">
-				<view v-if="item.status == 1" class="h5">开始换电</view>
-				<view v-if="item.status == 2" class="h5">换电中</view>
-				<view v-if="item.status == 3" class="h5">换电成功</view>
-				<view v-if="item.status == 4" class="h5">换电失败</view>
-				<view v-if="item.status == 5" class="h5">部分成功</view>
-				<view v-if="item.status == 0" class="h5">未知</view>
+				<view v-if="item.status == 1" class="h5">{{ $t('开始换电') }}</view>
+				<view v-if="item.status == 2" class="h5">{{ $t('换电中') }}</view>
+				<view v-if="item.status == 3" class="h5">{{ $t('换电成功') }}</view>
+				<view v-if="item.status == 4" class="h5">{{ $t('换电失败') }}</view>
+				<view v-if="item.status == 5" class="h5">{{ $t('部分成功') }}</view>
+				<view v-if="item.status == 0" class="h5">{{ $t('未知') }}</view>
 				<view class="time">{{dayjsFn(item.ctime)}}</view>
 			</view>
 			<view class="dl">
-				<view class="dt">换电单号</view>
+				<view class="dt">{{ $t('换电单号') }}</view>
 				<view class="dd">{{item.order_sn}}</view>
 			</view>
 			<view class="dl">
-				<view class="dt">归还电池</view>
+				<view class="dt">{{ $t('归还电池') }}</view>
 				<view class="dd">{{item.btn_battery}}</view>
 			</view>
 			<view class="dl">
-				<view class="dt">借出电池</view>
+				<view class="dt">{{ $t('借出电池') }}</view>
 				<view class="dd">{{item.bor_battery}}</view>
 			</view>
 			<view class="dl">
-				<view class="dt">换电类型</view>
-				<view v-if="item.type == 0" class="dd">机柜换电</view>
-				<view v-if="item.type == 1" class="dd">门店换电</view>
+				<view class="dt">{{ $t('换电类型') }}</view>
+				<view v-if="item.type == 0" class="dd">{{ $t('机柜换电') }}</view>
+				<view v-if="item.type == 1" class="dd">{{ $t('门店换电') }}</view>
 			</view>
 			<view class="dl">
-				<view class="dt">电柜名称</view>
+				<view class="dt">{{ $t('电柜名称') }}</view>
 				<view class="dd">{{item.dev_name}}</view>
 			</view>
 			<!-- <image class="top" src="https://qiniu.bms16.com/FpVjOP5pZY1gXcCcS3TwI0GkywEe" mode=""></image> -->

+ 36 - 37
pages/bluetoothUnlock/bluetoothPair.vue

@@ -1,33 +1,32 @@
 <template>
 	<view class="bluetoothPair-page">
-		<navBar name="开启感应解锁"></navBar>
+		<navBar :name="$t('开启感应解锁')"></navBar>
 		<view class="car-wrap">
 			<view class="name">{{car_info.model_name}}</view>
 			<image :src="QINIU_URL + 'Fi6CPKj4-raA86oizhL3PiXD4DkH'" class="car-img" />
 			<view>
-				<viwe class="pair-title">是否配对改设备</viwe>
+				<viwe class="pair-title">{{ $t('是否配对改设备') }}</viwe>
 				<view class="pair-options">
-					<view class="btn cancle">取消</view>
-					<view class="btn confirm">配对</view>
+					<view class="btn cancle">{{ $t('取消') }}</view>
+					<view class="btn confirm">{{ $t('配对') }}</view>
 				</view>
 			</view>
 		</view>
 		<view class="pair-desc">
-			点击下方 “ <text class="t">开始配对</text>”,请在系统弹窗中选择 “<text class="t">配对</text>”,以完成功能开启。
+			{{ $t('点击下方') }} {{ $t('') }} <text class="t">{{ $t('开始配对') }}</text>{{ $t('”,请在系统弹窗中选择') }} {{ $t('') }}<text class="t">{{ $t('配对') }}</text>{{ $t('”,以完成功能开启。') }}
 		</view>
 		<view class="pair-tips">
-			<view class="title">提示信息</view>
-			<view class="text">使用感应解锁功能时,请务必保证手机蓝牙功能开启,在蓝牙列表中忽略此设备会导致感应解锁失败</view>
+			<view class="title">{{ $t('提示信息') }}</view>
+			<view class="text">{{ $t('使用感应解锁功能时,请务必保证手机蓝牙功能开启,在蓝牙列表中忽略此设备会导致感应解锁失败') }}</view>
 		</view>
 
-		<!-- 测试指令!!!别删除 -->
-		<view class="pair-btn" style="bottom: 240rpx;" @tap="nearCloseUnlockBtn">关闭靠近解锁</view>
-		<!-- <view class="pair-btn" style="bottom: 240rpx;" @tap="nearTest">跳转解绑配对</view> -->
-		<!-- <view class="pair-btn" style="bottom: 240rpx;" @tap="nearUnlockBtn">靠近解锁</view> -->
-		<!-- <view class="pair-btn" style="bottom: 140rpx;" @tap="otaUpgrade">OTA升级</view> -->
-		<view class="pair-btn" @tap="initiateBluetoothPairing">开始配对</view>
-		<CenterDialog confirmText="配对" ref="centerDialog" />
-		<!-- <Notice v-model="showNotice" title="感应解锁已开启" btnText="关闭" type="bluetoothPail" text='注意:请勿在手机蓝牙中忽略“电动车蓝牙02"设备,否则感应解锁功能将无法使用' /> -->
+		<!-- {{ $t('测试指令!!!别删除') }} -->
+		<view class="pair-btn" style="bottom: 240rpx;" @tap="nearCloseUnlockBtn">{{ $t('关闭靠近解锁') }}</view>
+		<!-- <view class="pair-btn" style="bottom: 240rpx;" @tap="nearTest">{{ $t('跳转解绑配对') }}</view> -->
+		<!-- <view class="pair-btn" style="bottom: 240rpx;" @tap="nearUnlockBtn">{{ $t('靠近解锁') }}</view> -->
+		<!-- <view class="pair-btn" style="bottom: 140rpx;" @tap="otaUpgrade">OTA{{ $t('升级') }}</view> -->
+		<view class="pair-btn" @tap="initiateBluetoothPairing">{{ $t('开始配对') }}</view>
+		<CenterDialog :confirmText="$t('配对')" ref="centerDialog" />
 	</view>
 </template>
 
@@ -87,10 +86,10 @@
 			otaUpgrade(){
 				const me=this
 				common.loading()
-				console.log('开始升级');
+				console.log(this.$t('开始升级'));
 				bluetooth.sendOTACommand(this.car_sn, (res) => {
 						// uni.hideLoading();
-						// console.log('结束?????');
+						// console.log(this.$t('结束?????'));
 						
 						bluetooth.onConnectionStateChange(this.car_sn, 'index', (res) => {
 							uni.hideLoading();
@@ -99,9 +98,9 @@
 								console.log('蓝牙连接断开11111');
 								if(!res.connected){
 									uni.showModal({
-										title: '提示',
-										confirmText: '重新连接',
-										content: '蓝牙连接中断,是否重新连接?',
+										title: this.$t('提示'),
+										confirmText: this.$t('重新连接'),
+										content: this.$t('蓝牙连接中断,是否重新连接?'),
 										success: function(res) {
 											if (res.confirm) {
 												me.loadBluetooth();
@@ -112,7 +111,7 @@
 								// common.simpleToast('蓝牙连接断开1111', 2000)
 							} else {
 								console.log('蓝牙连接成功2222');
-								common.simpleToast('蓝牙连接成功', 2000)
+								common.simpleToast(this.$t('蓝牙连接成功'), 2000)
 							}
 						});
 						// if (!res.connected) {
@@ -124,10 +123,10 @@
 					});
 			},
 			 initiateBluetoothPairing() {
-				const deviceName = '电动车蓝牙';
+				const deviceName = this.$t('电动车蓝牙');
 				const pairingCode = '1234567890';
 				// this.$refs.centerDialog.open({
-				// 	title: '蓝牙配对请求',
+				// 	title: this.$t('蓝牙配对请求'),
 				// 	content: `<span style="color:#060809;font-weight:bold">${deviceName}</span>
     //             想与您配对,请确保显示的配对密钥为
     //             <span style="color:#060809;font-weight:bold">${pairingCode}</span>`
@@ -141,7 +140,7 @@
 				bluetooth.closeDevice(
 					this.car_sn,
 					() => {
-						console.log('关闭蓝牙连接');
+						console.log(this.$t('关闭蓝牙连接'));
 						// this.setData({
 						// 	bt_loading: false
 						// });
@@ -172,12 +171,12 @@
 			},
 			nearUnlockBtn(){
 				bluetooth.nearUnlock(this.car_sn, (res) => {
-						console.log('接近解锁下发成功');
+						console.log(this.$t('接近解锁下发成功'));
 					});
 			},
 			nearCloseUnlockBtn(){
 				bluetooth.nearCloseUnlock(this.car_sn, (res) => {
-						console.log('接近解锁下发成功');
+						console.log(this.$t('接近解锁下发成功'));
 					});
 			},
 			isBluetoothLock(mac_id){
@@ -185,7 +184,7 @@
 				bluetooth.getNearUnlockSet(mac_id, 'index',(res)=>{
 					
 					//下发打开接近解锁指令
-					console.log('获取接近解锁下发成功');
+					console.log(this.$t('获取接近解锁下发成功'));
 				})
 			},
 			loadBluetooth() {
@@ -217,7 +216,7 @@
 								
 								if (!res.connected &&!('lockType' in app.globalData.nearLockInfo)) {
 									// 蓝牙连接断开
-									console.log('蓝牙连接断开');
+									console.log(this.$t('蓝牙连接断开'));
 									if (!me.isReconnecting) { // 检查标志位
 										me.isReconnecting = true; // 设置标志位
 										setTimeout(() => {
@@ -226,7 +225,7 @@
 										}, 100);
 									}
 								} else {
-									console.log('蓝牙连接成功');
+									console.log(this.$t('蓝牙连接成功'));
 									// uni.hideLoading();
 									me.isBluetoothLock(device.mac_id)
 									
@@ -248,8 +247,8 @@
 								// 	var showContent = "连接失败,请尝试重新连接55555"
 								// }
 								// uni.showModal({
-								// 	title: '提示',
-								// 	confirmText: '重新连接',
+								// 	title: this.$t('提示'),
+								// 	confirmText: this.$t('重新连接'),
 								// 	content: showContent,
 								// 	success: function(res) {
 								// 		if (res.confirm) {
@@ -264,8 +263,8 @@
 								// console.log('蓝牙未打开或请在右上角设置授权小程序使用蓝牙66666');
 								uni.hideLoading();
 								uni.showModal({
-									title: '提示',
-									confirmText: '我知道了',
+									title: this.$t('提示'),
+									confirmText: this.$t('我知道了'),
 									content: '蓝牙未打开或请在右上角设置授权小程序使用蓝牙66666',
 									success: function(res) {
 										if (res.confirm) {
@@ -278,13 +277,13 @@
 					}, );
 				} else {
 					//蓝牙连接未成功
-					console.log('当前机柜未找到符合的蓝牙类型');
+					console.log(this.$t('当前机柜未找到符合的蓝牙类型'));
 					uni.hideLoading();
 					// uni.showModal({
-					// 	confirmText: '我知道了',
-					// 	content: '当前机柜未找到符合的蓝牙类型',
+					// 	confirmText: this.$t('我知道了'),
+					// 	content: this.$t('当前机柜未找到符合的蓝牙类型'),
 					// 	showCancel: false,
-					// 	title: '提示',
+					// 	title: this.$t('提示'),
 					// 	complete: (res) => {}
 					// });
 				}

+ 11 - 11
pages/bluetoothUnlock/unlockSet.vue

@@ -1,14 +1,14 @@
 <template>
 	<view class="unlockSet-page">
-		<navBar name="开启感应解锁" left="0"></navBar>
+		<navBar :name="$t('开启感应解锁')" left="0"></navBar>
 		<view class="lock-img"></view>
 		<view class="main">
-			<view class="primary-text">开启感应解锁后,携带手机靠近车辆并按Auto 键即可开机</view>
+			<view class="primary-text">{{ $t('开启感应解锁后,携带手机靠近车辆并按') }}Auto {{ $t('键即可开机') }}</view>
 			<view class="car-option-wrap">
 				<view class="img"></view>
 				<view class="opt-text-wrap">
 					<view class="text">{{ $t('按键解锁') }}</view>
-					<view class="sub-text">手机接近车辆后,长按Auto键即可解锁</view>
+					<view class="sub-text">{{ $t('手机接近车辆后,长按') }}Auto{{ $t('键即可解锁') }}</view>
 				</view>
 			</view>
 			<view class="sensitivity-set" @tap="openSensitivityDialog">
@@ -19,8 +19,8 @@
 
 		<u-popup v-model="showSensitivityDialog" mode="bottom" border-radius="28" @close="close">
 			<view class="popup-content">
-				<view class="title">灵敏度设置</view>
-				<view class="text">距离建议适中,设置过近会降低成功率,设置过远可能会有风险</view>
+				<view class="title">{{ $t('灵敏度设置') }}</view>
+				<view class="text">{{ $t('距离建议适中,设置过近会降低成功率,设置过远可能会有风险') }}</view>
 				<!-- <slider v-model="sensitivityValue" @change="changeValue"   height="16" :step="1" :min="0" :max="4" activeColor="#060809" backgroundColor="#F1F3F4" block-color="#060809" block-size="20"></slider> -->
 				<!-- <u-slider v-model="sensitivityValue"  height="16"  :step="1"  activeColor="#060809" backgroundColor="#F1F3F4" block-color="#060809"></u-slider> -->
 
@@ -30,9 +30,9 @@
 					<view class="slider-bg"></view>
 				</view>
 				<view class="flex-row step-text">
-					<text>最近</text>
-					<text>适中</text>
-					<text>最远</text>
+					<text>{{ $t('最近') }}</text>
+					<text>{{ $t('适中') }}</text>
+					<text>{{ $t('最远') }}</text>
 				</view>
 				<!-- <slider v-model="sensitivityValue" @change="changeValue"   height="16rpx" :step="1" :min="0" :max="4" activeColor="#060809" backgroundColor="#F1F3F4" block-color="#8A6DE9" block-size="20"></slider> -->
 				<!-- <u-slider v-model="sensitivityValue" height="16rpx" inactive-color="#F1F3F4" active-color="#060809" :step="1" :min="0" :max="4"></u-slider> -->
@@ -72,7 +72,7 @@
 				this.end = pageX
 				if(this.start > this.Move ){
 					if((this.start - this.Move) > 20){
-						console.log('左')
+						console.log(this.$t('左'))
 						if(this.sensitivityValue==0) return
 						this.sensitivityValue --
 						this.changeValue()
@@ -99,14 +99,14 @@
 				const car_sn = uni.getStorageSync('car_info').car_sn
 				common.loading();
 				bluetooth.setSensitivity(car_sn, value, () => {
-					console.log('设置灵敏度指令成功');
+					console.log(this.$t('设置灵敏度指令成功'));
 				})
 			},
 			closeNeerUnlock(){
 				const car_sn = uni.getStorageSync('car_info').car_sn
 				common.loading();
 				bluetooth.nearCloseUnlock(car_sn,()=>{
-					console.log('关闭接近解锁成功');
+					console.log(this.$t('关闭接近解锁成功'));
 				})
 			}
 		}

+ 16 - 16
pages/cabinetDetail/cabinetDetail.vue

@@ -17,7 +17,7 @@
 			</view>
 
 			<view v-if="tagList.length==0" class="no_battery">
-					无可用电池
+					{{ $t('无可用电池') }}
 				</view>
 				<view class="flex-row" style="justify-content: center;">
 					<view class="icon-box flex-row">
@@ -35,7 +35,7 @@
 					<view class="flex-row">
 						<img class="icon_grid"
 							:src="!isWorkTimer ? 'https://zxappfile.bms16.com/zx_admin/cab_timer.png' : 'https://zxappfile.bms16.com/zx_admin/cab_timer_work.png'">
-						<view :class="isWorkTimer ? 'grid_text_1' : 'grid_text_rest' ">{{isWorkTimer ? '营业中' : '已休息'}}
+						<view :class="isWorkTimer ? 'grid_text_1' : 'grid_text_rest' ">{{isWorkTimer ? $t('营业中'): t('已休息')}}
 						</view>
 					</view>
 					<view class="grid_text_2">
@@ -45,21 +45,21 @@
 				<view @tap="navToCabinet" class="right_grid flex-between">
 					<view>
 						<view class="cab_distance">
-							直线距您{{cabinetInfo.distance>1?(cabinetInfo.distance+'千米'):(cabinetInfo.distance*1000+'米')}}
+							{{ $t('直线距您') }}{{cabinetInfo.distance>1?(cabinetInfo.distance+$t('千米')):(cabinetInfo.distance*1000+$t('米'))}}
 						</view>
 						<view class="cab_address">{{cabinetInfo.address}}</view>
 					</view>
 					<view>
 						<img class="icon_grid_1" src="https://zxappfile.bms16.com/zx_admin/cab_nav.png">
-						<view class="grid_nav">导航</view>
+						<view class="grid_nav">{{ $t('导航') }}</view>
 					</view>
 				</view>
 			</view>
 		</view>
 		<view class="battery-list-view">
 			<view class="battery-title flex-row flex-between">
-				<text class="blod-text">格口详情</text>
-				<text class="cabinet-ref">电柜编号:<text class="cabinet-ref-text"> {{cabinetInfo.dev_id}}</text></text>
+				<text class="blod-text">{{ $t('格口详情') }}</text>
+				<text class="cabinet-ref">{{ $t('电柜编号:') }}<text class="cabinet-ref-text"> {{cabinetInfo.dev_id}}</text></text>
 			</view>
 			<view class="battery-list-main flex-row flex-start">
 				<view class="battery-list" v-for="(item, index) in batteryList" :key="item.unique">
@@ -75,12 +75,12 @@
 									<img class="status-img" src="https://zxappfile.bms16.com/zx_admin/reservation.png"
 										alt="">
 								</view>
-								<view class="tip-text tip-text-g1">已预约</view>
+								<view class="tip-text tip-text-g1">{{ $t('已预约') }}</view>
 							</view>
 						</block> -->
-					<!-- 没有预约-->
+					<!-- {{ $t('没有预约') }}-->
 					<!-- <block v-else> -->
-					<!-- 空仓或者仓门不可用-->
+					<!-- {{ $t('空仓或者仓门不可用') }}-->
 					<view v-if="!item.cabinet_battery_sn||(item.fault_reason&&item.fault_reason.length>0)"
 						:class="(item.fault_reason&&item.fault_reason.length>0)?'battery-list-s':'battery-list-g'">
 						<!-- <view class="namber-view flex-row">
@@ -108,12 +108,12 @@
 						</view>
 						<!-- <view class="battery-ref">124513215</view> -->
 						<view v-if="!item.cabinet_battery_sn&&!(item.fault_reason&&item.fault_reason.length>0)"
-							class="tip-text tip-text-g">空仓</view>
+							class="tip-text tip-text-g">{{ $t('空仓') }}</view>
 						<view v-if="item.fault_reason&&item.fault_reason.length>0" class="tip-text tip-text-u">
 							{{item.fault_reason[0]}}
 						</view>
 					</view>
-					<!-- 满电或者电量未满 -->
+					<!-- {{ $t('满电或者电量未满') }} -->
 					<view v-else :class="(item.is_full_soc==1)?'battery-list-b':'battery-list-o'">
 						<view class="namber-view flex-row flex-between">
 							<view :class="(item.is_full_soc==1)?'namber namber-b':'namber namber-o'">{{item.box_sn}}
@@ -131,8 +131,8 @@
 								<!-- 0168 8256 9608 -->
 							</view>
 						</view>
-						<view v-if="item.is_full_soc==1" class="tip-text tip-text-b">电池可用</view>
-						<view v-else class="tip-text tip-text-o">待充满</view>
+						<view v-if="item.is_full_soc==1" class="tip-text tip-text-b">{{ $t('电池可用') }}</view>
+						<view v-else class="tip-text tip-text-o">{{ $t('待充满') }}</view>
 					</view>
 					<!-- </block> -->
 				</view>
@@ -266,9 +266,9 @@
 			getBindBattery(packInfo) {
 				this.loadNowCabinetDetail(this.dev_id, this.myLocation, packInfo.order_sn, (bindSuccess) => {
 					uni.showModal({
-						title: '提示',
-						content: '领取电池成功',
-						confirmText: '确定',
+						title: this.$t('提示'),
+						content: this.$t('领取电池成功'),
+						confirmText: this.$t('确定'),
 						showCancel: false,
 						success: function(res) {
 							if (res.confirm) {

+ 13 - 13
pages/carDetail/carDetail.vue

@@ -21,29 +21,29 @@
 			<view style="flex-wrap: wrap;justify-content: flex-start;" class="flex-row car-detail-time">
 				<view v-for="(item,index) in car_detail.rental_setting" :key="index" @click="tapSelectType(item)"
 					:class="['time-unit',selectType==item.hire_duration_unit? 'time-unit-i':'']">
-					<text v-if="item.hire_duration_unit==1">日租</text>
-					<text v-if="item.hire_duration_unit==2">月租</text>
-					<text v-if="item.hire_duration_unit==3">年租</text>
-					<text v-if="item.hire_duration_unit==4">时租</text>
-					<text v-if="item.hire_duration_unit==5">分租</text>
-					<text v-if="item.hire_duration_unit==6">周租</text>
-					<text v-if="item.hire_duration_unit==7">季租</text>
+					<text v-if="item.hire_duration_unit==1">{{ $t('日租') }}</text>
+					<text v-if="item.hire_duration_unit==2">{{ $t('月租') }}</text>
+					<text v-if="item.hire_duration_unit==3">{{ $t('年租') }}</text>
+					<text v-if="item.hire_duration_unit==4">{{ $t('时租') }}</text>
+					<text v-if="item.hire_duration_unit==5">{{ $t('分租') }}</text>
+					<text v-if="item.hire_duration_unit==6">{{ $t('周租') }}</text>
+					<text v-if="item.hire_duration_unit==7">{{ $t('季租') }}</text>
 				</view>
 
 				<view v-if="car_detail.sell_price != 0" @click="tapSelectType({hire_duration_unit:100,hire_price:car_detail.sell_price})"
 					:data-select_type="100" :data-price="car_detail.sell_price"
-					:class="['time-unit',selectType==100? 'time-unit-i':'']">购买</view>
+					:class="['time-unit',selectType==100? 'time-unit-i':'']">{{ $t('购买') }}</view>
 			</view>
 		</view>
 		<!-- <view class="free-num-model">
 			<view class="flex-row flex-between">
 				<view class="free-num-view">
 					<img style="width: 40rpx;height: 40rpx;" src="https://qiniu.bms16.com/FtlfBtBE5-TeTI5EdrciX_u8u_Sx" alt="">
-					<text class="free-num-text">免费换电次数</text>
+					<text class="free-num-text">{{ $t('免费换电次数') }}</text>
 				</view>
-				<view class="free-num-time">1 次/日</view>
+				<view class="free-num-time">1 {{ $t('') }}/{{ $t('') }}</view>
 			</view>
-			<view class="free-num-tip">日租享1次免费换电数,超出后需要单独支付换电费用;</view>
+			<view class="free-num-tip">{{ $t('日租享') }}1{{ $t('次免费换电数,超出后需要单独支付换电费用;') }}</view>
 		</view> -->
 		<useGuidance />
 		<view class="card-car-detail">
@@ -87,7 +87,7 @@
 		</view>
 		<view style="height: 150rpx;"></view>
 		<view class="use-car-view flex-row">
-			<view @tap="useCarBtn" class="use-car-btn">我要用车</view>
+			<view @tap="useCarBtn" class="use-car-btn">{{ $t('我要用车') }}</view>
 		</view>
 		<carPlan v-if="showCarPlan" @changeSelectType="changeSelectType" @closeShowMore="closeShowMore" :params="params"
 			:selectType="selectType" />
@@ -184,7 +184,7 @@
 				// const phone = 18170410707
 				uni.showModal({
 					content: `您是否要拨打电话${phone}?`,
-					confirmText: '确定',
+					confirmText: this.$t('确定'),
 					success: (res) => {
 						if (res.confirm) {
 							uni.makePhoneCall({

+ 1 - 1
pages/carFunctionSet/more.vue

@@ -1,6 +1,6 @@
 <template>
 	<view class="zx-container car-function-set-more">
-		<navBar name="更多功能" left="0"></navBar>
+		<navBar :name="$t('更多功能')" left="0"></navBar>
 		<view style='margin-top: 20rpx;' class="fn-wrap">
 			<view class="title">
 				{{ $t('固定导航栏') }}

+ 5 - 5
pages/carFunctionSet/unbind.vue

@@ -1,6 +1,6 @@
 <template>
 	<view>
-		<navBar name="解除绑定" bgColor="#fff"></navBar>
+		<navBar :name="$t('解除绑定')" bgColor="#fff"></navBar>
 		<view class="zx-container unbind-page">
 		  <view class="zx-wrap car-info-wrap">
 		    <image :src="carInfo.model_images" class="car-img" />
@@ -21,11 +21,11 @@
 		    <view class="title">{{ $t('提示信息') }}</view>
 		    <view class="text">
 		      <text>1、</text>
-		      解绑后,您将失去当前设备的控制权,其他人可以连接绑定您的设备。
+		      {{ $t('解绑后,您将失去当前设备的控制权,其他人可以连接绑定您的设备。') }}
 		    </view>
 		    <view class="text">
 		      <text>2、</text>
-		      解绑后将立即删除家庭账号,感应解锁等数据。
+		      {{ $t('解绑后将立即删除家庭账号,感应解锁等数据。') }}
 		    </view>
 		  </view>
 		  <view
@@ -93,14 +93,14 @@
         this.showConfirm = true
       },
       async unbindSubmit() {
-        console.log('解除绑定', this.passwd)
+        console.log(this.$t('解除绑定'), this.passwd)
         let { data } = await request.postApi(config.API_FLK_CAR_UNBIND_CAR, {
           car_sn: this.carInfo.car_sn,
           passwd: this.passwd
         })
         if (data.code == 200) {
           //返回首页
-          common.simpleToast('解绑成功!')
+          common.simpleToast(this.$t('解绑成功!'))
           setTimeout(()=> {
             uni.switchTab({
               url: `/pages/index/index`,

+ 7 - 7
pages/carList/carList.vue

@@ -1,6 +1,6 @@
 <template>
 	<view>
-	<navBar name="请选择设备" type="select"/>
+	<navBar :name="$t('请选择设备')" type="select"/>
 	<view class="car-list">
 		<view v-for="(item,index) of carList" :key="index" @click="clickItem(item)"  :class="['car-list-card',  car_info.car_sn == item.car_sn?'car-list-card-i' :'']">
 		    <view class="flex-row">
@@ -12,17 +12,17 @@
 			<image class="img" :src="item.model_images" mode="aspectFit"></image>
 			<view v-if="car_info.car_sn == item.car_sn" class="select">
 				<image class="icon1" src="/static/resource/images/gyq_select.png" mode=""></image>
-				<text>当前选择</text>
+				<text>{{ $t('当前选择') }}</text>
 			</view>
 		</view>
 		<!-- <view class="options">
-			<view @click="navCarDetail" class="btn btn-left">{{ $t('租赁设备') }}</view>
-			<view class="btn btn-right">{{ $t('绑定设备') }}</view>
+			<view @click="navCarDetail" class="btn btn-left">{{ $t('{{ $t('租赁设备') }}') }}</view>
+			<view class="btn btn-right">{{ $t('{{ $t('绑定设备') }}') }}</view>
 		</view> -->
 		<!-- <Confirm
         v-model="showConfirm"
         :dialog-info="{
-          text: $t('是否切换到车辆' + clickItemData.car_name ),
+          text: $t('{{ $t('是否切换到车辆') }}' + clickItemData.car_name ),
           showCancelButton: true
         }"
         @confirm="unbindSubmit"
@@ -98,7 +98,7 @@
 						app.globalData.connectionState={}
 						
 						me.bluetoothClose()
-						common.simpleToast('切换成功!')
+						common.simpleToast(this.$t('切换成功!'))
 						setTimeout(()=> {
 							uni.navigateBack({
 								delta:1
@@ -132,7 +132,7 @@
 				bluetooth.closeDevice(
 					this.car_info.car_sn,
 					() => {
-						console.log('关闭蓝牙连接');
+						console.log(this.$t('关闭蓝牙连接'));
 						// this.setData({
 						// 	bt_loading: false
 						// });

+ 12 - 12
pages/carLocation/carLocation.vue

@@ -1,6 +1,6 @@
 <template>
 	<view class="">
-		<navBar name="车辆位置"></navBar>
+		<navBar :name="$t('车辆位置')"></navBar>
 		<!-- #ifndef APP -->
 		<map @touchmove="hiddenNav" @markertap="showNav" style="width: 100%; height: calc(100vh - 506rpx);" :latitude="latitude"
 			:longitude="longitude" :markers="markers" show-location>
@@ -12,19 +12,19 @@
 			longitude:car_info.longitude,
 		}'></googleMap>
 		<!-- #endif -->
-		<!-- 由于cover-view一些样式及点击事件不支持 -->
-		<!-- 气泡内容 -->
+		<!-- {{ $t('由于') }}cover-view{{ $t('一些样式及点击事件不支持') }} -->
+		<!-- {{ $t('气泡内容') }} -->
 		<view v-if="is_show_nav" class="block-view">
 			<view class="custom-bubble-name">{{address}}</view>
 			<view class="flex-row" style="justify-content: flex-end;">
 				<!-- <view class="flex-row block-car-time align-center">
 					<img style="width: 52rpx;height: 52rpx;" src="https://qiniu.bms16.com/FhKkijkN__9UzhYNgamBFSggIlYo" alt="">
-					<text class="car-time-text">已驻车 <text class="car-time-text-b">9</text>分钟</text>
+					<text class="car-time-text">{{ $t('已驻车') }} <text class="car-time-text-b">9</text>{{ $t('分钟') }}</text>
 				</view> -->
 				<view class="" @tap="navAddress"><img style="width: 112rpx;height: 64rpx;" src="https://qiniu.bms16.com/Fts38M35doVjK09GfOza5qD-wwkK" alt=""></view>
 			</view>
-			<view v-if="car_info.heart_time" class="updata-time">更新于 {{car_info.heart_time}} </view>
-			<view @tap="findCar"  class="car-config-btn">闪灯鸣笛</view>
+			<view v-if="car_info.heart_time" class="updata-time">{{ $t('更新于') }} {{car_info.heart_time}} </view>
+			<view @tap="findCar"  class="car-config-btn">{{ $t('闪灯鸣笛') }}</view>
 		</view>
 	</view>
 </template>
@@ -65,7 +65,7 @@ import googleMap from "@/component/googleMap/googleMap";
 			car_info.latitude = `${car_info.latitude}`
 			car_info.longitude = `${car_info.longitude}`
 			this.car_info = car_info
-			this.car_info.heart_time = this.car_info.heart_time ?  dayjs(this.car_info.heart_time*1000).format('YYYY-MM-DD hh:mm:ss') : '未知时间'
+			this.car_info.heart_time = this.car_info.heart_time ?  dayjs(this.car_info.heart_time*1000).format('YYYY-MM-DD hh:mm:ss') : this.$t('未知时间')
 			this.init()
 			// this.longitude = {
 			// 	longitude:car_info.longitude,
@@ -189,15 +189,15 @@ import googleMap from "@/component/googleMap/googleMap";
 			findCar(){
 				const me=this
 				uni.showModal({
-					title: '提示',
-					content: '您确认开启闪灯鸣笛吗',
+					title: this.$t('提示'),
+					content: this.$t('您确认开启闪灯鸣笛吗'),
 					showCancel: true,
-					cancelText: '取消',
-					confirmText: '确定',
+					cancelText: this.$t('取消'),
+					confirmText: this.$t('确定'),
 					success: function(res) {
 						if (res.confirm) {
 							me.setData({
-								popText:'闪灯鸣笛',
+								popText:this.$t('闪灯鸣笛'),
 								cmdType:'findCar',
 							})
 							me.tapBlueToothCmd('',true)

+ 5 - 5
pages/contract/contract.vue

@@ -3,15 +3,15 @@
 		<rich-text class="rich_text" :nodes="htmlContent"></rich-text>
 		<view class="bottom_view flex-row flex-between">
 			<view v-if="isAgree&&isBottom" @tap="clickAgreeContract" class="click_view">
-				本人已知晓上述内容
+				{{ $t('本人已知晓上述内容') }}
 			</view>
 			<view v-if="!isAgree&&isBottom" class="click_view_gray">
-				阅读合同倒计时{{countdownTime}}秒
+				{{ $t('阅读合同倒计时') }}{{countdownTime}}{{ $t('') }}
 			</view>
 	
 			<view v-if="orderSign == 1" @tap="clickWriteSign" class="write_sign" style="background-color: #ffffff;">
 				<image class="write_sign_img" src="https://qiniu.bms16.com/appsrc%2Fhire%2Fwrite_sign.png" />
-				<view class="sign_view">{{orderSignUrl == ''?'签名':'重新签名'}}</view>
+				<view class="sign_view">{{orderSignUrl == ''?$t('签名'):$t('重新签名')}}</view>
 			</view>
 		</view>
 	</view>
@@ -114,8 +114,8 @@
 			clickAgreeContract() {
 				// if (this.orderSign == 1 && this.orderSignUrl == '') {
 				// 	uni.showModal({
-				// 		title: '提示',
-				// 		content: '您当前没有手写签名,是否要进行填写',
+				// 		title: this.$t('提示'),
+				// 		content: this.$t('您当前没有手写签名,是否要进行填写'),
 				// 		showCancel: true,
 				// 		success: function(res) {
 				// 			if (res.confirm) {

+ 5 - 5
pages/dashboard/dashboard.vue

@@ -19,7 +19,7 @@
 				<view :style="{width:(((infoList.remain_mail || 0) / (infoList.endurance /1000) || 0) * 100) + '%'}"
 					class="is_progress"></view>
 				<view class="text">
-					<text style="margin-left: 20rpx;">续航</text>
+					<text style="margin-left: 20rpx;">{{ $t('续航') }}</text>
 					<!-- <text style="margin-left: 16rpx;"> {{(infoList.remain_mail || 0/1000).toFixed(0) || 0}}km </text> -->
 					<text style="margin-left: 16rpx;"> {{ infoList.remain_mail > 0 ? infoList.remain_mail : 0 }}km </text>
 					
@@ -85,22 +85,22 @@
 				if (data.code == 200) {
 					this.infoList = data.data.data
 					this.infoList.list = [{
-							label: '骑行里程',
+							label: this.$t('骑行里程'),
 							prop: this.infoList.current_mail || 0,
 							unit: 'km'
 						},
 						{
-							label: '骑行时长',
+							label: this.$t('骑行时长'),
 							prop: (this.infoList.current_time / 60 /60).toFixed(2) || 0,
 							unit: 'h'
 						},
 						{
-							label: '最大速度',
+							label: this.$t('最大速度'),
 							prop: this.infoList.max_speed || 0,
 							unit: 'km/h'
 						},
 						{
-							label: '平均速度',
+							label: this.$t('平均速度'),
 							prop: this.infoList.avg_speed || 0,
 							unit: 'km/h'
 						},

+ 5 - 5
pages/deviceInfo/deviceInfo.vue

@@ -4,27 +4,27 @@
 		<view class="device-name">{{list.car_name}}</view>
 		<view class="block-card">
 			<view class="info-view">
-				<view class="info-title">车架号</view>
+				<view class="info-title">{{ $t('车架号') }}</view>
 				<view class="info-value">{{list.frame_no}}</view>
 			</view>
 			<view class="info-view">
-				<view class="info-title">设备编号</view>
+				<view class="info-title">{{ $t('设备编号') }}</view>
 				<view class="info-value">{{car_sn}}</view>
 			</view>
 			<view class="info-view">
-				<view class="info-title">车辆总里程</view>
+				<view class="info-title">{{ $t('车辆总里程') }}</view>
 				<view class="info-value">{{(Number(list.total_mil) / 1000).toFixed(2)}}km</view>
 			</view>
 		</view>
 		<view class="flex-row">
 			<view class="block-card-1" style="margin-right: 18rpx;">
 				<img class="info-icon" src="https://qiniu.bms16.com/FoyFReERWQ5jmqQIk0Aj9V7SWGR2" alt="">
-				<view class="info-text">中控硬件</view>
+				<view class="info-text">{{ $t('中控硬件') }}</view>
 				<view class="info-vosion">{{list.control_hardware}}</view>
 			</view>
 			<view class="block-card-1">
 				<img class="info-icon" src="https://qiniu.bms16.com/Fvf3btY0699U2P65cRxYGDBADNHr" alt="">
-				<view class="info-text">中控软件</view>
+				<view class="info-text">{{ $t('中控软件') }}</view>
 				<view class="info-vosion">{{list.control_software}}</view>
 			</view>
 		</view>

+ 14 - 14
pages/feedback/index.vue

@@ -1,8 +1,8 @@
 <template>
 	<view class="container">
-		<navBar name="意见反馈" left="0"></navBar>
+		<navBar :name="$t('意见反馈')" left="0"></navBar>
 		<view style="display: flex;">
-			<text class="title">问题类型</text>
+			<text class="title">{{ $t('问题类型') }}</text>
 			<text style="color: red; margin-left: 10rpx;">*</text>
 		</view>
 		<view class="title-wrapper">
@@ -12,20 +12,20 @@
 		</view>
 		<view style="margin: 64rpx 0;">
 			<view style="display: flex;">
-				<text class="title">问题描述</text>
+				<text class="title">{{ $t('问题描述') }}</text>
 				<text style="color: red; margin-left: 10rpx;">*</text>
 			</view>
 			<view class="text-description-input">
 				<textarea :enableNative="false" @input="inputContent" :value="content"
-					placeholder-class="description-placeholder" placeholder="请详细说明,以便我们解决问题,最多可填写300字。"
+					placeholder-class="description-placeholder" :placeholder="$t('请详细说明,以便我们解决问题,最多可填写')+300+$t('字。')"
 					maxlength="300"></textarea>
 			</view>
 		</view>
 		<view>
 			<view class="title-img">
-				<!-- <view class="title-img-text">问题图片</view> -->
+				<!-- <view class="title-img-text">{{ $t('问题图片') }}</view> -->
 				<view style="display: flex;">
-					<text class="title">问题图片</text>
+					<text class="title">{{ $t('问题图片') }}</text>
 					<text style="color: red; margin-left: 10rpx;">*</text>
 				</view>
 				<view class="img-text">{{ imgList.length }} / 3</view>
@@ -46,9 +46,9 @@
 
 		</view>
 		<view class="submit-btn-view">
-			<view v-if="typeId != '' && imgList.length != 0 && content != ''" class="submit" @tap="submitFeedback">提交
+			<view v-if="typeId != '' && imgList.length != 0 && content != ''" class="submit" @tap="submitFeedback">{{ $t('提交') }}
 			</view>
-			<view v-else class="submit-btn">提交</view>
+			<view v-else class="submit-btn">{{ $t('提交') }}</view>
 		</view>
 	</view>
 </template>
@@ -66,23 +66,23 @@
 			return {
 				typeList: [{
 						type_id: 1,
-						type_name: '车辆'
+						type_name: this.$t('车辆')
 					},
 					{
 						type_id: 2,
-						type_name: '电池'
+						type_name: this.$t('电池')
 					},
 					{
 						type_id: 3,
-						type_name: '电柜'
+						type_name: this.$t('电柜')
 					},
 					{
 						type_id: 4,
-						type_name: '应用操作'
+						type_name: this.$t('应用操作')
 					},
 					{
 						type_id: 5,
-						type_name: '其他'
+						type_name: this.$t('其他')
 					},
 				],
 				typeId: '',
@@ -177,7 +177,7 @@
 						// that.setData({
 						// 	isDiabled:true
 						// })
-						common.simpleToast('提交成功')
+						common.simpleToast(this.$t('提交成功'))
 						setTimeout(() => {
 							wx.navigateBack({
 								delta: 1 // 返回上一级页面

+ 8 - 8
pages/index/components/AndroidUnlockAuth.vue

@@ -3,7 +3,7 @@
     <view class="dialog-content">
       <view class="title">{{ $t('开启感应解锁') }}</view>
       <view class="tips">
-        为保证 感应解锁 的正常使用,请依次开以下权限,开启后可以显著提高解锁成功率,且不会明显增加手机电量消耗
+        {{ $t('为保证') }} {{ $t('感应解锁') }} {{ $t('的正常使用,请依次开以下权限,开启后可以显著提高解锁成功率,且不会明显增加手机电量消耗') }}
       </view>
       <view class="authorization-wrap">
         <view class="corner-mark">{{ $t('授权引导') }}</view>
@@ -60,10 +60,10 @@ export default {
   //   authStepList() {
   //     const lang = v => this.$t(v)
   //     return [
-  //       { title: ('位置权限'), type: 'location', desc: '打开手机定位,并运行APP始终使用' },
-  //       { title: ('电池优化'), type: 'battery', desc: '打开电池优化设置, 将弗兰克APP加入保护名单' },
-  //       // { title: ('后台运行'), type: 'backstage', desc: '打开后台运行权限 清选择手动控制' },
-  //       // { title: ('打开应用锁'), type: 'appLock', desc: '打开应用权限锁' }
+  //       { title: (this.$t('位置权限')), type: 'location', desc: '打开手机定位,并运行APP始终使用' },
+  //       { title: (this.$t('电池优化')), type: 'battery', desc: '打开电池优化设置, 将弗兰克APP加入保护名单' },
+  //       // { title: (this.$t('后台运行')), type: 'backstage', desc: '打开后台运行权限 清选择手动控制' },
+  //       // { title: (this.$t('打开应用锁')), type: 'appLock', desc: this.$t('打开应用权限锁') }
   //     ]
   //   }
   // },
@@ -87,11 +87,11 @@ export default {
       return result == AUTHORIZ
       // var strStatus
       // if (result == 1) {
-      //   strStatus = "已获得授权"
+      //   strStatus = this.$t('已获得授权')
       // } else if (result == 0) {
-      //   strStatus = "未获得授权"
+      //   strStatus = this.$t('未获得授权')
       // } else {
-      //   strStatus = "被永久拒绝权限"
+      //   strStatus = this.$t('被永久拒绝权限')
       // }
       // permision.gotoAppPermissionSetting()
       // uni.showModal({

+ 12 - 12
pages/index/components/IosUnlockAuth.vue

@@ -1,22 +1,22 @@
 <template>
     <u-popup v-model="showDialog" mode="bottom" border-radius="28" @close="close">
         <view class="dialog-content">
-            <view class="title">请先开启位置授权</view>
-            <view class="tips">为保证 感应解锁 的正常使用,请 开启位置授权 并 打开精准位置 开关,可提高解锁成功率,且不会明显增加手机电量消耗。</view>
+            <view class="title">{{ $t('请先开启位置授权') }}</view>
+            <view class="tips">{{ $t('为保证') }} {{ $t('感应解锁') }} {{ $t('的正常使用,请') }} {{ $t('开启位置授权') }} {{ $t('') }} {{ $t('打开精准位置') }} {{ $t('开关,可提高解锁成功率,且不会明显增加手机电量消耗。') }}</view>
             <view class="authorization-wrap">
-                <view class="corner-mark">授权引导</view>
+                <view class="corner-mark">{{ $t('授权引导') }}</view>
                  <view class="step-item">
                     <view class="address-title-view flex-row">
                     	<image style="width: 62rpx;height: 84rpx;" src="https://qiniu.bms16.com/Fve-wxQ2MHOLXoQ3IZ7QdcKoLlwW" mode=""></image>
 						<view class="address-title">
-							<view>位置权限</view>
-							<view class="address-text-tip">打开手机定位,并允许APP <text style="color: #0A59F7;">「始终」</text>使用</view>
+							<view>{{ $t('位置权限') }}</view>
+							<view class="address-text-tip">{{ $t('打开手机定位,并允许') }}APP <text style="color: #0A59F7;">{{ $t('「始终」') }}</text>{{ $t('使用') }}</view>
 						</view>
 					</view>
 					<view v-for="(item, idx) in authStepList" :key="idx" @tap="enablePermissions(item)" class="permission-set-view">
 					<!-- <view class="permission-set-view" style="margin-bottom: 42rpx;"> -->
 						<view class="icon-step"><image style="width: 160rpx;height: 78rpx;" src="https://qiniu.bms16.com/FvTiAtpG8QOlJxGrNquB-yI396Be" /></view>
-						<view class="step-text">第<text style="font-size: 40rpx; font-weight: 600;margin: 0 6rpx;"> {{ idx+1 }} </text>步</view>
+						<view class="step-text">{{ $t('') }}<text style="font-size: 40rpx; font-weight: 600;margin: 0 6rpx;"> {{ idx+1 }} </text>{{ $t('') }}</view>
 						<view class="permission-tip-view flex-row flex-between">
 							<view class="permission-tip flex-row">
 								{{ item.desc }}
@@ -28,27 +28,27 @@
 						</view>
 						<view class="permission-top-view">{{ item.title }}</view>
 						<view v-if="item.type=='awalysLocation'" class="permission-one flex-row flex-between">
-							<text class="alaways-text">始终</text>
+							<text class="alaways-text">{{ $t('始终') }}</text>
 							<image class="check-icon" src="https://qiniu.bms16.com/Fj595k1vS6PArDsvoPTkO8PcyqRc" mode=""></image>
 						</view>
 					</view>
 					<!-- <view class="permission-set-view">
 						<view class="icon-step"><image style="width: 160rpx;height: 78rpx;" src="https://qiniu.bms16.com/FvTiAtpG8QOlJxGrNquB-yI396Be" /></view>
-						<view class="step-text">第<text style="font-size: 40rpx; font-weight: 600;margin: 0 6rpx;"> 2 </text>步</view>
+						<view class="step-text">{{ $t('') }}<text style="font-size: 40rpx; font-weight: 600;margin: 0 6rpx;"> 2 </text>{{ $t('') }}</view>
 						<view class="permission-tip-view flex-row flex-between">
 							<view class="permission-tip flex-row">
-								开启请准位置开关
+								{{ $t('开启请准位置开关') }}
 								<image style="width: 28rpx;height: 28rpx;" src="https://qiniu.bms16.com/FrLjB8R1kL_AQNJjWUaKcDkLC-8O" />
 							</view>
 							<view :class="['turn-on-switch', state && 'is-open']">
-								{{ state ? $t('已开启') : $t('未开启') }}
+								{{ state ? $t('{{ $t('已开启') }}') : $t('{{ $t('未开启') }}') }}
 							</view>
 						</view>
-						<view class="permission-top-view">精准位置</view>
+						<view class="permission-top-view">{{ $t('精准位置') }}</view>
 					</view> -->
                  </view>
             </view>
-            <view class="btn" @tap="linkTo" >我已开启</view>
+            <view class="btn" @tap="linkTo" >{{ $t('我已开启') }}</view>
         </view>
     </u-popup>
 </template>

+ 32 - 32
pages/index/components/control/control.vue

@@ -13,7 +13,7 @@
 		<view class="flex-row power-view">
 			<!-- <view class="power-on-off flex-row" >
 				<view :style="sliderStyle" @touchstart="touchStart" @touchmove="touchMove" @touchend="touchEnd" class="power-on-btn"><image style="width: 52rpx;height: 52rpx;" src="https://qiniu.bms16.com/Fkovrpq1bexe-Unal_VJREbLUhdu" mode=""></image></view>
-				<view class="power-on-text" >滑动启动</view>
+				<view class="power-on-text" >{{ $t('滑动启动') }}</view>
 			</view> -->
 			<custom-switch  :width="'400rpx'"
 				:height="'96rpx'"  :modelValue="switchValue" :fetchData="loadData"></custom-switch>
@@ -21,7 +21,7 @@
 			    :height="'96rpx'"  v-model="switchValue" :fetchData="loadData"></custom-switch> -->
 			<view @tap="navToInputPages" class="car-change-battery flex-row">
 				<view class="car-change-btn"><image style="width: 80rpx;height: 80rpx;" src="https://qiniu.bms16.com/FgvnT-msLbL5RHjl6fvNlM0kab5N" mode=""></image></view>
-				<view class="car-change-text">车辆换电</view>
+				<view class="car-change-text">{{ $t('车辆换电') }}</view>
 			</view>
 		</view>
 		<view v-if="popupControlShow" class="show-modal">
@@ -35,17 +35,17 @@
 			</view>
 		</view>
 		<!-- <u-popup v-model="popupControlShow" mode="center" border-radius="30" height="30%" length="60%">
-			<view class="popup-title">开启车辆</view>
-			<view class="popup-content">确定打开</view>
+			<view class="popup-title">{{ $t('开启车辆') }}</view>
+			<view class="popup-content">{{ $t('确定打开') }}</view>
 			<view class="flex-row">
-				<view class="sure-btn cencel-btn" @tap="closePopup">取消</view>
-				<view class="sure-btn ok-btn" >确定</view>
+				<view class="sure-btn cencel-btn" @tap="closePopup">{{ $t('取消') }}</view>
+				<view class="sure-btn ok-btn" >{{ $t('确定') }}</view>
 			</view>
 		</u-popup> -->
 		<!-- <view v-if="isShowMore" class="show-more">
 			<view class="more-info">
 				<view class="flex-row flex-between model-title">
-					<view>{{$t("更多功能")}}</view>
+					<view>{{$t("{{ $t('更多功能') }}")}}</view>
 					<view>
 						<image style="width: 32rpx;height: 32rpx;" @tap="isShowMore = false"
 							src="https://qiniu.bms16.com/FtoTEHOJiUf_gjPCJGGHMsAtHI5M" />
@@ -54,19 +54,19 @@
 				<view style="height: 300rpx;">
 					<view data-url="test" @tap="navUrl" class="more-item flex-row">
 						<img class="more-img" src="https://qiniu.bms16.com/FgxiD-W96FGvgyLI_kXUfWVDYLQ9" alt="">
-						<text>{{$t("胎压")}}</text>
+						<text>{{$t("{{ $t('胎压') }}")}}</text>
 					</view>
 					<view class="more-item flex-row">
 						<img class="more-img" src="https://qiniu.bms16.com/FgxiD-W96FGvgyLI_kXUfWVDYLQ9" alt="">
-						<text>{{$t("电池信息")}}</text>
+						<text>{{$t("{{ $t('电池信息') }}")}}</text>
 					</view>
 					<view @tap="navCarLocation" class="more-item flex-row">
 						<img class="more-img" src="https://qiniu.bms16.com/FgxiD-W96FGvgyLI_kXUfWVDYLQ9" alt="">
-						<text>{{$t("导航")}}</text>
+						<text>{{$t("{{ $t('导航') }}")}}</text>
 					</view>
 				</view>
 				<view class="lift-btn-view">
-					<view class="lift-btn">{{$t("解除绑定")}}</view>
+					<view class="lift-btn">{{$t("{{ $t('解除绑定') }}")}}</view>
 				</view>
 			</view>
 		</view>
@@ -157,11 +157,11 @@ export default {
 				http.postApi(config.API_FLK_CAR_SWITCH, pData, (resp) => {
 					uni.hideLoading();
 					if (resp.data.code === 200) {
-						common.simpleToast(me.popText + '成功');
+						common.simpleToast(me.popText + this.$t('成功'));
 						const activeTag = me.contrilList.map(item => {
 							if('isLock' in item){
 								item.isTurnOn = (item.isTurnOn == 1) ? 0 : 1
-								item.name = i18n.t((item.isTurnOn == 1) ? '关机' : '开机')
+								item.name = i18n.t((item.isTurnOn == 1) ? this.$t('关机') : this.$t('开机'))
 							}
 							return item
 						})
@@ -200,16 +200,16 @@ export default {
 						me.loadGeneralQRData(res.result)
 					},
 					fail() {
-						me.$msg('扫码失败,请重新扫码')
+						me.$msg(this.$t('扫码失败,请重新扫码'))
 					}
 				})
 			}else if(exchange_need_package==1){
 				uni.showModal({
-					title: '温馨提示',
-					content: '您还未购买换电套餐,是否前往购买换电套餐?',
+					title: this.$t('温馨提示'),
+					content: this.$t('您还未购买换电套餐,是否前往购买换电套餐?'),
 					showCancel: true,
-					cancelText: '取消',
-					confirmText: '前往购买',
+					cancelText: this.$t('取消'),
+					confirmText: this.$t('前往购买'),
 					success: function(res) {
 						if (res.confirm) {
 							if(isCarLocation){
@@ -225,7 +225,7 @@ export default {
 					complete: function(res) {},
 				})
 			}else if(exchange_need_package==-1){
-				this.$msg('当前车辆暂未绑定电池')
+				this.$msg(this.$t('当前车辆暂未绑定电池'))
 			}
 			
 		},
@@ -234,14 +234,14 @@ export default {
 			let objOpt = this.$paramsObj(options)
 			
 			if (objOpt.d) {
-				console.log('扫码的是机柜')
+				console.log(this.$t('扫码的是机柜'))
 				uni.navigateTo({
 					url: `/pages/cabinetDetail/cabinetDetail?dev_id=${objOpt.d}`,
 				})
 				return
 			} else {
-				console.log('扫码的是车辆')
-				this.$msg('请扫描机柜二维码')
+				console.log(this.$t('扫码的是车辆'))
+				this.$msg(this.$t('请扫描机柜二维码'))
 				return
 			}
 		},
@@ -263,12 +263,12 @@ export default {
 									console.log(resp.data)
 									
 									if (resp.data.code === 200) {
-										//const textStr = (this.switchValue==0)?'开机':'关机'
+										//const textStr = (this.switchValue==0)?this.$t('开机'):this.$t('关机')
 	
 										// const activeTag = me.contrilList.map(item => {
 										// 	if('isLock' in item){
 										// 		item.isTurnOn = (item.isTurnOn == 1) ? 0 : 1
-										// 		item.name = i18n.t((item.isTurnOn == 1) ? '关机' : '开机')
+										// 		item.name = i18n.t((item.isTurnOn == 1) ? this.$t('关机') : this.$t('开机'))
 										// 	}
 										// 	return item
 										// })
@@ -365,10 +365,10 @@ export default {
 		// 			http.postApi(config.API_FLK_CAR_SWITCH, pData, (resp) => {
 		// 				uni.hideLoading();
 		// 				if (resp.data.code === 200) {
-		// 					common.simpleToast(me.popText + '成功');
+		// 					common.simpleToast(me.popText + this.$t('成功'));
 		// 					const activeTag=me.contrilList.map(item=>{
 		// 						item.isTurnOn=(item.isTurnOn==1)?0:1
-		// 						item.name=i18n.t((item.isTurnOn==1)?'关机':'开机')
+		// 						item.name=i18n.t((item.isTurnOn==1)?this.$t('关机'):this.$t('开机'))
 		// 						return item
 		// 					})
 		// 					const tag=getFunctionTag().tag
@@ -390,7 +390,7 @@ export default {
 		// 			http.postApi(config.API_FLK_CAR_REMOTE_CONTROL, pData, (resp) => {
 		// 				uni.hideLoading();
 		// 				if (resp.data.code === 200) {
-		// 					common.simpleToast(me.popText + '成功');
+		// 					common.simpleToast(me.popText + this.$t('成功'));
 		// 				} else {
 		// 					common.simpleToast(resp.data.msg);
 		// 				}
@@ -415,18 +415,18 @@ export default {
 		// 				command('900000997', () => {
 		// 					uni.hideLoading();
 		// 					if(this.cmdType=='openSeatBag'||this.cmdType=='openTailBox'){
-		// 						common.simpleToast('操作成功');
+		// 						common.simpleToast(this.$t('操作成功'));
 		// 					}
 		// 					console.log(`发送${this.popText}指令结束`);
 		// 				});
 		// 			}
 		// 		}else{
 		// 			uni.showModal({
-		// 				title: '提示',
-		// 				content: '当前车辆处于离线,是否前往开启蓝牙配对操作车辆?',
+		// 				title: this.$t('提示'),
+		// 				content: this.$t('当前车辆处于离线,是否前往开启蓝牙配对操作车辆?'),
 		// 				showCancel: true,
-		// 				cancelText: '取消',
-		// 				confirmText: '确定',
+		// 				cancelText: this.$t('取消'),
+		// 				confirmText: this.$t('确定'),
 		// 				success: function(res) {
 		// 					if (res.confirm) {
 		// 						me.$emit('toBluetooth')

+ 3 - 3
pages/index/components/mapCard/mapCard.vue

@@ -4,7 +4,7 @@
 		<view :style="{width:'100%',height: height?'258rpx':'140rpx'}" class="map">
 			<cover-view  class="top-car-location">
 				<cover-image class='img' style="width: 36rpx;height: 36rpx;" src="https://qiniu.bms16.com/FrKY7Ex5za22plr39ddIsJcjFVpi" ></cover-image>
-				<cover-view class="text">车辆位置</cover-view>
+				<cover-view class="text">{{ $t('车辆位置') }}</cover-view>
 			</cover-view>
 			<googleMap keyId="1" width='100%' :height="height?'258rpx':'140rpx'" v-if="car_info.latitude"  :mapData="{type:3}" :myLocations='{
 				longitude:car_info.longitude,
@@ -18,7 +18,7 @@
 			:latitude="car_info.latitude" scale="16" show-location :style="{width:'300rpx',height: height?'258rpx':'140rpx'}" :markers="carLocation">
 			<view class="top-car-location flex-row">
 				<img style="width: 36rpx;height: 36rpx;" src="https://qiniu.bms16.com/FrKY7Ex5za22plr39ddIsJcjFVpi" alt="">
-				<text>车辆位置</text>
+				<text>{{ $t('车辆位置') }}</text>
 			</view>
 		</map>
 		<!-- #endif -->
@@ -37,7 +37,7 @@
 		},
 		data() {
 			return {
-				carAddress:'未知',
+				carAddress:this.$t('未知'),
 				carLocation:[]
 			};
 		},

+ 13 - 13
pages/index/components/unleasedPages/unleasedPages.vue

@@ -18,19 +18,19 @@
 			<view class="car-model-step">
 				<view style="padding-top: 80rpx;margin-bottom: 60rpx;">
 					<view class="recommend-car-name w_100 text-center">{{moder_info.model_name}}</view>
-					<view class="recommend-car-tip w_100 text-center line2">{{moder_info.title||'续航开新路 路遥见实力'}}</view>
+					<view class="recommend-car-tip w_100 text-center line2">{{moder_info.title || $t('续航开新路') + $t('路遥见实力')}}</view>
 					<!-- <view class="car-speed-view">
 						<view class="car-speed">72 <text class="company">km</text></view>
-						<text>全速续航</text>
+						<text>{{ $t('全速续航') }}</text>
 					</view> -->
 					<!-- <view class="car-speed-view">
 						<view class="car-speed">52 <text class="company">km/h</text></view>
-						<text>极速可达</text>
+						<text>{{ $t('极速可达') }}</text>
 					</view> -->
 				</view>
 				<view class="flex-row" @tap="navCarDetail" style="justify-content: center;">
 					<view class="more-btn flex-row">
-						<view class="more-btn-text">了解更多</view>
+						<view class="more-btn-text">{{ $t('了解更多') }}</view>
 						<img class="more-btn-img" src="https://qiniu.bms16.com/Fi2Lg800Mc1MhCnvHT1DkvOEdJB1" alt="">
 					</view>
 				</view>
@@ -39,8 +39,8 @@
 					</view>
 				</view>
 				<view class="flex-row flex-around">
-					<view @tap="navCarDetail" class="lease-btn">租赁设备</view>
-					<view class="binding-btn">绑定设备</view>
+					<view @tap="navCarDetail" class="lease-btn">{{ $t('租赁设备') }}</view>
+					<view class="binding-btn">{{ $t('绑定设备') }}</view>
 				</view>
 			</view>
 		</view>
@@ -52,28 +52,28 @@
 			</view>
 			<view class="car-model-step">
 				<view style="padding-top: 80rpx;margin-bottom: 60rpx;">
-					<view class="recommend-car-name w_100 text-center">全新车型,即将发布!</view>
-					<view class="recommend-car-tip w_100 text-center line2">更智能、更高效,全新车型即将亮相,敬请期待!</view>
+					<view class="recommend-car-name w_100 text-center">{{ $t('全新车型,即将发布!') }}</view>
+					<view class="recommend-car-tip w_100 text-center line2">{{ $t('更智能、更高效,全新车型即将亮相,敬请期待!') }}</view>
 					<!-- <view class="car-speed-view">
 						<view class="car-speed">72 <text class="company">km</text></view>
-						<text>全速续航</text>
+						<text>{{ $t('全速续航') }}</text>
 					</view> -->
 					<!-- <view class="car-speed-view">
 						<view class="car-speed">52 <text class="company">km/h</text></view>
-						<text>极速可达</text>
+						<text>{{ $t('极速可达') }}</text>
 					</view> -->
 					
 				</view>
 				<view class="flex-row" @tap="navCarDetail1" style="justify-content: center;">
 					<view class="more-btn flex-row">
-						<view class="more-btn-text">了解更多</view>
+						<view class="more-btn-text">{{ $t('了解更多') }}</view>
 						<img class="more-btn-img" src="https://qiniu.bms16.com/Fi2Lg800Mc1MhCnvHT1DkvOEdJB1" alt="">
 					</view>
 				</view>
 				<view style="height: 160rpx;"></view>
 				<view class="flex-row flex-around">
-					<view @tap="navCarDetail1" class="lease-btn">租赁设备</view>
-					<view class="binding-btn">绑定设备</view>
+					<view @tap="navCarDetail1" class="lease-btn">{{ $t('租赁设备') }}</view>
+					<view class="binding-btn">{{ $t('绑定设备') }}</view>
 				</view>
 			</view>
 		</view>

+ 1 - 1
pages/index/homeNotRent.vue

@@ -17,7 +17,7 @@
           <swiper-item v-for="(item, index) in descArr" :key="index">
             <view class="swiper-item">
                 {{ item.speed }}
-                <view class="more-btn">了解更多</view>
+                <view class="more-btn">{{ $t('了解更多') }}</view>
             </view>
           </swiper-item>
         </swiper>

+ 8 - 8
pages/index/index.vue

@@ -29,19 +29,19 @@
 					</view>
 					<view v-if="isOverdueShow" class="overdue-view flex-row flex-between">
 						<view class="overdue-view-text flex-row">
-							<text class="overdue-text-left">您已逾期
+							<text class="overdue-text-left">{{ $t('您已逾期') }}
 								<text class="overdue-num">
 									<block v-if="orderInfo.hire_duration_time">
 										{{orderInfo.hire_duration_time.day > 0 ? orderInfo.hire_duration_time.day :'' }}<text
-											v-if="orderInfo.hire_duration_time.day>0">日</text>{{orderInfo.hire_duration_time.hour > 0 ? orderInfo.hire_duration_time.hour :'' }}<text
-											v-if="orderInfo.hire_duration_time.hour>0">小时</text>{{orderInfo.hire_duration_time.minute > 0 ? orderInfo.hire_duration_time.minute :'' }}<text
-											v-if="orderInfo.hire_duration_time.minute>0">分</text>
+											v-if="orderInfo.hire_duration_time.day>0">{{ $t('') }}</text>{{orderInfo.hire_duration_time.hour > 0 ? orderInfo.hire_duration_time.hour :'' }}<text
+											v-if="orderInfo.hire_duration_time.hour>0">{{ $t('小时') }}</text>{{orderInfo.hire_duration_time.minute > 0 ? orderInfo.hire_duration_time.minute :'' }}<text
+											v-if="orderInfo.hire_duration_time.minute>0">{{ $t('') }}</text>
 									</block>
 								</text>
 							</text>
-							<text style="font-size: 24rpx;opacity: 0.5;">请及时续费或归还车辆</text>
+							<text style="font-size: 24rpx;opacity: 0.5;">{{ $t('请及时续费或归还车辆') }}</text>
 						</view>
-						<view @click="routerLink('/pages/order/order')" class="renew-btn">去续费</view>
+						<view @click="routerLink('/pages/order/order')" class="renew-btn">{{ $t('去续费') }}</view>
 					</view>
 					<view class="car-img-view" >
 						<view v-if="!car_info.sold_time" class="flex-row flex-between" style="align-items: center;">
@@ -49,7 +49,7 @@
 									style="font-size: 28rpx;font-weight: 500;">%</text></text>
 							<view @tap.stop="tapReturnCar" class="return-car-btn flex-row">
 								<image style="width: 46rpx;height: 46rpx;" src="https://qiniu.bms16.com/FtyG7Gq2QBaVVrZmTnmZFzXhE5nN" mode=""></image>
-								<view style="margin-left: 12rpx;">我要还车</view>
+								<view style="margin-left: 12rpx;">{{ $t('我要还车') }}</view>
 							</view>
 						</view>
 						<view class="quantity-view flex-row">
@@ -90,7 +90,7 @@
 									<view class="flex-row align-center">
 										<img style="width: 36rpx;height: 36rpx;"
 											src="https://qiniu.bms16.com/FkrcMCV__HraZ0W0NBNdEZPIlwss" alt="">
-										<text class="margin_l_8">{{isTrackOrAll?'最近骑行':'总里程'}}</text>
+										<text class="margin_l_8">{{isTrackOrAll?$t('最近骑行'):$t('总里程')}}</text>
 									</view>
 									<view @tap.stop="isTrackOrAll=!isTrackOrAll"><img
 											style="width: 24rpx;height: 20rpx;"

+ 13 - 13
pages/login/login.vue

@@ -1,20 +1,20 @@
 <template>
 	<view class="container">
 		<view class="bg-img">
-			<view>欢迎来到{{appConfig.app_name}}</view>
+			<view>{{ $t('欢迎来到') }}{{appConfig.app_name}}</view>
 		</view>
 		<view class="content-box">
-			<view @tap="clickGetLoginInfo">手机号快捷登录</view>
-			<view @tap="navToPage" data-url="/pages/phoneLogin/phoneLogin">其他手机号登录</view>
+			<view @tap="clickGetLoginInfo">{{ $t('手机号快捷登录') }}</view>
+			<view @tap="navToPage" data-url="/pages/phoneLogin/phoneLogin">{{ $t('其他手机号登录') }}</view>
 			<view class="contract-item flex-row">
 				<view @tap="bindContractInfo">
 					<img class="check-icon"
 						:src="contract_id==1?'https://qiniu.bms16.com/FjLudtM29xwqgJh5kUKR9kyhK0Lu':'https://qiniu.bms16.com/FuQZipm9g7wX6CyGQBCjK2RTXfbW'" />
 				</view>
-				<view @tap="bindContractInfo" style="padding-left: 8rpx;">已阅读并同意
+				<view @tap="bindContractInfo" style="padding-left: 8rpx;">{{ $t('已阅读并同意') }}
 					<text style="color:#0074FF"
-						@click.native.stop="bindContractToAgreement">{{'《' + appConfig.app_name + '电动车租赁用户协议》'}}</text>和
-					<text style="color:#0074FF" @click.native.stop="bindContractToPrivacy">《隐私协议》</text>
+						@click.native.stop="bindContractToAgreement">{{'《' + appConfig.app_name + $t('电动车租赁用户协议》')}}</text>{{ $t('') }}
+					<text style="color:#0074FF" @click.native.stop="bindContractToPrivacy">{{ $t('《隐私协议》') }}</text>
 				</view>
 			</view>
 		</view>
@@ -25,14 +25,14 @@
 					<img :src="appConfig.app_logo" class="mini_logo_img" mode="widthFix" />
 					<view class="mini_app_name">{{appConfig.app_name}}</view>
 				</view>
-				<view class="mark_view">申请获取并验证你的手机号</view>
-				<view class="mark_lable">快捷登录</view>
+				<view class="mark_view">{{ $t('申请获取并验证你的手机号') }}</view>
+				<view class="mark_lable">{{ $t('快捷登录') }}</view>
 				<view @tap="clickFastLogin" class="mark_btn">
 					<view class="last_phone">{{openUser.maskPhone}}</view>
-					<view class="last_phone_mark">上次提供</view>
+					<view class="last_phone_mark">{{ $t('上次提供') }}</view>
 				</view>
-				<view @tap="clickNoAllow" class="mark_btn_no">不允许</view>
-				<view @tap="clickOtherPhone" class="other_text">使用其他号码</view>
+				<view @tap="clickNoAllow" class="mark_btn_no">{{ $t('不允许') }}</view>
+				<view @tap="clickOtherPhone" class="other_text">{{ $t('使用其他号码') }}</view>
 			</view>
 		</view>
 	</view>
@@ -120,7 +120,7 @@
 
 			clickGetLoginInfo() {
 				if (this.contract_id === 0) {
-					common.simpleToast('请查阅隐私和协议')
+					common.simpleToast(this.$t('请查阅隐私和协议'))
 					return;
 				}
 				const me = this
@@ -181,7 +181,7 @@
 									open_data: encryptionCode
 								}
 								storage.setUserToken(response.data.data.baseInfo.token)
-								common.simpleToast('登录成功')
+								common.simpleToast(this.$t('登录成功'))
 								uni.reLaunch({
 									url: '/pages/index/index',
 								})

+ 1 - 1
pages/loginRegister/changePassword.vue

@@ -1,6 +1,6 @@
 <template>
 	<view class="">
-		<navBar name="修改密码"></navBar>
+		<navBar :name="$t('修改密码')"></navBar>
 		<view class="changePassword-page">
 			
 		    <ZxInput

+ 1 - 1
pages/loginRegister/forgetPassword.vue

@@ -1,6 +1,6 @@
 <template>
     <view class="forgetPassword-page">
-		<navBar name="忘记密码"  left="0" bgColor="transparent"></navBar>
+		<navBar :name="$t('忘记密码')"  left="0" bgColor="transparent"></navBar>
         <zx-input
             v-model="email"
             :placeholder="$t('请输入要重置的邮箱账号')"

+ 3 - 3
pages/loginRegister/login.vue

@@ -2,7 +2,7 @@
     <view class="zx-page-linear login-page">
 		<navBar type="login" left="0" bgColor="transparent"></navBar>
       <view class="title-wrap">
-        <view class="title">{{ $t('欢迎来到FRANCO MORINI') }}</view>
+        <view class="title">{{ $t('欢迎来到') }}FRANCO MORINI</view>
         <view class="sub-title">{{ $t('邮箱密码登录') }}</view>
       </view>
       <view class="main">
@@ -37,7 +37,7 @@
           </view>
           <view class="split-line"/>
           <view class="register" @tap="routerLink('/pages/loginRegister/register')">
-            {{ $t('没有账号 立即注册') }}
+            {{ $t('没有账号') + ' ' + $t('立即注册') }}
           </view>
         </view>
 <!--        <view class="other-type-login">
@@ -115,7 +115,7 @@
             const { baseInfo } = res.body.data
             storage.setUserInfoData(baseInfo)
 			uni.setStorageSync('storage_user_token', baseInfo.token);
-            common.simpleToast('登录成功')
+            common.simpleToast(this.$t('登录成功'))
             uni.reLaunch({
               url: '/pages/index/index',
             })

+ 2 - 2
pages/loginRegister/register.vue

@@ -1,6 +1,6 @@
 <template>
     <view class="register-page">
-		<navBar name="账号注册" left="0" bgColor="transparent"></navBar>
+		<navBar :name="$t('账号注册')" left="0" bgColor="transparent"></navBar>
 		<view style="height: 20rpx;"></view>
         <ZxInput
             v-model="form.email"
@@ -34,7 +34,7 @@
             type="register"
 			@close='close'
             :email="form.email"
-            :text="`我们已向 <span>${this.form.email}</span> 发送注册邮件,请您登录邮箱点击链接完成注册。`"
+            :text="`{{ $t('我们已向') }} <span>${this.form.email}</span> {{ $t('发送注册邮件,请您登录邮箱点击链接完成注册。') }}`"
             v-model="isSendSucceed"
         />
     </view>

+ 16 - 16
pages/manualInput/manualInput.vue

@@ -1,14 +1,14 @@
 <template>
 	<view class="container-view">
-		<!-- <input class="input" type="text" placeholder="请输入车牌号全称" placeholder-style="color:#BAC1D0;"> -->
+		<!-- <input class="input" type="text" :placeholder="$t('请输入车牌号全称')" placeholder-style="color:#BAC1D0;"> -->
 		<input @input="onInput" @blur="inputBlur" @confirm="handleConfirm" :value="hideValue" class="input" type="text"
-			:focus="hideFocus" placeholder="请输入车牌号" placeholder-style="color:#BAC1D0;">
+			:focus="hideFocus" :placeholder="$t('请输入车牌号')" placeholder-style="color:#BAC1D0;">
 		<view :class="['confirm-btn', !hideValue && 'btn-disable']" @tap="handleConfirmHandle">
-			{{ hideValue ? '确认' : '请先输入车牌号' }}
+			{{ hideValue ? $t('确认') : $t('请先输入车牌号') }}
 		</view>
-		<!-- <view class="input-text">温馨提示:各省市因地制宜,制定相关的牌照格式,请按照实际车辆牌照的格式进行填写~</view>
-		<view class="title">参考格式</view>
-		<view class="content-view">北京<text>123456</text></view> -->
+		<!-- <view class="input-text">{{ $t('温馨提示:各省市因地制宜,制定相关的牌照格式,请按照实际车辆牌照的格式进行填写~') }}</view>
+		<view class="title">{{ $t('参考格式') }}</view>
+		<view class="content-view">{{ $t('北京') }}<text>123456</text></view> -->
 	</view>
 </template>
 
@@ -93,7 +93,7 @@
 			},
 			handleConfirmHandle() {
 				if (!this.hideValue) {
-					common.simpleToast('请先输入车牌号')
+					common.simpleToast(this.$t('请先输入车牌号'))
 					return
 				}
 				this.handleConfirm()
@@ -105,9 +105,9 @@
 					wx.getSetting({
 						success(res) {
 							if (res.authSetting["scope.userLocation"] == false) { // 判断原因是否为微信小程序内部没有授权定位
-								common.simpleToast('无法获取位置信息,请检查您的微信定位权限设置')
+								common.simpleToast(this.$t('无法获取位置信息,请检查您的微信定位权限设置'))
 							} else {
-								common.simpleToast('您的手机未授权微信定位权限,请前往手机设置开启权限')
+								common.simpleToast(this.$t('您的手机未授权微信定位权限,请前往手机设置开启权限'))
 							}
 							me.hideFocus = true
 						}
@@ -115,7 +115,7 @@
 					return
 				}
 				if (this.hideValue == '') {
-					common.simpleToast('请输入车牌号')
+					common.simpleToast(this.$t('请输入车牌号'))
 					this.hideFocus = true
 				} else {
 					this.hideFocus = false
@@ -137,7 +137,7 @@
 						const timestamp = Date.now(); // 获取当前时间戳(毫秒)
 						const isOffline = (Math.floor(timestamp / 1000) - resp.data.data.last_comm_time) > 1800
 						if (resp.data.data.last_comm_time === 0 || isOffline) {
-							common.simpleToast('此车辆已离线,请选择其他车辆')
+							common.simpleToast(this.$t('此车辆已离线,请选择其他车辆'))
 						} else {
 							let carInfo = JSON.stringify(resp.data.data)
 							const car_model = resp.data.data.model_info.car_model
@@ -147,10 +147,10 @@
 							if (resp.data.data.has_owner) { //车辆正在被使用
 								if (resp.data.data.is_mine) { //是本人在使用
 									wx.showModal({
-										title: '提示',
+										title: this.$t('提示'),
 										content: '已有正在使用的车辆,是否跳转至车辆详情页?',
-										cancelText: '取消',
-										confirmText: '确定',
+										cancelText: this.$t('取消'),
+										confirmText: this.$t('确定'),
 										success: function(res) {
 											this.isReturnHome = false
 											uni.navigateTo({
@@ -163,12 +163,12 @@
 										complete: function(res) {},
 									})
 								} else {
-									common.simpleToast('此车辆正在被使用')
+									common.simpleToast(this.$t('此车辆正在被使用'))
 								}
 							} else {
 								if (me.order_sn != '') {
 									if (this.order_model_id != model_id) { // 预租车型与之前预约车型不一致
-										common.simpleToast('与预约车型不符')
+										common.simpleToast(this.$t('与预约车型不符'))
 									} else {
 										this.isReturnHome = false
 										uni.navigateTo({

+ 1 - 1
pages/message/detail.vue

@@ -1,6 +1,6 @@
 <template>
 	<view class="container">
-		<navBar name="信息详情"></navBar>
+		<navBar :name="$t('信息详情')"></navBar>
 		<view class="title">{{info.title}}</view>
 		<view>{{info.overview}}</view>
 		<image v-if="info.cover" :src="info.cover" class="img" mode="aspectFit" />

+ 4 - 4
pages/message/index.vue

@@ -1,6 +1,6 @@
 <template>
 	<view class="message-page">
-		<navBar :name="isSys === '0' ? '设备信息' : '我的消息'"></navBar>
+		<navBar :name="isSys === '0' ? $t('设备信息') : $t('我的消息')"></navBar>
 		<view v-if="isSys==='0' && deviceList.length>0">
 			<view class="device-msg-wrap base-wrap" v-for="(item, index) in deviceList" :key="index"
 				@tap="toDeviceMsgPage(item)">
@@ -22,7 +22,7 @@
 		</view>
 		<view v-if="isSys==='0' && deviceList.length === 0"
 			style="display: flex;align-items: center;justify-content: center;height: 80vh;">
-			您还没有设备消息
+			{{ $t('您还没有设备消息') }}
 		</view>
 
 		<view v-if="isSys==='1' && sysMsgList.length > 0 " style="margin-top: 20rpx;" class="sys-msg-wrap base-wrap">
@@ -39,7 +39,7 @@
 						<view v-if="item.read == 0" class="dot"></view>
 						{{ item.title }}
 					</view>
-					<view v-if="item.type === 1" class="btn">绑定设备</view>
+					<view v-if="item.type === 1" class="btn">{{ $t('绑定设备') }}</view>
 				</view>
 				<view class="time">{{ item.ctime }}</view>
 				<view class="dtl">{{ item.overview }}</view>
@@ -48,7 +48,7 @@
 
 		<view v-if="isSys==='1' && sysMsgList.length === 0 "
 			style="display: flex;align-items: center;justify-content: center;height: 80vh;">
-			您还没有系统消息
+			{{ $t('您还没有系统消息') }}
 		</view>
 	</view>
 </template>

+ 5 - 5
pages/message/location.vue

@@ -175,15 +175,15 @@
 			findCar() {
 				const me = this
 				uni.showModal({
-					title: '提示',
-					content: '您确认开启闪灯鸣笛吗',
+					title: this.$t('提示'),
+					content: this.$t('您确认开启闪灯鸣笛吗'),
 					showCancel: true,
-					cancelText: '取消',
-					confirmText: '确定',
+					cancelText: this.$t('取消'),
+					confirmText: this.$t('确定'),
 					success: function(res) {
 						if (res.confirm) {
 							me.setData({
-								popText: '闪灯鸣笛',
+								popText: this.$t('闪灯鸣笛'),
 								cmdType: 'findCar',
 							})
 							me.tapBlueToothCmd('', true)

+ 13 - 13
pages/mileageStatistics/index.vue

@@ -51,7 +51,7 @@
         class="list-item"
       >
         <view class="row top-row">
-          <view>行驶里程
+          <view>{{ $t('行驶里程') }}
             <u-count-to
               :start-val="0"
               :end-val="54"
@@ -63,9 +63,9 @@
           <view>2024-12-04 16:15</view>
         </view>
         <view class="row bottom-row">
-          <text>功率: 30wh</text>
-          <text>减少碳排放: 40g</text>
-          <text>骑行时长: 00:20:31</text>
+          <text>{{ $t('功率') }}: 30wh</text>
+          <text>{{ $t('减少碳排放') }}: 40g</text>
+          <text>{{ $t('骑行时长') }}: 00:20:31</text>
         </view>
       </view>
     </view>
@@ -95,10 +95,10 @@ export default {
     statisticsEnum() {
       const t = v => this.$t(v)
       return [
-        { label: t('骑行次数'), unit: t('次'), prop: 'num' },
-        { label: t('累计功率'), unit: 'wh', prop: 'power' },
-        { label: t('减少排放量'), unit: 'g', prop: 'reduceEmissions' },
-        { label: t('骑行时长'), unit: '天', prop: 'cyclingDuration' }
+        { label: t(this.$t('骑行次数')), unit: t(this.$t('次')), prop: 'num' },
+        { label: t(this.$t('累计功率')), unit: 'wh', prop: 'power' },
+        { label: t(this.$t('减少排放量')), unit: 'g', prop: 'reduceEmissions' },
+        { label: t(this.$t('骑行时长')), unit: this.$t('天'), prop: 'cyclingDuration' }
       ]
     }
   },
@@ -111,11 +111,11 @@ export default {
   methods: {
     _initQueryTypes() {
       this.queryTypes = [
-        { label: '总', type: '0' },
-        { label: '年', type: '1' },
-        { label: '月', type: '2' },
-        { label: '周', type: '3' },
-        { label: '日', type: '4' }
+        { label: this.$t('总'), type: '0' },
+        { label: this.$t('年'), type: '1' },
+        { label: this.$t('月'), type: '2' },
+        { label: this.$t('周'), type: '3' },
+        { label: this.$t('日'), type: '4' }
       ]
     },
     changeType(type) {

+ 9 - 9
pages/modifyPhone/modifyPhone.vue

@@ -3,21 +3,21 @@
 		<form @submit="bindModifyPhone">
 			<view class="form-container">
 				<view class="form-item">
-					<input type="number" name="phone" @input="inputPhone" placeholder="请输入绑定的新手机号" />
+					<input type="number" name="phone" @input="inputPhone" :placeholder="$t('请输入绑定的新手机号')" />
 				</view>
 				<view class="form-item flex-row flex-between">
-					<input type="number" name="verify_code" placeholder="请输入验证码" @input="inputVerifyCode" />
+					<input type="number" name="verify_code" :placeholder="$t('请输入验证码')" @input="inputVerifyCode" />
 					<view class="send-code">
 						<form @submit="bindGetVerifyCode">
 							<button class="def-btn-verify" form-type="submit">
-								<text v-if="codeGetting"> {{curTime}}秒后再次获取</text>
-								<text v-else>获取验证码</text>
+								<text v-if="codeGetting"> {{curTime}}{{ $t('秒后再次获取') }}</text>
+								<text v-else>{{ $t('获取验证码') }}</text>
 							</button>
 						</form>
 					</view>
 				</view>
 				<view class="form-btn">
-					<button class="login-btn" form-type="submit">绑定新手机号</button>
+					<button class="login-btn" form-type="submit">{{ $t('绑定新手机号') }}</button>
 				</view>
 			</view>
 		</form>
@@ -62,11 +62,11 @@
 				if (this.codeGetting)
 					return
 				if (!this.phone) {
-					common.alert('提示', '请输入手机号码');
+					common.alert(this.$t('提示'), this.$t('请输入手机号码'));
 					return;
 				}
 				if (!common.isPhone(this.phone)) {
-					common.alert('提示', '请检测您的手机号码是否正确');
+					common.alert(this.$t('提示'), this.$t('请检测您的手机号码是否正确'));
 					return;
 				}
 
@@ -96,7 +96,7 @@
 					if (response.data.code === 200) {
 
 					} else {
-						common.alert('提示', response.data.msg);
+						common.alert(this.$t('提示'), response.data.msg);
 					}
 				})
 			},
@@ -119,7 +119,7 @@
 				}
 				http.postApi(config.API_MODIFY_PHONE, pData, function(resp) {
 					if (resp.data.code === 200) {
-						common.simpleToast('修改成功')
+						common.simpleToast(this.$t('修改成功'))
 						setTimeout(function() {
 							uni.reLaunch({
 								url: '/pages/index/index',

+ 2 - 2
pages/moreInfo/moreInfo.vue

@@ -12,7 +12,7 @@
 						style="width: 80rpx;height: 80rpx;" mode="aspectFit"></image>
 				</view>
 				<view class="text">
-					仪表盘
+					{{ $t('仪表盘') }}
 				</view>
 				<image src="https://qiniu.bms16.com/FqnbZ2iKHmzCGJA8XD30sf5g_CAm" style="width: 28rpx;height: 28rpx;"
 					mode="aspectFit"></image>
@@ -23,7 +23,7 @@
 						style="width: 80rpx;height: 80rpx;" mode="aspectFit"></image>
 				</view>
 				<view class="text">
-					设备信息
+					{{ $t('设备信息') }}
 				</view>
 				<image src="https://qiniu.bms16.com/FqnbZ2iKHmzCGJA8XD30sf5g_CAm" style="width: 28rpx;height: 28rpx;"
 					mode="aspectFit"></image>

+ 18 - 18
pages/my/my.vue

@@ -15,7 +15,7 @@
 		</view>
 		<view class="user-info-wrap" @tap="loginHandle">
 			<image :src="userInfo.headimg || defaultAvatarUrl" class="head-img" />
-			<view class="user-name">{{ userInfo.nickname || '请点击登录' }}</view>
+			<view class="user-name">{{ userInfo.nickname || $t('请点击登录') }}</view>
 			<view v-if="userInfo.user_name" class="e-mail">
 				{{ userInfo.user_name }}
 			</view>
@@ -75,10 +75,10 @@ var request = require('@/common/request.js');
 				defaultAvatarUrl: defaultHeadImg,
 				comboDialoginfo: {
 					showConfirm: false,
-					title: '温馨提示',
+					title: this.$t('温馨提示'),
 					opType: 'combo',
-					text: '您还未购买换电套餐,是否前往进行换电套餐?',
-					confirmBtnText: '前往购买',
+					text: this.$t('您还未购买换电套餐,是否前往进行换电套餐?'),
+					confirmBtnText: this.$t('前往购买'),
 					showCancelButton: false
 				},
 				userInfo: {}
@@ -87,40 +87,40 @@ var request = require('@/common/request.js');
 		computed: {
 			// commonTabs() {
 			//   return [
-			//     { name: `${this.$t('我的车辆')}`, url: '/pages/dashboard/dashboard', icon: 'Fp6G-Kzb-YUGkP2WR-kjTlIbbTj1' },
-			//     { name: `${this.$t('用车人')}`, url: '/pages/userManagement/userManagement', icon: 'FnxGW52BCkTkK9HxsTdVrghU7B4D' },
-			//     { name: `${this.$t('换电套餐')}`, jumpCheck: 'combo', url: '', icon: 'FsOsd1SxYDHDm00aiwrTib_k0Mbr' }
+			//     { name: `${this.$t(this.$t('我的车辆'))}`, url: '/pages/dashboard/dashboard', icon: 'Fp6G-Kzb-YUGkP2WR-kjTlIbbTj1' },
+			//     { name: `${this.$t(this.$t('用车人'))}`, url: '/pages/userManagement/userManagement', icon: 'FnxGW52BCkTkK9HxsTdVrghU7B4D' },
+			//     { name: `${this.$t(this.$t('换电套餐'))}`, jumpCheck: 'combo', url: '', icon: 'FsOsd1SxYDHDm00aiwrTib_k0Mbr' }
 			//   ]
 			// },
 			baseTabs() {
 				const lang = t => this.$t(t)
 				return [{
-						name: `${lang('我的订单')}`,
+						name: `${lang(this.$t('我的订单'))}`,
 						url: '/pages/order/order',
 						icon: 'FkLJGLo1faYtJWhW4Q0gt5dphI7g',
 						isLogin:1
 					},
 					{
-						name: `${lang('换电记录')}`,
+						name: `${lang(this.$t('换电记录'))}`,
 						url: '/pages/batteryRecord/batteryRecord',
 						icon: 'FnSjwcN7Mcpa-WA7Cqx2cGTvX2V1',
 						isLogin:1
 					},
 					{
-						name: `${lang('意见反馈')}`,
+						name: `${lang(this.$t('意见反馈'))}`,
 						url: '/pages/feedback/index',
 						icon: 'Fh1tuCqkBQ1A20WTsiizSR9w4tQ4'
 					},
-					//   { name: `${lang('关于我们')}`, url: '/pages/bluetoothUnlock/unlockSet', icon: 'Fmin1_DG6ZkENCdsI1qJZJpDNkhQ' },
+					//   { name: `${lang(this.$t('关于我们'))}`, url: '/pages/bluetoothUnlock/unlockSet', icon: 'Fmin1_DG6ZkENCdsI1qJZJpDNkhQ' },
 					{
-						name: `${lang('客服中心')}`,
+						name: `${lang(this.$t('客服中心'))}`,
 						url: '',
 						statues:'service',
 						icon: 'FhA9TUbTMF0e7ma6NZXqPrkscN6l',
 						isLogin:1
 					},
 					{
-						name: `${lang('设置')}`,
+						name: `${lang(this.$t('设置'))}`,
 						url: '/pages/my/set',
 						icon: 'Fu3f2iRi5BspRfbVLPcw8ryWc4lu'
 					}
@@ -179,15 +179,15 @@ var request = require('@/common/request.js');
 			checkHandle_combo() {
 				
 				if(!this.car_info.sold_time){
-					this.$msg('您还未购买车辆,购买车辆才可享受换电套餐')
+					this.$msg(this.$t('您还未购买车辆,购买车辆才可享受换电套餐'))
 					return
 				}
 				if(!this.car_info.battery_tag_info.tag_code){
-					this.$msg('当前没有可更换的电池,购买车辆绑定电池后才可享受换电套餐')
+					this.$msg(this.$t('当前没有可更换的电池,购买车辆绑定电池后才可享受换电套餐'))
 					return
 				}
 				if(!this.car_info.car_sn){
-					this.$msg('您还未绑定车辆!')
+					this.$msg(this.$t('您还未绑定车辆!'))
 					return
 				}
 				if(this.car_info.exchange_package_info){
@@ -219,12 +219,12 @@ var request = require('@/common/request.js');
 				if(statues){
 					let _this = this
 					if(!_this.shopInfo.link_phone){
-						this.$msg("未获取到手机号码")
+						this.$msg(this.$t('未获取到手机号码'))
 						return
 					}
 					uni.showModal({
 						content: `您是否要拨打电话${_this.shopInfo.link_phone}?`,
-						confirmText: '确定',
+						confirmText: this.$t('确定'),
 						success: (res) => {
 							if (res.confirm) {
 								uni.makePhoneCall({

+ 12 - 12
pages/my/set.vue

@@ -1,6 +1,6 @@
 <template>
 	<view class="set-page">
-		<navBar name="设置" left="0"></navBar>
+		<navBar :name="$t('设置')" left="0"></navBar>
 		<image @click="editAvatarFn" :src="userInfo.headimg || defaultHeadImg" class="head-img" />
 		<view class="list-wrap">
 			<view v-for="(item, index) in list" :key="index" class="item" @tap="routerLink(item.url)">
@@ -17,7 +17,7 @@
 				</view>
 			</view>
 		</view>
-		<view class="zx-form-btn fix-bottom-btn logout-btn" @tap="handleQuit">退出登录</view>
+		<view class="zx-form-btn fix-bottom-btn logout-btn" @tap="handleQuit">{{ $t('退出登录') }}</view>
 	</view>
 </template>
 
@@ -40,30 +40,30 @@
 				defaultHeadImg,
 				userInfo: {},
 				list: [{
-						title: '昵称',
+						title: this.$t('昵称'),
 						url: '',
 						textProp: 'nickname'
 					},
 					{
-						title: '注册时间',
+						title: this.$t('注册时间'),
 						textProp: 'registrationTime',
 						hideArrow: true
 					},
 					{
-						title: '修改密码',
+						title: this.$t('修改密码'),
 						url: '/pages/loginRegister/changePassword'
 					},
 					{
-						title: '关于我们',
+						title: this.$t('关于我们'),
 						url: '/pages/aboutMy/aboutMy',
 						textProp: 'version'
 					},
 					{
-						title: '隐私协议',
+						title: this.$t('隐私协议'),
 						url: '/pages/contract/contract?contract_id=270'
 					},
 					{
-						title: '用户条款',
+						title: this.$t('用户条款'),
 						url: '/pages/contract/contract?contract_id=102'
 					}
 				]
@@ -140,11 +140,11 @@
 			},
 			handleQuit() {
 				uni.showModal({
-					title: '提示',
-					content: '您确定要退出当前账号吗?',
+					title: this.$t('提示'),
+					content: this.$t('您确定要退出当前账号吗?'),
 					showCancel: true,
-					cancelText: '取消',
-					confirmText: '确定',
+					cancelText: this.$t('取消'),
+					confirmText: this.$t('确定'),
 					success: function(res) {
 						if (res.confirm) {
 							storage.clearStorage()

+ 17 - 17
pages/openCabinet/openCabinet.vue

@@ -5,19 +5,19 @@
 		</view>
 		<view class="explain-view">
 			<view class="explain-num-view flex-row">
-				<!-- <text><text class="explain-num">{{empty_door_id}} </text>号仓门已打开</text> -->
-				<text>仓门已打开</text>
-				<!-- <text v-if="list.status == 2">换电中</text>
-				<text v-if="list.status == 3">换电成功</text>
-				<text v-if="list.status == 4">换电失败</text> -->
+				<!-- <text><text class="explain-num">{{empty_door_id}} </text>{{ $t('号仓门已打开') }}</text> -->
+				<text>{{ $t('仓门已打开') }}</text>
+				<!-- <text v-if="list.status == 2">{{ $t('换电中') }}</text>
+				<text v-if="list.status == 3">{{ $t('换电成功') }}</text>
+				<text v-if="list.status == 4">{{ $t('换电失败') }}</text> -->
 			</view>
-			<view class="explain-text">请存入更换电池,取走满电电池,并关好仓门</view>
-			<!-- <view class="explain-text">请 归还 / 取出 电池并关上仓门</view> -->
-			<!-- <view class="explain-text">请取出电池并关上仓门</view> -->
-			<!-- <view class="explain-text-grap">归还完成后电柜会自动打开可租仓门</view> -->
-			<!-- <view class="explain-text-grap">自动为您匹配最高电量电池</view> -->
+			<view class="explain-text">{{ $t('请存入更换电池') }},{{ $t('取走满电电池') }},{{ $t('并关好仓门') }}</view>
+			<!-- <view class="explain-text">{{ $t('') }} {{ $t('归还') }} / {{ $t('取出') }} {{ $t('电池并关上仓门') }}</view> -->
+			<!-- <view class="explain-text">{{ $t('请取出电池并关上仓门') }}</view> -->
+			<!-- <view class="explain-text-grap">{{ $t('归还完成后电柜会自动打开可租仓门') }}</view> -->
+			<!-- <view class="explain-text-grap">{{ $t('自动为您匹配最高电量电池') }}</view> -->
 		</view>
-		<!-- 完成弹窗 -->
+		<!-- {{ $t('完成弹窗') }} -->
 		<view v-if="isOverModal" class="modal-group">
 			<view class="payment-info-main">
 				<view class="payment-info-top flex-row">
@@ -26,17 +26,17 @@
 					<img v-if="list.status==4" class="check-icon" src="https://qiniu.bms16.com/FmGcOOZZm09nx9lH3lez7D3DYHKn" alt="">
 				</view>
 				<view v-if="list.status==3" class="open-result-view">
-					<view class="open-result flex-row">换电成功</view>
-					<view class="open-result-tip flex-row">祝您骑行愉快</view>
+					<view class="open-result flex-row">{{ $t('换电成功') }}</view>
+					<view class="open-result-tip flex-row">{{ $t('祝您骑行愉快') }}</view>
 				</view>
 				<view v-if="list.status==4" class="open-result-view">
-					<view class="open-result flex-row">换电失败</view>
+					<view class="open-result flex-row">{{ $t('换电失败') }}</view>
 					<view class="open-result-tip flex-row">{{list.fail_reason}}</view>
 				</view>
 				<view class="over-btn-view">
-					<view v-if="list.status==3" @tap="tapToIndex" class="over-btn flex-row">回到首页</view>
-					<view v-if="list.status==4" @tap="connectStore" class="over-btn flex-row">联系门店</view>
-					<view v-if="list.status==4" @click="srcFn(`/pages/index/index`)" class="over-btn flex-row">确认</view>
+					<view v-if="list.status==3" @tap="tapToIndex" class="over-btn flex-row">{{ $t('回到首页') }}</view>
+					<view v-if="list.status==4" @tap="connectStore" class="over-btn flex-row">{{ $t('联系门店') }}</view>
+					<view v-if="list.status==4" @click="srcFn(`/pages/index/index`)" class="over-btn flex-row">{{ $t('确认') }}</view>
 				</view>
 			</view>
 		</view>

+ 58 - 58
pages/order/order.vue

@@ -1,6 +1,6 @@
 <template>
 	<view class="container-view">
-		<navBar name="我的订单" ></navBar>
+		<navBar :name="$t('我的订单')" ></navBar>
 		<!-- <view v-if="selectOrderType == 0" class="order-type-view flex-row flex-between">
 			<view v-if="car_info.car_sn && selectOrderType == 0" @click="srcFn(`/pages/carList/carList`)" class="car-model-list flex-row">
 				<view class="car-model-text">{{car_info.car_name}}</view><img class="right-corner-icon"
@@ -36,48 +36,48 @@
 
 				<block v-if="selectOrderType == 0">
 					<view v-if="item.package_type == 1">
-						{{item.total_day}}天
+						{{item.total_day}}{{ $t('') }}
 					</view>
 					<view v-if="item.package_type == 2">
-						{{item.num}}次
+						{{item.num}}{{ $t('') }}
 					</view>
 					<view v-if="item.package_type == 3">
-						{{item.total_day}}天{{item.num}}次
+						{{item.total_day}}{{ $t('') }}{{item.num}}{{ $t('') }}
 					</view>
 				</block>
 
 				<view v-if="item.finally == 1 && selectOrderType == 1">
-					<view class="card card-k" v-if="item.order_status == 0">待支付</view>
-					<view class="card card-k" v-if="item.order_status == 1">待取车</view>
-					<view class="card card-k" v-else-if="item.order_status == 2">待激活</view>
-					<view class="card card-b" v-else-if="item.order_status == 3">使用中</view>
-					<view class="card card-r" v-else-if="item.order_status == 4">已逾期</view>
-					<view class="card card-k" v-else-if="item.order_status == 5">还车申请中</view>
-					<view class="card card-k" v-else-if="item.order_status == 6">还车中</view>
-					<view class="card card-k" v-else-if="item.order_status == 7">车辆已归还</view>
-					<view class="card card-k" v-else-if="item.order_status == 8 ">订单已支付,已取消</view>
-					<view class="card card-k" v-else-if=" item.order_status == 9">订单未支付,已取消</view>
-					<view class="card card-k" v-else-if=" item.order_status == 10">已完结</view>
+					<view class="card card-k" v-if="item.order_status == 0">{{ $t('待支付') }}</view>
+					<view class="card card-k" v-if="item.order_status == 1">{{ $t('待取车') }}</view>
+					<view class="card card-k" v-else-if="item.order_status == 2">{{ $t('待激活') }}</view>
+					<view class="card card-b" v-else-if="item.order_status == 3">{{ $t('使用中') }}</view>
+					<view class="card card-r" v-else-if="item.order_status == 4">{{ $t('已逾期') }}</view>
+					<view class="card card-k" v-else-if="item.order_status == 5">{{ $t('还车申请中') }}</view>
+					<view class="card card-k" v-else-if="item.order_status == 6">{{ $t('还车中') }}</view>
+					<view class="card card-k" v-else-if="item.order_status == 7">{{ $t('车辆已归还') }}</view>
+					<view class="card card-k" v-else-if="item.order_status == 8 ">{{ $t('订单已支付') }},{{ $t('已取消') }}</view>
+					<view class="card card-k" v-else-if=" item.order_status == 9">{{ $t('订单未支付') }},{{ $t('已取消') }}</view>
+					<view class="card card-k" v-else-if=" item.order_status == 10">{{ $t('已完结') }}</view>
 				</view>
 
 				<view v-if="item.finally != 1 && selectOrderType == 1">
-					<view class="card card-k" v-if="item.pay_status == 0">待支付</view>
-					<view class="card card-k" v-else-if="item.pay_status == 1">支付中</view>
-					<view class="card card-k" v-else-if="item.pay_status == 2">支付成功</view>
-					<view class="card card-r" v-else-if="item.pay_status == 3">支付失败</view>
-					<view class="card card-k" v-else-if="item.pay_status == 4">支付取消</view>
-					<view class="card card-b" v-else-if="item.pay_status == 5">线下待审核</view>
-					<view class="card card-k" v-else-if="item.pay_status == 6">线下审核拒绝</view>
+					<view class="card card-k" v-if="item.pay_status == 0">{{ $t('待支付') }}</view>
+					<view class="card card-k" v-else-if="item.pay_status == 1">{{ $t('支付中') }}</view>
+					<view class="card card-k" v-else-if="item.pay_status == 2">{{ $t('支付成功') }}</view>
+					<view class="card card-r" v-else-if="item.pay_status == 3">{{ $t('支付失败') }}</view>
+					<view class="card card-k" v-else-if="item.pay_status == 4">{{ $t('支付取消') }}</view>
+					<view class="card card-b" v-else-if="item.pay_status == 5">{{ $t('线下待审核') }}</view>
+					<view class="card card-k" v-else-if="item.pay_status == 6">{{ $t('线下审核拒绝') }}</view>
 				</view>
 
 				<view v-if="selectOrderType == 0">
-					<view class="card card-k" v-if="item.pay_status == 0">待支付</view>
-					<view class="card card-k" v-else-if="item.pay_status == 1">支付中</view>
-					<view class="card card-k" v-else-if="item.pay_status == 2">支付成功</view>
-					<view class="card card-r" v-else-if="item.pay_status == 3">支付失败</view>
-					<view class="card card-k" v-else-if="item.pay_status == 4">支付取消</view>
-					<view class="card card-b" v-else-if="item.pay_status == 5">线下待审核</view>
-					<view class="card card-k" v-else-if="item.pay_status == 6">线下审核拒绝</view>
+					<view class="card card-k" v-if="item.pay_status == 0">{{ $t('待支付') }}</view>
+					<view class="card card-k" v-else-if="item.pay_status == 1">{{ $t('支付中') }}</view>
+					<view class="card card-k" v-else-if="item.pay_status == 2">{{ $t('支付成功') }}</view>
+					<view class="card card-r" v-else-if="item.pay_status == 3">{{ $t('支付失败') }}</view>
+					<view class="card card-k" v-else-if="item.pay_status == 4">{{ $t('支付取消') }}</view>
+					<view class="card card-b" v-else-if="item.pay_status == 5">{{ $t('线下待审核') }}</view>
+					<view class="card card-k" v-else-if="item.pay_status == 6">{{ $t('线下审核拒绝') }}</view>
 				</view>
 
 			</view>
@@ -86,76 +86,76 @@
 				<view class="bottom-item">
 					<block v-if="selectOrderType == 1">
 						<view class="item-label-view flex-row">
-							<view class="item-label">订单编号</view>
+							<view class="item-label">{{ $t('订单编号') }}</view>
 							<view class="item-value">{{ item.sub_sn }}</view>
 						</view>
 						<view class="item-label-view flex-row">
-							<view class="item-label">下单时间</view>
+							<view class="item-label">{{ $t('下单时间') }}</view>
 							<view class="item-value">{{ tools.formatTime(item.ctime) }}</view>
 						</view>
 						<view v-if="item.hire_end_time && item.order_type != 3" class="item-label-view flex-row">
-							<view class="item-label">有效期至</view>
+							<view class="item-label">{{ $t('有效期至') }}</view>
 							<view class="item-value">{{ tools.formatTime(item.hire_end_time) }}</view>
 						</view>
 
 						<view v-if="item.hire_duration_time && item.order_type != 3" class="item-label-view flex-row">
-							<view class="item-label">有效时长</view>
+							<view class="item-label">{{ $t('有效时长') }}</view>
 							<view class="item-value">
 								{{ item.hire_duration_time.day > 0 ? item.hire_duration_time.day : '' }}<text
-									v-if="item.hire_duration_time.day > 0">日</text>{{ item.hire_duration_time.hour > 0 ?
-									item.hire_duration_time.hour : '' }}<text v-if="item.hire_duration_time.hour > 0">小时</text>{{ item.hire_duration_time.minute > 0 ?
-									item.hire_duration_time.minute : '' }}<text v-if="item.hire_duration_time.minute > 0">分</text>
+									v-if="item.hire_duration_time.day > 0">{{ $t('') }}</text>{{ item.hire_duration_time.hour > 0 ?
+									item.hire_duration_time.hour : '' }}<text v-if="item.hire_duration_time.hour > 0">{{ $t('小时') }}</text>{{ item.hire_duration_time.minute > 0 ?
+									item.hire_duration_time.minute : '' }}<text v-if="item.hire_duration_time.minute > 0">{{ $t('') }}</text>
 							</view>
 						</view>
 					</block>
 					<block v-if="selectOrderType == 0">
 						<view class="item-label-view flex-row">
-							<view class="item-label">下单时间</view>
+							<view class="item-label">{{ $t('下单时间') }}</view>
 							<view class="item-value">{{ tools.formatTime(item.ctime) }}</view>
 						</view>
 						<view v-if="item.expire_time" class="item-label-view flex-row">
-							<view class="item-label">有效期至</view>
+							<view class="item-label">{{ $t('有效期至') }}</view>
 							<view class="item-value">{{ tools.formatTime(item.expire_time) }}</view>
 						</view>
 						<view v-if="item.package_type != 2 && item.expire_time" class="item-label-view flex-row">
-							<view class="item-label">有效时长</view>
+							<view class="item-label">{{ $t('有效时长') }}</view>
 							<view class="item-value">
 								{{calculateRemainingDays(item.expire_time)}}<text
-									style="color: #9FA7B7;">/{{item.total_day}}天</text>
+									style="color: #9FA7B7;">/{{item.total_day}}{{ $t('') }}</text>
 							</view>
 						</view>
 						<view v-if="item.package_type == 1" class="item-label-view flex-row">
-							<view class="item-label">免费换电数</view>
-							<!-- <view class="item-value">{{item.last_num}}次</view> -->
-							<view class="item-value">不限次数</view>
+							<view class="item-label">{{ $t('免费换电数') }}</view>
+							<!-- <view class="item-value">{{item.last_num}}{{ $t('') }}</view> -->
+							<view class="item-value">{{ $t('不限次数') }}</view>
 						</view>
 						<view v-if="item.package_type == 2" class="item-label-view flex-row">
-							<view class="item-label">免费换电数</view>
-							<view class="item-value">{{item.last_num}}/{{item.num}}次</view>
+							<view class="item-label">{{ $t('免费换电数') }}</view>
+							<view class="item-value">{{item.last_num}}/{{item.num}}{{ $t('') }}</view>
 						</view>
 						<view v-if="item.package_type == 3" class="item-label-view flex-row">
-							<view class="item-label">免费换电数</view>
-							<view class="item-value">{{item.total_day}}天/{{item.last_num}}次</view>
+							<view class="item-label">{{ $t('免费换电数') }}</view>
+							<view class="item-value">{{item.total_day}}{{ $t('') }}/{{item.last_num}}{{ $t('') }}</view>
 						</view>
 
 					</block>
 
 					<view v-if="selectOrderType==1" class="item-label-view flex-row">
-						<view class="item-label">订单类型</view>
-						<view class="item-value">{{ item.order_type==3?'购车':'租车' }}</view>
+						<view class="item-label">{{ $t('订单类型') }}</view>
+						<view class="item-value">{{ item.order_type==3?$t('购车'):$t('租车') }}</view>
 					</view>
 
 					<view v-if="selectOrderType==0" class="flex-row button-config-view">
-						<view v-if="item.order_refund_status == 1" class="return-money">申请中</view>
-						<view v-if="item.order_refund_status == 2" class="return-money">审核失败</view>
-						<view v-if="item.order_refund_status == 3" class="return-money">退款失败</view>
-						<view v-if="item.order_refund_status == 4" class="return-money">已退款</view>
-						<view class="item-value">套餐金额$ <text
+						<view v-if="item.order_refund_status == 1" class="return-money">{{ $t('申请中') }}</view>
+						<view v-if="item.order_refund_status == 2" class="return-money">{{ $t('审核失败') }}</view>
+						<view v-if="item.order_refund_status == 3" class="return-money">{{ $t('退款失败') }}</view>
+						<view v-if="item.order_refund_status == 4" class="return-money">{{ $t('已退款') }}</view>
+						<view class="item-value">{{ $t('套餐金额') }}$ <text
 								class="money-style">{{(item.package_money / 100).toFixed(2)}}</text></view>
 					</view>
 					<view v-if="selectOrderType==1" class="flex-row button-config-view">
-						<view class="order-money">订单金额 $ {{(item.money / 100).toFixed(2)}}</view>
-						<view v-if="item.order_status == 2" class="activation-btn">激活车辆</view>
+						<view class="order-money">{{ $t('订单金额') }} $ {{(item.money / 100).toFixed(2)}}</view>
+						<view v-if="item.order_status == 2" class="activation-btn">{{ $t('激活车辆') }}</view>
 					</view>
 				</view>
 			</view>
@@ -184,11 +184,11 @@
 				selectOrderType: 1,
 				orderTypes: [{
 						value: 0,
-						text: '换电套餐'
+						text: this.$t('换电套餐')
 					},
 					{
 						value: 1,
-						text: '租车购车'
+						text: this.$t('租车购车')
 					}
 				],
 				start_id:0,

+ 119 - 120
pages/orderStatus/orderStatus.vue

@@ -6,28 +6,28 @@
 			<navBar bgColor="transparent" left="0"></navBar>
 			<view>
 				<view v-if="orderInfo.pay_status!=2">
-					<view class="get-time-view flex-row" v-if="orderInfo.pay_status == 0">待支付</view>
-					<view class="get-time-view flex-row" v-else-if="orderInfo.pay_status == 1">支付中</view>
-					<view class="get-time-view flex-row" v-else-if="orderInfo.pay_status == 3">支付失败</view>
-					<view class="get-time-view flex-row" v-else-if="orderInfo.pay_status == 4">支付取消</view>
-					<view class="get-time-view flex-row" v-else-if="orderInfo.pay_status == 5">线下待审核</view>
-					<view class="get-time-view flex-row" v-else-if="orderInfo.pay_status == 6">线下审核拒绝</view>
+					<view class="get-time-view flex-row" v-if="orderInfo.pay_status == 0">{{ $t('待支付') }}</view>
+					<view class="get-time-view flex-row" v-else-if="orderInfo.pay_status == 1">{{ $t('支付中') }}</view>
+					<view class="get-time-view flex-row" v-else-if="orderInfo.pay_status == 3">{{ $t('支付失败') }}</view>
+					<view class="get-time-view flex-row" v-else-if="orderInfo.pay_status == 4">{{ $t('支付取消') }}</view>
+					<view class="get-time-view flex-row" v-else-if="orderInfo.pay_status == 5">{{ $t('线下待审核') }}</view>
+					<view class="get-time-view flex-row" v-else-if="orderInfo.pay_status == 6">{{ $t('线下审核拒绝') }}</view>
 				</view>
 				<block v-if="orderInfo.pay_status == 2">
-					<view :class="['get-time-view', 'flex-row', 'blue-text']" v-if="orderInfo.order_status == 3">使用中...
+					<view :class="['get-time-view', 'flex-row', 'blue-text']" v-if="orderInfo.order_status == 3">{{ $t('使用中') }}...
 					</view>
-					<view :class="['get-time-view', 'flex-row', 'red-text']" v-if="orderInfo.order_status == 4">已逾期
+					<view :class="['get-time-view', 'flex-row', 'red-text']" v-if="orderInfo.order_status == 4">{{ $t('已逾期') }}
 					</view>
-					<view class="get-time-view flex-row" v-if="orderInfo.order_status == 2">请上传车辆图片激活车辆</view>
-					<view class="get-time-view flex-row" v-if="orderInfo.order_status == 5">待门店确认</view>
-					<view class="get-time-view flex-row" v-if="orderInfo.order_status == 6">还车中,等待门店取车</view>
-					<view class="get-time-view flex-row" v-if="orderInfo.order_status == 7">已完成</view>
+					<view class="get-time-view flex-row" v-if="orderInfo.order_status == 2">{{ $t('请上传车辆图片激活车辆') }}</view>
+					<view class="get-time-view flex-row" v-if="orderInfo.order_status == 5">{{ $t('待门店确认') }}</view>
+					<view class="get-time-view flex-row" v-if="orderInfo.order_status == 6">{{ $t('还车中') }},{{ $t('等待门店取车') }}</view>
+					<view class="get-time-view flex-row" v-if="orderInfo.order_status == 7">{{ $t('已完成') }}</view>
 					<view class="get-time-view flex-row"
-						v-if="orderInfo.order_status == 8||orderInfo.order_status == 9">已取消</view>
-					<view class="get-time-view flex-row" v-if="orderInfo.order_status == 1 "><text>请于</text><text
-							class="get-car-time">{{tools.formatTimeSecond( orderInfo.pick_up_time)}}</text><text>到门店取车</text>
+						v-if="orderInfo.order_status == 8||orderInfo.order_status == 9">{{ $t('已取消') }}</view>
+					<view class="get-time-view flex-row" v-if="orderInfo.order_status == 1 "><text>{{ $t('请于') }}</text><text
+							class="get-car-time">{{tools.formatTimeSecond( orderInfo.pick_up_time)}}</text><text>{{ $t('到门店取车') }}</text>
 					</view>
-					<view v-if="orderInfo.order_status == 10">已完结</view>
+					<view v-if="orderInfo.order_status == 10">{{ $t('已完结') }}</view>
 				</block>
 
 			</view>
@@ -40,29 +40,29 @@
 							<block v-else>{{Number(orderInfo.hire_cycle) * (orderInfo.hire_duration)}}</block>
 						</view>
 						
-						<view>{{((orderInfo.order_status == 2) || orderInfo.order_status == 3)?'租期剩余':(orderInfo.order_status == 4 ? '逾期时长':'租借周期')}}·<text style="opacity: 0.4;">{{leaseUnits(orderInfo.hire_duration_unit)}}</text></view>
+						<view>{{((orderInfo.order_status == 2) || orderInfo.order_status == 3)?$t('租期剩余'):(orderInfo.order_status == 4 ? $t('逾期时长'):$t('租借周期'))}}·<text style="opacity: 0.4;">{{leaseUnits(orderInfo.hire_duration_unit)}}</text></view>
 						
 						<!-- <view v-if="(orderInfo.order_status == 2&&orderInfo.hire_type==2) || orderInfo.order_status == 3">
-							租期剩余·天</view>
-						<view v-else-if="orderInfo.order_status == 4 " class="red-status">逾期时长·天</view>
-						<view v-else>租借周期·天</view> -->
+							{{ $t('租期剩余') }}·{{ $t('') }}</view>
+						<view v-else-if="orderInfo.order_status == 4 " class="red-status">{{ $t('逾期时长') }}·{{ $t('') }}</view>
+						<view v-else>{{ $t('租借周期') }}·{{ $t('') }}</view> -->
 					</view>
 					<view v-if="orderInfo.order_status != 4" class="money-item">
 						<view>
 							{{(orderInfo.hire_money + orderInfo.deposit / 100).toFixed(2)}}
 						</view>
-						<view>订单金额<text style="opacity: 0.4;">·$</text></view>
+						<view>{{ $t('订单金额') }}<text style="opacity: 0.4;">·$</text></view>
 					</view>
 
 					<view v-if="orderInfo.order_status == 4" class="money-item">
 						<view style="color:#F95151" class="red-status">
 							{{(orderInfo.money / 100).toFixed(2)}}
 						</view>
-						<view style="color:#F95151">逾期金额·$</view>
+						<view style="color:#F95151">{{ $t('逾期金额') }}·$</view>
 					</view>
 
 					<view @tap="bindExpanded">
-						<text>{{isExpanded?'收起':'展开'}}</text>
+						<text>{{isExpanded?$t('收起'): $t('展开')}}</text>
 						<img
 							:src="isExpanded?'https://qiniu.bms16.com/FvRah8ro91B_TUVEmInBq6n69W2f':'https://qiniu.bms16.com/FtbxPP0aXYG8hyJTEJfNTXa_Puuc'" />
 					</view>
@@ -71,16 +71,16 @@
 				<view v-if="orderInfo.order_type == 3" class="flex-row flex-between">
 					<view class="money-item">
 						<view></view>
-						<view>租借周期:购买</view>
+						<view>{{ $t('租借周期:购买') }}</view>
 					</view>
 					<view class="money-item">
 						<view :class="orderInfo.order_status == 4?'red-status':''">
-							{{orderInfo.order_status == 4?tools.toFix(over_fee/100):tools.toFix(orderInfo.money / 100)}}<text>元</text>
+							{{orderInfo.order_status == 4?tools.toFix(over_fee/100):tools.toFix(orderInfo.money / 100)}}<text>{{ $t('') }}</text>
 						</view>
-						<view>订单金额</view>
+						<view>{{ $t('订单金额') }}</view>
 					</view>
 					<view @tap="bindExpanded">
-						<text>{{isExpanded?'收起':'展开'}}</text>
+						<text>{{isExpanded?$t('收起'):$t('展开')}}</text>
 						<img
 							:src="isExpanded?'https://qiniu.bms16.com/FvRah8ro91B_TUVEmInBq6n69W2f':'https://qiniu.bms16.com/FtbxPP0aXYG8hyJTEJfNTXa_Puuc'" />
 					</view>
@@ -89,32 +89,32 @@
 				<view v-if="isExpanded" class="dashed-border"></view>
 				
 				<view v-if="isExpanded">
-					<view class="big-text">订单信息</view>
+					<view class="big-text">{{ $t('订单信息') }}</view>
 					<view class="sn-content flex-row flex-between">
-						<view class="sn-title">订单编号</view>
+						<view class="sn-title">{{ $t('订单编号') }}</view>
 						<view class="sn-text">{{orderInfo.sub_sn}}</view>
 					</view>
 					<view class="sn-content flex-row flex-between">
-						<view class="sn-title">下单时间</view>
+						<view class="sn-title">{{ $t('下单时间') }}</view>
 						<view class="sn-text">{{tools.formatTime(orderInfo.ctime)}}</view>
 					</view>
 					<view v-if="orderInfo.pay_time" class="sn-content flex-row flex-between">
-						<view class="sn-title">支付时间</view>
+						<view class="sn-title">{{ $t('支付时间') }}</view>
 						<view class="sn-text">{{tools.formatTime(orderInfo.pay_time)}}</view>
 					</view>
 					<view class="sn-content flex-row flex-between">
-						<view class="sn-title">支付方式</view>
-						<view v-if="orderInfo.pay_type == 0" class="sn-text">微信支付</view>
-						<view v-if="orderInfo.pay_type == 1" class="sn-text">线下支付</view>
-						<view v-if="orderInfo.pay_type == 2" class="sn-text">支付宝支付</view>
-						<view v-if="orderInfo.pay_type == 9" class="sn-text">钱包余额支付</view>
+						<view class="sn-title">{{ $t('支付方式') }}</view>
+						<view v-if="orderInfo.pay_type == 0" class="sn-text">{{ $t('微信支付') }}</view>
+						<view v-if="orderInfo.pay_type == 1" class="sn-text">{{ $t('线下支付') }}</view>
+						<view v-if="orderInfo.pay_type == 2" class="sn-text">{{ $t('支付宝支付') }}</view>
+						<view v-if="orderInfo.pay_type == 9" class="sn-text">{{ $t('钱包余额支付') }}</view>
 					</view>
 					<view v-if="orderInfo.order_type != 3" class="sn-content flex-row flex-between">
-						<view class="sn-title">租车金额</view>
+						<view class="sn-title">{{ $t('租车金额') }}</view>
 						<view class="sn-text">$ {{tools.toFix(orderInfo.hire_money/100)}}</view>
 					</view>
 					<view v-if="orderInfo.order_type != 3" class="sn-content flex-row flex-between">
-						<view class="sn-title">租车押金</view>
+						<view class="sn-title">{{ $t('租车押金') }}</view>
 						<view class="sn-text"><text class="grey-text"></text> $
 							{{tools.toFix(orderInfo.deposit/100)}}
 						</view>
@@ -124,14 +124,14 @@
 		</view>
 		<view class="car-info">
 			<view class="flex-row flex-between" style="margin-bottom: 40rpx;">
-				<text>自行去门店取还</text>
+				<text>{{ $t('自行去门店取还') }}</text>
 				<text class="distance-num">{{orderInfo.distance}}m</text>
 			</view>
 			<view class="flex-row store-img-view">
 				<img src="https://qiniu.bms16.com/FrwDlFZdSMiBgqnqDjB19PiDUmuu" alt="">
 				<view style="width: calc(100% - 180rpx);margin-left: 24rpx;">
 					<view class="store-name">{{orderInfo.shop_name}}</view>
-					<view class="store-name-address">{{orderInfo.address || '未知地址'}}</view>
+					<view class="store-name-address">{{orderInfo.address || $t('未知地址')}}</view>
 					<view class="flex-row flex-between align-center">
 						<view class="flex-row time-style align-center">
 							<img v-if="orderInfo.work_begin_time && orderInfo.work_end_time"
@@ -147,16 +147,16 @@
 			</view>
 		</view>
 		<view class="car-info">
-			<view>车辆信息</view>
+			<view>{{ $t('车辆信息') }}</view>
 			<view class="car-top flex-row flex-between">
 				<view>
 					<view class="top-flex">
 						<view>{{orderInfo.model_name}}</view>
 						<view>
-							续航{{(orderInfo.endurance /1000).toFixed(0)}}km|重量{{(orderInfo.weight / 1000).toFixed(0)}}kg
+							{{ $t('续航') }}{{(orderInfo.endurance /1000).toFixed(0)}}km{{ $t('|重量') }}{{(orderInfo.weight / 1000).toFixed(0)}}kg
 						</view>
 					</view>
-					<!-- //配套服务 -->
+					<!-- //{{ $t('配套服务') }} -->
 					<view class="serviceList">
 						<view v-for="(item,index) of orderInfo.service_list" :key="index" class="tag">
 							{{item}}
@@ -170,30 +170,30 @@
 				<view class="flex-row flex-between">
 					<view class="exchange-info-title flex-row align-center">
 						<img style="width: 40rpx;height: 40rpx;" src="https://qiniu.bms16.com/Fj_ifr41AqH2PijZBdOBa3SCxADg" alt="">
-						<text style="margin-left: 16rpx;">换电信息</text>
+						<text style="margin-left: 16rpx;">{{ $t('换电信息') }}</text>
 					</view>
 					<view @tap="navToExchange" class="flex-row" style="margin-bottom: 28rpx;">
-						<view class="exchange-button">共3次</view>
+						<view class="exchange-button">{{ $t('') }}3{{ $t('') }}</view>
 						<image src="https://qiniu.bms16.com/FpIN7AVzFU75slFlX-SIdnSEmn1k" style="width: 28rpx;height: 28rpx;" />
 					</view>
 				</view>			
-				<view class="exchange-content">本单可享3次免费换电数,超出后需单独支付</view>
-				<view class="exchange-content">自费换电:S1/次</view> -->
-			<!-- <view class="exchange-content">本单您可享受{{orderInfo.gift_exchange_num}}次免费换电,
-				当前免费换电剩余{{(orderInfo.gift_exchange_num - orderInfo.used_exchange_num) > 0 ? (orderInfo.gift_exchange_num - orderInfo.used_exchange_num) : '0' }}次,超出后需要单独支付换电费用
+				<view class="exchange-content">{{ $t('本单可享') }}3{{ $t('次免费换电数,超出后需单独支付') }}</view>
+				<view class="exchange-content">{{ $t('自费换电') }}:S1/{{ $t('') }}</view> -->
+			<!-- <view class="exchange-content">{{ $t('本单您可享受') }}{{orderInfo.gift_exchange_num}}{{ $t('次免费换电,') }}
+				{{ $t('当前免费换电剩余') }}{{(orderInfo.gift_exchange_num - orderInfo.used_exchange_num) > 0 ? (orderInfo.gift_exchange_num - orderInfo.used_exchange_num) : '0' }}{{ $t('次,超出后需要单独支付换电费用') }}
 				</view> -->
 			<!-- </view> -->
 		</view>
 
 		<view v-if="orderInfo.hire_begin_time!=0&&orderInfo.hire_end_time!=0" class="return-info">
 			<view class="return-top flex-row flex-between">
-				<view>取还时间</view>
+				<view>{{ $t('取还时间') }}</view>
 				<view>
-					<!-- 共3天{{orderInfo.hire_return_time.day > 0 ? orderInfo.hire_return_time.day :'' }}<text
-						v-if="orderInfo.hire_return_time.day>0">日</text>{{orderInfo.hire_return_time.hour > 0 ? orderInfo.hire_return_time.hour :'' }}<text
-						v-if="orderInfo.hire_return_time.hour>0">小时</text>{{orderInfo.hire_return_time.minute > 0 ? orderInfo.hire_return_time.minute :'' }}<text
-						v-if="orderInfo.hire_return_time.minute>0">分</text> -->
-					共{{hireDurationUnitsFn(orderInfo.total_hire_time,orderInfo.hire_duration_unit)}}{{leaseUnits(orderInfo.hire_duration_unit)}}
+					<!-- {{ $t('') }}3{{ $t('') }}{{orderInfo.hire_return_time.day > 0 ? orderInfo.hire_return_time.day :'' }}<text
+						v-if="orderInfo.hire_return_time.day>0">{{ $t('') }}</text>{{orderInfo.hire_return_time.hour > 0 ? orderInfo.hire_return_time.hour :'' }}<text
+						v-if="orderInfo.hire_return_time.hour>0">{{ $t('小时') }}</text>{{orderInfo.hire_return_time.minute > 0 ? orderInfo.hire_return_time.minute :'' }}<text
+						v-if="orderInfo.hire_return_time.minute>0">{{ $t('') }}</text> -->
+					{{ $t('') }}{{hireDurationUnitsFn(orderInfo.total_hire_time,orderInfo.hire_duration_unit)}}{{leaseUnits(orderInfo.hire_duration_unit)}}
 				</view>
 			</view>
 			<view class="return-bottom flex-row">
@@ -209,18 +209,18 @@
 
 		<view v-if="orderInfo.order_status==2||orderInfo.order_status==3||orderInfo.order_status==4"
 			class="overdue-info">
-			<view>逾期规则</view>
+			<view>{{ $t('逾期规则') }}</view>
 			<view class="overdue-one">
-				<view>1. 逾期后还可用车吗?</view>
-				<view>如果逾期将触发智能锁车逻辑,可能导致您无法正常用车,请及时续费或联系商家处理。</view>
+				<view>1. {{ $t('逾期后还可用车吗') }}?</view>
+				<view>{{ $t('如果逾期将触发智能锁车逻辑,可能导致您无法正常用车,请及时续费或联系商家处理。') }}</view>
 			</view>
 			<view class="overdue-two">
-				<view>2. 逾期费计算标准是什么?</view>
-				<view>小时租逾期费=每小时费用*逾期小时;当日还/日/周/月/季租逾期费=每天费用*逾期天数;如果不满1小时按1小时算,不满1天按1天算,最终收取的逾期费以门店确认的费用为准</view>
+				<view>2. {{ $t('逾期费计算标准是什么') }}?</view>
+				<view>{{ $t('小时租逾期费') }}={{ $t('每小时费用') }}*{{ $t('逾期小时;当日还') }}/{{ $t('') }}/{{ $t('') }}/{{ $t('') }}/{{ $t('季租逾期费') }}={{ $t('每天费用') }}*{{ $t('逾期天数;如果不满') }}1{{ $t('小时按') }}1{{ $t('小时算,不满') }}1{{ $t('天按') }}1{{ $t('天算,最终收取的逾期费以门店确认的费用为准') }}</view>
 			</view>
 			<view class="overdue-thr">
-				<view>3. 逾期后续租如何收费?</view>
-				<view>逾期后及时续租不收取逾期费,逾期时长将从续租订单的用车时间中抵扣</view>
+				<view>3. {{ $t('逾期后续租如何收费') }}?</view>
+				<view>{{ $t('逾期后及时续租不收取逾期费,逾期时长将从续租订单的用车时间中抵扣') }}</view>
 			</view>
 		</view>
 		<view class="inset-bottom"></view>
@@ -228,78 +228,77 @@
 			<view>
 				<view
 					v-if="(orderInfo.order_status == 0 ||orderInfo.order_status == 1 || orderInfo.pay_status == 5 || orderInfo.pay_status == 0) && orderInfo.order_type != 3"
-					class="cancel" @tap="clickCancel">结束订单</view>
+					class="cancel" @tap="clickCancel">{{ $t('结束订单') }}</view>
 			</view>
 			<view class="flex-row">
-				<view v-if="orderInfo.order_status == 1" @tap="navToScan" class="sesame-btn ">扫码绑定</view>
-				<view v-if="orderInfo.order_status == 2" @tap="navToScan" class="sesame-btn ">去上传</view>
+				<view v-if="orderInfo.order_status == 1" @tap="navToScan" class="sesame-btn ">{{ $t('扫码绑定') }}</view>
+				<view v-if="orderInfo.order_status == 2" @tap="navToScan" class="sesame-btn ">{{ $t('去上传') }}</view>
 				<view
 					v-if="(orderInfo.order_status == 3||orderInfo.order_status == 4) && orderInfo.order_type != 3 && orderInfo.pay_status != 5"
-					@tap="tapReturnCar" class="deposit-btn">到店还车</view>
+					@tap="tapReturnCar" class="deposit-btn">{{ $t('到店还车') }}</view>
 				<view
 					v-if="(orderInfo.order_status == 3||orderInfo.order_status == 4) && orderInfo.order_type != 3 && orderInfo.pay_status != 5"
-					@tap="bindRenew" class="sesame-btn">续租</view>
-				<view @tap="callStorePhone" class="deposit-btn ">联系门店</view>
+					@tap="bindRenew" class="sesame-btn">{{ $t('续租') }}</view>
+				<view @tap="callStorePhone" class="deposit-btn ">{{ $t('联系门店') }}</view>
 			</view>
 		</view>
 
 		<!-- <view class="payment-info flex-row flex-between">
 			<view v-if="orderInfo.order_status == 1 || orderInfo.pay_status == 5" class="flex-row"> 
 				<view v-if="orderInfo.order_type != 3"
-					class="cancel" @tap="clickCancel">结束订单
+					class="cancel" @tap="clickCancel">{{ $t('结束订单') }}
 				</view>
-				<view @tap="callStorePhone" class="deposit-btn ">联系门店</view>
+				<view @tap="callStorePhone" class="deposit-btn ">{{ $t('联系门店') }}</view>
 			</view>
 			<view v-if="orderInfo.order_status == 1" class="flex-row"> 
-				<view @tap="callStorePhone" class="deposit-btn ">联系门店</view>
-				<view @tap="navToScan" class="sesame-btn ">扫码绑定</view>
+				<view @tap="callStorePhone" class="deposit-btn ">{{ $t('联系门店') }}</view>
+				<view @tap="navToScan" class="sesame-btn ">{{ $t('扫码绑定') }}</view>
 			</view>
 
 			<view v-if="orderInfo.order_status == 2" class="flex-row">
-				<view @tap="callStorePhone" class="deposit-btn ">联系门店</view>
-				<view @tap="navToScan" class="sesame-btn ">去上传</view>
+				<view @tap="callStorePhone" class="deposit-btn ">{{ $t('联系门店') }}</view>
+				<view @tap="navToScan" class="sesame-btn ">{{ $t('去上传') }}</view>
 			</view>
 
 			<view
 				v-else-if="(orderInfo.order_status == 3||orderInfo.order_status == 4) && orderInfo.order_type != 3 && orderInfo.pay_status != 5"
 				class="flex-row"> 
-				<view @tap="callStorePhone" class="cancel">联系门店</view>
-				<view @tap="tapReturnCar" class="deposit-btn">到店还车</view>
-				<view @tap="bindRenew" class="sesame-btn">续租</view>
+				<view @tap="callStorePhone" class="cancel">{{ $t('联系门店') }}</view>
+				<view @tap="tapReturnCar" class="deposit-btn">{{ $t('到店还车') }}</view>
+				<view @tap="bindRenew" class="sesame-btn">{{ $t('续租') }}</view>
 			</view>
 
 			<view v-else-if="orderInfo.order_status == 5||orderInfo.order_status == 6" @tap="callStorePhone"
 				class="pay-btn">
-				联系门店</view> 
-			<view v-else-if="orderInfo.order_status == 7" @tap="callStorePhone" class="pay-btn">联系门店</view>
+				{{ $t('联系门店') }}</view> 
+			<view v-else-if="orderInfo.order_status == 7" @tap="callStorePhone" class="pay-btn">{{ $t('联系门店') }}</view>
 			
 
 			<view v-if="orderInfo.order_type == 3 && (orderInfo.order_status == 3||orderInfo.order_status == 4)"
-				@tap="callStorePhone" class="pay-btn">联系门店</view>
+				@tap="callStorePhone" class="pay-btn">{{ $t('联系门店') }}</view>
 		</view> -->
 
 		<view v-if="isShowCancel" class="cancel-b">
 			<view class="cancel-box">
 				<view class="cancel-title flex-row flex-between">
-					<view>选择取消原因</view>
+					<view>{{ $t('选择取消原因') }}</view>
 					<view @tap="isShowCancel = false" style="font-size: 60rpx;">×</view>
 				</view>
-				<view @click="reason = '行程变更无需用车'" class="cancel-item flex-row flex-between">
-					<view>行程变更无需用车</view>
-					<img
-						:src="reason == '行程变更无需用车'?'https://qiniu.bms16.com/FhWimtmWybKlYMB6mgIReVWArbfq':'https://qiniu.bms16.com/Fh0JH6_QbiXYmVy7FNYnDkVIGvLC'" />
+				<view @click="reason = $t('行程变更无需用车')" class="cancel-item flex-row flex-between">
+					<view>{{ $t('行程变更无需用车') }}</view>
+					<img :src="reason == $t('行程变更无需用车') ? 'https://qiniu.bms16.com/FhWimtmWybKlYMB6mgIReVWArbfq':'https://qiniu.bms16.com/Fh0JH6_QbiXYmVy7FNYnDkVIGvLC'" />
 				</view>
-				<view @click="reason = '修改订单信息'" class="cancel-item flex-row flex-between">
-					<view>修改订单信息</view>
+				<view @click="reason = $t('修改订单信息')" class="cancel-item flex-row flex-between">
+					<view>{{ $t('修改订单信息') }}</view>
 					<img
-						:src="reason == '修改订单信息'?'https://qiniu.bms16.com/FhWimtmWybKlYMB6mgIReVWArbfq':'https://qiniu.bms16.com/Fh0JH6_QbiXYmVy7FNYnDkVIGvLC'" />
+						:src="reason == $t('修改订单信息') ?'https://qiniu.bms16.com/FhWimtmWybKlYMB6mgIReVWArbfq':'https://qiniu.bms16.com/Fh0JH6_QbiXYmVy7FNYnDkVIGvLC'" />
 				</view>
-				<view @click="reason = '不想要了'" class="cancel-item flex-row flex-between">
-					<view>不想要了</view>
+				<view @click="reason = $t('不想要了')" class="cancel-item flex-row flex-between">
+					<view>{{ $t('不想要了') }}</view>
 					<img
-						:src="reason == '不想要了'?'https://qiniu.bms16.com/FhWimtmWybKlYMB6mgIReVWArbfq':'https://qiniu.bms16.com/Fh0JH6_QbiXYmVy7FNYnDkVIGvLC'" />
+						:src="reason == $t('不想要了') ?'https://qiniu.bms16.com/FhWimtmWybKlYMB6mgIReVWArbfq':'https://qiniu.bms16.com/Fh0JH6_QbiXYmVy7FNYnDkVIGvLC'" />
 				</view>
-				<view @click="bindCancel" class="cancel_btn">确认取消</view>
+				<view @click="bindCancel" class="cancel_btn">{{ $t('确认取消') }}</view>
 			</view>
 		</view>
 
@@ -356,7 +355,7 @@
 				charge_standard: {},
 				isShowCancel: false,
 				order_sn: '',
-				reason: '行程变更无需用车',
+				reason: this.$t('行程变更无需用车'),
 				orderInfo: {},
 				shop_image: [],
 				isExpanded: false,
@@ -476,24 +475,24 @@
 					if (data.data.model_id == this.orderInfo.model_id) {
 						return true
 					} else {
-						common.simpleToast('车型不匹配!')
+						common.simpleToast(this.$t('车型不匹配!'))
 						return false
 					}
 
 					if (data.data.is_hire == 1) {
 						return true
 					} else {
-						common.simpleToast('车辆已被租售!')
+						common.simpleToast(this.$t('车辆已被租售!'))
 						return false
 					}
 					if (data.data.is_display == 1) {
 						return true
 					} else {
-						common.simpleToast('车辆未展示!')
+						common.simpleToast(this.$t('车辆未展示!'))
 						return false
 					}
 				} else {
-					common.simpleToast('请扫描正确的二维码!')
+					common.simpleToast(this.$t('请扫描正确的二维码!'))
 					return false
 				}
 				return false
@@ -542,19 +541,19 @@
 
 			hireDurationUnitFn(type) {
 				if (type == 1) {
-					return '天'
+					return this.$t('天')
 				} else if (type == 2) {
-					return '月'
+					return this.$t('月')
 				} else if (type == 3) {
-					return '年'
+					return this.$t('年')
 				} else if (type == 4) {
-					return '小时'
+					return this.$t('小时')
 				} else if (type == 5) {
-					return '分钟'
+					return this.$t('分钟')
 				} else if (type == 6) {
-					return '周'
+					return this.$t('周')
 				} else if (type == 7) {
-					return '季'
+					return this.$t('季')
 				}
 			},
 			hireDurationUnitsFn(time, type) {
@@ -715,11 +714,11 @@
 			async bindCancel() {
 				const me = this
 				let res = await uni.showModal({
-					title: '取消订单',
-					content: '您是否需要取消该订单',
-					confirmText: '是',
+					title: this.$t('取消订单'),
+					content: this.$t('您是否需要取消该订单'),
+					confirmText: this.$t('是'),
 					confirmColor: '#0074FF',
-					cancelText: '否',
+					cancelText: this.$t('否'),
 					cancelColor: '#191D23',
 				});
 				if (res[1].confirm) {
@@ -771,7 +770,7 @@
 				const phone = me.shopInfo.link_phone
 				uni.showModal({
 					content: `您是否要拨打电话${phone}?`,
-					confirmText: '确定',
+					confirmText: this.$t('确定'),
 					success: (res) => {
 						if (res.confirm) {
 							uni.makePhoneCall({
@@ -877,7 +876,7 @@
 							.last_comm_time) > 1800
 						me.plate_number = resp.data.data.license_plate_number
 						if (resp.data.data.last_comm_time === 0 || isOffline) {
-							common.simpleToast('此车辆已离线,请选择其他车辆')
+							common.simpleToast(this.$t('此车辆已离线,请选择其他车辆'))
 						} else {
 							let carInfo = JSON.stringify(resp.data.data)
 							const car_model = resp.data.data.model_info.car_model
@@ -887,10 +886,10 @@
 							if (resp.data.data.has_owner) { //车辆正在被使用
 								if (resp.data.data.is_mine) { //是本人在使用
 									wx.showModal({
-										title: '提示',
+										title: this.$t('提示'),
 										content: '已有正在使用的车辆,是否跳转至车辆详情页?',
-										cancelText: '取消',
-										confirmText: '确定',
+										cancelText: this.$t('取消'),
+										confirmText: this.$t('确定'),
 										success: function(res) {
 											this.isReturnHome = false
 											uni.navigateTo({
@@ -902,12 +901,12 @@
 										complete: function(res) {},
 									})
 								} else {
-									common.simpleToast('此车辆正在被使用')
+									common.simpleToast(this.$t('此车辆正在被使用'))
 								}
 							} else {
 								if (me.order_sn && me.order_sn != '') {
 									if (this.orderInfo.model_id != model_id) { // 预租车型与之前预约车型不一致
-										common.simpleToast('与预约车型不符')
+										common.simpleToast(this.$t('与预约车型不符'))
 									} else {
 										this.isReturnHome = false
 										uni.navigateTo({
@@ -962,14 +961,14 @@
 							tradeNO: resp.data.data.trade_no,
 							success: function(res) {
 								if (res.resultCode == 9000) {
-									common.simpleToast('支付成功');
+									common.simpleToast(this.$t('支付成功'));
 								}
 								setTimeout(function() {
 									me.bindOrderInfo()
 								}, 1000)
 							},
 							fail: function(res) {
-								common.simpleToast('支付失败,请重试')
+								common.simpleToast(this.$t('支付失败,请重试'))
 							},
 						})
 						//#endif
@@ -977,12 +976,12 @@
 						var payParams = JSON.parse(resp.data.data.payParams);
 						user.wxPay(me.order_sn, payParams, function(isSuccess) {
 							if (isSuccess) {
-								common.simpleToast('支付成功')
+								common.simpleToast(this.$t('支付成功'))
 								setTimeout(function() {
 									me.bindOrderInfo()
 								}, 1000)
 							} else {
-								common.simpleToast('支付失败,请重试')
+								common.simpleToast(this.$t('支付失败,请重试'))
 							}
 						});
 						//#endif
@@ -1065,7 +1064,7 @@
 				this.bindOrderInfo()
 			},
 			navToExchange() {
-				console.log('跳转换电记录');
+				console.log(this.$t('跳转换电记录'));
 				uni.navigateTo({
 					url: '/pages/exchangeRecord/exchangeRecord' +
 						'?order_sn=' + this.orderInfo.order_sn

+ 20 - 20
pages/package/package.vue

@@ -10,11 +10,11 @@
 						<img class="left-img" src="https://qiniu.bms16.com/Fpf25Lkkrx05pvLw08mksVQKAQWf" />
 					</view>
 					<view class="left-second flex-row">
-						<view style="margin-right: 32rpx;">适用电池:<text>{{car_info.battery_tag_info.main_tag_name ? (car_info.battery_tag_info.main_tag_name) : ''}}{{car_info.battery_tag_info.child_tag_name ? '/' + car_info.battery_tag_info.child_tag_name : ''}}</text></view>
-						<!-- <view>押金:<text>$5.0</text></view> -->
+						<view style="margin-right: 32rpx;">{{ $t('适用电池') }}:<text>{{car_info.battery_tag_info.main_tag_name ? (car_info.battery_tag_info.main_tag_name) : ''}}{{car_info.battery_tag_info.child_tag_name ? '/' + car_info.battery_tag_info.child_tag_name : ''}}</text></view>
+						<!-- <view>{{ $t('押金') }}:<text>$5.0</text></view> -->
 					</view>
 					<view class="left-third">
-						<view>车辆编号:<text>{{car_info.car_sn}}</text></view>
+						<view>{{ $t('车辆编号') }}:<text>{{car_info.car_sn}}</text></view>
 					</view>
 				</view>
 				<img class="card-right" src="https://qiniu.bms16.com/FuOJQxzypa-NginyHGdsWlzwnB8z" />
@@ -24,46 +24,46 @@
 			<view class="package-view" v-for="item in hireOrderList">
 				<view class="top-view flex-row flex-between">
 					<view class="top-title" v-if="item.package_type == 1">
-						{{item.total_day}}天
+						{{item.total_day}}{{ $t('') }}
 					</view>
 					<view class="top-title" v-if="item.package_type == 2">
-						{{item.num}}次
+						{{item.num}}{{ $t('') }}
 					</view>
 					<view class="top-title" v-if="item.package_type == 3">
-						{{item.total_day}}天{{item.num}}次
+						{{item.total_day}}{{ $t('') }}{{item.num}}{{ $t('') }}
 					</view>
-					<view v-if="item.package_status==1" class="card-text card-b">生效中</view>
-					<view v-if="item.package_status==0" class="card-text card-o">待生效</view>
-					<view v-if="item.package_status==2" class="card-text card-o">已结束</view>
+					<view v-if="item.package_status==1" class="card-text card-b">{{ $t('生效中') }}</view>
+					<view v-if="item.package_status==0" class="card-text card-o">{{ $t('待生效') }}</view>
+					<view v-if="item.package_status==2" class="card-text card-o">{{ $t('已结束') }}</view>
 				</view>
 				<view class="package-item" style="margin-bottom: 32rpx;">
-					<view v-if="item.expire_time != 0" class="item-title">有效期至</view>
+					<view v-if="item.expire_time != 0" class="item-title">{{ $t('有效期至') }}</view>
 					<view class="item-info">{{tools.formatTime(item.expire_time)}}</view>
 				</view>
 				<view v-if="item.package_type != 2" class="package-item" style="margin-bottom: 32rpx;">
-					<view class="item-title">有效时长</view>
+					<view class="item-title">{{ $t('有效时长') }}</view>
 					<view class="item-info">
 						{{ item.expire_time != 0 ? calculateRemainingDays(item.expire_time) : item.total_day }}<text
-							style="color: #9FA7B7;">/{{item.total_day}}天</text>
+							style="color: #9FA7B7;">/{{item.total_day}}{{ $t('') }}</text>
 					</view>
 				</view>
 				<view v-if="item.package_type == 1" class="package-item">
-					<view class="item-title">免费换电数</view>
-					<!-- <view style="color: #060809;" class="item-info">{{item.last_num}}次</view> -->
-					<view style="color: #060809;" class="item-info">不限次数</view>
+					<view class="item-title">{{ $t('免费换电数') }}</view>
+					<!-- <view style="color: #060809;" class="item-info">{{item.last_num}}{{ $t('') }}</view> -->
+					<view style="color: #060809;" class="item-info">{{ $t('不限次数') }}</view>
 				</view>
 				<view v-if="item.package_type == 2" class="package-item">
-					<view class="item-title">免费换电数</view>
-					<view class="item-info">{{item.last_num}} <text style="color: #9FA7B7;">/{{item.num}}次</text></view>
+					<view class="item-title">{{ $t('免费换电数') }}</view>
+					<view class="item-info">{{item.last_num}} <text style="color: #9FA7B7;">/{{item.num}}{{ $t('') }}</text></view>
 				</view>
 				<view v-if="item.package_type == 3" class="package-item">
-					<view class="item-title">免费换电数</view>
-					<view style="color: #060809;" class="item-info">{{item.total_day}}天/{{item.last_num}}次</view>
+					<view class="item-title">{{ $t('免费换电数') }}</view>
+					<view style="color: #060809;" class="item-info">{{item.total_day}}{{ $t('') }}/{{item.last_num}}{{ $t('') }}</view>
 				</view>
 			</view>
 		</view>
 		<view style="height: 200rpx;"></view>
-		<view @click='srcFn' class="packageBtn">前往购买套餐</view>
+		<view @click='srcFn' class="packageBtn">{{ $t('前往购买套餐') }}</view>
 	</view>
 </template>
 <script module="tools" lang="wxs" src="@/pages/common/wxs/tools.wxs"></script>

+ 13 - 13
pages/phoneLogin/phoneLogin.vue

@@ -2,28 +2,28 @@
 	<view class="container">
 		<view class="content-top">
 			<img src="https://qiniu.bms16.com/FikV2SyfTEYQCgXjObAwwtkK27Hk" />
-			<view>欢迎来到{{appConfig.app_name}}</view>
+			<view>{{ $t('欢迎来到') }}{{appConfig.app_name}}</view>
 		</view>
 		<view class="content-input flex-row flex-between">
-			<input type="number" name="phone" @input="inputPhone" placeholder="请输入手机号" placeholder-style="color:#CBD1DD" />
+			<input type="number" name="phone" @input="inputPhone" :placeholder="$t('请输入手机号')" placeholder-style="color:#CBD1DD" />
 			<view @tap="bindGetVerifyCode" class="send-code">
-				<text v-if="codeGetting" class="g-text">重新获取 ·{{curTime}}S </text>
-				<text v-else class="b-text">获取验证码</text>
+				<text v-if="codeGetting" class="g-text">{{ $t('重新获取') }} ·{{curTime}}S </text>
+				<text v-else class="b-text">{{ $t('获取验证码') }}</text>
 			</view>
 		</view>
 		<view class="content-input">
-			<input type="number" name="verify_code" @input="inputVerifyCode" placeholder="请输入验证码" placeholder-style="color:#CBD1DD" />
+			<input type="number" name="verify_code" @input="inputVerifyCode" :placeholder="$t('请输入验证码')" placeholder-style="color:#CBD1DD" />
 		</view>
-		<view v-if="contract_id==1&&phone.length==11&&verify_code.length==4" @tap="bindLoginSubmit" class="submit-btn">登录</view>
-		<view v-else class="disable-btn">登录</view>
+		<view v-if="contract_id==1&&phone.length==11&&verify_code.length==4" @tap="bindLoginSubmit" class="submit-btn">{{ $t('登录') }}</view>
+		<view v-else class="disable-btn">{{ $t('登录') }}</view>
 		
 		<view class="contract-item flex-row">
 			<view @tap="bindContractInfo">
 				<img class="check-icon" :src="contract_id==1?'https://qiniu.bms16.com/FjLudtM29xwqgJh5kUKR9kyhK0Lu':'https://qiniu.bms16.com/FuQZipm9g7wX6CyGQBCjK2RTXfbW'" />
 			</view>
-			<view @tap="bindContractInfo" style="padding-left: 8rpx;">已阅读并同意 
-				<text style="color:#0074FF" @click.native.stop="bindContractToAgreement">{{'《' + appConfig.app_name + '电动车租赁用户协议》'}}</text>和
-				<text style="color:#0074FF" @click.native.stop="bindContractToPrivacy">《隐私协议》</text>
+			<view @tap="bindContractInfo" style="padding-left: 8rpx;">{{ $t('已阅读并同意') }} 
+				<text style="color:#0074FF" @click.native.stop="bindContractToAgreement">{{'《' + appConfig.app_name + $t('电动车租赁用户协议》')}}</text>{{ $t('') }}
+				<text style="color:#0074FF" @click.native.stop="bindContractToPrivacy">{{ $t('《隐私协议》') }}</text>
 			</view>
 		</view>
 	</view>
@@ -86,11 +86,11 @@
 					return
 				}
 				if (!this.phone) {
-					common.simpleToast('请输入手机号码');
+					common.simpleToast(this.$t('请输入手机号码'));
 					return;
 				}
 				if (!common.isPhone(this.phone)) {
-					common.simpleToast('请检测您的手机号码是否正确');
+					common.simpleToast(this.$t('请检测您的手机号码是否正确'));
 					return;
 				}
 				this.setData({
@@ -196,7 +196,7 @@
 								}
 				
 								storage.setUserToken(resp.data.data.baseInfo.token)
-								common.simpleToast('登录成功')
+								common.simpleToast(this.$t('登录成功'))
 								uni.reLaunch({
 									url: '/pages/index/index',
 								})

+ 12 - 12
pages/powerSetting/powerSetting.vue

@@ -1,17 +1,17 @@
 <template>
 		<view class="power-setting-main">
-			<navBar name="权限设置" bgColor="transparent"></navBar>
+			<navBar :name="$t('权限设置')" bgColor="transparent"></navBar>
 			<view class="flex-row power-setting-head">
 				<image class="head-img" :src="headimg" mode="aspectFit"></image>
 				<view class="head-name">{{nickname}}</view>
 				<text class="head-email">{{form.email}}</text>
 			</view>
 			<view class="setting-card" style="margin-bottom: 20rpx;">
-				<view class="setting-card-name">权限设置</view>
+				<view class="setting-card-name">{{ $t('权限设置') }}</view>
 				<view @click="selctFn(4)" class="setting-card-list flex-row">
 					<img src="https://qiniu.bms16.com/FgFEr3CUA43kd7yVCDcK4F7v9_zx" alt="">
 					<view class="setting-list-text flex-row flex-between">
-						<text>查看实时位置</text>
+						<text>{{ $t('查看实时位置') }}</text>
 						<img v-if="form.authority_list.indexOf(4) == -1" class="setting-list-arrow"
 							src="https://qiniu.bms16.com/FrA97op1dwM9XWH1ocqnF5FFlqoY" alt="">
 						<img v-else class="setting-list-arrow" src="https://qiniu.bms16.com/FuA5w59wrvsisg3bGhe3hQ2dR3Bk"
@@ -21,7 +21,7 @@
 				<view @click="selctFn(5)" class="setting-card-list flex-row">
 					<img src="https://qiniu.bms16.com/FmcZqGTnt64_v2xpgNbqS9Fa-fwy" alt="">
 					<view class="setting-list-text flex-row flex-between">
-						<text>使用换电</text>
+						<text>{{ $t('使用换电') }}</text>
 						<!-- <img class="setting-list-arrow" src="https://qiniu.bms16.com/FuA5w59wrvsisg3bGhe3hQ2dR3Bk" alt=""> -->
 						<img v-if="form.authority_list.indexOf(5) == -1" class="setting-list-arrow"
 							src="https://qiniu.bms16.com/FrA97op1dwM9XWH1ocqnF5FFlqoY" alt="">
@@ -31,22 +31,22 @@
 				</view>
 			</view>
 			<view class="setting-card" style="margin-bottom: 32rpx;">
-				<view class="setting-card-name">默认设置</view>
+				<view class="setting-card-name">{{ $t('默认设置') }}</view>
 				<view class="setting-card-list flex-row">
 					<img src="https://qiniu.bms16.com/FsUxQz3DwHIj_vt3fY25Twmjfpek" alt="">
-					<view class="setting-list-text flex-row">远程开关锁</view>
+					<view class="setting-list-text flex-row">{{ $t('远程开关锁') }}</view>
 				</view>
 				<view class="setting-card-list flex-row">
 					<img src="https://qiniu.bms16.com/FuCNZSqsoMxn2ha-njRW3zC2ORTz" alt="">
-					<view class="setting-list-text flex-row">座桶锁</view>
+					<view class="setting-list-text flex-row">{{ $t('座桶锁') }}</view>
 				</view>
 				<view class="setting-card-list flex-row">
 					<img src="https://qiniu.bms16.com/Fs7i3i_LBM7Zpxyj7Ad7_Kc_8z-J" alt="">
-					<view class="setting-list-text flex-row">感应解锁</view>
+					<view class="setting-list-text flex-row">{{ $t('感应解锁') }}</view>
 				</view>
 			</view>
-			<view v-if="isSet" @tap="submit" class="check-btn add-btn">确认添加</view>
-			<view v-else @tap="delSubmit" class="check-btn del-btn">删除成员</view>
+			<view v-if="isSet" @tap="submit" class="check-btn add-btn">{{ $t('确认添加') }}</view>
+			<view v-else @tap="delSubmit" class="check-btn del-btn">{{ $t('删除成员') }}</view>
 		</view>
 </template>
 
@@ -106,7 +106,7 @@
 			},
 			async delSubmit() {
 				let res = await uni.showModal({
-					content:'确定删除这个成员吗?'
+					content:this.$t('确定删除这个成员吗?')
 				})
 				if(!res[1].confirm) return
 				let {
@@ -137,7 +137,7 @@
 					data
 				} = await http.postApi(config.API_FLK_CAR_ADD_SHARE_USER, this.form)
 				if (data.code == 200) {
-					msg("添加成功!")
+					msg(this.$t('添加成功!'))
 					setTimeout(() => {
 						uni.navigateBack({
 							delta: 2

+ 27 - 27
pages/purchaseOrder/purchaseOrder.vue

@@ -1,8 +1,8 @@
 <template>
 	<view class="container-view">
-		<navBar name="确认订单" left="0"></navBar>
+		<navBar :name="$t('确认订单')" left="0"></navBar>
 		<view class="select-time-view">
-			<view class="flex-row">选择取车时间</view>
+			<view class="flex-row">{{ $t('选择取车时间') }}</view>
 			<view @tap="tapSelectTime" class="flex-row align-center" style="margin-bottom:20rpx ;">
 				<text class="select-time-text">{{takeCar}}</text>
 				<img style="width: 28rpx;height: 28rpx;" src="https://qiniu.bms16.com/FpbKGisSPfL9r8a7QkZCYXolhu1Y"
@@ -19,7 +19,7 @@
 							src="https://qiniu.bms16.com/FlMiRsUF-KZyevFCZDP9DwffOlag" alt="">
 					</view>
 					<view class="car-information">{{leaseUnitsResult}}
-						共计{{tools.countToDay(modelInfo.count,modelInfo.selectType)}}天</view>
+						{{ $t('共计') }}{{tools.countToDay(modelInfo.count,modelInfo.selectType)}}{{ $t('') }}</view>
 					<allPrice v-if="modelInfo.selectType == 100" :amount="modelInfo.sell_price / 100"></allPrice>
 					<allPrice v-else :amount="price"></allPrice>
 				</view>
@@ -35,16 +35,16 @@
 
 		<view v-if="modelInfo.selectType != 100" class="deposit-info">
 			<view class="deposit-info-title flex-row flex-between">
-				<text>车辆押金</text>
+				<text>{{ $t('车辆押金') }}</text>
 				<text>${{modelInfo.deposit/100}}</text>
 			</view>
-			<view class="deposit-info-text">需要支付{{modelInfo.deposit/100}}元押金,诺无车损、违章及逾期,还车后可退</view>
+			<view class="deposit-info-text">{{ $t('需要支付') }}{{modelInfo.deposit/100}}{{ $t('元押金,诺无车损、违章及逾期,还车后可退') }}</view>
 		</view>
 
 		<view class="method-info">
 			<view class="flex-row flex-between" style="margin-bottom: 40rpx;">
-				<view class="font_32">前往门店取还</view>
-				<view class="font_32">门店距您 <text class="distance-num">{{modelInfo.distance}}</text></view>
+				<view class="font_32">{{ $t('前往门店取还') }}</view>
+				<view class="font_32">{{ $t('门店距您') }} <text class="distance-num">{{modelInfo.distance}}</text></view>
 			</view>
 			<view @tap="navAddress" class="shop-bg flex-row flex-between">
 				<view class="shop-name-view">
@@ -56,7 +56,7 @@
 				<view class="nav-btn flex-row">
 					<img style="width: 48rpx;height: 48rpx;" src="https://zxappfile.bms16.com/zx_admin/cab_nav.png"
 						alt="">
-					<view style="margin-top: 12rpx;font-size: 24rpx;">导航</view>
+					<view style="margin-top: 12rpx;font-size: 24rpx;">{{ $t('导航') }}</view>
 				</view>
 			</view>
 		</view>
@@ -68,11 +68,11 @@
 			<view class="payment-bottom flex-row flex-between">
 				<view style="margin-right: 20rpx;" class="bottom-left flex-row">
 					<allPrice :amount="totalPrice"></allPrice>
-					<view v-if="modelInfo.selectType != 100" @tap="bindDetail" class="all-money">明细
+					<view v-if="modelInfo.selectType != 100" @tap="bindDetail" class="all-money">{{ $t('明细') }}
 							<image class="img" src="https://qiniu.bms16.com/Fvl1d-AWRvwY_ehNrw7bMZOK6LBZ" mode=""></image>
 							</view>
 				</view>
-				<view @tap="navToPage">确认下单</view>
+				<view @tap="navToPage">{{ $t('确认下单') }}</view>
 			</view>
 		</view>
 		
@@ -80,14 +80,14 @@
 			<view class="detail-info">
 				<view class="pay-money">
 					<view class="flex-row flex-between" style="margin-bottom: 46rpx;">
-						<view>价格明细</view>
+						<view>{{ $t('价格明细') }}</view>
 						<view>
 							<image style="width: 32rpx;height: 32rpx;" @tap="isShowDetail = false"
 								src="https://qiniu.bms16.com/FtoTEHOJiUf_gjPCJGGHMsAtHI5M" />
 						</view>
 					</view>
 					<view class="flex-row flex-between" style="margin-bottom: 44rpx;">
-						<view>车辆租金</view>
+						<view>{{ $t('车辆租金') }}</view>
 						<view>
 							<!-- ¥{{(leaseTime * price_list[0].hire_price) /100}} -->
 							¥{{price+'x'+modelInfo.count}}
@@ -95,12 +95,12 @@
 						</view>
 					</view>
 					<view class="flex-row flex-between" style="margin-bottom: 44rpx;">
-						<view>车辆押金</view>
+						<view>{{ $t('车辆押金') }}</view>
 						<view>¥{{modelInfo.deposit /100}}</view>
 					</view>
 
 					<view class="detail-money flex-row" style="padding-bottom: 44rpx;">
-						<view style="margin-right: 20rpx;">支付金额</view>
+						<view style="margin-right: 20rpx;">{{ $t('支付金额') }}</view>
 						<allPrice :amount="totalPrice"></allPrice>
 					</view>
 				</view>
@@ -108,11 +108,11 @@
 					<view class="payment-bottom flex-row flex-between">
 						<view style="margin-right: 20rpx;" class="bottom-left flex-row">
 							<allPrice :amount="totalPrice"></allPrice>
-							<view @tap="isShowDetail = false" class="all-money">明细
+							<view @tap="isShowDetail = false" class="all-money">{{ $t('明细') }}
 									<image class="img"  src="https://qiniu.bms16.com/FkzZI0r5jO-c2JRahNkZW2pHb9dR" mode=""></image>
 									</view>
 						</view>
-						<view @tap="navToPage">确认下单</view>
+						<view @tap="navToPage">{{ $t('确认下单') }}</view>
 					</view>
 				</view>
 			</view>
@@ -122,14 +122,14 @@
 		<view v-if="isShowReturnCar" class="return-box">
 			<view class="return-item">
 				<view class="return-title flex-row flex-between">
-					<view>还车到门店</view>
+					<view>{{ $t('还车到门店') }}</view>
 					<view @tap="isShowReturnCar = false" class="close-view"><img style="width: 24rpx;height: 24rpx;"
 							src="https://qiniu.bms16.com/FoWVlo-Nmx6wTDpsL2Rf9_BamU7L" alt=""></view>
 				</view>
-				<view class="return-text">系统会根据您的定位判断您是否已到还车位置,如您已经到达门店,请点击「我已到店」按钮,待门店确认还车后,即可还车成功。</view>
+				<view class="return-text">{{ $t('系统会根据您的定位判断您是否已到还车位置,如您已经到达门店,请点击「我已到店」按钮,待门店确认还车后,即可还车成功。') }}</view>
 				<view class="return-btn flex-row">
-					<view @tap="toRurnCarPage">导航到店</view>
-					<view @tap="toNearbyStorePage">我已到店</view>
+					<view @tap="toRurnCarPage">{{ $t('导航到店') }}</view>
+					<view @tap="toNearbyStorePage">{{ $t('我已到店') }}</view>
 				</view>
 			</view>
 		</view>
@@ -138,13 +138,13 @@
 				<view style="text-align: center;margin-bottom: 120rpx;">
 					<img style="width: 88rpx;height: 88rpx;" src="https://qiniu.bms16.com/Fqb-i2uJWlZOg8EvUXHr_1qhlndf"
 						alt="">
-					<view class="check-order-text">租车订单已提交</view>
-					<view>请于 <text class="get-car-time">{{takeCar}}</text> 到 <text
-							class="get-car-name">{{modelInfo.shop_name}}</text> 取车</view>
+					<view class="check-order-text">{{ $t('租车订单已提交') }}</view>
+					<view>{{ $t('请于') }} <text class="get-car-time">{{takeCar}}</text> {{ $t('') }} <text
+							class="get-car-name">{{modelInfo.shop_name}}</text> {{ $t('取车') }}</view>
 				</view>
 				<view class="return-btn flex-row">
-					<view @tap="toIndexPage">我知道了</view>
-					<view @tap="toOrderInfo">订单详情</view>
+					<view @tap="toIndexPage">{{ $t('我知道了') }}</view>
+					<view @tap="toOrderInfo">{{ $t('订单详情') }}</view>
 				</view>
 			</view>
 		</view>
@@ -322,7 +322,7 @@
 				uni.hideLoading();
 				if (data.code == 200) {
 					if (!data.data.need_pay) {
-						common.simpleToast(this.$t('支付成功'));
+						common.simpleToast(this.$t(this.$t('支付成功')));
 						this.order_sn = data.data.order_sn;
 						this.sub_sn = data.data.sub_sn;
 						this.setData({
@@ -341,7 +341,7 @@
 					uni.hideLoading();
 					if (resp.data.code === 200) {
 						if (!resp.data.data.need_pay) {
-							common.simpleToast(me, me.$t('支付成功'));
+							common.simpleToast(me, me.$t(this.$t('支付成功')));
 							me.order_sn = resp.data.data.order_sn;
 							me.sub_sn = resp.data.data.sub_sn;
 							me.setData({

+ 18 - 18
pages/scanCar/scanCar.vue

@@ -3,9 +3,9 @@
 		<view class="clap-info">
 			<view class="flex-row">
 				<view><img class="clap-img" src="https://qiniu.bms16.com/Fn80rw2jge0oUlkYH-Ac6HzQVVvz" /></view>
-				<view class="clap-title">拍照车牌号</view>
+				<view class="clap-title">{{ $t('拍照车牌号') }}</view>
 			</view>
-			<view class="clap-text">拍照时请留意照片的清晰度,便于系统提取车牌号</view>
+			<view class="clap-text">{{ $t('拍照时请留意照片的清晰度,便于系统提取车牌号') }}</view>
 			<camera v-if="src==''" class="camera" :flash="flashValue" device-position="back" mode="normal"></camera>
 			<!-- <camera v-if="src==''" class="camera" :flash="flashValue" device-position="back" mode="scanCode"></camera> -->
 			<view v-else>
@@ -21,15 +21,15 @@
 							src="https://qiniu.bms16.com/FncX5x6TJ3SqRmvz9YwkwmEYkCgq" /></view>
 				</view>
 				<view v-else class="flex-row">
-					<button @tap="bindRetake" class="retake flex-row">重拍</button>
-					<button @tap="bindUsePhoto" class="use-photo flex-row">使用照片</button>
+					<button @tap="bindRetake" class="retake flex-row">{{ $t('重拍') }}</button>
+					<button @tap="bindUsePhoto" class="use-photo flex-row">{{ $t('使用照片') }}</button>
 				</view>
 			</view>
 		</view>
 		<view @tap="navToPage" class="input-info flex-row flex-between">
 			<view class="flex-row">
 				<view><img class="input-img" src="https://qiniu.bms16.com/Fmjwred5RFltqVGpxlP33MWim689" /></view>
-				<view class="input-title">手动输入车牌号</view>
+				<view class="input-title">{{ $t('手动输入车牌号') }}</view>
 			</view>
 			<view><img class="right-img" src="https://qiniu.bms16.com/FpIN7AVzFU75slFlX-SIdnSEmn1k" /></view>
 		</view>
@@ -39,8 +39,8 @@
 				<view @tap="isShowInput=false" class="close">×</view>
 				<input :value="plate_number" type="text">
 				<view class="input-button flex-row">
-					<view @tap="isShowInput=false" class="close-button flex-row">取消</view>
-					<view @tap="bindOkPhoto" class="use-button flex-row">确定</view>
+					<view @tap="isShowInput=false" class="close-button flex-row">{{ $t('取消') }}</view>
+					<view @tap="bindOkPhoto" class="use-button flex-row">{{ $t('确定') }}</view>
 				</view>
 			</view>
 		</view> -->
@@ -188,13 +188,13 @@
 			navToPage() {
 				const me = this
 				if (!me.loading) {
-					common.simpleToast('数据加载中,请稍等')
+					common.simpleToast(this.$t('数据加载中,请稍等'))
 				} else {
 					if ((!me.myLocation.longitude) && (!me.myLocation.latitude)) { // 未获取到经纬度
 						if (me.userLocation == false) { // 判断原因是否为微信小程序内部没有授权定位
-							common.simpleToast('无法获取位置信息,请检查您的定位权限设置')
+							common.simpleToast(this.$t('无法获取位置信息,请检查您的定位权限设置'))
 						} else {
-							common.simpleToast('您的手机未授权定位权限,请前往手机设置开启权限')
+							common.simpleToast(this.$t('您的手机未授权定位权限,请前往手机设置开启权限'))
 						}
 						return
 					}
@@ -230,9 +230,9 @@
 				const me = this
 				if ((!this.myLocation.longitude) && (!this.myLocation.latitude)) { // 未获取到经纬度
 					if (me.userLocation == false) { // 判断原因是否为微信小程序内部没有授权定位
-						common.simpleToast('无法获取位置信息,请检查您的定位权限设置')
+						common.simpleToast(this.$t('无法获取位置信息,请检查您的定位权限设置'))
 					} else {
-						common.simpleToast('您的手机未授权定位权限,请前往手机设置开启权限')
+						common.simpleToast(this.$t('您的手机未授权定位权限,请前往手机设置开启权限'))
 					}
 					return
 				}
@@ -283,7 +283,7 @@
 						const timestamp = Date.now(); // 获取当前时间戳(毫秒)  
 						const isOffline = (Math.floor(timestamp / 1000) - resp.data.data.last_comm_time) > 1800
 						if (resp.data.data.last_comm_time === 0 || isOffline) {
-							common.simpleToast('此车辆已离线,请选择其他车辆')
+							common.simpleToast(this.$t('此车辆已离线,请选择其他车辆'))
 						} else {
 							let carInfo = JSON.stringify(resp.data.data)
 							const car_model = resp.data.data.model_info.car_model
@@ -293,10 +293,10 @@
 							if (resp.data.data.has_owner) { //车辆正在被使用
 								if (resp.data.data.is_mine) { //是本人在使用
 									uni.showModal({
-										title: '提示',
+										title: this.$t('提示'),
 										content: '已有正在使用的车辆,是否跳转至车辆详情页?',
-										cancelText: '取消',
-										confirmText: '确定',
+										cancelText: this.$t('取消'),
+										confirmText: this.$t('确定'),
 										success: function(res) {
 											this.isReturnHome = false
 											uni.navigateTo({
@@ -308,12 +308,12 @@
 										complete: function(res) {},
 									})
 								} else {
-									common.simpleToast('此车辆正在被使用')
+									common.simpleToast(this.$t('此车辆正在被使用'))
 								}
 							} else {
 								if (me.order_sn != '') {
 									if (this.order_model_id != model_id) { // 预租车型与之前预约车型不一致
-										common.simpleToast('与预约车型不符')
+										common.simpleToast(this.$t('与预约车型不符'))
 									} else {
 										this.isReturnHome = false
 										uni.navigateTo({

+ 6 - 6
pages/service/components/carRentalList/carRentalList.vue

@@ -15,7 +15,7 @@
 						</view>
 						<view class="align-c tag">
 							<text class="card-center-num">{{item.model_list.length}}</text>
-							款车型
+							{{ $t('款车型') }}
 						</view>
 					</view>
 				</view>
@@ -31,7 +31,7 @@
 							<view class="bottom-item">
 								<view>{{item.model_list[0].model_name}}</view>
 								<view>
-									续航{{ tools.formatDistance(item.model_list[0].endurance-0) }}|重量{{ tools.formatWeight(item.model_list[0].weight-0) }}
+									{{ $t('续航') }}{{ tools.formatDistance(item.model_list[0].endurance-0) }}{{ $t('|重量') }}{{ tools.formatWeight(item.model_list[0].weight-0) }}
 								</view>
 								<view class="flex-row flex-between">
 									<view class="bottom-text">
@@ -58,7 +58,7 @@
 							<view class="bottom-item">
 								<view>{{ items.model_name }}</view>
 								<view>
-									续航{{ tools.formatDistance(items.endurance-0) }}|重量{{ tools.formatWeight(items.weight-0) }}
+									{{ $t('续航') }}{{ tools.formatDistance(items.endurance-0) }}{{ $t('|重量') }}{{ tools.formatWeight(items.weight-0) }}
 								</view>
 								<view class="flex-row flex-between">
 									<view class="bottom-text">
@@ -66,7 +66,7 @@
 											style="margin-left: 10rpx;">¥</text><text>{{(items.hire_price /100).toFixed(2)}}</text>
 									</view>
 									<view v-if="items.sell_price && isBuy" class="bottom-text">
-										购买<text
+										{{ $t('购买') }}<text
 											style="margin-left: 10rpx;">¥</text><text>{{(items.sell_price /100).toFixed(2)}}</text>
 									</view>
 								</view>
@@ -197,7 +197,7 @@
 			callFn(tel) {
 				uni.showModal({
 					content: `您是否要拨打电话${tel}?`,
-					confirmText: '确定',
+					confirmText: this.$t('确定'),
 					success: (res) => {
 						if (res.confirm) {
 							uni.makePhoneCall({
@@ -210,7 +210,7 @@
 			curType() {
 				// const obj = LEASE_TYPE_ARR.find(v => v.value == this.duration_unit)
 				// return obj && obj.label
-				return '租'
+				return this.$t('租')
 			},
 			async navToStore(admin_id) {
 				const url = '/pages/storeDetails/storeDetails?admin_id=' + admin_id

+ 2 - 2
pages/service/components/leaseType/leaseType.vue

@@ -2,7 +2,7 @@
     <view class="container-view-contril">
 		<u-popup zIndex='9999' v-model="showLeaseType" :mask-close-able='false' :closeable="false" mode="bottom" border-radius="32">
 		    <view class="bottom-popup">
-		        <view class="title">{{ selectType == 'cabinet' ? '车辆类型' : '租借类型' }}</view>
+		        <view class="title">{{ selectType == 'cabinet' ? $t('车辆类型') : $t('租借类型')}}</view>
 		        <scroll-view style="max-height: 700rpx;" scroll-y>
 		        	<view class="item-wrap">
 		        	    <template v-if="selectType == 'cabinet'">
@@ -29,7 +29,7 @@
 		        	        		</view>
 		        	        	</view>
 		        	        	<view class="bugFlex">
-		        	        		  <view class="title">购买</view>
+		        	        		  <view class="title">{{ $t('购买') }}</view>
 		        	        		  <u-switch v-model="buy"></u-switch>
 		        	        	</view>
 		        	        </view>

+ 10 - 10
pages/service/service.vue

@@ -21,7 +21,7 @@
 		</view>
 		<!-- #endif -->
 
-		<!-- 地图控件 -->
+		<!-- {{ $t('地图控件') }} -->
 	<!-- 	<cover-view @click="isSearch = false" :class="[
         'control-icon-view',
         'flex-row',
@@ -36,13 +36,13 @@
 			<view v-if="isSearch" class="search-view flex-row">
 				<view class="search-input-view">
 					<img class="search-icon" src="https://qiniu.bms16.com/FgvJrOE8Lps7tyNL86SOZKbLT1uH" alt="" />
-					<input v-model="inputSearchValue" type="text" class="search-input" placeholder="请输入搜索内容"
+					<input v-model="inputSearchValue" type="text" class="search-input" :placeholder="$t('请输入搜索内容')"
 						placeholder-class="input-placeholder" :focus="isFocused" @focus="handleFocus"
 						@blur="handleBlur" />
 					<img v-if="isFocused" @tap="clearSearch" class="search-close-icon"
-						src="https://qiniu.bms16.com/FhKzwftEPo70kloqIVxKH7g0pD6I" alt="清空" />
+						src="https://qiniu.bms16.com/FhKzwftEPo70kloqIVxKH7g0pD6I" />
 				</view>
-				<view v-if="isFocused" @tap="tapSearch" :class="['search-btn', isFocused ? 'search-btn-i' : '']">搜索
+				<view v-if="isFocused" @tap="tapSearch" :class="['search-btn', isFocused ? 'search-btn-i' : '']">{{ $t('搜索') }}
 				</view>
 			</view>
 			<view class="flex-row flex-between" style="margin-bottom: 40rpx">
@@ -50,24 +50,24 @@
 					<view @tap="tapSelectType" data-type="store" :class="[
               'store-type',
               selectType === 'store' ? 'store-type-i' : 'store-type-s',
-            ]">门店</view>
+            ]">{{ $t('门店') }}</view>
 					<view @tap="tapSelectType" data-type="cabinet" :class="[
               'cabinet-type',
               selectType === 'cabinet' ? 'cabinet-type-i' : 'cabinet-type-s',
-            ]">换电柜</view>
+            ]">{{ $t('换电柜') }}</view>
 				</view>
 				<view class="config-view flex-row">
 					<view @click='openSelectType' class="flex-row selectFlex">
-						<text v-if="selectType === 'store'" class="text">{{leaseUnitsResult}}{{isBuy ? "+购买" : ''}}</text>
-						<text v-if="selectType === 'cabinet'" class="text">{{cabinetType ? cabinetType : '全部'}}</text>
+						<text v-if="selectType === 'store'" class="text">{{leaseUnitsResult}}{{isBuy ? $t('购买') : ''}}</text>
+						<text v-if="selectType === 'cabinet'" class="text">{{cabinetType ? cabinetType : $t('全部')}}</text>
 						<u-icon v-if="showLeaseType" name="arrow-down" color="#9FA7B7" size="26"></u-icon>
 						<u-icon v-else name="arrow-up" color="#9FA7B7" size="26"></u-icon>
 					</view>
 					<view class="seach-img" @tap="openSearch"><img
-							src="https://qiniu.bms16.com/FiWnFuZm5vWQ_Si3CEYLGJnVhSal" alt="搜索" /></view>
+							src="https://qiniu.bms16.com/FiWnFuZm5vWQ_Si3CEYLGJnVhSal" /></view>
 					<!-- <view @tap="openSelectType" class="screen-img"><img
 							:src="'https://qiniu.bms16.com/'+(shop_type!=''?'FikPWd13ENc2SWnC3q1n5F22uUDs':'FpElQHM5NbxHDjz1LrwaHYN668LR')"
-							alt="筛选" /></view> -->
+							alt="{{ $t('筛选') }}" /></view> -->
 				</view>
 			</view>
 			<CarRentalList :isBuy='isBuy' :shopType='shopType' :activeMarkersId='activeMarkersId' v-if="selectType === 'store'" :near_store_list="nearCabinetList" />

+ 13 - 13
pages/storeDetails/storeDetails.vue

@@ -23,7 +23,7 @@
 						{{item.title}}
 					</view>
 					<view class="store-num-type"> <text class="store-num">{{storeInfo.model_list.length || 0}}</text>
-						款车型
+						{{ $t('款车型') }}
 					</view>
 					<view class="store-phone" @tap="tapPhone"><img style="width: 84rpx;height: 64rpx;"
 							src="https://qiniu.bms16.com/Ft0YA1JYmq66hdoeEN-PgBHy5vLa" alt=""></view>
@@ -34,7 +34,7 @@
 							<img style="width: 40rpx;height: 40rpx;"
 								:src="!isWorkTimer ? 'https://zxappfile.bms16.com/zx_admin/cab_timer.png' : 'https://zxappfile.bms16.com/zx_admin/cab_timer_work.png'">
 							<view :class="isWorkTimer ? 'grid_text_1' : 'grid_text_rest' ">
-								{{isWorkTimer ? '营业中' : '已休息'}}
+								{{isWorkTimer ? $t('营业中') : $t('已休息')}}
 							</view>
 						</view>
 						<!-- <view v-if="storeInfo.work_begin_time" class="grid_text_2">
@@ -47,13 +47,13 @@
 					<view @tap="bindToNav" class="right_grid flex-between">
 						<view>
 							<view class="cab_distance">
-								直线距您 {{storeInfo.distance}}
+								{{ $t('直线距您') }} {{storeInfo.distance}}
 							</view>
 							<view class="cab_address">{{storeInfo.address}}</view>
 						</view>
 						<view>
 							<img class="icon_grid_1" src="https://zxappfile.bms16.com/zx_admin/cab_nav.png">
-							<view class="grid_nav">导航</view>
+							<view class="grid_nav">{{ $t('导航') }}</view>
 						</view>
 					</view>
 				</view>
@@ -88,17 +88,17 @@
 					<view class="step-tip-text">
 						<image class="step-num-1" src="https://qiniu.bms16.com/Fm4gMRmW6UOwLcU-eW8LDLNfiUJe"
 							mode='aspectFill'>
-						</image>线上选择用车方案生成待支付订单
+						</image>{{ $t('线上选择用车方案生成待支付订单') }}
 					</view>
 					<view class="step-tip-text">
 						<image class="step-num-2" src="https://qiniu.bms16.com/FvYN7SxOYIhXEqSAJZrQIBQuTx79"
 							mode='aspectFill'>
-						</image>导航到店向商家支付订单金额
+						</image>{{ $t('导航到店向商家支付订单金额') }}
 					</view>
 					<view class="step-tip-text">
 						<image class="step-num-3" src="https://qiniu.bms16.com/FhZ7w0X8iVuxFPdetEF9C3YYkJ7Z"
 							mode='aspectFill'>
-						</image>支付完成后直接现场取车
+						</image>{{ $t('支付完成后直接现场取车') }}
 					</view>
 				</view>
 			</view>
@@ -106,11 +106,11 @@
 
 
 			<!-- 	<view class="unit-type-view">
-				<view @click="status = 0;modelListsFn()" class="unit-type " :class="{'unit-type-i' : status == 0}">短租
+				<view @click="status = 0;modelListsFn()" class="unit-type " :class="{'unit-type-i' : status == 0}">{{ $t('短租') }}
 				</view>
-				<view @click="status = 1;modelListsFn()" class="unit-type" :class="{'unit-type-i' : status == 1}">长租
+				<view @click="status = 1;modelListsFn()" class="unit-type" :class="{'unit-type-i' : status == 1}">{{ $t('长租') }}
 				</view>
-				<view @click="status = 2;modelListsFn()" class="unit-type " :class="{'unit-type-i' : status == 2}">出售
+				<view @click="status = 2;modelListsFn()" class="unit-type " :class="{'unit-type-i' : status == 2}">{{ $t('出售') }}
 				</view>
 			</view> -->
 
@@ -127,13 +127,13 @@
 					<image class="car-img" :src="item.model_images[0]" mode="aspectFit"></image>
 					<view class="car-info">
 						<view class="car-name flex-row">{{item.model_name}}</view>
-						<view class="car-model-info">续航{{item.endurance}}km|重量{{item.weight}}kg</view>
+						<view class="car-model-info">{{ $t('续航') }}{{item.endurance}}km{{ $t('|重量') }}{{item.weight}}kg</view>
 						<view class="flex-row flex-between">
 							<view class="unit-type-price flex-row">
 								<text style="margin-right: 8rpx;">{{typeArrFn(tagId)}}</text>
 								<priceTool :price="Number(item.money)" :font_size="40" />
 							</view>
-							<view class="lease-btn">购/租</view>
+							<view class="lease-btn">{{ $t('') }}/{{ $t('') }}</view>
 						</view>
 					</view>
 				</view>
@@ -297,7 +297,7 @@
 				const me = this
 				uni.showModal({
 					content: `您是否要拨打电话${me.storeInfo.link_phone}?`,
-					confirmText: '确定',
+					confirmText: this.$t('确定'),
 					success: (res) => {
 						if (res.confirm) {
 							me.clearTimer()

+ 8 - 8
pages/travelingTrack/travelingTrack.vue

@@ -1,6 +1,6 @@
 <template>
 	<view class="container-view">
-		<navBar :name="'最近骑行'" />
+		<navBar :name="$t('最近骑行')" />
 		<!-- #ifdef MP-WEIXIN -->
 		<map class="my_app" id="myMap" :longitude="myLocation.longitude" :latitude="myLocation.latitude" :scale="scale"
 			:markers="markers" :enable-satellite="mapParams.enableSatellite" :enable-traffic="mapParams.enableTraffic"
@@ -22,7 +22,7 @@
 			<view class="info-top flex-row flex-between">
 				<view class="top-left f">
 					<view>{{carInfo.car_name}}</view>
-					<view>车牌号:{{carInfo.license_plate_number}}</view>
+					<view>{{ $t('车牌号:') }}{{carInfo.license_plate_number}}</view>
 				</view>
 				<view>
 					<image class="img"
@@ -45,19 +45,19 @@
 			<view class="info-bottom flex-row flex-between">
 				<view class="bottom-item">
 					<view>{{trackInfo.total_mil}}<text>km</text></view>
-					<view>行驶里程</view>
+					<view>{{ $t('行驶里程') }}</view>
 				</view>
 				<view class="bottom-item">
 					<view>{{tools.toFix((trackInfo.total_time || 0) / 60 / 60)}}<text>h</text></view>
-					<view>骑行时长</view>
+					<view>{{ $t('骑行时长') }}</view>
 				</view>
 				<view class="bottom-item">
 					<view>{{trackInfo.avg_speed}}<text>km/h</text></view>
-					<view>平均时速</view>
+					<view>{{ $t('平均时速') }}</view>
 				</view>
 				<!-- <view class="bottom-item">
 					<view>40.0<text>g</text></view>
-					<view>减少碳排量</view>
+					<view>{{ $t('减少碳排量') }}</view>
 				</view> -->
 			</view>
 		</view>
@@ -81,7 +81,7 @@
 		data() {
 			return {
 				mapShow:false,
-				time:'未知',
+				time:this.$t('未知'),
 				carInfo: {},
 				id: 0, // 使用 marker点击事件 需要填写id
 				title: 'map',
@@ -154,7 +154,7 @@
 					})
 					
 					if(this.pointsList.length < 1){
-						common.simpleToast('暂无骑行数据!')
+						common.simpleToast(this.$t('暂无骑行数据!'))
 						setTimeout(function() {
 							uni.navigateBack({
 								delta: 1

+ 4 - 4
pages/userManagement/userManagement.vue

@@ -1,12 +1,12 @@
 <template>
 	<view class="">
-		<navBar name="共享用户" />
+		<navBar :name="$t('共享用户')" />
 		<view class="user-card">
 			<view class="flex-row align-center user-card-heard">
 				<img style="width: 48rpx;height: 48rpx;" src="https://qiniu.bms16.com/FieeNq75ybyjIzQO6fmNcdTlRsp5" alt="">
-				<text style="margin-left: 16rpx;">共享用户</text>
+				<text style="margin-left: 16rpx;">{{ $t('共享用户') }}</text>
 			</view>
-			<view class="user-card-text">家人、朋友长期共用车辆,授权账户可以使用感应解锁,寻车定位,查看设置等功能;</view>
+			<view class="user-card-text">{{ $t('家人、朋友长期共用车辆,授权账户可以使用感应解锁,寻车定位,查看设置等功能;') }}</view>
 			<!-- <view v-for="(item,index) in userList" :key="index"> -->
 			<view @click="srcFn(`/pages/powerSetting/powerSetting?id=${item.target_user_id}`)" v-for="(item,index) of list" :key="index" class="user-list flex-row align-center">
 				<image class="user-heard-img" :src="item.headimg" mode="aspectFill"></image>
@@ -18,7 +18,7 @@
 			</view>
 			<view @click="addUser" class="flex-row user-card-btn align-center">
 				<img style="width: 20rpx;height: 20rpx;" src="https://qiniu.bms16.com/FvP_5VTgawzExIHW3kJahXAvE04z" alt="">
-				<text style="margin-left: 6rpx;">添加成员</text>
+				<text style="margin-left: 6rpx;">{{ $t('添加成员') }}</text>
 			</view>
 		</view>