evaluationIntroduction.js 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236
  1. // subpages/evaluationIntroduction/evaluationIntroduction.js
  2. Page({
  3. /**
  4. * 页面的初始数据
  5. */
  6. data: {
  7. type: "physique",//报告类型
  8. testMin: 3,
  9. testSize: 9,
  10. comScoreIndex: 6,
  11. testTitle: "睡眠质量指数评测",
  12. testDesc: "本测评系统依据山东睡眠质量指数量表(SDPSQI)开发。\nSDPSQI由山东省中医药大学医学中心精神科睡眠和生物节律研究中心睡眠专家组编制,专门用于评定被试者近一个月的主观睡眠质量。SDPSQI作为一种科学、系统的睡眠质量评估工具为了解个体睡眠状况、诊断睡眠障碍以及制定相应的干预措施提供了重要的工具和平台。",
  13. isHaveRes: false,//是否有测试过
  14. },
  15. /**
  16. * 生命周期函数--监听页面加载
  17. */
  18. onLoad(options) {
  19. console.log(options);
  20. if (options.type) {
  21. var type = options.type;
  22. var testTitle = "";
  23. var testDesc = "";
  24. var testMin = 3;
  25. var testSize = 9;
  26. if (type == "physique") {
  27. // 体质
  28. testSize = 9;
  29. testMin = 3;
  30. testTitle = "体质诊断检测";
  31. testDesc = "本测试表由山东省中医药大学中医专家组(具有中医针灸师、中医芳香疗法指导师、医院临床检验科资质的主任医师们)提出。中医学依据气、血、水的平衡状态,将人分为六种体质。要改善身体的“不调”,最重要的就是先了解自己的体质。有人也可能是不同体质混合的“复合型”,而且人的体质日常是变化的,因此应根据每天变化的身体状态进行相应调理的养生疗法。我们根据人体部位分了八个方面,请从下面选项里选出和自己相符的项,提交后,系统会进行判断,并显示您的体质、分析和建议。";
  32. this.checkPhysiqueData()
  33. } else if (type == "sleep") {
  34. // 睡眠质量
  35. testSize = 25;
  36. testMin = 8;
  37. testTitle = "睡眠质量指数评测";
  38. testDesc = "本测评系统依据山东睡眠质量指数量表(SDPSQI)开发。\nSDPSQI由山东省中医药大学医学中心精神科睡眠和生物节律研究中心睡眠专家组编制,专门用于评定被试者近一个月的主观睡眠质量。SDPSQI作为一种科学、系统的睡眠质量评估工具为了解个体睡眠状况、诊断睡眠障碍以及制定相应的干预措施提供了重要的工具和平台。";
  39. }
  40. this.setData({
  41. testMin,
  42. testSize,
  43. testTitle,
  44. testDesc,
  45. type
  46. })
  47. }
  48. },
  49. hasPrevPage() {
  50. // 获取页面栈
  51. let pages = getCurrentPages();
  52. // 页面栈数组中的页面实例数量大于1时,表示当前页之前有页面
  53. if (pages.length > 1) {
  54. return true;
  55. }
  56. return false;
  57. },
  58. toHome() {
  59. // 回家啦
  60. wx.removeStorageSync('testType')
  61. wx.reLaunch({
  62. url: '/pages/index/index'
  63. })
  64. },
  65. leftBack() {
  66. if (this.hasPrevPage()) {
  67. wx.navigateBack()
  68. console.log('当前页之前有上一页');
  69. } else {
  70. this.toHome()
  71. console.log('当前页之前没有上一页');
  72. }
  73. },
  74. toTest() {
  75. // 去测试
  76. wx.setStorageSync("testType", this.data.type);
  77. wx.navigateTo({
  78. url: '/subpages/textStep/textStep?type=' + this.data.type
  79. })
  80. },
  81. toResult() {
  82. // 结果页
  83. if (this.data.type == "physique") {
  84. // 体质
  85. wx.navigateTo({
  86. url: `/subpages/testResultB/testResultB?comScoreIndex=${this.data.comScoreIndex}`
  87. })
  88. } else if (this.data.type == "sleep") {
  89. // 睡眠质量
  90. wx.navigateTo({
  91. url: '/subpages/testResultA/testResultA'
  92. })
  93. }
  94. },
  95. checkPhysiqueData() {
  96. var that = this;
  97. var userId = wx.getStorageSync("unionid");
  98. wx.request({
  99. url: `https://fare.somnisix.top/system/constitutionDiagnosis/user/${userId}`,
  100. data: {
  101. "token": "eyJhbGciOiJIUzUxMiJ9.eyJ1c2VyX2lkIjoxLCJ1c2VyX2tleSI6Ijk5YzI3MjI2LTdkOWQtNDhiOC1hYjlhLWM4YjVjYWZiZGNkNyIsInVzZXJuYW1lIjoiYWRtaW4ifQ.zITQOINFkHs19_1RAgHS4I9YMaVxVq0Dsn3t6r_K7rv3rXvJy0sMtodejIMi_PNa_m4uQYxnU-6k3wC2LZht_Q"
  102. },
  103. header: {
  104. 'Authorization': 'Bearer ' + "eyJhbGciOiJIUzUxMiJ9.eyJ1c2VyX2lkIjoxLCJ1c2VyX2tleSI6Ijk5YzI3MjI2LTdkOWQtNDhiOC1hYjlhLWM4YjVjYWZiZGNkNyIsInVzZXJuYW1lIjoiYWRtaW4ifQ.zITQOINFkHs19_1RAgHS4I9YMaVxVq0Dsn3t6r_K7rv3rXvJy0sMtodejIMi_PNa_m4uQYxnU-6k3wC2LZht_Q" // 在头部设置Bearer Token
  105. },
  106. method: 'GET',
  107. success(res) {
  108. try {
  109. if (res && res.data && res.data.data) {
  110. if (res.data.data.value2) {
  111. var data = JSON.parse(res.data.data.value2);
  112. var maxValueObj = that.findMaxValueKeyAndIndex(data);
  113. that.setData({
  114. comScoreIndex: maxValueObj.index,
  115. isHaveRes: true
  116. })
  117. }
  118. }
  119. } catch (error) {
  120. console.error(error);
  121. }
  122. },
  123. })
  124. },
  125. // 体质的方法
  126. // 取出最大值的obj
  127. findMaxValueKeyAndIndex(obj) {
  128. if (typeof obj !== 'object' || obj === null || Array.isArray(obj)) {
  129. throw new Error('Input must be a plain object');
  130. }
  131. let maxKey = null;
  132. let maxValue = 0;
  133. let maxIndex = 6;
  134. const keys = Object.keys(obj);
  135. keys.forEach((key, index) => {
  136. const value = obj[key];
  137. if (value > maxValue) {
  138. maxValue = value;
  139. maxKey = key;
  140. maxIndex = index;
  141. }
  142. });
  143. return {
  144. key: maxKey,
  145. value: maxValue,
  146. index: maxIndex
  147. };
  148. },
  149. /**
  150. * A、B、C、D、E、F 最后积累的数量对比,按数量多少来判断,6个分别对应:气虚型、气滞型、血虚型、淤血型、水虚型、痰湿型
  151. * 找出对象中值最大的键
  152. * @param {Object} obj - 包含键值对的对象
  153. * @returns {string|null} - 值最大的键,如果没有找到则返回null
  154. */
  155. findKeyWithMaxValue(obj) {
  156. if (typeof obj !== 'object' || obj === null || Array.isArray(obj)) {
  157. throw new Error('Input must be a plain object');
  158. }
  159. let maxKey = null;
  160. let maxValue = 0;
  161. for (let key in obj) {
  162. if (obj.hasOwnProperty(key)) {
  163. if (obj[key] > maxValue) {
  164. maxValue = obj[key];
  165. maxKey = key;
  166. }
  167. }
  168. }
  169. return maxKey;
  170. },
  171. /**
  172. * 生命周期函数--监听页面初次渲染完成
  173. */
  174. onReady() {
  175. },
  176. /**
  177. * 生命周期函数--监听页面显示
  178. */
  179. onShow() {
  180. wx.removeStorageSync('testType');
  181. },
  182. /**
  183. * 生命周期函数--监听页面隐藏
  184. */
  185. onHide() {
  186. },
  187. /**
  188. * 生命周期函数--监听页面卸载
  189. */
  190. onUnload() {
  191. },
  192. /**
  193. * 页面相关事件处理函数--监听用户下拉动作
  194. */
  195. onPullDownRefresh() {
  196. },
  197. /**
  198. * 页面上拉触底事件的处理函数
  199. */
  200. onReachBottom() {
  201. },
  202. /**
  203. * 用户点击右上角分享
  204. */
  205. onShareAppMessage() {
  206. var that = this;
  207. return {
  208. title: that.data.testTitle,
  209. path: '/subpages/evaluationIntroduction/evaluationIntroduction?type=' + that.data.type,
  210. }
  211. }
  212. })