Compare commits
	
		
			No commits in common. "b59215e5b05cafd29931b6467d78c8047969ef26" and "cfc22f0b1eae3245a59830abc960a15105a282cf" have entirely different histories.
		
	
	
		
			b59215e5b0
			...
			cfc22f0b1e
		
	
		
| @ -1210,9 +1210,6 @@ let defaultTableData = [ | |||||||
|         "volume": "561" |         "volume": "561" | ||||||
|     } |     } | ||||||
| ] | ] | ||||||
| defaultTableData.map(item => { | defaultTableData.map(item=>item.close='') | ||||||
|     item.close = '' |  | ||||||
|     item.adjClose = '' |  | ||||||
| }) |  | ||||||
| 
 | 
 | ||||||
| export default defaultTableData; | export default defaultTableData; | ||||||
|  | |||||||
| @ -1,13 +1,9 @@ | |||||||
| <template> | <template> | ||||||
|   <div class="historic-data-container" style="margin-bottom: 100px"> |   <div class="historic-data-container"> | ||||||
|     <img |     <img src="@/assets/image/historic-stock.png" alt="1" /> | ||||||
|       src="@/assets/image/historic-stock.png" |  | ||||||
|       alt="1" |  | ||||||
|       style="max-width: 100%; margin: 0 auto" |  | ||||||
|     /> |  | ||||||
| 
 | 
 | ||||||
|     <div class="header mt-[20px]"> |     <div class="header"> | ||||||
|       <div class="title">Historical Data</div> |       <h1 class="title">Historical Data</h1> | ||||||
|       <div class="filter-container"> |       <div class="filter-container"> | ||||||
|         <n-dropdown |         <n-dropdown | ||||||
|           trigger="click" |           trigger="click" | ||||||
| @ -36,58 +32,20 @@ | |||||||
| 
 | 
 | ||||||
|     <n-data-table |     <n-data-table | ||||||
|       :columns="columns" |       :columns="columns" | ||||||
|       :data="paginatedData" |       :data="state.tableData" | ||||||
|       :bordered="false" |       :bordered="false" | ||||||
|       :single-line="false" |       :single-line="false" | ||||||
|     /> |     /> | ||||||
| 
 |  | ||||||
|     <div class="pagination-container"> |  | ||||||
|       <n-button class="page-btn prev-btn" @click="handlePrevPage"> |  | ||||||
|         <n-icon><chevron-back-outline /></n-icon> Previous |  | ||||||
|       </n-button> |  | ||||||
| 
 |  | ||||||
|       <div class="page-info"> |  | ||||||
|         Page {{ state.currentPage }} of {{ totalPages }} |  | ||||||
|       </div> |  | ||||||
| 
 |  | ||||||
|       <div class="right-controls"> |  | ||||||
|         <n-dropdown |  | ||||||
|           trigger="click" |  | ||||||
|           :options="pageSizeOptions" |  | ||||||
|           @select="handlePageSizeChange" |  | ||||||
|         > |  | ||||||
|           <n-button class="rows-dropdown"> |  | ||||||
|             {{ state.pageSize }} Rows <n-icon><chevron-down-outline /></n-icon> |  | ||||||
|           </n-button> |  | ||||||
|         </n-dropdown> |  | ||||||
| 
 |  | ||||||
|         <n-button class="page-btn next-btn" @click="handleNextPage"> |  | ||||||
|           Next <n-icon><chevron-forward-outline /></n-icon> |  | ||||||
|         </n-button> |  | ||||||
|       </div> |  | ||||||
|     </div> |  | ||||||
| 
 |  | ||||||
|     <div class="back-to-top-link"> |  | ||||||
|       <a href="#" @click.prevent="scrollToTop" |  | ||||||
|         >Back to Top <n-icon><arrow-up-outline /></n-icon |  | ||||||
|       ></a> |  | ||||||
|     </div> |  | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import { NDataTable, NButton, NDropdown, NIcon } from "naive-ui"; | import { NDataTable, NButton, NDropdown, NIcon } from "naive-ui"; | ||||||
| import { reactive, onMounted, h, computed } from "vue"; | import { reactive, onMounted, h } from "vue"; | ||||||
| import axios from "axios"; | import axios from "axios"; | ||||||
| import { | import { ChevronDownOutline } from "@vicons/ionicons5"; | ||||||
|   ChevronDownOutline, |  | ||||||
|   ChevronBackOutline, |  | ||||||
|   ChevronForwardOutline, |  | ||||||
|   ArrowUpOutline, |  | ||||||
| } from "@vicons/ionicons5"; |  | ||||||
| import defaultTableData from "../data"; | import defaultTableData from "../data"; | ||||||
| console.log("defaultTableData", defaultTableData); | console.log("defaultTableData", defaultTableData); | ||||||
| 
 |  | ||||||
