天波h5前端应用
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.

296 lines
7.5KB

  1. <template>
  2. <div class="page">
  3. <div class="tip">
  4. <div class="icon">
  5. <i class="iconfont icon-tishi"></i>
  6. </div>
  7. <div class="info">
  8. <div class="titie">温馨提醒:</div>
  9. <div class="content">
  10. 首次佩戴,需完成以下2步,建立情绪模型。完成初始化建模后,将为您计算抑郁、压力、疲劳分值。
  11. </div>
  12. </div>
  13. </div>
  14. <div v-if="info">
  15. <div class="step">
  16. <div class="name">第一步</div>
  17. <div class="title">
  18. <div class="text">连续佩戴两小时</div>
  19. <div class="status success" v-if="info.progress === 1">
  20. <span class="icon"
  21. ><i class="iconfont icon-caozuochenggong"></i
  22. ></span>
  23. <span>已完成</span>
  24. </div>
  25. <div class="status" v-else>待完成</div>
  26. </div>
  27. <div class="schedule">
  28. <van-progress
  29. :percentage="info.progress"
  30. stroke-width="10px"
  31. color="#638ee4"
  32. :show-pivot="false"
  33. ></van-progress>
  34. </div>
  35. <div class="sub_title">
  36. 请连续佩戴不低于2小时,有助于为您输出更加精准的情绪分析指标。
  37. </div>
  38. </div>
  39. <div class="step">
  40. <div class="name">第二步</div>
  41. <div class="title">
  42. <div class="text">情绪初始化评估</div>
  43. <div class="status success" v-if="info.initScaleState === 1">
  44. <span class="icon"
  45. ><i class="iconfont icon-caozuochenggong"></i
  46. ></span>
  47. <span>已完成</span>
  48. </div>
  49. <div class="status" v-else>待完成</div>
  50. </div>
  51. <div class="sub_title">
  52. 完成一次“情绪初始化评估”,有助于建立您的个人情绪模型。
  53. </div>
  54. </div>
  55. <div class="button">
  56. <van-button
  57. round
  58. type="info"
  59. style="width: 100%; height: 100%"
  60. @click="toQuestion"
  61. v-if="info.initScaleState !== 1"
  62. >去完成</van-button
  63. >
  64. </div>
  65. </div>
  66. </div>
  67. </template>
  68. <script>
  69. import axios from 'axios'
  70. export default {
  71. name: 'PsychologicalModeling',
  72. data() {
  73. return {
  74. info: null,
  75. }
  76. },
  77. mounted() {
  78. //页面标题
  79. window.document.title = '情绪初始化建模'
  80. //页面传参
  81. let params = { ...this.$route.query }
  82. if (params.uid) {
  83. this.uid = params.uid;
  84. // 缓存从随后精灵传过来的token
  85. this.$store.commit('ssjlToken', params.token);
  86. //初始化
  87. this.init()
  88. } else {
  89. this.$toast('参数错误')
  90. }
  91. },
  92. methods: {
  93. async init() {
  94. let ssjlToken = this.$store.getters.ssjlToken;
  95. let re = await this.api('/api/Question/Progress', {
  96. method: 'GET',
  97. sslVerify: false,
  98. withCredentials: false,
  99. params: {
  100. uid: this.uid,
  101. },
  102. }, ssjlToken)
  103. if (re.success) {
  104. if (re.response && re.response.state === -1) {
  105. this.$toast('用户不存在或未绑定手表')
  106. } else if (re.response && re.response.state === 1) {
  107. // 2023.6.1 需求变更,建模完成直接跳到心理健康汇总页面
  108. this.$router.push(`/psychologicalMain?uid=${this.uid}`);
  109. } else {
  110. this.info = re.response
  111. }
  112. } else {
  113. this.$toast(re.msg)
  114. }
  115. },
  116. toQuestion() {
  117. this.$router.push(`/PsychologicalQuestionnaire?uid=${this.uid}`)
  118. },
  119. api(url, config, token) {
  120. let baseUrl = 'https://dbmq.rzliot.com/heart'
  121. setTimeout(() => {
  122. this.$toast.loading({
  123. message: '',
  124. forbidClick: true,
  125. duration: 0,
  126. })
  127. }, 100)
  128. return new Promise((res) => {
  129. axios({
  130. url: `${baseUrl}${url}`,
  131. ...config,
  132. // 增加请求头部 token
  133. headers: {
  134. 'AuthToken': token
  135. }
  136. })
  137. .then((re) => {
  138. if (re) {
  139. if (re.data) {
  140. console.log(re.data)
  141. res(re.data)
  142. this.$toast.clear()
  143. return
  144. }
  145. this.$toast(`信息获取失败-${re.status}`)
  146. res(true)
  147. this.$toast.clear()
  148. return
  149. }
  150. this.$toast(`信息获取失败-${url}`)
  151. res(true)
  152. this.$toast.clear()
  153. })
  154. .catch((e) => {
  155. this.$toast(`信息获取失败-${url}`)
  156. res(true)
  157. this.$toast.clear()
  158. console.log(e)
  159. })
  160. })
  161. },
  162. },
  163. }
  164. </script>
  165. <style lang="scss" scoped>
  166. @font-face {
  167. font-family: 'iconfont'; /* Project id 2652084 */
  168. src: url('data:application/x-font-woff2;charset=utf-8;base64,d09GMgABAAAAAAQoAAsAAAAACFQAAAPaAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHFQGYACDBgqEIIQDATYCJAMMCwgABCAFhGcHQRtqBxEVnBvJPhLjmMRz8aCJJho3wfN8ne+5817QmS/XTApqUAGT1kmpHaidloBWXGdzOaZE+Aj1S75l+ek70v5OL82zLE6hFEIiJEbx96dyFkjAnwUAJnXNTcUP1HiBAtaxhhUr2KsXyLuo1/rCrIx6BgFM6tACo12HbjZpk4bPmkIRGksqkFbKpPFjhxOWRnRLpRBGCEKXamQTATDWGo+AjeHn5RdRCYNBQGHt0mtM+1Hc+Zr+1VZ+0gf1Gl+CgIcbQABQQI2NmWVIu7MfKk7WQGHWKTUpDKIRjEkjySSEglIHt/zHM0CCWMoUTFVRGBclugwEvto8VnH9qyAIhIDrIApTOVMVOr2mNDQjKSPHeM4zz6ZrPrYDY3fjR7a4+xTrY15tvZVw5KkZtx/X+HznyRPHnvCeqZskVmTOjMmRnF1girdzz7F4ju3uiB/xc53CoFi1HdXMW9Vu1TonY+gTzqB98OucaHakkW3GjxWJhX9kQXymq/AjJ5sfbS5Hc9nm5+KfvW9ZiYfnRXbG8tzG6nK7+u265yW2Hv38lNG3PmqlJo7Hjv0enTXu0fJ0ouuAIf1WL94ysHiw9aA5vca2mth0ZPGOvtu99JioF7HtiBd95LA4E7Gj3qPSVmO6tC3erV1e54F9yvUsu3Bh2Z7l+lwiLGETNtvRp9ylmtsGlm7eieOF8GLvn+zifT/067/LLFd8TdeujrureHTFyFEf+hbPVft+SK96RrBXE7tqx8rt21XpUO2QwwZswmZvsZsOz8+pN3TsrzXZ143c71m5NwLL+4xyo30jdTbxttGdTvRcMG4rPzrU0SFdrfTjHqXWlOrxuHR1FdK1219m/7yFvU52Hh3x6th9I25U9b0QTS1XvFyq35thACTvqtuqZZiOq5kq9v9/w/jtj8cOTW/2P2xpAN5vbXsP+5NxDcwN4RfjFPjbqkFApFYhULpOcFsQQLEkk4cBmLYJfm81QBZvh6uzweUghMlOwSBEcVCEKYdpqhoEsIhCkDDNwaQ67VdbZPsIzBFdDKjEC4GQwRsM0rgKigw+mKa+ECCPHwTJ4A8mrqy2s6gkZs2oBC3oB9SGBudoJJR7QD92iqtiF+RY4wjkSVbM7HFAHmNGvPpCxIFj6mHHT8OuIwhMDRpJKpFQpqmre0liqJ+sYRCFgFgAzQOgxkAMOB8t+e87gHhGOhQMxC52JlKeyAdyEjIAtlcOoLYb6R254ikQBEdHORiiB9gpO9LZSQII9YMaEIOQUA2IB0pSgnJQZbK8un+5XYCJtaUSQ5Ro0kcqeo5kKhy8J7dhKXWs6skEAAA=');
  169. }
  170. .iconfont {
  171. font-family: 'iconfont' !important;
  172. // font-size: 16px;
  173. font-style: normal;
  174. -webkit-font-smoothing: antialiased;
  175. -moz-osx-font-smoothing: grayscale;
  176. }
  177. .icon-caozuochenggong:before {
  178. content: '\e60f';
  179. }
  180. .icon-tishi:before {
  181. content: '\e654';
  182. }
  183. .page {
  184. width: 100%;
  185. min-height: 100%;
  186. box-sizing: border-box;
  187. font-size: 3.6vw;
  188. text-align: left;
  189. background: #f4f4f4;
  190. padding-bottom: 30vw;
  191. .tip {
  192. display: flex;
  193. font-size: 3.3vw;
  194. padding: 6vw 4vw;
  195. justify-content: space-between;
  196. align-items: center;
  197. background: white;
  198. .icon {
  199. overflow: hidden;
  200. display: flex;
  201. justify-content: center;
  202. align-items: center;
  203. width: 40px;
  204. height: 40px;
  205. color: #ff865a;
  206. font-size: 6vw;
  207. border-radius: 50%;
  208. background: #fff5f1;
  209. }
  210. .info {
  211. width: calc(100% - 50px);
  212. line-height: 20px;
  213. text-align: left;
  214. .titie {
  215. color: #ff865a;
  216. }
  217. .content {
  218. color: gray;
  219. }
  220. }
  221. }
  222. .step {
  223. margin-top: 3vw;
  224. padding: 4vw 8vw;
  225. padding-right: 4vw;
  226. background: white;
  227. .name {
  228. display: flex;
  229. align-items: center;
  230. font-size: 3.8vw;
  231. padding-bottom: 2vw;
  232. &::before {
  233. content: '';
  234. display: block;
  235. width: 1vw;
  236. height: 1vw;
  237. border: 2px solid #638ee4;
  238. border-radius: 50%;
  239. margin-left: calc(-2vw - 4px);
  240. margin-right: 1vw;
  241. }
  242. }
  243. .title {
  244. display: flex;
  245. justify-content: space-between;
  246. padding: 3vw 0;
  247. .status {
  248. color: #ff865a;
  249. }
  250. .success {
  251. color: #638ee4;
  252. .icon {
  253. font-size: 4vw;
  254. margin-right: 1vw;
  255. }
  256. }
  257. }
  258. .sub_title {
  259. padding: 3vw 0;
  260. color: gray;
  261. }
  262. }
  263. .button {
  264. position: fixed;
  265. left: 0;
  266. right: 0;
  267. bottom: 15vw;
  268. width: 75vw;
  269. height: 14vw;
  270. margin: auto;
  271. .van-button--info {
  272. background-color: #638ee4;
  273. border: 1px solid #638ee4;
  274. }
  275. }
  276. }
  277. </style>