You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

transfer-page.vue 7.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236
  1. <template>
  2. </template>
  3. <script setup lang="ts">
  4. import { reactive } from "vue";
  5. import { onLoad } from "@dcloudio/uni-app";
  6. import {
  7. navTo
  8. } from "@/utils/utils"
  9. import {
  10. orderList,
  11. userInfoQuery,
  12. silentLoginApi,
  13. selectCarInfo
  14. } from "@/utils/network/api.js";
  15. import {
  16. getItem,
  17. StorageKeys,
  18. setItem
  19. } from "@/utils/storage";
  20. import {
  21. request
  22. } from "@/utils/network/request.js";
  23. import {
  24. stringToJson
  25. } from "@/utils/network/encryption";
  26. import { msg } from "@/utils/utils";
  27. import { vehiclePlateColorPai } from "@/datas/vehiclePlateColor.js";
  28. const state = reactive({
  29. type: "",
  30. name: "",
  31. vehicleId: "",
  32. customerId: "",
  33. vehiclePlate: "",
  34. vehiclePlateColor: "",
  35. id: "",
  36. orderId: "",
  37. deptShortName: "",
  38. userType: "",
  39. userIdNum: "",
  40. mobile: ""
  41. });
  42. //type:1用户信息变更,2车辆信息变更3,异常上报,4卡签注销,5挂失,6设备更换,7退货,8解挂 ,
  43. // 9有两个 1个是解除车牌占用 2个ETC设备更换车牌
  44. // 20 设备升级 21增补OBU设备 22卡续期 23欠费补缴 24余额补领 25公务车发行 26补卡额 27解锁卡 28激活 29通行流水 30黑名单查询
  45. // 31发票 32月结单查询
  46. onLoad((options) => {
  47. state.type = options.type
  48. state.name = options.name
  49. state.vehicleId = options.vehicleId
  50. state.deptShortName = options.deptShortName
  51. state.userType = options.userType
  52. state.userIdNum = options.userIdNum
  53. state.mobile = options.mobile
  54. console.log("options", options)
  55. silentLogin().then(() => {
  56. quanCheckActionTrue().then((item : any) => {
  57. console.log("item====", item, item.data.length)
  58. if (item.data.length == 1) {
  59. state.id = item.data[0]['id']
  60. state.orderId = item.data[0]['orderId']
  61. console.log(item)
  62. jump()
  63. } else {
  64. msg('暂无车辆')
  65. setTimeout(() => {
  66. uni.switchTab({
  67. url: "/pages/index/index"
  68. })
  69. }, 1500)
  70. }
  71. })
  72. })
  73. })
  74. const silentLogin = () => {
  75. if (state.userType == "1") {
  76. var data = {
  77. userType: state.userType,
  78. account: state.mobile,
  79. loginSource: getItem("loginSource"),
  80. };
  81. } else {
  82. var data = {
  83. userType: state.userType,
  84. account: state.userIdNum,
  85. loginSource: getItem("loginSource"),
  86. };
  87. }
  88. const options = {
  89. type: 2,
  90. data: data,
  91. method: "POST",
  92. showLoading: true,
  93. };
  94. return new Promise(async (resolve, reject) => {
  95. const res = await request(silentLoginApi, options);
  96. const data = stringToJson(res.bizContent);
  97. setItem("openId", data.openId);
  98. setItem("token", data.accessToken);
  99. resolve(data);
  100. }).catch((error) => {
  101. reject(error);
  102. });
  103. }
  104. const quanCheckActionTrue = () => {
  105. let source = ""
  106. // #ifdef MP-ALIPAY
  107. source = "ALI"
  108. // #endif
  109. // #ifdef MP-WEIXIN
  110. source = "WECHAT"
  111. // #endif
  112. var data = {
  113. opId: getItem(StorageKeys.OpenId),
  114. source: source,
  115. tabIndex: '0',
  116. orderStep: '11',
  117. isValueCard: '',
  118. orderStatus: "1",
  119. isAfter: true,
  120. vehiclePlate: state.vehicleId.split('_')[0],
  121. vehiclePlateColor: state.vehicleId.split('_')[1]
  122. };
  123. const options = {
  124. type: 2,
  125. data: data,
  126. method: "POST",
  127. showLoading: true,
  128. };
  129. return new Promise(async (resolve, reject) => {
  130. const res = await request(orderList, options);
  131. const data = stringToJson(res.bizContent);
  132. resolve(data);
  133. }).catch((error) => {
  134. reject(error);
  135. });
  136. }
  137. const jump = () => {
  138. if (state.type == '4') {
  139. navTo(`/subpackage/after-sale/ETC-log-off/log-off-confirm?id=${state.id}`)
  140. } else if (state.type == "6") {
  141. navTo(`/subpackage/after-sale/replace-equipment/replace-equipment-confirm?id=${state.id}`)
  142. } else if (state.type == "5" || state.type == "8") {
  143. navTo(`/subpackage/after-sale/card-loss-reporting/cardloss-confirm?id=${state.id}`)
  144. } else if (state.type == "9" && state.name == '解除车牌占用') {
  145. navTo('/subpackage/after-sale/rescind-carId/rescind-carId-select')
  146. } else if (state.type == "20") {
  147. queryCarMsg().then((item) => {
  148. console.log("item", item.vehicleManages)
  149. const params = encodeURIComponent(JSON.stringify(item.vehicleManages[0]))
  150. uni.navigateTo({
  151. url: `/subpackage/personal-center/car-details?params=${params}`
  152. })
  153. })
  154. } else if (state.type == "21") {
  155. navTo(`/subpackage/after-sale/additional-equipment/additional-equipment-confirm?id=${state.id}`)
  156. } else if (state.type == "22") {
  157. navTo(`/subpackage/after-sale/card-Renewal/renewal-confirm?id=${state.id}&orderId=${state.orderId}`)
  158. } else if (state.type == "23") {
  159. navTo(`/subpackage/after-sale/arrears/arrears`)
  160. } else if (state.type == "24") {
  161. navTo(`/subpackage/after-sale/refund-order-balance/refund-order-balance?vehicleId=${state.vehicleId}`)
  162. } else if (state.type == "25") {
  163. if (!state.deptShortName) {
  164. navTo("/subpackage/personal-center/query-company-list")
  165. } else {
  166. navTo("/subpackage/personal-center/query-company-list?deptShortName=" + state.deptShortName)
  167. }
  168. } else if (state.type == "26") {
  169. navTo(`/subpackage/orders/flowingWater?vehicleId=${state.vehicleId}`)
  170. } else if (state.type == "27") {
  171. navTo(`/subpackage/after-sale/pin-code-deblocking/pin-code-confirm?id=${state.id}`)
  172. } else if (state.type == "28") {
  173. navTo(`/subpackage/personal-center/install-activation-order`)
  174. } else if (state.type == "29") {
  175. navTo(`/subpackage/personal-center/search/select-card?vehicleId=${state.vehicleId}`)
  176. } else if (state.type == "30") {
  177. var vehiclePlate = state.vehicleId.split("_")[0]
  178. var vehiclePlateColor = state.vehicleId.split("_")[1]
  179. navTo(`/subpackage/after-sale/blacklist-query/list?vehiclePlate=${vehiclePlate}&vehiclePlateColor=${vehiclePlateColor}`)
  180. } else if (state.type == "31") {
  181. if (state.name == "服务发票") {
  182. navTo(`/subpackage/orders/invoiceApply/invoice-content?type=1`)
  183. } else {
  184. navTo(`/subpackage/orders/invoiceApply/invoice-content?type=2`)
  185. }
  186. } else if (state.type == "32") {
  187. navTo(`/subpackage/after-sale/month-statement/month-statement-query-list?vehicleId=${state.vehicleId}`)
  188. } else if (state.type == "33") {
  189. var vehiclePlate = state.vehicleId.split("_")[0]
  190. var vehiclePlateColor = state.vehicleId.split("_")[1]
  191. navTo(`/subpackage/after-sale/progress-query/progress-query-business?vehiclePlate=${vehiclePlate}&vehiclePlateColor=${vehiclePlateColor}`)
  192. }
  193. }
  194. // 查询车辆信息
  195. const queryCarMsg = () => {
  196. const options = {
  197. type: 2,
  198. data: {
  199. "openId": getItem('openId'),
  200. "vehicleId": state.vehicleId
  201. },
  202. method: "POST",
  203. showLoading: true,
  204. };
  205. return new Promise(async (resolve, reject) => {
  206. const res = await request(selectCarInfo, options);
  207. const data = stringToJson(res.bizContent);
  208. for (var i = 0; i < data.length; i++) {
  209. for (var j = 0; j < vehiclePlateColorPai.length; j++) {
  210. if (data[i].vehiclePlateColor == vehiclePlateColorPai[j]['id']) {
  211. data[i].color = vehiclePlateColorPai[j]['color']
  212. data[i].showColor = vehiclePlateColorPai[j]['showColor']
  213. }
  214. }
  215. }
  216. resolve(data);
  217. }).catch((error) => {
  218. reject(error);
  219. });
  220. }
  221. </script>
  222. <style scoped>
  223. </style>