rank.js 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. "use strict";
  2. const common_vendor = require("../../common/vendor.js");
  3. const utils_auth = require("../../utils/auth.js");
  4. const utils_api = require("../../utils/api.js");
  5. const _sfc_main = {
  6. __name: "rank",
  7. setup(__props) {
  8. const isLoggedIn = common_vendor.ref(false);
  9. const myStocks = common_vendor.ref([]);
  10. const loadMyStocks = async () => {
  11. if (!isLoggedIn.value) {
  12. myStocks.value = [];
  13. return;
  14. }
  15. try {
  16. const stocks = common_vendor.index.getStorageSync("my_stocks") || [];
  17. myStocks.value = stocks;
  18. console.log("[我的股票] 加载股票列表:", stocks.length, "只");
  19. if (stocks.length > 0) {
  20. await refreshAllQuotes();
  21. }
  22. } catch (e) {
  23. console.error("加载股票列表失败:", e);
  24. myStocks.value = [];
  25. }
  26. };
  27. const refreshAllQuotes = async () => {
  28. if (myStocks.value.length === 0) {
  29. return;
  30. }
  31. try {
  32. const codes = myStocks.value.map((stock) => stock.code).join(",");
  33. console.log("[我的股票] 批量刷新行情,股票代码:", codes);
  34. const quoteRes = await utils_api.getStockQuotes(codes);
  35. console.log("[我的股票] 批量行情数据:", quoteRes);
  36. if (quoteRes.code === 200 && quoteRes.data && quoteRes.data.length > 0) {
  37. quoteRes.data.forEach((quoteData) => {
  38. const index = myStocks.value.findIndex((stock) => stock.code === quoteData.stockCode);
  39. if (index !== -1) {
  40. myStocks.value[index].priceChange = quoteData.priceChange;
  41. myStocks.value[index].changePercent = quoteData.changePercent;
  42. myStocks.value[index].stockName = quoteData.stockName || myStocks.value[index].name;
  43. }
  44. });
  45. common_vendor.index.setStorageSync("my_stocks", myStocks.value);
  46. console.log("[我的股票] 行情刷新成功");
  47. }
  48. } catch (e) {
  49. console.error("[我的股票] 批量刷新行情失败:", e);
  50. }
  51. };
  52. const goToLogin = () => {
  53. common_vendor.index.navigateTo({
  54. url: "/pages/login/login"
  55. });
  56. };
  57. const removeStock = (index) => {
  58. common_vendor.index.showModal({
  59. title: "确认删除",
  60. content: `确定要删除 ${myStocks.value[index].name} 吗?`,
  61. confirmText: "删除",
  62. cancelText: "取消",
  63. success: (res) => {
  64. if (res.confirm) {
  65. myStocks.value.splice(index, 1);
  66. common_vendor.index.setStorageSync("my_stocks", myStocks.value);
  67. common_vendor.index.showToast({
  68. title: "删除成功",
  69. icon: "success"
  70. });
  71. }
  72. }
  73. });
  74. };
  75. const getChangeClass = (value) => {
  76. if (!value || value === "--")
  77. return "";
  78. if (value.startsWith("+") || value.match(/^[\d.]/) && !value.startsWith("-")) {
  79. return "change-up";
  80. }
  81. if (value.startsWith("-")) {
  82. return "change-down";
  83. }
  84. return "";
  85. };
  86. const formatDate = (timestamp) => {
  87. const date = new Date(timestamp);
  88. const year = date.getFullYear();
  89. const month = String(date.getMonth() + 1).padStart(2, "0");
  90. const day = String(date.getDate()).padStart(2, "0");
  91. const hours = String(date.getHours()).padStart(2, "0");
  92. const minutes = String(date.getMinutes()).padStart(2, "0");
  93. return `${year}-${month}-${day} ${hours}:${minutes}`;
  94. };
  95. common_vendor.onLoad(() => {
  96. isLoggedIn.value = utils_auth.isLoggedIn();
  97. console.log("[我的股票] 登录状态:", isLoggedIn.value);
  98. console.log("[我的股票] Token:", common_vendor.index.getStorageSync("user_token"));
  99. loadMyStocks();
  100. });
  101. common_vendor.onShow(() => {
  102. isLoggedIn.value = utils_auth.isLoggedIn();
  103. console.log("[我的股票] 登录状态:", isLoggedIn.value);
  104. console.log("[我的股票] Token:", common_vendor.index.getStorageSync("user_token"));
  105. loadMyStocks();
  106. common_vendor.index.setNavigationBarTitle({ title: "量化交易大师" });
  107. });
  108. return (_ctx, _cache) => {
  109. return common_vendor.e({
  110. a: myStocks.value.length > 0
  111. }, myStocks.value.length > 0 ? {
  112. b: common_vendor.f(myStocks.value, (stock, index, i0) => {
  113. return {
  114. a: common_vendor.t(stock.name),
  115. b: common_vendor.t(stock.code),
  116. c: common_vendor.o(($event) => removeStock(index), index),
  117. d: common_vendor.t(stock.priceChange || "--"),
  118. e: common_vendor.n(getChangeClass(stock.priceChange)),
  119. f: common_vendor.t(stock.changePercent || "--"),
  120. g: common_vendor.n(getChangeClass(stock.changePercent)),
  121. h: common_vendor.t(formatDate(stock.addTime)),
  122. i: index
  123. };
  124. })
  125. } : {}, {
  126. c: !isLoggedIn.value ? 1 : "",
  127. d: !isLoggedIn.value
  128. }, !isLoggedIn.value ? {
  129. e: common_vendor.o(goToLogin)
  130. } : {});
  131. };
  132. }
  133. };
  134. const MiniProgramPage = /* @__PURE__ */ common_vendor._export_sfc(_sfc_main, [["__file", "D:/program/gupiao-wx/src/pages/rank/rank.vue"]]);
  135. wx.createPage(MiniProgramPage);