index.vue 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. <script setup>
  2. import { ref, onMounted, computed } from 'vue';
  3. import axios from 'axios';
  4. import packageJson from '@/../../package.json';
  5. import { ElMessage } from 'element-plus';
  6. import client from "@/stores/modules/client";
  7. import icpList from '@/utils/ipc'
  8. import socket from "@/stores/modules/socket";
  9. import UpdateDialog from '@/components/UpdateDialog'
  10. const currentVersion = ref(packageJson.version);
  11. const latestVersion = ref('');
  12. const isLatest = ref(true);
  13. const versions = ref([]); // 所有版本数据
  14. // 分页相关
  15. const currentPage = ref(1);
  16. const pageSize = ref(20);
  17. const totalItems = ref(0);
  18. // 计算属性:获取当前页的数据
  19. const paginatedVersions = computed(() => {
  20. const start = (currentPage.value - 1) * pageSize.value;
  21. const end = start + pageSize.value;
  22. return (versions.value || []).slice(start, end).reverse();
  23. });
  24. // 获取版本信息
  25. const fetchVersions = async () => {
  26. try {
  27. // 添加时间戳避免缓存问题
  28. const timestamp = new Date().getTime();
  29. const response = await axios.get('https://ossimg.valimart.net/frontend/html/zhihuiyin/yi/version.json', {
  30. params: {
  31. _t: timestamp
  32. }
  33. });
  34. // 确保 response.data 是 JSON 数据
  35. let data;
  36. if (typeof response.data === 'string') {
  37. data = JSON.parse(response.data);
  38. } else {
  39. data = response.data;
  40. }
  41. versions.value = data;
  42. if (data.length > 0) {
  43. const latest = data[data.length - 1];
  44. latestVersion.value = latest.version;
  45. // 比较版本号
  46. isLatest.value = compareVersions(currentVersion.value, latest.version) >= 0;
  47. }
  48. // 初始化分页信息
  49. totalItems.value = versions.value.length;
  50. } catch (error) {
  51. console.error('获取版本信息失败:', error);
  52. ElMessage.error('无法获取版本信息');
  53. }
  54. };
  55. // 版本号比较函数
  56. const compareVersions = (v1, v2) => {
  57. const parts1 = v1.split('.').map(Number);
  58. const parts2 = v2.split('.').map(Number);
  59. for (let i = 0; i < Math.max(parts1.length, parts2.length); i++) {
  60. const num1 = parts1[i] || 0;
  61. const num2 = parts2[i] || 0;
  62. if (num1 > num2) return 1;
  63. if (num1 < num2) return -1;
  64. }
  65. return 0;
  66. };
  67. // 下载最新版本
  68. const downloadUpdate = () => {
  69. downloadSpecificVersion(versions.value[versions.value.length - 1].url)
  70. };
  71. const updateVisible = ref( false)
  72. const updateResult = ref({})
  73. const clientStore = client();
  74. const socketStore = socket()
  75. // 下载特定版本
  76. const downloadSpecificVersion = (url) => {
  77. clientStore.ipc.removeAllListeners('app.updater');
  78. clientStore.ipc.removeAllListeners(icpList.ota.updateVersion);
  79. clientStore.ipc.send(icpList.ota.updateVersion,url);
  80. clientStore.ipc.on(icpList.ota.updateVersion, async (event, result) => {
  81. console.log('==============================')
  82. console.log('checkUpdate')
  83. console.log(event)
  84. console.log(result)
  85. })
  86. clientStore.ipc.on('app.updater', async (event, result) => {
  87. try {
  88. let res = JSON.parse(result)
  89. if([1,3,4].includes(res.status)){
  90. updateResult.value = res
  91. updateVisible.value = true
  92. console.log(updateResult.value)
  93. console.log(updateVisible.value)
  94. }else{
  95. updateVisible.value = false
  96. ElMessage.error('下载失败')
  97. }
  98. }catch (e) {
  99. console.log(e)
  100. }
  101. })
  102. };
  103. // 处理分页变化
  104. const handlePageChange = (page) => {
  105. currentPage.value = page;
  106. };
  107. onMounted(() => {
  108. fetchVersions();
  109. });
  110. </script>
  111. <template>
  112. <el-container>
  113. <el-dialog
  114. v-model="updateVisible"
  115. :close-on-click-modal="false"
  116. title="软件下载中"
  117. >
  118. <div class="desc line-30 fs-16">{{updateResult.desc}}</div>
  119. </el-dialog>
  120. <el-main>
  121. <div class="version-check-container">
  122. <el-card class="current-version-card">
  123. <p>当前版本 <span class="fs-14">版本号: {{ currentVersion }}</span></p>
  124. <p>状态: <span :class="{ 'text-green': isLatest, 'text-red': !isLatest }">{{ isLatest ? '您已经是最新版本' : '发现新版本' }}</span></p>
  125. <p v-if="!isLatest">新版本: {{ latestVersion }}</p>
  126. <el-button v-if="!isLatest" type="primary" @click="downloadUpdate" v-log="{ describe: { action: '点击下载最新版本', latestVersion } }">下载更新</el-button>
  127. </el-card>
  128. <el-card class="history-versions-card mar-top-10">
  129. <h3>历史版本</h3>
  130. <!-- 使用计算属性获取分页数据 -->
  131. <el-table :data="paginatedVersions" border>
  132. <el-table-column prop="version" label="版本号" width="70"></el-table-column>
  133. <el-table-column prop="date" label="发布日期" width="100"></el-table-column>
  134. <el-table-column label="描述">
  135. <template #default="{ row }">
  136. <el-tooltip :content="row.describe" placement="top" :show-when="hover" :width="500">
  137. <span class="version-describe" v-html="row.describe"></span>
  138. </el-tooltip>
  139. </template>
  140. </el-table-column>
  141. <el-table-column label="操作" width="80">
  142. <template #default="{ row }">
  143. <el-button size="small" @click="downloadSpecificVersion(row.url)" v-log="{ describe: { action: '点击下载历史版本', version: row.version, url: row.url } }">下载</el-button>
  144. </template>
  145. </el-table-column>
  146. </el-table>
  147. <el-pagination
  148. layout="prev, pager, next"
  149. :total="totalItems"
  150. :page-size="pageSize"
  151. v-model:current-page="currentPage"
  152. @current-change="handlePageChange"
  153. style="margin-top: 15px;"
  154. />
  155. </el-card>
  156. </div>
  157. </el-main>
  158. </el-container>
  159. </template>
  160. <style scoped>
  161. .version-describe {
  162. display: inline-block;
  163. width: 100%; /* 根据需要调整 */
  164. white-space: nowrap;
  165. overflow: hidden;
  166. text-overflow: ellipsis;
  167. }
  168. </style>