diff --git a/.env b/.env
new file mode 100644
index 0000000..e69de29
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..8c7dae1
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,8 @@
+node_modules
+dist
+*.local
+.history
+.idea
+dist/
+.hbuilderx
+keys
\ No newline at end of file
diff --git a/index.html b/index.html
new file mode 100644
index 0000000..5bc08f0
--- /dev/null
+++ b/index.html
@@ -0,0 +1,27 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/jsconfig.json b/jsconfig.json
new file mode 100644
index 0000000..730626d
--- /dev/null
+++ b/jsconfig.json
@@ -0,0 +1,9 @@
+{
+ "compilerOptions": {
+ "types": [
+ "@dcloudio/types",
+ "miniprogram-api-typings",
+ "mini-types"
+ ]
+ }
+}
diff --git a/package.json b/package.json
new file mode 100644
index 0000000..c79310d
--- /dev/null
+++ b/package.json
@@ -0,0 +1,67 @@
+{
+ "name": "uni-preset-vue",
+ "version": "0.0.0",
+ "scripts": {
+ "dev:app": "uni -p app",
+ "dev:app-android": "uni -p app-android",
+ "dev:app-ios": "uni -p app-ios",
+ "dev:custom": "uni -p",
+ "dev:h5": "uni",
+ "dev:h5:ssr": "uni --ssr",
+ "dev:mp-alipay": "uni -p mp-alipay",
+ "dev:mp-baidu": "uni -p mp-baidu",
+ "dev:mp-kuaishou": "uni -p mp-kuaishou",
+ "dev:mp-lark": "uni -p mp-lark",
+ "dev:mp-qq": "uni -p mp-qq",
+ "dev:mp-toutiao": "uni -p mp-toutiao",
+ "dev:mp-weixin": "uni -p mp-weixin",
+ "dev:quickapp-webview": "uni -p quickapp-webview",
+ "dev:quickapp-webview-huawei": "uni -p quickapp-webview-huawei",
+ "dev:quickapp-webview-union": "uni -p quickapp-webview-union",
+ "build:app": "uni build -p app",
+ "build:app-android": "uni build -p app-android",
+ "build:app-ios": "uni build -p app-ios",
+ "build:custom": "uni build -p",
+ "build:h5": "uni build",
+ "build:h5:ssr": "uni build --ssr",
+ "build:mp-alipay": "uni build -p mp-alipay",
+ "build:mp-baidu": "uni build -p mp-baidu",
+ "build:mp-kuaishou": "uni build -p mp-kuaishou",
+ "build:mp-lark": "uni build -p mp-lark",
+ "build:mp-qq": "uni build -p mp-qq",
+ "build:mp-toutiao": "uni build -p mp-toutiao",
+ "build:mp-weixin": "uni build -p mp-weixin",
+ "build:quickapp-webview": "uni build -p quickapp-webview",
+ "build:quickapp-webview-huawei": "uni build -p quickapp-webview-huawei",
+ "build:quickapp-webview-union": "uni build -p quickapp-webview-union"
+ },
+ "dependencies": {
+ "@amap/amap-jsapi-loader": "^1.0.1",
+ "@dcloudio/uni-app": "3.0.0-3060520221121001",
+ "@dcloudio/uni-app-plus": "3.0.0-3060520221121001",
+ "@dcloudio/uni-components": "3.0.0-3060520221121001",
+ "@dcloudio/uni-h5": "3.0.0-3060520221121001",
+ "@dcloudio/uni-mp-alipay": "3.0.0-3060520221121001",
+ "@dcloudio/uni-mp-baidu": "3.0.0-3060520221121001",
+ "@dcloudio/uni-mp-kuaishou": "3.0.0-3060520221121001",
+ "@dcloudio/uni-mp-lark": "3.0.0-3060520221121001",
+ "@dcloudio/uni-mp-qq": "3.0.0-3060520221121001",
+ "@dcloudio/uni-mp-toutiao": "3.0.0-3060520221121001",
+ "@dcloudio/uni-mp-weixin": "3.0.0-3060520221121001",
+ "@dcloudio/uni-quickapp-webview": "3.0.0-3060520221121001",
+ "@dcloudio/uni-ui": "^1.4.23",
+ "@gykeji/jsutil": "^2.0.2",
+ "vue": "^3.2.37",
+ "vue-i18n": "^9.1.9",
+ "vuex": "^4.1.0"
+ },
+ "devDependencies": {
+ "@dcloudio/types": "^3.0.13",
+ "@dcloudio/uni-automator": "3.0.0-3060520221121001",
+ "@dcloudio/uni-cli-shared": "3.0.0-3060520221121001",
+ "@dcloudio/uni-stacktracey": "3.0.0-3060520221121001",
+ "@dcloudio/vite-plugin-uni": "3.0.0-3060520221121001",
+ "sass": "^1.56.2",
+ "vite": "^2.9.14"
+ }
+}
diff --git a/src/App.vue b/src/App.vue
new file mode 100644
index 0000000..b5f7a25
--- /dev/null
+++ b/src/App.vue
@@ -0,0 +1,48 @@
+
+
+
diff --git a/src/api/city.js b/src/api/city.js
new file mode 100644
index 0000000..354c6ee
--- /dev/null
+++ b/src/api/city.js
@@ -0,0 +1,47 @@
+/*
+ * @Author: ch cwl_ch@163.com
+ * @Date: 2022-12-28 14:42:03
+ * @LastEditors: ch
+ * @LastEditTime: 2022-12-28 14:54:32
+ * @Description: file content
+ */
+
+import { _ToAsyncAwait } from '@gykeji/jsutil';
+import MAP_CON from '../config/gdMapConf';
+const formatCity = (data)=>{
+ let arr = [];
+ data.forEach(i => {
+ if(i.citycode.length){
+ arr.push(i);
+ }
+ if(i.districts.length){
+ arr = arr.concat(formatCity(i.districts))
+ }
+ });
+ return arr;
+}
+/**
+ * @Description: 获取城市列表,直接使用高德API
+ * @return {*}
+ */
+const ApiGetCityList = () => _ToAsyncAwait(
+ new Promise((res, rej) => {
+ uni.request({
+ method: 'GET',
+ url: `${MAP_CON.cityApiUrl}?subdistrict=2&key=${MAP_CON.cityKey}`,
+ success(result){
+ res(
+ formatCity(result.data.districts[0].districts).sort((a,b)=>{
+ return a.name.localeCompare(b.name, 'zh-CN');
+ })
+ );
+ },
+ error(e){
+ rej(e)
+ }
+ })
+ })
+)
+export {
+ ApiGetCityList
+}
\ No newline at end of file
diff --git a/src/api/order.js b/src/api/order.js
new file mode 100644
index 0000000..589ba31
--- /dev/null
+++ b/src/api/order.js
@@ -0,0 +1,72 @@
+/*
+ * @Author: ch cwl_ch@163.com
+ * @Date: 2022-12-19 15:33:58
+ * @LastEditors: ch
+ * @LastEditTime: 2022-12-30 16:48:20
+ * @Description: file content
+ */
+import { MsbRequest } from "../plugins/requset";
+
+const ApiGetUserProgressOrder = () => MsbRequest.get("/UserProgressOrder");
+
+/**
+ * @Description: 获取价格
+ * @param {*}
+ * @return {*}
+ */
+const ApiGetPrice = (
+ params = {
+ depLongitude, //城市编码
+ depLatitude, //出发地纬度
+ destLongitude, //目的地纬度
+ destLatitude, //目的地纬度
+ cityCode, //城市编码
+ vehicleType, //车辆类型
+ }
+) => MsbRequest.post("/forecast-price", params);
+
+/**
+ * @Description:乘客下单
+ * @return {*}
+ */
+const ApiPostOrderAdd = (
+ data = {
+ address,
+ departTime,
+ orderTime,
+ departure,
+ depLongitude,
+ depLatitude,
+ destination,
+ destLongitude,
+ destLatitude,
+ encrypt,
+ fareType,
+ fareVersion,
+ passengerId,
+ passengerPhone,
+ vehicleType,
+ }
+) => MsbRequest.post("/order/add", data);
+
+/**
+ * @Description: 乘客取消订单
+ * @param {*} orderId
+ * @return {*}
+ */
+const ApiPostOrderCancel = ({orderId}) => MsbRequest.post('/order/cancel',{orderId},{
+ 'content-type':'application/x-www-form-urlencoded'
+});
+/**
+ * @Description: 查询当前用户正在进行的订单
+ * @return {*}
+ */
+const ApiGetCurrentOrder = () => MsbRequest.get('/order/current');
+
+export {
+ ApiGetUserProgressOrder,
+ ApiGetPrice,
+ ApiPostOrderAdd,
+ ApiPostOrderCancel,
+ ApiGetCurrentOrder
+};
diff --git a/src/api/user.js b/src/api/user.js
new file mode 100644
index 0000000..1653567
--- /dev/null
+++ b/src/api/user.js
@@ -0,0 +1,38 @@
+/*
+ * @Author: ch cwl_ch@163.com
+ * @Date: 2022-12-19 11:30:32
+ * @LastEditors: ch
+ * @LastEditTime: 2022-12-30 18:19:04
+ * @Description: file content
+ */
+import { MsbRequest } from '../plugins/requset';
+
+/**
+ * @Description: 获取验证码
+ * @param {*} passengerPhone
+ * @return {*}
+ */
+const ApiGetVerifyCode = ({passengerPhone}) => MsbRequest.post('/verification-code',{
+ passengerPhone
+},{notVerifyToken:true})
+/**
+ * @Description: 验证验证码
+ * @param {*} passengerPhone
+ * @param {*} verificationCode
+ * @return {*}
+ */
+const ApiPostVerifyCodeCheck = ({passengerPhone,verificationCode}) => MsbRequest.post('/verification-code-check',{
+ passengerPhone,
+ verificationCode,
+},{notVerifyToken:true})
+/**
+ * @Description: 根据token获取乘客信息
+ * @return {*}
+ */
+const ApiGetUserInfo = () => MsbRequest.get('/users/');
+
+export {
+ ApiGetVerifyCode,
+ ApiPostVerifyCodeCheck,
+ ApiGetUserInfo
+}
\ No newline at end of file
diff --git a/src/component/BMap.vue b/src/component/BMap.vue
new file mode 100644
index 0000000..7abac14
--- /dev/null
+++ b/src/component/BMap.vue
@@ -0,0 +1,191 @@
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/component/BSseMessage.vue b/src/component/BSseMessage.vue
new file mode 100644
index 0000000..077702f
--- /dev/null
+++ b/src/component/BSseMessage.vue
@@ -0,0 +1,26 @@
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/config/dicts.js b/src/config/dicts.js
new file mode 100644
index 0000000..acafcf7
--- /dev/null
+++ b/src/config/dicts.js
@@ -0,0 +1,31 @@
+/*
+ * @Author: ch cwl_ch@163.com
+ * @Date: 2022-12-27 14:52:17
+ * @LastEditors: ch
+ * @LastEditTime: 2022-12-30 16:33:24
+ * @Description: 字典表
+ */
+const ORDER_STATUS = {
+ // 乘客发起订单
+ orderStart : 1,
+ // 司机接单
+ driverReceive: 2,
+ // 司机去接乘客
+ driverToPickUp: 3,
+ // 司机到底上车点
+ driverArriveStartPoint: 4,
+ // 行程开始,乘客上车
+ tripStart: 5,
+ // 行程结束,到达目的地
+ tripFinish: 6,
+ // 发起收款,待支付
+ awaitPay: 7,
+ // 付款完成,订单完成
+ orderFinish: 8,
+ // 订单取消
+ orderCancel: 9,
+
+}
+export {
+ ORDER_STATUS
+}
\ No newline at end of file
diff --git a/src/config/gdMapConf.js b/src/config/gdMapConf.js
new file mode 100644
index 0000000..9108ae1
--- /dev/null
+++ b/src/config/gdMapConf.js
@@ -0,0 +1,24 @@
+/*
+ * @Author: ch cwl_ch@163.com
+ * @Date: 2022-12-28 14:39:29
+ * @LastEditors: ch
+ * @LastEditTime: 2022-12-30 16:35:53
+ * @Description: 高德地图配置,需要自行去高德开放平台申请
+ */
+export default {
+ // 高德地图JS Api key
+ key:'accb4fe7de2b5efd04f187dc0f978777',
+ // 高德地图JS Api key对应的秘钥,正式环境最好不要放前端
+ securityJsCode : '617eba916a16270f5fa3203a4ee2e2a6',
+ // 城市获取key
+ cityKey : 'fe5524e832a0fc6e2bcaf1bb781ac830',
+ // 高德城市请求地址
+ cityApiUrl : 'https://restapi.amap.com/v3/config/district',
+ // 默认选中城市
+ city: {
+ adcode: "110000",
+ center: "116.407387,39.904179",
+ citycode: "010",
+ name: "北京市"
+ }
+}
\ No newline at end of file
diff --git a/src/config/serverConf.js b/src/config/serverConf.js
new file mode 100644
index 0000000..3f64f0e
--- /dev/null
+++ b/src/config/serverConf.js
@@ -0,0 +1,27 @@
+/*
+ * @Author: ch cwl_ch@163.com
+ * @Date: 2022-12-30 14:47:25
+ * @LastEditors: ch
+ * @LastEditTime: 2022-12-30 15:42:42
+ * @Description: 服务端配置
+ */
+
+export default {
+ // #ifdef H5
+ // 支付服务
+ pay: '/payApi',
+ // sse服务
+ sse: '/sseApi',
+ // 其他接口服务
+ other: '/api',
+ // #endif
+
+ // #ifdef APP-PLUS ||MP
+ // 支付服务
+ pay: 'http://192.168.40.193:9001',
+ // sse服务
+ sse: 'http://192.168.40.193:60001',
+ // 其他接口服务
+ other: 'http://192.168.40.193:8081'
+ // #endif
+}
\ No newline at end of file
diff --git a/src/config/storageKey.js b/src/config/storageKey.js
new file mode 100644
index 0000000..802c21a
--- /dev/null
+++ b/src/config/storageKey.js
@@ -0,0 +1,13 @@
+/*
+ * @Author: ch cwl_ch@163.com
+ * @Date: 2022-12-19 10:58:26
+ * @LastEditors: ch
+ * @LastEditTime: 2022-12-30 14:51:56
+ * @Description: 本地存储key管理
+ */
+const STORAGE_KEY = {
+ token : 'tk',
+ userInfo : 'u_i',
+ serverConf: 's_c'
+}
+export default STORAGE_KEY;
\ No newline at end of file
diff --git a/src/main.js b/src/main.js
new file mode 100644
index 0000000..9733527
--- /dev/null
+++ b/src/main.js
@@ -0,0 +1,19 @@
+/*
+ * @Author: ch cwl_ch@163.com
+ * @Date: 2022-11-21 17:23:51
+ * @LastEditors: ch
+ * @LastEditTime: 2022-12-13 17:41:14
+ * @Description: file content
+ */
+import {
+ createSSRApp
+} from "vue";
+import App from "./App.vue";
+import store from './store'
+export function createApp() {
+ const app = createSSRApp(App);
+ app.use(store)
+ return {
+ app,
+ };
+}
diff --git a/src/manifest.json b/src/manifest.json
new file mode 100644
index 0000000..e9002f9
--- /dev/null
+++ b/src/manifest.json
@@ -0,0 +1,76 @@
+{
+ "name" : "飞滴出行",
+ "appid" : "__UNI__390779D",
+ "description" : "",
+ "versionName" : "1.0.0",
+ "versionCode" : "100",
+ "transformPx" : false,
+ /* 5+App特有相关 */
+ "app-plus" : {
+ "usingComponents" : true,
+ "nvueStyleCompiler" : "uni-app",
+ "compilerVersion" : 3,
+ "splashscreen" : {
+ "alwaysShowBeforeRender" : true,
+ "waiting" : true,
+ "autoclose" : true,
+ "delay" : 0
+ },
+ /* 模块配置 */
+ "modules" : {},
+ /* 应用发布信息 */
+ "distribute" : {
+ /* android打包配置 */
+ "android" : {
+ "permissions" : [
+ "",
+ "",
+ "",
+ "",
+ "",
+ "",
+ "",
+ "",
+ "",
+ "",
+ "",
+ ""
+ ]
+ },
+ /* ios打包配置 */
+ "ios" : {},
+ /* SDK配置 */
+ "sdkConfigs" : {
+ "maps" : {},
+ "payment" : {
+ "alipay" : {
+ "__platform__" : [ "ios", "android" ]
+ }
+ }
+ }
+ }
+ },
+ /* 快应用特有相关 */
+ "quickapp" : {},
+ /* 小程序特有相关 */
+ "mp-weixin" : {
+ "appid" : "",
+ "setting" : {
+ "urlCheck" : false
+ },
+ "usingComponents" : true
+ },
+ "mp-alipay" : {
+ "usingComponents" : true
+ },
+ "mp-baidu" : {
+ "usingComponents" : true
+ },
+ "mp-toutiao" : {
+ "usingComponents" : true
+ },
+ "uniStatistics" : {
+ "enable" : false
+ },
+ "vueVersion" : "3"
+}
diff --git a/src/pages.json b/src/pages.json
new file mode 100644
index 0000000..d86db06
--- /dev/null
+++ b/src/pages.json
@@ -0,0 +1,60 @@
+{
+ "pages": [
+ {
+ "path": "pages/index/index",
+ "style": {
+ "navigationBarTitleText": "飞滴出行",
+ "titleImage":"/static/logo.png"
+ }
+ },
+ {
+ "path": "pages/city",
+ "style": {
+ "navigationBarTitleText": "飞滴出行",
+ "titleImage":"/static/logo.png"
+ }
+ },
+ {
+ "path": "pages/createOrder",
+ "style": {
+ // "navigationBarTitleText": "飞滴出行",
+ "titleImage":"/static/logo.png"
+ }
+ },
+ {
+ "path": "pages/orderDetail",
+ "style": {
+ // "navigationBarTitleText": "飞滴出行",
+ "titleImage":"/static/logo.png"
+ }
+ },
+ {
+ "path": "pages/pay",
+ "style": {
+ // "navigationBarTitleText": "飞滴出行",
+ "titleImage":"/static/logo.png"
+ }
+ },
+ {
+ "path": "pages/login",
+ "style": {
+ // "navigationBarTitleText": "飞滴出行",
+ "titleImage":"/static/logo.png"
+ }
+ },
+ {
+ "path": "pages/account",
+ "style": {
+ // "navigationBarTitleText": "飞滴出行",
+ "titleImage":"/static/logo.png"
+ }
+ }
+
+ ],
+ "globalStyle": {
+ "navigationBarTextStyle": "black",
+ "navigationBarTitleText": "uni-app",
+ "navigationBarBackgroundColor": "#F8F8F8",
+ "backgroundColor": "#F8F8F8"
+ }
+}
diff --git a/src/pages/account.vue b/src/pages/account.vue
new file mode 100644
index 0000000..70e333e
--- /dev/null
+++ b/src/pages/account.vue
@@ -0,0 +1,76 @@
+
+
+ 在此设置你的后端服务地址:
+
+ 支付服务
+
+
+
+ SSE服务
+
+
+
+ 其他服务
+
+
+
+ 保存成功后如不生效,请重启APP
+
+
+
+
+
\ No newline at end of file
diff --git a/src/pages/city.vue b/src/pages/city.vue
new file mode 100644
index 0000000..052dec1
--- /dev/null
+++ b/src/pages/city.vue
@@ -0,0 +1,87 @@
+
+
+
+
+ 取消
+
+
+ {{item.name}}
+
+
+
+
+
diff --git a/src/pages/createOrder.vue b/src/pages/createOrder.vue
new file mode 100644
index 0000000..89688a4
--- /dev/null
+++ b/src/pages/createOrder.vue
@@ -0,0 +1,194 @@
+
+
+
+
+
+ 预计价格:
+ ¥{{priceResult.price}}
+
+
+ 出发时间:
+
+
+ {{departDay}}
+
+
+ {{departTime}}
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/pages/index/index.vue b/src/pages/index/index.vue
new file mode 100644
index 0000000..c315e9a
--- /dev/null
+++ b/src/pages/index/index.vue
@@ -0,0 +1,97 @@
+
+
+
+ {{city.name}}
+ 设置
+
+
+
+
+
\ No newline at end of file
diff --git a/src/pages/index/modules/PointList.vue b/src/pages/index/modules/PointList.vue
new file mode 100644
index 0000000..0b61c54
--- /dev/null
+++ b/src/pages/index/modules/PointList.vue
@@ -0,0 +1,105 @@
+
+
+
+ {{city.name}}
+
+ 取消
+
+
+
+ {{item.name}}
+ {{item.address}}
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/pages/index/modules/SelectPoint.vue b/src/pages/index/modules/SelectPoint.vue
new file mode 100644
index 0000000..3db8459
--- /dev/null
+++ b/src/pages/index/modules/SelectPoint.vue
@@ -0,0 +1,104 @@
+
+
+
+ 您在哪上车?
+
+ 您将从
+ {{startPoint.name}}
+ 上车
+
+
+
+ 您要去哪儿?
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/pages/login.vue b/src/pages/login.vue
new file mode 100644
index 0000000..957793d
--- /dev/null
+++ b/src/pages/login.vue
@@ -0,0 +1,123 @@
+
+
+
+ 飞滴出行,一路畅行
+
+
+
+
+ {{codeText}}
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/pages/orderDetail.vue b/src/pages/orderDetail.vue
new file mode 100644
index 0000000..f89f8cf
--- /dev/null
+++ b/src/pages/orderDetail.vue
@@ -0,0 +1,129 @@
+
+
+
+
+
+
+ 行程已完成,请等待司机收款
+
+ 您的行程已结束,请您尽快完成支付
+
+
+
+
+ 等待附近司机接单中...
+
+ {{orderDetail.vehicleNo}}
+ 已接单
+ 正在赶来的路上
+ 到达上车点
+ 正在为您服务
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/pages/pay.vue b/src/pages/pay.vue
new file mode 100644
index 0000000..33ee953
--- /dev/null
+++ b/src/pages/pay.vue
@@ -0,0 +1,17 @@
+
+
+
+
\ No newline at end of file
diff --git a/src/plugins/Base64Markers.js b/src/plugins/Base64Markers.js
new file mode 100644
index 0000000..c0fa4c7
--- /dev/null
+++ b/src/plugins/Base64Markers.js
@@ -0,0 +1,9 @@
+/*
+ * @Author: ch cwl_ch@163.com
+ * @Date: 2022-12-12 15:13:46
+ * @LastEditors: ch
+ * @LastEditTime: 2022-12-12 15:14:01
+ * @Description: file content
+ */
+
+export const MarkerIcon = ""
\ No newline at end of file
diff --git a/src/plugins/msbUniRequest.js b/src/plugins/msbUniRequest.js
new file mode 100644
index 0000000..4070b80
--- /dev/null
+++ b/src/plugins/msbUniRequest.js
@@ -0,0 +1,123 @@
+/*
+ * @Author: ch
+ * @Date: 2022-03-17 16:36:59
+ * @LastEditors: ch
+ * @LastEditTime: 2023-01-03 11:23:23
+ * @Description: 针对uniapp request请求做了一次封装,使用思维参考axios
+ *
+ *
+ * 方法
+ * method(option) 自定义请求,同uni.request
+ * get(url, params, header) url 请求地址 params 请求参数
+ * header 请求头会针对当前请求头设置特定的请求头。传了此参数request拦截器会失效
+ * post(url, data, header) 同上
+ * put(url, data, header) 同上
+ * delete(url, data, header) 同上
+ * use(hookName, callback) 注入hook拦截器 hookName 拦截器名(request/response/error) callback拦截器具体见拦截器说明
+ *
+ * 属性
+ * baseUrl 请求地址前缀
+ *
+ * 拦截器
+ * request 请求前拦截,在这可统一设置请求头,请求体等参数。uni.request的第一个参数option都可以重置
+ * success 请求成功结果拦截
+ * error 请求错误拦截
+ *
+ * 示例
+ * const myReq = new MsbUniRequest();
+ * myReq.baseUrl = 'xxxx'
+ * myReq.use('request', (option)=>{
+ * // option 返回请求配置
+ * .....这里可以对option做一系列操作
+ * return option //最后返回一个正确的请求配置
+ * })
+ * myReq.use('success', (res)=>{
+ * //res 返回请求结果
+ * let newRes = ..... //这里可以对请求结果做统一处理
+ * return newRes
+ * })
+ *
+ * myReq.use('error', (error)=>{
+ * //error 返回错误结果
+ * let newError = ..... //这里可以对请求错误做统一处理
+ * return newError
+ * })
+ */
+class MsbUniRequest {
+ constructor (option){
+ this.baseUrl = '';
+ this.header = {
+ repeat : true
+ }
+ this.hook = {
+ request : null,
+ success : null,
+ error : null
+ }
+
+ }
+ method(option){
+ option.header = {...this.header,...option.header};
+ option.url = this.baseUrl ? this.baseUrl + option.url : option.url;
+ if(this.hook.request){
+ option = this.hook.request(option);
+ };
+
+ if(!option){
+ throw new Error('没有请求配置,或是request拦截未做return');
+ }
+ if(option.constructor === Promise){
+ return option
+ }
+ return new Promise((resolve, reject)=>{
+ uni.request({
+ ...option,
+ success: res => {
+ const response = res || res[1];
+ // 200 - 399状态为正常
+ if(response.statusCode >= 200 && response.statusCode < 400){
+ if(!this.hook.success){
+ resolve(response);
+ }else{
+ let newRes = this.hook.success(response, option);
+ // 业务结果处理可能为一个Promise对象,根据结果调用错误或正确状态
+ if(newRes && newRes.constructor === Promise){
+ newRes.then(res => {
+ resolve(res);
+ }, error =>{
+ reject(error);
+ })
+ }else{
+ resolve(newRes);
+ }
+ }
+ return false;
+ }
+ reject(this.hook.error ? this.hook.error(response, option) : response);
+
+ },
+ fail: error =>{
+ reject(this.hook.error ? this.hook.error(error, option) : error);
+
+ }
+ });
+ });
+ }
+ use(hookName, cb){
+ this.hook[hookName] = cb;
+ }
+ get(url, data, header){
+ return this.method({method : 'GET', url, data, header});
+ }
+ post(url, data, header){
+ return this.method({method : 'POST', url, data, header});
+ }
+ put(url, data, header){
+ return this.method({method : 'PUT', url, data, header});
+ }
+ delete(url, data, header){
+ return this.method({method : 'DELETE', url, data, header});
+ }
+}
+
+export default MsbUniRequest;
\ No newline at end of file
diff --git a/src/plugins/requset.js b/src/plugins/requset.js
new file mode 100644
index 0000000..3cd887e
--- /dev/null
+++ b/src/plugins/requset.js
@@ -0,0 +1,125 @@
+/*
+ * @Author: ch
+ * @Date: 2022-03-17 17:42:32
+ * @LastEditors: ch
+ * @LastEditTime: 2022-12-30 15:44:40
+ * @Description: 项目接口请求统一处理器,返回一个需要token和不需要token的请求封装方法
+ */
+
+import MsbUniRequest from './msbUniRequest';
+import $store from '@/store';
+import { _ToAsyncAwait } from '@gykeji/jsutil';
+// const ENV = process.env;
+
+/**
+ * 接口返回成功结果统一处理
+ * @param {*} response
+ * @param {*} option
+ */
+const successIntercept = (response, option) =>{
+ clearRepeat(option);
+ if(response.statusCode === 200){
+ const result = response.data;
+ if(result.code === 1){
+ return result.data;
+ }
+ if(result.code === 0){
+ uni.navigateTo({url : '/login'});
+ $store.commit('setToken', '');
+ return result;
+ }
+ return Promise.reject(result);
+ }
+ return response;
+}
+/**
+ * 接口返回错误结果统一处理
+ * @param {*} error
+ * @param {*} option
+ */
+const errorIntercept = (error, option) =>{
+ clearRepeat(option);
+ if(error.statusCode === 404){
+ error.errMsg = '404 请求地址未找到';
+ }
+ return {message:error.errMsg,code:error.statusCode}
+}
+
+//正在执行的请求标识
+let repeatFlag = [];
+/**
+ * 验证是否重复请求,没有则添加一条到标记
+ * @param {*} option
+ */
+const repeatVerify = (option)=>{
+ let flag = {
+ url : option.url,
+ method : option.method,
+ data : option.data
+ }
+ if(repeatFlag.includes(JSON.stringify(flag))){
+ return Promise.reject({message:'请勿频繁操作'});
+ }
+ repeatFlag.push(JSON.stringify(flag));
+ return false;
+};
+/**
+ * 清除请求标记
+ * @param {*} option
+ */
+const clearRepeat = (option) =>{
+ repeatFlag = repeatFlag.filter( i => {
+ return i !== JSON.stringify({
+ url : option.url,
+ method : option.method,
+ data : option.data
+ })
+ });
+}
+
+
+
+// 接口封装
+const Request = new MsbUniRequest();
+
+Request.baseUrl = $store.state.serverConf.other;
+
+
+Request.use('request', (option) => {
+ const token = $store.state.token;
+ if(!token && !option.header.notVerifyToken){
+ // 登录状态处理,没有token直接跳转至登录
+ uni.redirectTo({
+ url: '/pages/login'
+ });
+ return Promise.reject({message:'要先登录才能操作哦~'});
+ }
+ if(!option.header.notVerifyToken){
+ option.header = {...option.header, Authorization:token};
+ }
+
+
+ if(option.header.repeat){
+ // 如果当前请求不允许重复调用,则检查重复请求,当前接口有正在请求则不发起请求
+ const isRepeatVerify = repeatVerify(option);
+ if(isRepeatVerify){
+ return isRepeatVerify;
+ }
+ }
+ delete option.header.repeat
+ delete option.header.notVerifyToken
+ return option;
+})
+Request.use('success', successIntercept);
+Request.use('error', errorIntercept);
+
+const MsbRequest = {
+ get : (...args) => _ToAsyncAwait(Request.get(...args)),
+ post: (...args) => _ToAsyncAwait(Request.post(...args)),
+ put: (...args) => _ToAsyncAwait(Request.put(...args)),
+ delete: (...args) => _ToAsyncAwait(Request.delete(...args)),
+}
+export {
+ MsbRequest
+}
+
diff --git a/src/static/logo.png b/src/static/logo.png
new file mode 100644
index 0000000..a32d63d
Binary files /dev/null and b/src/static/logo.png differ
diff --git a/src/static/sseMessage.html b/src/static/sseMessage.html
new file mode 100644
index 0000000..ae86e3a
--- /dev/null
+++ b/src/static/sseMessage.html
@@ -0,0 +1,67 @@
+
+
+
+
+
+
+
+ -
+
+
+
+
diff --git a/src/static/uniwebview.js b/src/static/uniwebview.js
new file mode 100644
index 0000000..c4bfbca
--- /dev/null
+++ b/src/static/uniwebview.js
@@ -0,0 +1,8 @@
+/*
+ * @Author: ch cwl_ch@163.com
+ * @Date: 2022-12-19 17:44:42
+ * @LastEditors: ch
+ * @LastEditTime: 2022-12-19 17:47:42
+ * @Description: file content
+ */
+!function(e,n){"object"==typeof exports&&"undefined"!=typeof module?module.exports=n():"function"==typeof define&&define.amd?define(n):(e=e||self).uni=n()}(this,(function(){"use strict";try{var e={};Object.defineProperty(e,"passive",{get:function(){!0}}),window.addEventListener("test-passive",null,e)}catch(e){}var n=Object.prototype.hasOwnProperty;function i(e,i){return n.call(e,i)}var t=[];function r(){return window.__dcloud_weex_postMessage||window.__dcloud_weex_}var o=function(e,n){var i={options:{timestamp:+new Date},name:e,arg:n};if(r()){if("postMessage"===e){var o={data:[n]};return window.__dcloud_weex_postMessage?window.__dcloud_weex_postMessage(o):window.__dcloud_weex_.postMessage(JSON.stringify(o))}var a={type:"WEB_INVOKE_APPSERVICE",args:{data:i,webviewIds:t}};window.__dcloud_weex_postMessage?window.__dcloud_weex_postMessageToService(a):window.__dcloud_weex_.postMessageToService(JSON.stringify(a))}if(!window.plus)return window.parent.postMessage({type:"WEB_INVOKE_APPSERVICE",data:i,pageId:""},"*");if(0===t.length){var d=plus.webview.currentWebview();if(!d)throw new Error("plus.webview.currentWebview() is undefined");var s=d.parent(),w="";w=s?s.id:d.id,t.push(w)}if(plus.webview.getWebviewById("__uniapp__service"))plus.webview.postMessageToUniNView({type:"WEB_INVOKE_APPSERVICE",args:{data:i,webviewIds:t}},"__uniapp__service");else{var u=JSON.stringify(i);plus.webview.getLaunchWebview().evalJS('UniPlusBridge.subscribeHandler("'.concat("WEB_INVOKE_APPSERVICE",'",').concat(u,",").concat(JSON.stringify(t),");"))}},a={navigateTo:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},n=e.url;o("navigateTo",{url:encodeURI(n)})},navigateBack:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},n=e.delta;o("navigateBack",{delta:parseInt(n)||1})},switchTab:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},n=e.url;o("switchTab",{url:encodeURI(n)})},reLaunch:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},n=e.url;o("reLaunch",{url:encodeURI(n)})},redirectTo:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},n=e.url;o("redirectTo",{url:encodeURI(n)})},getEnv:function(e){r()?e({nvue:!0}):window.plus?e({plus:!0}):e({h5:!0})},postMessage:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};o("postMessage",e.data||{})}},d=/uni-app/i.test(navigator.userAgent),s=/Html5Plus/i.test(navigator.userAgent),w=/complete|loaded|interactive/;var u=window.my&&navigator.userAgent.indexOf(["t","n","e","i","l","C","y","a","p","i","l","A"].reverse().join(""))>-1;var g=window.swan&&window.swan.webView&&/swan/i.test(navigator.userAgent);var v=window.qq&&window.qq.miniProgram&&/QQ/i.test(navigator.userAgent)&&/miniProgram/i.test(navigator.userAgent);var c=window.tt&&window.tt.miniProgram&&/toutiaomicroapp/i.test(navigator.userAgent);var m=window.wx&&window.wx.miniProgram&&/micromessenger/i.test(navigator.userAgent)&&/miniProgram/i.test(navigator.userAgent);var p=window.qa&&/quickapp/i.test(navigator.userAgent);var f=window.ks&&window.ks.miniProgram&&/micromessenger/i.test(navigator.userAgent)&&/miniProgram/i.test(navigator.userAgent);var l=window.tt&&window.tt.miniProgram&&/Lark|Feishu/i.test(navigator.userAgent);var _=window.jd&&window.jd.miniProgram&&/micromessenger/i.test(navigator.userAgent)&&/miniProgram/i.test(navigator.userAgent);var E=window.xhs&&window.xhs.miniProgram&&/xhsminiapp/i.test(navigator.userAgent);for(var h,P=function(){window.UniAppJSBridge=!0,document.dispatchEvent(new CustomEvent("UniAppJSBridgeReady",{bubbles:!0,cancelable:!0}))},b=[function(e){if(d||s)return window.__dcloud_weex_postMessage||window.__dcloud_weex_?document.addEventListener("DOMContentLoaded",e):window.plus&&w.test(document.readyState)?setTimeout(e,0):document.addEventListener("plusready",e),a},function(e){if(m)return window.WeixinJSBridge&&window.WeixinJSBridge.invoke?setTimeout(e,0):document.addEventListener("WeixinJSBridgeReady",e),window.wx.miniProgram},function(e){if(v)return window.QQJSBridge&&window.QQJSBridge.invoke?setTimeout(e,0):document.addEventListener("QQJSBridgeReady",e),window.qq.miniProgram},function(e){if(u){document.addEventListener("DOMContentLoaded",e);var n=window.my;return{navigateTo:n.navigateTo,navigateBack:n.navigateBack,switchTab:n.switchTab,reLaunch:n.reLaunch,redirectTo:n.redirectTo,postMessage:n.postMessage,getEnv:n.getEnv}}},function(e){if(g)return document.addEventListener("DOMContentLoaded",e),window.swan.webView},function(e){if(c)return document.addEventListener("DOMContentLoaded",e),window.tt.miniProgram},function(e){if(p){window.QaJSBridge&&window.QaJSBridge.invoke?setTimeout(e,0):document.addEventListener("QaJSBridgeReady",e);var n=window.qa;return{navigateTo:n.navigateTo,navigateBack:n.navigateBack,switchTab:n.switchTab,reLaunch:n.reLaunch,redirectTo:n.redirectTo,postMessage:n.postMessage,getEnv:n.getEnv}}},function(e){if(f)return window.WeixinJSBridge&&window.WeixinJSBridge.invoke?setTimeout(e,0):document.addEventListener("WeixinJSBridgeReady",e),window.ks.miniProgram},function(e){if(l)return document.addEventListener("DOMContentLoaded",e),window.tt.miniProgram},function(e){if(_)return window.JDJSBridgeReady&&window.JDJSBridgeReady.invoke?setTimeout(e,0):document.addEventListener("JDJSBridgeReady",e),window.jd.miniProgram},function(e){if(E)return window.xhs.miniProgram},function(e){return document.addEventListener("DOMContentLoaded",e),a}],y=0;y{
+ let result = false;
+ if (error) {
+ const tip = name ? `${name}错误:` : '';
+ ShowToast(error.message ? `${tip}${error.message}` : `请求失败: ${error}`);
+ result = true;
+ }
+ return result;
+}
+const ShowToast = (str) =>{
+ uni.showToast({title:str,duration:3000, icon:'none'});
+}
+export {
+ HandleApiError,
+ ShowToast
+}
\ No newline at end of file
diff --git a/vite.config.js b/vite.config.js
new file mode 100644
index 0000000..0f2178a
--- /dev/null
+++ b/vite.config.js
@@ -0,0 +1,38 @@
+/*
+ * @Author: ch cwl_ch@163.com
+ * @Date: 2022-11-21 17:23:51
+ * @LastEditors: ch
+ * @LastEditTime: 2022-12-30 16:32:05
+ * @Description: file content
+ */
+import { defineConfig } from 'vite'
+import uni from '@dcloudio/vite-plugin-uni'
+import fs from 'fs';
+import path from 'path';
+// https://vitejs.dev/config/
+export default defineConfig({
+ plugins: [
+ uni(),
+ ],
+ server: {
+ // 浏览器本地开发代理配置
+ proxy: {
+ "/api": {
+ target: "http://192.168.40.193:8081",
+ changeOrigin: true,
+ rewrite: (path) => path.replace(/^\/api/, "/")
+ },
+ "/sseApi": {
+ target: "http://192.168.40.193:60001",
+ changeOrigin: true,
+ rewrite: (path) => path.replace(/^\/sseApi/, "/")
+ },
+
+ "/payApi": {
+ target: "http://192.168.40.193:9001",
+ changeOrigin: true,
+ rewrite: (path) => path.replace(/^\/payApi/, "/")
+ },
+ },
+ },
+})