| // 数据筛选选项 | // 数据筛选选项 | ||||||
| const periodOptions = [ | const periodOptions = [ | ||||||
|   { label: "Daily", key: "Daily" }, |   { label: "Daily", key: "Daily" }, | ||||||
| @ -106,32 +64,10 @@ const durationOptions = [ | |||||||
|   { label: "10 Years", key: "10 Years" }, |   { label: "10 Years", key: "10 Years" }, | ||||||
| ]; | ]; | ||||||
| 
 | 
 | ||||||
| // 分页大小选项 |  | ||||||
| const pageSizeOptions = [ |  | ||||||
|   { label: "50", key: 50 }, |  | ||||||
|   { label: "100", key: 100 }, |  | ||||||
|   { label: "500", key: 500 }, |  | ||||||
|   { label: "1000", key: 1000 }, |  | ||||||
| ]; |  | ||||||
| 
 |  | ||||||
| const state = reactive({ | const state = reactive({ | ||||||
|   selectedPeriod: "Daily", |   selectedPeriod: "Daily", | ||||||
|   selectedDuration: "3 Months", |   selectedDuration: "3 Months", | ||||||
|   tableData: [], |   tableData: [], | ||||||
|   currentPage: 1, |  | ||||||
|   pageSize: 50, |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // 计算总页数 |  | ||||||
| const totalPages = computed(() => { |  | ||||||
|   return Math.ceil(state.tableData.length / state.pageSize); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // 计算当前页的数据 |  | ||||||
| const paginatedData = computed(() => { |  | ||||||
|   const start = (state.currentPage - 1) * state.pageSize; |  | ||||||
|   const end = start + state.pageSize; |  | ||||||
|   return state.tableData.slice(start, end); |  | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| // 表格列定义 | // 表格列定义 | ||||||
| @ -194,75 +130,24 @@ const handleDurationChange = (key) => { | |||||||
|   getPageData(); |   getPageData(); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // 处理分页 |  | ||||||
| const handlePrevPage = () => { |  | ||||||
|   if (state.currentPage === 1) { |  | ||||||
|     return; |  | ||||||
|   } |  | ||||||
|   state.currentPage--; |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| const handleNextPage = () => { |  | ||||||
|   if (state.currentPage >= totalPages.value) { |  | ||||||
|     return; |  | ||||||
|   } |  | ||||||
|   state.currentPage++; |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| const handlePageSizeChange = (size) => { |  | ||||||
|   state.pageSize = size; |  | ||||||
|   state.currentPage = 1; // 重置到第一页 |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| // 回到顶部 |  | ||||||
| const scrollToTop = () => { |  | ||||||
|   window.scrollTo({ |  | ||||||
|     top: 0, |  | ||||||
|     behavior: "smooth", |  | ||||||
|   }); |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   getPageDefaultData(); |   getPageDefaultData(); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| const getPageDefaultData = async () => { | const getPageDefaultData = async () => { | ||||||
|   try { |   try { | ||||||
|  |     // 实际项目中应该根据state.selectedPeriod和state.selectedDuration动态调整API请求 | ||||||
|     let url = |     let url = | ||||||
|       "https://stockanalysis.com/api/symbol/a/OTC-MINM/history?type=chart"; |       "https://stockanalysis.com/api/symbol/a/OTC-MINM/history?type=chart"; | ||||||
|     const res = await axios.get(url); |     const res = await axios.get(url); | ||||||
|     let originalData = res.data.data; |     let originalData = res.data.data; | ||||||
| 
 |     // 转换为日期格式 | ||||||
|     // 转换为日期格式:"Nov 26, 2024" |  | ||||||
|     let calcApiData = originalData.map((item) => [ |     let calcApiData = originalData.map((item) => [ | ||||||
|       new Date(item[0]).toLocaleDateString("en-US", { |       new Date(item[0]).toISOString().split("T")[0], // 转换时间戳为YYYY-MM-DD格式 | ||||||
|         month: "short", |  | ||||||
|         day: "numeric", |  | ||||||
|         year: "numeric", |  | ||||||
|       }), |  | ||||||
|       item[1], |       item[1], | ||||||
|     ]); |     ]); | ||||||
|     console.log("接口数据", calcApiData); |     console.log("接口数据", calcApiData); | ||||||
| 
 |     state.tableData = defaultTableData; | ||||||
|     // 使用API数据更新defaultTableData中的close和adjClose值 |  | ||||||
|     const updatedTableData = defaultTableData.map((tableItem) => { |  | ||||||
|       // 查找对应日期的API数据 |  | ||||||
|       const matchedApiData = calcApiData.find( |  | ||||||
|         (apiItem) => apiItem[0] === tableItem.date |  | ||||||
|       ); |  | ||||||
| 
 |  | ||||||
|       if (matchedApiData) { |  | ||||||
|         // 更新close和adjClose值 |  | ||||||
|         return { |  | ||||||
|           ...tableItem, |  | ||||||
|           close: matchedApiData[1].toFixed(2), |  | ||||||
|           adjClose: matchedApiData[1].toFixed(2), |  | ||||||
|         }; |  | ||||||
|       } |  | ||||||
|       return tableItem; |  | ||||||
|     }); |  | ||||||
| 
 |  | ||||||
|     state.tableData = updatedTableData; |  | ||||||
|   } catch (error) { |   } catch (error) { | ||||||
|     console.error("获取数据失败", error); |     console.error("获取数据失败", error); | ||||||
|   } |   } | ||||||
| @ -277,8 +162,7 @@ const getPageData = async () => { | |||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
| .historic-data-container { | .historic-data-container { | ||||||
|   padding: 20px; |   padding: 20px; | ||||||
|   max-width: 1200px; |   width: 100%; | ||||||
|   margin: 0 auto; |  | ||||||
| 
 | 
 | ||||||
|   .header { |   .header { | ||||||
|     display: flex; |     display: flex; | ||||||
| @ -287,7 +171,7 @@ const getPageData = async () => { | |||||||
|     margin-bottom: 20px; |     margin-bottom: 20px; | ||||||
| 
 | 
 | ||||||
|     .title { |     .title { | ||||||
|       font-size: 40px; |       font-size: 24px; | ||||||
|       font-weight: bold; |       font-weight: bold; | ||||||
|       margin: 0; |       margin: 0; | ||||||
|     } |     } | ||||||
| @ -298,72 +182,6 @@ const getPageData = async () => { | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   .pagination-container { |  | ||||||
|     display: flex; |  | ||||||
|     justify-content: space-between; |  | ||||||
|     align-items: center; |  | ||||||
|     margin-top: 20px; |  | ||||||
|     padding: 10px 16px; |  | ||||||
|     border-radius: 4px; |  | ||||||
|     background-color: #ffffff; |  | ||||||
| 
 |  | ||||||
|     .page-btn { |  | ||||||
|       display: flex; |  | ||||||
|       align-items: center; |  | ||||||
|       gap: 5px; |  | ||||||
|       padding: 6px 12px; |  | ||||||
|       font-size: 20px; |  | ||||||
| 
 |  | ||||||
|       &.prev-btn { |  | ||||||
|         margin-right: auto; |  | ||||||
|       } |  | ||||||
| 
 |  | ||||||
|       &.next-btn { |  | ||||||
|         margin-left: 10px; |  | ||||||
|       } |  | ||||||
| 
 |  | ||||||
|       &:disabled { |  | ||||||
|         opacity: 0.5; |  | ||||||
|         cursor: not-allowed; |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     .page-info { |  | ||||||
|       font-size: 16px; |  | ||||||
|       color: #374151; |  | ||||||
|       margin: 0 10px; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     .right-controls { |  | ||||||
|       display: flex; |  | ||||||
|       align-items: center; |  | ||||||
| 
 |  | ||||||
|       .rows-dropdown { |  | ||||||
|         font-size: 16px; |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   .back-to-top-link { |  | ||||||
|     display: flex; |  | ||||||
|     justify-content: center; |  | ||||||
|     margin-top: 16px; |  | ||||||
| 
 |  | ||||||
|     a { |  | ||||||
|       display: flex; |  | ||||||
|       align-items: center; |  | ||||||
|       gap: 5px; |  | ||||||
|       color: #2563eb; |  | ||||||
|       font-size: 20px; |  | ||||||
|       font-weight: bold; |  | ||||||
|       text-decoration: none; |  | ||||||
| 
 |  | ||||||
|       &:hover { |  | ||||||
|         text-decoration: underline; |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   :deep(.n-data-table) { |   :deep(.n-data-table) { | ||||||
|     .n-data-table-td { |     .n-data-table-td { | ||||||
|       padding: 12px 8px; |       padding: 12px 8px; | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user