index.vue 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  1. <template>
  2. <div class="download-wrap">
  3. <div class="content">
  4. <h1 class="title">下载</h1>
  5. <div class="hr"></div>
  6. <div class="list">
  7. <div class="item">
  8. <h2>安卓版(flutter)</h2>
  9. <p>
  10. 最新版本:<span
  11. class="link"
  12. @click="openToTarget(COMMON_URL.download.androidFlutter)"
  13. >v0.0.1</span
  14. >
  15. </p>
  16. <p>
  17. 历史版本:<span
  18. class="link"
  19. @click="openToTarget(COMMON_URL.release.flutter)"
  20. >查看</span
  21. >
  22. </p>
  23. </div>
  24. <div class="hr"></div>
  25. <div class="item">
  26. <h2>安卓版(react-native)</h2>
  27. <p>最新版本:<span>todo</span></p>
  28. <p>
  29. 历史版本:<span
  30. class="link"
  31. @click="openToTarget(COMMON_URL.release.reactNative)"
  32. >查看</span
  33. >
  34. </p>
  35. </div>
  36. <div class="hr"></div>
  37. <div class="item">
  38. <h2>安卓版(kotlin)</h2>
  39. <p>最新版本:<span>todo</span></p>
  40. <p>
  41. 历史版本:<span
  42. class="link"
  43. @click="openToTarget(COMMON_URL.release.kotlin)"
  44. >查看</span
  45. >
  46. </p>
  47. </div>
  48. <div class="hr"></div>
  49. <div class="item">
  50. <h2>苹果版(flutter)</h2>
  51. <p>最新版本:<span>todo</span></p>
  52. <p>
  53. 历史版本:<span
  54. class="link"
  55. @click="openToTarget(COMMON_URL.release.flutter)"
  56. >查看</span
  57. >
  58. </p>
  59. </div>
  60. <div class="hr"></div>
  61. <div class="item">
  62. <h2>苹果版(react-native)</h2>
  63. <p>最新版本:<span>todo</span></p>
  64. <p>
  65. 历史版本:<span
  66. class="link"
  67. @click="openToTarget(COMMON_URL.release.reactNative)"
  68. >查看</span
  69. >
  70. </p>
  71. </div>
  72. <div class="hr"></div>
  73. <div class="item">
  74. <h2>Windows版(electron)</h2>
  75. <p>最新版本:<span>todo</span></p>
  76. <p>
  77. 历史版本:<span
  78. class="link"
  79. @click="openToTarget(COMMON_URL.release.electron)"
  80. >查看</span
  81. >
  82. </p>
  83. </div>
  84. <div class="hr"></div>
  85. <div class="item">
  86. <h2>macOS版(electron)</h2>
  87. <p>最新版本:<span>todo</span></p>
  88. <p>
  89. 历史版本:<span
  90. class="link"
  91. @click="openToTarget(COMMON_URL.release.electron)"
  92. >查看</span
  93. >
  94. </p>
  95. </div>
  96. <div class="hr"></div>
  97. <div class="item">
  98. <h2>Linux版(electron)</h2>
  99. <p>最新版本:<span>todo</span></p>
  100. <p>
  101. 历史版本:<span
  102. class="link"
  103. @click="openToTarget(COMMON_URL.release.electron)"
  104. >查看</span
  105. >
  106. </p>
  107. </div>
  108. </div>
  109. </div>
  110. <div class="aside">
  111. <div class="title">本页目录</div>
  112. <div class="item">安卓版(flutter)</div>
  113. <div class="item">安卓版(react-native)</div>
  114. <div class="item">安卓版(kotlin)</div>
  115. <div class="item">苹果版(flutter)</div>
  116. <div class="item">苹果版(react-native)</div>
  117. <div class="item">Windows版(electron)</div>
  118. <div class="item">macOS版(electron)</div>
  119. <div class="item">Linux版(electron)</div>
  120. </div>
  121. </div>
  122. </template>
  123. <script lang="ts" setup>
  124. import { openToTarget } from 'billd-utils';
  125. import { onMounted, ref } from 'vue';
  126. import { fetchServerInfo } from '@/api/other';
  127. import { COMMON_URL } from '@/constant';
  128. import { IServerInfo } from '@/interface';
  129. const serverInfo = ref<IServerInfo>();
  130. const loading = ref(false);
  131. async function handleFetchServerInfo() {
  132. try {
  133. loading.value = true;
  134. const res = await fetchServerInfo();
  135. if (res.code === 200) {
  136. serverInfo.value = res.data;
  137. }
  138. } catch (error) {
  139. console.log(error);
  140. } finally {
  141. loading.value = false;
  142. }
  143. }
  144. onMounted(() => {
  145. handleFetchServerInfo();
  146. });
  147. </script>
  148. <style lang="scss" scoped>
  149. .download-wrap {
  150. display: flex;
  151. box-sizing: border-box;
  152. margin: 0 auto;
  153. padding-top: 50px;
  154. width: 960px;
  155. color: rgb(33, 53, 71);
  156. .link {
  157. cursor: pointer;
  158. color: $theme-color-gold;
  159. }
  160. .content {
  161. flex: 1;
  162. .title {
  163. margin: 0;
  164. font-weight: 500;
  165. font-size: 40px;
  166. margin-bottom: 20px;
  167. }
  168. .hr {
  169. margin: 60px 0 20px 0;
  170. width: 100%;
  171. height: 1px;
  172. background-color: #e7e7e7;
  173. }
  174. .list {
  175. h2 {
  176. font-weight: 600;
  177. }
  178. .item {
  179. position: relative;
  180. font-size: 16px;
  181. }
  182. }
  183. }
  184. .aside {
  185. padding-left: 90px;
  186. width: 150px;
  187. .title {
  188. color: rgb(33, 53, 71);
  189. font-weight: 700;
  190. font-size: 12px;
  191. margin-bottom: 8px;
  192. }
  193. .item {
  194. margin-bottom: 8px;
  195. color: rgba(60, 60, 60, 0.7);
  196. font-size: 13px;
  197. cursor: pointer;
  198. &:hover {
  199. color: #213547;
  200. }
  201. }
  202. }
  203. }
  204. </style>