Compare commits
	
		
			No commits in common. "7561f0d22e07cb642c25b1a4090f04571a4457be" and "c445366624393a438d2b7cfa104701cd7fbfe946" have entirely different histories.
		
	
	
		
			7561f0d22e
			...
			c445366624
		
	
		
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 176 KiB | 
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 184 KiB | 
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 210 KiB | 
| @ -33,13 +33,11 @@ | |||||||
|       <div class="table-container"> |       <div class="table-container"> | ||||||
|         <n-data-table |         <n-data-table | ||||||
|           :columns="columns" |           :columns="columns" | ||||||
|           :loading="state.tableLoading" |           :data="paginatedData" | ||||||
|           :data="state.tableData" |  | ||||||
|           :pagination="false" |           :pagination="false" | ||||||
|           :bordered="false" |           :bordered="false" | ||||||
|           :size="'medium'" |           :size="'medium'" | ||||||
|           :row-key="(row) => row.idx" |           :row-key="(row) => row.idx" | ||||||
|           @update:sorter="handleSort" |  | ||||||
|         /> |         /> | ||||||
| 
 | 
 | ||||||
|         <!-- 分页器 --> |         <!-- 分页器 --> | ||||||
| @ -49,7 +47,7 @@ | |||||||
|             v-model:page-size="state.pageSize" |             v-model:page-size="state.pageSize" | ||||||
|             show-size-picker |             show-size-picker | ||||||
|             show-quick-jumper |             show-quick-jumper | ||||||
|             :item-count="state.total" |             :item-count="filteredData.length" | ||||||
|             :page-sizes="[10, 25, 50]" |             :page-sizes="[10, 25, 50]" | ||||||
|             @update:page="handlePageChange" |             @update:page="handlePageChange" | ||||||
|             @update:page-size="handlePageSizeChange" |             @update:page-size="handlePageSizeChange" | ||||||
| @ -64,106 +62,49 @@ | |||||||
| 
 | 
 | ||||||
|           <div class="pagination-info"> |           <div class="pagination-info"> | ||||||
|             Displaying {{ startIndex }} - {{ endIndex }} of |             Displaying {{ startIndex }} - {{ endIndex }} of | ||||||
|             {{ state.total }} results |             {{ filteredData.length }} results | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
|  | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import { reactive, computed, h, onMounted } from "vue"; | import { reactive, computed, h, onMounted } from "vue"; | ||||||
| import { NSelect, NDataTable, NPagination, NButton, NIcon } from "naive-ui"; | import { NSelect, NDataTable, NPagination, NButton, NIcon } from "naive-ui"; | ||||||
| import { useI18n } from "vue-i18n"; | import { useI18n } from "vue-i18n"; | ||||||
| import { useRouter } from "vue-router"; | import { useRouter } from "vue-router"; | ||||||
| 
 | import { fileList } from "@/dict/secFiles.js"; | ||||||
| const { t } = useI18n(); | const { t } = useI18n(); | ||||||
| const router = useRouter(); | const router = useRouter(); | ||||||
| import pdfFile from "@/assets/image/icon/icon-pdf.png"; | import iconLink from "@/assets/image/icon/icon-link.png"; | ||||||
| import wordFile from "@/assets/image/icon/icon-word.png"; |  | ||||||
| import excelFile from "@/assets/image/icon/icon-excel.png"; |  | ||||||
| import fileLink from "@/assets/image/icon/icon-link.png"; |  | ||||||
| // 使用 reactive 管理所有状态 | // 使用 reactive 管理所有状态 | ||||||
| const state = reactive({ | const state = reactive({ | ||||||
|   selectedYear: null, |   selectedYear: null, | ||||||
|   pageSize: 10, |   pageSize: 10, | ||||||
|   currentPage: 1, |   currentPage: 1, | ||||||
|   tableData: [], |  | ||||||
|   tableLoading: false, |  | ||||||
|   total: 0, |  | ||||||
|   sortParams: {}, |  | ||||||
| 
 | 
 | ||||||
|   // 年份选项 |   // 年份选项 | ||||||
|   yearOptions: [ |   yearOptions: [ | ||||||
|     { label: "- Any -", value: null }, |     { label: "- Any -", value: null }, | ||||||
|     { |     { label: "2025", value: 2025 }, | ||||||
|       label: "2025", |     { label: "2024", value: 2024 }, | ||||||
|       value: "2025", |     { label: "2023", value: 2023 }, | ||||||
|     }, |     { label: "2022", value: 2022 }, | ||||||
|     { |     { label: "2021", value: 2021 }, | ||||||
|       label: "2024", |     { label: "2020", value: 2020 }, | ||||||
|       value: "2024", |     { label: "2019", value: 2019 }, | ||||||
|     }, |     { label: "2018", value: 2018 }, | ||||||
|     { |     { label: "2017", value: 2017 }, | ||||||
|       label: "2023", |     { label: "2016", value: 2016 }, | ||||||
|       value: "2023", |     { label: "2015", value: 2015 }, | ||||||
|     }, |     { label: "2014", value: 2014 }, | ||||||
|     { |     { label: "2013", value: 2013 }, | ||||||
|       label: "2022", |     { label: "2012", value: 2012 }, | ||||||
|       value: "2022", |     { label: "2011", value: 2011 }, | ||||||
|     }, |     { label: "2010", value: 2010 }, | ||||||
|     { |     { label: "2009", value: 2009 }, | ||||||
|       label: "2021", |  | ||||||
|       value: "2021", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2020", |  | ||||||
|       value: "2020", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2019", |  | ||||||
|       value: "2019", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2018", |  | ||||||
|       value: "2018", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2017", |  | ||||||
|       value: "2017", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2016", |  | ||||||
|       value: "2016", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2015", |  | ||||||
|       value: "2015", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2014", |  | ||||||
|       value: "2014", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2013", |  | ||||||
|       value: "2013", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2012", |  | ||||||
|       value: "2012", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2011", |  | ||||||
|       value: "2011", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2010", |  | ||||||
|       value: "2010", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2009", |  | ||||||
|       value: "2009", |  | ||||||
|     }, |  | ||||||
|   ], |   ], | ||||||
| 
 | 
 | ||||||
|   // 每页条数选项 |   // 每页条数选项 | ||||||
| @ -172,9 +113,13 @@ const state = reactive({ | |||||||
|     { label: "25", value: 25 }, |     { label: "25", value: 25 }, | ||||||
|     { label: "50", value: 50 }, |     { label: "50", value: 50 }, | ||||||
|   ], |   ], | ||||||
| }); |  | ||||||
| 
 | 
 | ||||||
| const monthNames = [ |   // SEC文件数据 | ||||||
|  |   secFilingsData: [], | ||||||
|  | }); | ||||||
|  | onMounted(() => { | ||||||
|  |   // 月份名称映射 | ||||||
|  |   const monthNames = [ | ||||||
|     "Jan", |     "Jan", | ||||||
|     "Feb", |     "Feb", | ||||||
|     "Mar", |     "Mar", | ||||||
| @ -187,28 +132,16 @@ const monthNames = [ | |||||||
|     "Oct", |     "Oct", | ||||||
|     "Nov", |     "Nov", | ||||||
|     "Dec", |     "Dec", | ||||||
| ]; |   ]; | ||||||
| onMounted(() => { | 
 | ||||||
|   getListData(); |   state.secFilingsData = fileList.map((item, index) => { | ||||||
| }); |     // 从 filingDate 中提取年份,支持两种格式: | ||||||
| import axios from "axios"; |     // 1. "Feb 04, 2019" 格式(英文) | ||||||
| const getListData = async () => { |     // 2. "2025-10-24" 格式(ISO格式)转换为英文格式 | ||||||
|   state.tableData = []; |  | ||||||
|   let url = "https://saas.fiee.com/api/fiee/sec-filing/web/list"; |  | ||||||
|   let params = { |  | ||||||
|     page: state.currentPage, |  | ||||||
|     pageSize: state.pageSize, |  | ||||||
|     year: state.selectedYear, |  | ||||||
|   }; |  | ||||||
|   Object.assign(params, state.sortParams); |  | ||||||
|   state.tableLoading = true; |  | ||||||
|   const res = await axios.post(url, params); |  | ||||||
|   if (res.data.status === 0) { |  | ||||||
|     let resData = res.data.data?.data || []; |  | ||||||
|     resData.forEach((item) => { |  | ||||||
|       if (item.filingDate) { |  | ||||||
|     let year = null; |     let year = null; | ||||||
|         let filingDate = item.filingDate; |     let formattedDate = item.filingDate; | ||||||
|  | 
 | ||||||
|  |     if (item.filingDate) { | ||||||
|       if (item.filingDate.includes(", ")) { |       if (item.filingDate.includes(", ")) { | ||||||
|         // "Feb 04, 2019" 格式,已经是英文格式,保持不变 |         // "Feb 04, 2019" 格式,已经是英文格式,保持不变 | ||||||
|         year = parseInt(item.filingDate.split(", ")[1]); |         year = parseInt(item.filingDate.split(", ")[1]); | ||||||
| @ -222,37 +155,29 @@ const getListData = async () => { | |||||||
|         year = yearPart; |         year = yearPart; | ||||||
|         const monthName = monthNames[monthPart - 1]; // 月份从1开始,数组从0开始 |         const monthName = monthNames[monthPart - 1]; // 月份从1开始,数组从0开始 | ||||||
|         const dayFormatted = dayPart.toString().padStart(2, "0"); |         const dayFormatted = dayPart.toString().padStart(2, "0"); | ||||||
|           filingDate = `${monthName} ${dayFormatted}, ${yearPart}`; |         formattedDate = `${monthName} ${dayFormatted}, ${yearPart}`; | ||||||
|           item.year = year; |  | ||||||
|           item.filingDate = filingDate; |  | ||||||
|           item.filing_date = filingDate; |  | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     return { | ||||||
|  |       ...item, | ||||||
|  |       formattedDate: formattedDate, // 更新为统一的英文格式 | ||||||
|  |       year: year, | ||||||
|  |     }; | ||||||
|   }); |   }); | ||||||
|     state.tableData = resData; | }); | ||||||
|     state.total = res.data.data?.total; |  | ||||||
|   } |  | ||||||
|   state.tableLoading = false; |  | ||||||
| }; |  | ||||||
| const handleSort = (sortData) => { |  | ||||||
|   state.sortParams = {}; |  | ||||||
|   if (sortData.order !== false) { |  | ||||||
|     state.sortParams["sortField"] = sortData.columnKey; |  | ||||||
|     state.sortParams["sortOrder"] = sortData.order.replace("end", ""); |  | ||||||
|   } |  | ||||||
|   getListData(); |  | ||||||
| }; |  | ||||||
| // 表格列定义 | // 表格列定义 | ||||||
| const columns = [ | const columns = [ | ||||||
|   { |   { | ||||||
|     title: "Filing Date", |     title: "Filing Date", | ||||||
|     key: "filing_date", |     key: "formattedDate", | ||||||
|     sorter: "default", |     sorter: "default", | ||||||
|     width: 150, |     width: 150, | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     title: "Form", |     title: "Form", | ||||||
|     key: "form", |     key: "form", | ||||||
|  |     sorter: "default", | ||||||
|     width: 120, |     width: 120, | ||||||
|     render: (row) => { |     render: (row) => { | ||||||
|       return h( |       return h( | ||||||
| @ -269,7 +194,7 @@ const columns = [ | |||||||
|             router.push({ |             router.push({ | ||||||
|               path: "/secfilingsDefail", |               path: "/secfilingsDefail", | ||||||
|               query: { |               query: { | ||||||
|                 filingKey: row.filingKey, |                 filingDate: row.filingDate, | ||||||
|               }, |               }, | ||||||
|             }); |             }); | ||||||
|           }, |           }, | ||||||
| @ -287,13 +212,14 @@ const columns = [ | |||||||
|   { |   { | ||||||
|     title: "Description", |     title: "Description", | ||||||
|     key: "description", |     key: "description", | ||||||
|  |     sorter: "default", | ||||||
|     ellipsis: { |     ellipsis: { | ||||||
|       tooltip: true, |       tooltip: true, | ||||||
|     }, |     }, | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     title: "View", |     title: "View", | ||||||
|     key: "fileLink", |     key: "view", | ||||||
|     width: 150, |     width: 150, | ||||||
|     render: (row) => { |     render: (row) => { | ||||||
|       return h( |       return h( | ||||||
| @ -305,101 +231,7 @@ const columns = [ | |||||||
|           }, |           }, | ||||||
|         }, |         }, | ||||||
|         [ |         [ | ||||||
|           row.pdfFile |           h( | ||||||
|             ? h( |  | ||||||
|                 "a", |  | ||||||
|                 { |  | ||||||
|                   href: "javascript:void(0)", |  | ||||||
|                   style: { |  | ||||||
|                     color: "#0078d7", |  | ||||||
|                     textDecoration: "none", |  | ||||||
|                     fontSize: "12px", |  | ||||||
|                   }, |  | ||||||
|                   onClick: (e) => { |  | ||||||
|                     e.preventDefault(); |  | ||||||
|                     handleViewDocument(row.pdfFile, "pdf"); |  | ||||||
|                   }, |  | ||||||
|                   onMouseover: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "underline"; |  | ||||||
|                   }, |  | ||||||
|                   onMouseout: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "none"; |  | ||||||
|                   }, |  | ||||||
|                 }, |  | ||||||
|                 h("img", { |  | ||||||
|                   src: pdfFile, |  | ||||||
|                   alt: "link", |  | ||||||
|                   style: { |  | ||||||
|                     width: "24px", |  | ||||||
|                     height: "24px", |  | ||||||
|                   }, |  | ||||||
|                 }) |  | ||||||
|               ) |  | ||||||
|             : null, |  | ||||||
|           row.wordFile |  | ||||||
|             ? h( |  | ||||||
|                 "a", |  | ||||||
|                 { |  | ||||||
|                   href: "javascript:void(0)", |  | ||||||
|                   style: { |  | ||||||
|                     color: "#0078d7", |  | ||||||
|                     textDecoration: "none", |  | ||||||
|                     fontSize: "12px", |  | ||||||
|                   }, |  | ||||||
|                   onClick: (e) => { |  | ||||||
|                     e.preventDefault(); |  | ||||||
|                     handleViewDocument(row.wordFile, "word"); |  | ||||||
|                   }, |  | ||||||
|                   onMouseover: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "underline"; |  | ||||||
|                   }, |  | ||||||
|                   onMouseout: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "none"; |  | ||||||
|                   }, |  | ||||||
|                 }, |  | ||||||
|                 h("img", { |  | ||||||
|                   src: wordFile, |  | ||||||
|                   alt: "link", |  | ||||||
|                   style: { |  | ||||||
|                     width: "24px", |  | ||||||
|                     height: "24px", |  | ||||||
|                   }, |  | ||||||
|                 }) |  | ||||||
|               ) |  | ||||||
|             : null, |  | ||||||
|           row.excelFile |  | ||||||
|             ? h( |  | ||||||
|                 "a", |  | ||||||
|                 { |  | ||||||
|                   href: "javascript:void(0)", |  | ||||||
|                   style: { |  | ||||||
|                     color: "#0078d7", |  | ||||||
|                     textDecoration: "none", |  | ||||||
|                     fontSize: "12px", |  | ||||||
|                   }, |  | ||||||
|                   onClick: (e) => { |  | ||||||
|                     e.preventDefault(); |  | ||||||
|                     handleViewDocument(row.excelFile, "excel"); |  | ||||||
|                   }, |  | ||||||
|                   onMouseover: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "underline"; |  | ||||||
|                   }, |  | ||||||
|                   onMouseout: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "none"; |  | ||||||
|                   }, |  | ||||||
|                 }, |  | ||||||
|                 h("img", { |  | ||||||
|                   src: excelFile, |  | ||||||
|                   alt: "link", |  | ||||||
|                   style: { |  | ||||||
|                     width: "24px", |  | ||||||
|                     height: "24px", |  | ||||||
|                   }, |  | ||||||
|                 }) |  | ||||||
|               ) |  | ||||||
|             : null, |  | ||||||
|           row.fileLink |  | ||||||
|             ? h( |  | ||||||
|             "a", |             "a", | ||||||
|             { |             { | ||||||
|               href: row.fileLink, |               href: row.fileLink, | ||||||
| @ -416,21 +248,43 @@ const columns = [ | |||||||
|               }, |               }, | ||||||
|             }, |             }, | ||||||
|             h("img", { |             h("img", { | ||||||
|                   src: fileLink, |               src: iconLink, | ||||||
|               alt: "link", |               alt: "link", | ||||||
|               style: { |               style: { | ||||||
|                 width: "24px", |                 width: "24px", | ||||||
|                 height: "24px", |                 height: "24px", | ||||||
|               }, |               }, | ||||||
|             }) |             }) | ||||||
|               ) |           ), | ||||||
|             : null, |  | ||||||
|         ] |         ] | ||||||
|       ); |       ); | ||||||
|     }, |     }, | ||||||
|   }, |   }, | ||||||
| ]; | ]; | ||||||
| 
 | 
 | ||||||
|  | // 筛选后的数据 | ||||||
|  | const filteredData = computed(() => { | ||||||
|  |   let data = state.secFilingsData; | ||||||
|  | 
 | ||||||
|  |   if (state.selectedYear) { | ||||||
|  |     data = data.filter((item) => item.year === state.selectedYear); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   return data; | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // 分页数据 | ||||||
|  | const paginatedData = computed(() => { | ||||||
|  |   const start = (state.currentPage - 1) * state.pageSize; | ||||||
|  |   const end = start + state.pageSize; | ||||||
|  |   return filteredData.value.slice(start, end); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // 总页数 | ||||||
|  | const totalPages = computed(() => { | ||||||
|  |   return Math.ceil(filteredData.value.length / state.pageSize); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
| // 当前页起始索引 | // 当前页起始索引 | ||||||
| const startIndex = computed(() => { | const startIndex = computed(() => { | ||||||
|   return (state.currentPage - 1) * state.pageSize + 1; |   return (state.currentPage - 1) * state.pageSize + 1; | ||||||
| @ -439,34 +293,24 @@ const startIndex = computed(() => { | |||||||
| // 当前页结束索引 | // 当前页结束索引 | ||||||
| const endIndex = computed(() => { | const endIndex = computed(() => { | ||||||
|   const end = state.currentPage * state.pageSize; |   const end = state.currentPage * state.pageSize; | ||||||
|   return Math.min(end, state.total); |   return Math.min(end, filteredData.value.length); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| // 处理年份变化 | // 处理年份变化 | ||||||
| const handleYearChange = (value) => { | const handleYearChange = (value) => { | ||||||
|   state.selectedYear = value; |   state.selectedYear = value; | ||||||
|   state.currentPage = 1; |   state.currentPage = 1; | ||||||
|   getListData(); |  | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // 处理页码变化 | // 处理页码变化 | ||||||
| const handlePageChange = (page) => { | const handlePageChange = (page) => { | ||||||
|   state.currentPage = page; |   state.currentPage = page; | ||||||
|   getListData(); |  | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // 处理每页条数变化 | // 处理每页条数变化 | ||||||
| const handlePageSizeChange = (size) => { | const handlePageSizeChange = (size) => { | ||||||
|   state.pageSize = size; |   state.pageSize = size; | ||||||
|   state.currentPage = 1; |   state.currentPage = 1; | ||||||
|   getListData(); |  | ||||||
| }; |  | ||||||
| // 查看文档 |  | ||||||
| const handleViewDocument = (val, type) => { |  | ||||||
|   window.open( |  | ||||||
|     `${import.meta.env.VITE_PAGE_URL}/office?url=${val}&attachmentName=${type}`, |  | ||||||
|     "_blank" |  | ||||||
|   ); |  | ||||||
| }; | }; | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -33,13 +33,11 @@ | |||||||
|       <div class="table-container"> |       <div class="table-container"> | ||||||
|         <n-data-table |         <n-data-table | ||||||
|           :columns="columns" |           :columns="columns" | ||||||
|           :loading="state.tableLoading" |           :data="paginatedData" | ||||||
|           :data="state.tableData" |  | ||||||
|           :pagination="false" |           :pagination="false" | ||||||
|           :bordered="false" |           :bordered="false" | ||||||
|           :size="'medium'" |           :size="'medium'" | ||||||
|           :row-key="(row) => row.idx" |           :row-key="(row) => row.idx" | ||||||
|           @update:sorter="handleSort" |  | ||||||
|         /> |         /> | ||||||
| 
 | 
 | ||||||
|         <!-- 分页器 --> |         <!-- 分页器 --> | ||||||
| @ -49,7 +47,7 @@ | |||||||
|             v-model:page-size="state.pageSize" |             v-model:page-size="state.pageSize" | ||||||
|             show-size-picker |             show-size-picker | ||||||
|             show-quick-jumper |             show-quick-jumper | ||||||
|             :item-count="state.total" |             :item-count="filteredData.length" | ||||||
|             :page-sizes="[10, 25, 50]" |             :page-sizes="[10, 25, 50]" | ||||||
|             @update:page="handlePageChange" |             @update:page="handlePageChange" | ||||||
|             @update:page-size="handlePageSizeChange" |             @update:page-size="handlePageSizeChange" | ||||||
| @ -64,7 +62,7 @@ | |||||||
| 
 | 
 | ||||||
|           <div class="pagination-info"> |           <div class="pagination-info"> | ||||||
|             Displaying {{ startIndex }} - {{ endIndex }} of |             Displaying {{ startIndex }} - {{ endIndex }} of | ||||||
|             {{ state.total }} results |             {{ filteredData.length }} results | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
| @ -77,94 +75,37 @@ import { reactive, computed, h, onMounted } from "vue"; | |||||||
| import { NSelect, NDataTable, NPagination, NButton, NIcon } from "naive-ui"; | import { NSelect, NDataTable, NPagination, NButton, NIcon } from "naive-ui"; | ||||||
| import { useI18n } from "vue-i18n"; | import { useI18n } from "vue-i18n"; | ||||||
| import { useRouter } from "vue-router"; | import { useRouter } from "vue-router"; | ||||||
|  | import { fileList } from "@/dict/secFiles.js"; | ||||||
| 
 | 
 | ||||||
| const { t } = useI18n(); | const { t } = useI18n(); | ||||||
| const router = useRouter(); | const router = useRouter(); | ||||||
| import pdfFile from "@/assets/image/icon/icon-pdf.png"; | import iconLink from "@/assets/image/icon/icon-link.png"; | ||||||
| import wordFile from "@/assets/image/icon/icon-word.png"; |  | ||||||
| import excelFile from "@/assets/image/icon/icon-excel.png"; |  | ||||||
| import fileLink from "@/assets/image/icon/icon-link.png"; |  | ||||||
| // 使用 reactive 管理所有状态 | // 使用 reactive 管理所有状态 | ||||||
| const state = reactive({ | const state = reactive({ | ||||||
|   selectedYear: null, |   selectedYear: null, | ||||||
|   pageSize: 10, |   pageSize: 10, | ||||||
|   currentPage: 1, |   currentPage: 1, | ||||||
|   tableData: [], |  | ||||||
|   tableLoading: false, |  | ||||||
|   total: 0, |  | ||||||
|   sortParams: {}, |  | ||||||
| 
 | 
 | ||||||
|   // 年份选项 |   // 年份选项 | ||||||
|   yearOptions: [ |   yearOptions: [ | ||||||
|     { label: "- Any -", value: null }, |     { label: "- Any -", value: null }, | ||||||
|     { |     { label: "2025", value: 2025 }, | ||||||
|       label: "2025", |     { label: "2024", value: 2024 }, | ||||||
|       value: "2025", |     { label: "2023", value: 2023 }, | ||||||
|     }, |     { label: "2022", value: 2022 }, | ||||||
|     { |     { label: "2021", value: 2021 }, | ||||||
|       label: "2024", |     { label: "2020", value: 2020 }, | ||||||
|       value: "2024", |     { label: "2019", value: 2019 }, | ||||||
|     }, |     { label: "2018", value: 2018 }, | ||||||
|     { |     { label: "2017", value: 2017 }, | ||||||
|       label: "2023", |     { label: "2016", value: 2016 }, | ||||||
|       value: "2023", |     { label: "2015", value: 2015 }, | ||||||
|     }, |     { label: "2014", value: 2014 }, | ||||||
|     { |     { label: "2013", value: 2013 }, | ||||||
|       label: "2022", |     { label: "2012", value: 2012 }, | ||||||
|       value: "2022", |     { label: "2011", value: 2011 }, | ||||||
|     }, |     { label: "2010", value: 2010 }, | ||||||
|     { |     { label: "2009", value: 2009 }, | ||||||
|       label: "2021", |  | ||||||
|       value: "2021", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2020", |  | ||||||
|       value: "2020", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2019", |  | ||||||
|       value: "2019", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2018", |  | ||||||
|       value: "2018", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2017", |  | ||||||
|       value: "2017", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2016", |  | ||||||
|       value: "2016", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2015", |  | ||||||
|       value: "2015", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2014", |  | ||||||
|       value: "2014", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2013", |  | ||||||
|       value: "2013", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2012", |  | ||||||
|       value: "2012", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2011", |  | ||||||
|       value: "2011", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2010", |  | ||||||
|       value: "2010", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2009", |  | ||||||
|       value: "2009", |  | ||||||
|     }, |  | ||||||
|   ], |   ], | ||||||
| 
 | 
 | ||||||
|   // 每页条数选项 |   // 每页条数选项 | ||||||
| @ -173,9 +114,13 @@ const state = reactive({ | |||||||
|     { label: "25", value: 25 }, |     { label: "25", value: 25 }, | ||||||
|     { label: "50", value: 50 }, |     { label: "50", value: 50 }, | ||||||
|   ], |   ], | ||||||
| }); |  | ||||||
| 
 | 
 | ||||||
| const monthNames = [ |   // SEC文件数据 | ||||||
|  |   secFilingsData: [], | ||||||
|  | }); | ||||||
|  | onMounted(() => { | ||||||
|  |   // 月份名称映射 | ||||||
|  |   const monthNames = [ | ||||||
|     "Jan", |     "Jan", | ||||||
|     "Feb", |     "Feb", | ||||||
|     "Mar", |     "Mar", | ||||||
| @ -188,28 +133,16 @@ const monthNames = [ | |||||||
|     "Oct", |     "Oct", | ||||||
|     "Nov", |     "Nov", | ||||||
|     "Dec", |     "Dec", | ||||||
| ]; |   ]; | ||||||
| onMounted(() => { | 
 | ||||||
|   getListData(); |   state.secFilingsData = fileList.map((item, index) => { | ||||||
| }); |     // 从 filingDate 中提取年份,支持两种格式: | ||||||
| import axios from "axios"; |     // 1. "Feb 04, 2019" 格式(英文) | ||||||
| const getListData = async () => { |     // 2. "2025-10-24" 格式(ISO格式)转换为英文格式 | ||||||
|   state.tableData = []; |  | ||||||
|   let url = "https://saas.fiee.com/api/fiee/sec-filing/web/list"; |  | ||||||
|   let params = { |  | ||||||
|     page: state.currentPage, |  | ||||||
|     pageSize: state.pageSize, |  | ||||||
|     year: state.selectedYear, |  | ||||||
|   }; |  | ||||||
|   Object.assign(params, state.sortParams); |  | ||||||
|   state.tableLoading = true; |  | ||||||
|   const res = await axios.post(url, params); |  | ||||||
|   if (res.data.status === 0) { |  | ||||||
|     let resData = res.data.data?.data || []; |  | ||||||
|     resData.forEach((item) => { |  | ||||||
|       if (item.filingDate) { |  | ||||||
|     let year = null; |     let year = null; | ||||||
|         let filingDate = item.filingDate; |     let formattedDate = item.filingDate; | ||||||
|  | 
 | ||||||
|  |     if (item.filingDate) { | ||||||
|       if (item.filingDate.includes(", ")) { |       if (item.filingDate.includes(", ")) { | ||||||
|         // "Feb 04, 2019" 格式,已经是英文格式,保持不变 |         // "Feb 04, 2019" 格式,已经是英文格式,保持不变 | ||||||
|         year = parseInt(item.filingDate.split(", ")[1]); |         year = parseInt(item.filingDate.split(", ")[1]); | ||||||
| @ -223,37 +156,29 @@ const getListData = async () => { | |||||||
|         year = yearPart; |         year = yearPart; | ||||||
|         const monthName = monthNames[monthPart - 1]; // 月份从1开始,数组从0开始 |         const monthName = monthNames[monthPart - 1]; // 月份从1开始,数组从0开始 | ||||||
|         const dayFormatted = dayPart.toString().padStart(2, "0"); |         const dayFormatted = dayPart.toString().padStart(2, "0"); | ||||||
|           filingDate = `${monthName} ${dayFormatted}, ${yearPart}`; |         formattedDate = `${monthName} ${dayFormatted}, ${yearPart}`; | ||||||
|           item.year = year; |  | ||||||
|           item.filingDate = filingDate; |  | ||||||
|           item.filing_date = filingDate; |  | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     return { | ||||||
|  |       ...item, | ||||||
|  |       formattedDate: formattedDate, // 更新为统一的英文格式 | ||||||
|  |       year: year, | ||||||
|  |     }; | ||||||
|   }); |   }); | ||||||
|     state.tableData = resData; | }); | ||||||
|     state.total = res.data.data?.total; |  | ||||||
|   } |  | ||||||
|   state.tableLoading = false; |  | ||||||
| }; |  | ||||||
| const handleSort = (sortData) => { |  | ||||||
|   state.sortParams = {}; |  | ||||||
|   if (sortData.order !== false) { |  | ||||||
|     state.sortParams["sortField"] = sortData.columnKey; |  | ||||||
|     state.sortParams["sortOrder"] = sortData.order.replace("end", ""); |  | ||||||
|   } |  | ||||||
|   getListData(); |  | ||||||
| }; |  | ||||||
| // 表格列定义 | // 表格列定义 | ||||||
| const columns = [ | const columns = [ | ||||||
|   { |   { | ||||||
|     title: "Filing Date", |     title: "Filing Date", | ||||||
|     key: "filing_date", |     key: "formattedDate", | ||||||
|     sorter: "default", |     sorter: "default", | ||||||
|     width: 150, |     width: 150, | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     title: "Form", |     title: "Form", | ||||||
|     key: "form", |     key: "form", | ||||||
|  |     sorter: "default", | ||||||
|     width: 120, |     width: 120, | ||||||
|     render: (row) => { |     render: (row) => { | ||||||
|       return h( |       return h( | ||||||
| @ -270,7 +195,7 @@ const columns = [ | |||||||
|             router.push({ |             router.push({ | ||||||
|               path: "/secfilingsDefail", |               path: "/secfilingsDefail", | ||||||
|               query: { |               query: { | ||||||
|                 filingKey: row.filingKey, |                 idx: row.idx, | ||||||
|               }, |               }, | ||||||
|             }); |             }); | ||||||
|           }, |           }, | ||||||
| @ -288,13 +213,14 @@ const columns = [ | |||||||
|   { |   { | ||||||
|     title: "Description", |     title: "Description", | ||||||
|     key: "description", |     key: "description", | ||||||
|  |     sorter: "default", | ||||||
|     ellipsis: { |     ellipsis: { | ||||||
|       tooltip: true, |       tooltip: true, | ||||||
|     }, |     }, | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     title: "View", |     title: "View", | ||||||
|     key: "fileLink", |     key: "view", | ||||||
|     width: 150, |     width: 150, | ||||||
|     render: (row) => { |     render: (row) => { | ||||||
|       return h( |       return h( | ||||||
| @ -306,101 +232,7 @@ const columns = [ | |||||||
|           }, |           }, | ||||||
|         }, |         }, | ||||||
|         [ |         [ | ||||||
|           row.pdfFile |           h( | ||||||
|             ? h( |  | ||||||
|                 "a", |  | ||||||
|                 { |  | ||||||
|                   href: "javascript:void(0)", |  | ||||||
|                   style: { |  | ||||||
|                     color: "#0078d7", |  | ||||||
|                     textDecoration: "none", |  | ||||||
|                     fontSize: "12px", |  | ||||||
|                   }, |  | ||||||
|                   onClick: (e) => { |  | ||||||
|                     e.preventDefault(); |  | ||||||
|                     handleViewDocument(row.pdfFile, "pdf"); |  | ||||||
|                   }, |  | ||||||
|                   onMouseover: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "underline"; |  | ||||||
|                   }, |  | ||||||
|                   onMouseout: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "none"; |  | ||||||
|                   }, |  | ||||||
|                 }, |  | ||||||
|                 h("img", { |  | ||||||
|                   src: pdfFile, |  | ||||||
|                   alt: "link", |  | ||||||
|                   style: { |  | ||||||
|                     width: "24px", |  | ||||||
|                     height: "24px", |  | ||||||
|                   }, |  | ||||||
|                 }) |  | ||||||
|               ) |  | ||||||
|             : null, |  | ||||||
|           row.wordFile |  | ||||||
|             ? h( |  | ||||||
|                 "a", |  | ||||||
|                 { |  | ||||||
|                   href: "javascript:void(0)", |  | ||||||
|                   style: { |  | ||||||
|                     color: "#0078d7", |  | ||||||
|                     textDecoration: "none", |  | ||||||
|                     fontSize: "12px", |  | ||||||
|                   }, |  | ||||||
|                   onClick: (e) => { |  | ||||||
|                     e.preventDefault(); |  | ||||||
|                     handleViewDocument(row.wordFile, "word"); |  | ||||||
|                   }, |  | ||||||
|                   onMouseover: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "underline"; |  | ||||||
|                   }, |  | ||||||
|                   onMouseout: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "none"; |  | ||||||
|                   }, |  | ||||||
|                 }, |  | ||||||
|                 h("img", { |  | ||||||
|                   src: wordFile, |  | ||||||
|                   alt: "link", |  | ||||||
|                   style: { |  | ||||||
|                     width: "24px", |  | ||||||
|                     height: "24px", |  | ||||||
|                   }, |  | ||||||
|                 }) |  | ||||||
|               ) |  | ||||||
|             : null, |  | ||||||
|           row.excelFile |  | ||||||
|             ? h( |  | ||||||
|                 "a", |  | ||||||
|                 { |  | ||||||
|                   href: "javascript:void(0)", |  | ||||||
|                   style: { |  | ||||||
|                     color: "#0078d7", |  | ||||||
|                     textDecoration: "none", |  | ||||||
|                     fontSize: "12px", |  | ||||||
|                   }, |  | ||||||
|                   onClick: (e) => { |  | ||||||
|                     e.preventDefault(); |  | ||||||
|                     handleViewDocument(row.excelFile, "excel"); |  | ||||||
|                   }, |  | ||||||
|                   onMouseover: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "underline"; |  | ||||||
|                   }, |  | ||||||
|                   onMouseout: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "none"; |  | ||||||
|                   }, |  | ||||||
|                 }, |  | ||||||
|                 h("img", { |  | ||||||
|                   src: excelFile, |  | ||||||
|                   alt: "link", |  | ||||||
|                   style: { |  | ||||||
|                     width: "24px", |  | ||||||
|                     height: "24px", |  | ||||||
|                   }, |  | ||||||
|                 }) |  | ||||||
|               ) |  | ||||||
|             : null, |  | ||||||
|           row.fileLink |  | ||||||
|             ? h( |  | ||||||
|             "a", |             "a", | ||||||
|             { |             { | ||||||
|               href: row.fileLink, |               href: row.fileLink, | ||||||
| @ -417,21 +249,43 @@ const columns = [ | |||||||
|               }, |               }, | ||||||
|             }, |             }, | ||||||
|             h("img", { |             h("img", { | ||||||
|                   src: fileLink, |               src: iconLink, | ||||||
|               alt: "link", |               alt: "link", | ||||||
|               style: { |               style: { | ||||||
|                 width: "24px", |                 width: "24px", | ||||||
|                 height: "24px", |                 height: "24px", | ||||||
|               }, |               }, | ||||||
|             }) |             }) | ||||||
|               ) |           ), | ||||||
|             : null, |  | ||||||
|         ] |         ] | ||||||
|       ); |       ); | ||||||
|     }, |     }, | ||||||
|   }, |   }, | ||||||
| ]; | ]; | ||||||
| 
 | 
 | ||||||
|  | // 筛选后的数据 | ||||||
|  | const filteredData = computed(() => { | ||||||
|  |   let data = state.secFilingsData; | ||||||
|  | 
 | ||||||
|  |   if (state.selectedYear) { | ||||||
|  |     data = data.filter((item) => item.year === state.selectedYear); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   return data; | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // 分页数据 | ||||||
|  | const paginatedData = computed(() => { | ||||||
|  |   const start = (state.currentPage - 1) * state.pageSize; | ||||||
|  |   const end = start + state.pageSize; | ||||||
|  |   return filteredData.value.slice(start, end); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // 总页数 | ||||||
|  | const totalPages = computed(() => { | ||||||
|  |   return Math.ceil(filteredData.value.length / state.pageSize); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
| // 当前页起始索引 | // 当前页起始索引 | ||||||
| const startIndex = computed(() => { | const startIndex = computed(() => { | ||||||
|   return (state.currentPage - 1) * state.pageSize + 1; |   return (state.currentPage - 1) * state.pageSize + 1; | ||||||
| @ -440,34 +294,24 @@ const startIndex = computed(() => { | |||||||
| // 当前页结束索引 | // 当前页结束索引 | ||||||
| const endIndex = computed(() => { | const endIndex = computed(() => { | ||||||
|   const end = state.currentPage * state.pageSize; |   const end = state.currentPage * state.pageSize; | ||||||
|   return Math.min(end, state.total); |   return Math.min(end, filteredData.value.length); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| // 处理年份变化 | // 处理年份变化 | ||||||
| const handleYearChange = (value) => { | const handleYearChange = (value) => { | ||||||
|   state.selectedYear = value; |   state.selectedYear = value; | ||||||
|   state.currentPage = 1; |   state.currentPage = 1; | ||||||
|   getListData(); |  | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // 处理页码变化 | // 处理页码变化 | ||||||
| const handlePageChange = (page) => { | const handlePageChange = (page) => { | ||||||
|   state.currentPage = page; |   state.currentPage = page; | ||||||
|   getListData(); |  | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // 处理每页条数变化 | // 处理每页条数变化 | ||||||
| const handlePageSizeChange = (size) => { | const handlePageSizeChange = (size) => { | ||||||
|   state.pageSize = size; |   state.pageSize = size; | ||||||
|   state.currentPage = 1; |   state.currentPage = 1; | ||||||
|   getListData(); |  | ||||||
| }; |  | ||||||
| // 查看文档 |  | ||||||
| const handleViewDocument = (val, type) => { |  | ||||||
|   window.open( |  | ||||||
|     `${import.meta.env.VITE_PAGE_URL}/office?url=${val}&attachmentName=${type}`, |  | ||||||
|     "_blank" |  | ||||||
|   ); |  | ||||||
| }; | }; | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -33,11 +33,9 @@ | |||||||
|       <div class="table-container"> |       <div class="table-container"> | ||||||
|         <n-data-table |         <n-data-table | ||||||
|           :columns="columns" |           :columns="columns" | ||||||
|           :loading="state.tableLoading" |           :data="paginatedData" | ||||||
|           :data="state.tableData" |  | ||||||
|           :pagination="false" |           :pagination="false" | ||||||
|           :row-key="(row) => row.idx" |           :row-key="(row) => row.idx" | ||||||
|           @update:sorter="handleSort" |  | ||||||
|           :bordered="false" |           :bordered="false" | ||||||
|           :single-line="false" |           :single-line="false" | ||||||
|           :scroll-x="600" |           :scroll-x="600" | ||||||
| @ -49,7 +47,7 @@ | |||||||
|             v-model:page="state.currentPage" |             v-model:page="state.currentPage" | ||||||
|             v-model:page-size="state.pageSize" |             v-model:page-size="state.pageSize" | ||||||
|             show-size-picker |             show-size-picker | ||||||
|             :item-count="state.total" |             :item-count="filteredData.length" | ||||||
|             :page-sizes="[10, 25, 50]" |             :page-sizes="[10, 25, 50]" | ||||||
|             @update:page="handlePageChange" |             @update:page="handlePageChange" | ||||||
|             @update:page-size="handlePageSizeChange" |             @update:page-size="handlePageSizeChange" | ||||||
| @ -64,7 +62,7 @@ | |||||||
| 
 | 
 | ||||||
|           <div class="pagination-info mt-[40px]"> |           <div class="pagination-info mt-[40px]"> | ||||||
|             Displaying {{ startIndex }} - {{ endIndex }} of |             Displaying {{ startIndex }} - {{ endIndex }} of | ||||||
|             {{ state.total }} results |             {{ filteredData.length }} results | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
| @ -77,94 +75,36 @@ import { reactive, computed, h, onMounted } from "vue"; | |||||||
| import { NSelect, NDataTable, NPagination, NButton, NIcon } from "naive-ui"; | import { NSelect, NDataTable, NPagination, NButton, NIcon } from "naive-ui"; | ||||||
| import { useI18n } from "vue-i18n"; | import { useI18n } from "vue-i18n"; | ||||||
| import { useRouter } from "vue-router"; | import { useRouter } from "vue-router"; | ||||||
| 
 | import { fileList } from "@/dict/secFiles.js"; | ||||||
| const { t } = useI18n(); | const { t } = useI18n(); | ||||||
| const router = useRouter(); | const router = useRouter(); | ||||||
| import pdfFile from "@/assets/image/icon/icon-pdf.png"; | import iconLink from "@/assets/image/icon/icon-link.png"; | ||||||
| import wordFile from "@/assets/image/icon/icon-word.png"; |  | ||||||
| import excelFile from "@/assets/image/icon/icon-excel.png"; |  | ||||||
| import fileLink from "@/assets/image/icon/icon-link.png"; |  | ||||||
| // 使用 reactive 管理所有状态 | // 使用 reactive 管理所有状态 | ||||||
| const state = reactive({ | const state = reactive({ | ||||||
|   selectedYear: null, |   selectedYear: null, | ||||||
|   pageSize: 10, |   pageSize: 10, | ||||||
|   currentPage: 1, |   currentPage: 1, | ||||||
|   tableData: [], |  | ||||||
|   tableLoading: false, |  | ||||||
|   total: 0, |  | ||||||
|   sortParams: {}, |  | ||||||
| 
 | 
 | ||||||
|   // 年份选项 |   // 年份选项 | ||||||
|   yearOptions: [ |   yearOptions: [ | ||||||
|     { label: "- Any -", value: null }, |     { label: "- Any -", value: null }, | ||||||
|     { |     { label: "2025", value: 2025 }, | ||||||
|       label: "2025", |     { label: "2024", value: 2024 }, | ||||||
|       value: "2025", |     { label: "2023", value: 2023 }, | ||||||
|     }, |     { label: "2022", value: 2022 }, | ||||||
|     { |     { label: "2021", value: 2021 }, | ||||||
|       label: "2024", |     { label: "2020", value: 2020 }, | ||||||
|       value: "2024", |     { label: "2019", value: 2019 }, | ||||||
|     }, |     { label: "2018", value: 2018 }, | ||||||
|     { |     { label: "2017", value: 2017 }, | ||||||
|       label: "2023", |     { label: "2016", value: 2016 }, | ||||||
|       value: "2023", |     { label: "2015", value: 2015 }, | ||||||
|     }, |     { label: "2014", value: 2014 }, | ||||||
|     { |     { label: "2013", value: 2013 }, | ||||||
|       label: "2022", |     { label: "2012", value: 2012 }, | ||||||
|       value: "2022", |     { label: "2011", value: 2011 }, | ||||||
|     }, |     { label: "2010", value: 2010 }, | ||||||
|     { |     { label: "2009", value: 2009 }, | ||||||
|       label: "2021", |  | ||||||
|       value: "2021", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2020", |  | ||||||
|       value: "2020", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2019", |  | ||||||
|       value: "2019", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2018", |  | ||||||
|       value: "2018", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2017", |  | ||||||
|       value: "2017", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2016", |  | ||||||
|       value: "2016", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2015", |  | ||||||
|       value: "2015", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2014", |  | ||||||
|       value: "2014", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2013", |  | ||||||
|       value: "2013", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2012", |  | ||||||
|       value: "2012", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2011", |  | ||||||
|       value: "2011", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2010", |  | ||||||
|       value: "2010", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2009", |  | ||||||
|       value: "2009", |  | ||||||
|     }, |  | ||||||
|   ], |   ], | ||||||
| 
 | 
 | ||||||
|   // 每页条数选项 |   // 每页条数选项 | ||||||
| @ -173,9 +113,13 @@ const state = reactive({ | |||||||
|     { label: "25", value: 25 }, |     { label: "25", value: 25 }, | ||||||
|     { label: "50", value: 50 }, |     { label: "50", value: 50 }, | ||||||
|   ], |   ], | ||||||
| }); |  | ||||||
| 
 | 
 | ||||||
| const monthNames = [ |   // SEC文件数据 | ||||||
|  |   secFilingsData: [], | ||||||
|  | }); | ||||||
|  | onMounted(() => { | ||||||
|  |   // 月份名称映射 | ||||||
|  |   const monthNames = [ | ||||||
|     "Jan", |     "Jan", | ||||||
|     "Feb", |     "Feb", | ||||||
|     "Mar", |     "Mar", | ||||||
| @ -188,28 +132,16 @@ const monthNames = [ | |||||||
|     "Oct", |     "Oct", | ||||||
|     "Nov", |     "Nov", | ||||||
|     "Dec", |     "Dec", | ||||||
| ]; |   ]; | ||||||
| onMounted(() => { | 
 | ||||||
|   getListData(); |   state.secFilingsData = fileList.map((item, index) => { | ||||||
| }); |     // 从 filingDate 中提取年份,支持两种格式: | ||||||
| import axios from "axios"; |     // 1. "Feb 04, 2019" 格式(英文) | ||||||
| const getListData = async () => { |     // 2. "2025-10-24" 格式(ISO格式)转换为英文格式 | ||||||
|   state.tableData = []; |  | ||||||
|   let url = "https://saas.fiee.com/api/fiee/sec-filing/web/list"; |  | ||||||
|   let params = { |  | ||||||
|     page: state.currentPage, |  | ||||||
|     pageSize: state.pageSize, |  | ||||||
|     year: state.selectedYear, |  | ||||||
|   }; |  | ||||||
|   Object.assign(params, state.sortParams); |  | ||||||
|   state.tableLoading = true; |  | ||||||
|   const res = await axios.post(url, params); |  | ||||||
|   if (res.data.status === 0) { |  | ||||||
|     let resData = res.data.data?.data || []; |  | ||||||
|     resData.forEach((item) => { |  | ||||||
|       if (item.filingDate) { |  | ||||||
|     let year = null; |     let year = null; | ||||||
|         let filingDate = item.filingDate; |     let formattedDate = item.filingDate; | ||||||
|  | 
 | ||||||
|  |     if (item.filingDate) { | ||||||
|       if (item.filingDate.includes(", ")) { |       if (item.filingDate.includes(", ")) { | ||||||
|         // "Feb 04, 2019" 格式,已经是英文格式,保持不变 |         // "Feb 04, 2019" 格式,已经是英文格式,保持不变 | ||||||
|         year = parseInt(item.filingDate.split(", ")[1]); |         year = parseInt(item.filingDate.split(", ")[1]); | ||||||
| @ -223,37 +155,29 @@ const getListData = async () => { | |||||||
|         year = yearPart; |         year = yearPart; | ||||||
|         const monthName = monthNames[monthPart - 1]; // 月份从1开始,数组从0开始 |         const monthName = monthNames[monthPart - 1]; // 月份从1开始,数组从0开始 | ||||||
|         const dayFormatted = dayPart.toString().padStart(2, "0"); |         const dayFormatted = dayPart.toString().padStart(2, "0"); | ||||||
|           filingDate = `${monthName} ${dayFormatted}, ${yearPart}`; |         formattedDate = `${monthName} ${dayFormatted}, ${yearPart}`; | ||||||
|           item.year = year; |  | ||||||
|           item.filingDate = filingDate; |  | ||||||
|           item.filing_date = filingDate; |  | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     return { | ||||||
|  |       ...item, | ||||||
|  |       formattedDate: formattedDate, // 更新为统一的英文格式 | ||||||
|  |       year: year, | ||||||
|  |     }; | ||||||
|   }); |   }); | ||||||
|     state.tableData = resData; | }); | ||||||
|     state.total = res.data.data?.total; |  | ||||||
|   } |  | ||||||
|   state.tableLoading = false; |  | ||||||
| }; |  | ||||||
| const handleSort = (sortData) => { |  | ||||||
|   state.sortParams = {}; |  | ||||||
|   if (sortData.order !== false) { |  | ||||||
|     state.sortParams["sortField"] = sortData.columnKey; |  | ||||||
|     state.sortParams["sortOrder"] = sortData.order.replace("end", ""); |  | ||||||
|   } |  | ||||||
|   getListData(); |  | ||||||
| }; |  | ||||||
| // 表格列定义 | // 表格列定义 | ||||||
| const columns = [ | const columns = [ | ||||||
|   { |   { | ||||||
|     title: "Filing Date", |     title: "Filing Date", | ||||||
|     key: "filing_date", |     key: "formattedDate", | ||||||
|     sorter: "default", |     sorter: "default", | ||||||
|     width: 150, |     width: 150, | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     title: "Form", |     title: "Form", | ||||||
|     key: "form", |     key: "form", | ||||||
|  |     sorter: "default", | ||||||
|     width: 120, |     width: 120, | ||||||
|     render: (row) => { |     render: (row) => { | ||||||
|       return h( |       return h( | ||||||
| @ -270,7 +194,7 @@ const columns = [ | |||||||
|             router.push({ |             router.push({ | ||||||
|               path: "/secfilingsDefail", |               path: "/secfilingsDefail", | ||||||
|               query: { |               query: { | ||||||
|                 filingKey: row.filingKey, |                 filingDate: row.filingDate, | ||||||
|               }, |               }, | ||||||
|             }); |             }); | ||||||
|           }, |           }, | ||||||
| @ -288,14 +212,15 @@ const columns = [ | |||||||
|   { |   { | ||||||
|     title: "Description", |     title: "Description", | ||||||
|     key: "description", |     key: "description", | ||||||
|  |     sorter: "default", | ||||||
|     ellipsis: { |     ellipsis: { | ||||||
|       tooltip: true, |       tooltip: true, | ||||||
|     }, |     }, | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     title: "View", |     title: "View", | ||||||
|     key: "fileLink", |     key: "view", | ||||||
|     width: 150, |     width: 80, | ||||||
|     render: (row) => { |     render: (row) => { | ||||||
|       return h( |       return h( | ||||||
|         "div", |         "div", | ||||||
| @ -306,101 +231,7 @@ const columns = [ | |||||||
|           }, |           }, | ||||||
|         }, |         }, | ||||||
|         [ |         [ | ||||||
|           row.pdfFile |           h( | ||||||
|             ? h( |  | ||||||
|                 "a", |  | ||||||
|                 { |  | ||||||
|                   href: "javascript:void(0)", |  | ||||||
|                   style: { |  | ||||||
|                     color: "#0078d7", |  | ||||||
|                     textDecoration: "none", |  | ||||||
|                     fontSize: "12px", |  | ||||||
|                   }, |  | ||||||
|                   onClick: (e) => { |  | ||||||
|                     e.preventDefault(); |  | ||||||
|                     handleViewDocument(row.pdfFile, "pdf"); |  | ||||||
|                   }, |  | ||||||
|                   onMouseover: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "underline"; |  | ||||||
|                   }, |  | ||||||
|                   onMouseout: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "none"; |  | ||||||
|                   }, |  | ||||||
|                 }, |  | ||||||
|                 h("img", { |  | ||||||
|                   src: pdfFile, |  | ||||||
|                   alt: "link", |  | ||||||
|                   style: { |  | ||||||
|                     width: "24px", |  | ||||||
|                     height: "24px", |  | ||||||
|                   }, |  | ||||||
|                 }) |  | ||||||
|               ) |  | ||||||
|             : null, |  | ||||||
|           row.wordFile |  | ||||||
|             ? h( |  | ||||||
|                 "a", |  | ||||||
|                 { |  | ||||||
|                   href: "javascript:void(0)", |  | ||||||
|                   style: { |  | ||||||
|                     color: "#0078d7", |  | ||||||
|                     textDecoration: "none", |  | ||||||
|                     fontSize: "12px", |  | ||||||
|                   }, |  | ||||||
|                   onClick: (e) => { |  | ||||||
|                     e.preventDefault(); |  | ||||||
|                     handleViewDocument(row.wordFile, "word"); |  | ||||||
|                   }, |  | ||||||
|                   onMouseover: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "underline"; |  | ||||||
|                   }, |  | ||||||
|                   onMouseout: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "none"; |  | ||||||
|                   }, |  | ||||||
|                 }, |  | ||||||
|                 h("img", { |  | ||||||
|                   src: wordFile, |  | ||||||
|                   alt: "link", |  | ||||||
|                   style: { |  | ||||||
|                     width: "24px", |  | ||||||
|                     height: "24px", |  | ||||||
|                   }, |  | ||||||
|                 }) |  | ||||||
|               ) |  | ||||||
|             : null, |  | ||||||
|           row.excelFile |  | ||||||
|             ? h( |  | ||||||
|                 "a", |  | ||||||
|                 { |  | ||||||
|                   href: "javascript:void(0)", |  | ||||||
|                   style: { |  | ||||||
|                     color: "#0078d7", |  | ||||||
|                     textDecoration: "none", |  | ||||||
|                     fontSize: "12px", |  | ||||||
|                   }, |  | ||||||
|                   onClick: (e) => { |  | ||||||
|                     e.preventDefault(); |  | ||||||
|                     handleViewDocument(row.excelFile, "excel"); |  | ||||||
|                   }, |  | ||||||
|                   onMouseover: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "underline"; |  | ||||||
|                   }, |  | ||||||
|                   onMouseout: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "none"; |  | ||||||
|                   }, |  | ||||||
|                 }, |  | ||||||
|                 h("img", { |  | ||||||
|                   src: excelFile, |  | ||||||
|                   alt: "link", |  | ||||||
|                   style: { |  | ||||||
|                     width: "24px", |  | ||||||
|                     height: "24px", |  | ||||||
|                   }, |  | ||||||
|                 }) |  | ||||||
|               ) |  | ||||||
|             : null, |  | ||||||
|           row.fileLink |  | ||||||
|             ? h( |  | ||||||
|             "a", |             "a", | ||||||
|             { |             { | ||||||
|               href: row.fileLink, |               href: row.fileLink, | ||||||
| @ -417,21 +248,43 @@ const columns = [ | |||||||
|               }, |               }, | ||||||
|             }, |             }, | ||||||
|             h("img", { |             h("img", { | ||||||
|                   src: fileLink, |               src: iconLink, | ||||||
|               alt: "link", |               alt: "link", | ||||||
|               style: { |               style: { | ||||||
|                 width: "24px", |                 width: "24px", | ||||||
|                 height: "24px", |                 height: "24px", | ||||||
|               }, |               }, | ||||||
|             }) |             }) | ||||||
|               ) |           ), | ||||||
|             : null, |  | ||||||
|         ] |         ] | ||||||
|       ); |       ); | ||||||
|     }, |     }, | ||||||
|   }, |   }, | ||||||
| ]; | ]; | ||||||
| 
 | 
 | ||||||
|  | // 筛选后的数据 | ||||||
|  | const filteredData = computed(() => { | ||||||
|  |   let data = state.secFilingsData; | ||||||
|  | 
 | ||||||
|  |   if (state.selectedYear) { | ||||||
|  |     data = data.filter((item) => item.year === state.selectedYear); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   return data; | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // 分页数据 | ||||||
|  | const paginatedData = computed(() => { | ||||||
|  |   const start = (state.currentPage - 1) * state.pageSize; | ||||||
|  |   const end = start + state.pageSize; | ||||||
|  |   return filteredData.value.slice(start, end); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // 总页数 | ||||||
|  | const totalPages = computed(() => { | ||||||
|  |   return Math.ceil(filteredData.value.length / state.pageSize); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
| // 当前页起始索引 | // 当前页起始索引 | ||||||
| const startIndex = computed(() => { | const startIndex = computed(() => { | ||||||
|   return (state.currentPage - 1) * state.pageSize + 1; |   return (state.currentPage - 1) * state.pageSize + 1; | ||||||
| @ -440,34 +293,24 @@ const startIndex = computed(() => { | |||||||
| // 当前页结束索引 | // 当前页结束索引 | ||||||
| const endIndex = computed(() => { | const endIndex = computed(() => { | ||||||
|   const end = state.currentPage * state.pageSize; |   const end = state.currentPage * state.pageSize; | ||||||
|   return Math.min(end, state.total); |   return Math.min(end, filteredData.value.length); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| // 处理年份变化 | // 处理年份变化 | ||||||
| const handleYearChange = (value) => { | const handleYearChange = (value) => { | ||||||
|   state.selectedYear = value; |   state.selectedYear = value; | ||||||
|   state.currentPage = 1; |   state.currentPage = 1; | ||||||
|   getListData(); |  | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // 处理页码变化 | // 处理页码变化 | ||||||
| const handlePageChange = (page) => { | const handlePageChange = (page) => { | ||||||
|   state.currentPage = page; |   state.currentPage = page; | ||||||
|   getListData(); |  | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // 处理每页条数变化 | // 处理每页条数变化 | ||||||
| const handlePageSizeChange = (size) => { | const handlePageSizeChange = (size) => { | ||||||
|   state.pageSize = size; |   state.pageSize = size; | ||||||
|   state.currentPage = 1; |   state.currentPage = 1; | ||||||
|   getListData(); |  | ||||||
| }; |  | ||||||
| // 查看文档 |  | ||||||
| const handleViewDocument = (val, type) => { |  | ||||||
|   window.open( |  | ||||||
|     `${import.meta.env.VITE_PAGE_URL}/office?url=${val}&attachmentName=${type}`, |  | ||||||
|     "_blank" |  | ||||||
|   ); |  | ||||||
| }; | }; | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -33,13 +33,11 @@ | |||||||
|       <div class="table-container"> |       <div class="table-container"> | ||||||
|         <n-data-table |         <n-data-table | ||||||
|           :columns="columns" |           :columns="columns" | ||||||
|           :loading="state.tableLoading" |           :data="paginatedData" | ||||||
|           :data="state.tableData" |  | ||||||
|           :pagination="false" |           :pagination="false" | ||||||
|           :bordered="false" |           :bordered="false" | ||||||
|           :size="'medium'" |           :size="'medium'" | ||||||
|           :row-key="(row) => row.idx" |           :row-key="(row) => row.idx" | ||||||
|           @update:sorter="handleSort" |  | ||||||
|         /> |         /> | ||||||
| 
 | 
 | ||||||
|         <!-- 分页器 --> |         <!-- 分页器 --> | ||||||
| @ -50,7 +48,7 @@ | |||||||
|             v-model:page-size="state.pageSize" |             v-model:page-size="state.pageSize" | ||||||
|             show-size-picker |             show-size-picker | ||||||
|             show-quick-jumper |             show-quick-jumper | ||||||
|             :item-count="state.total" |             :item-count="filteredData.length" | ||||||
|             :page-sizes="[10, 25, 50]" |             :page-sizes="[10, 25, 50]" | ||||||
|             @update:page="handlePageChange" |             @update:page="handlePageChange" | ||||||
|             @update:page-size="handlePageSizeChange" |             @update:page-size="handlePageSizeChange" | ||||||
| @ -65,7 +63,7 @@ | |||||||
| 
 | 
 | ||||||
|           <div class="pagination-info w-full mt-[20px]"> |           <div class="pagination-info w-full mt-[20px]"> | ||||||
|             Displaying {{ startIndex }} - {{ endIndex }} of |             Displaying {{ startIndex }} - {{ endIndex }} of | ||||||
|             {{ state.total }} results |             {{ filteredData.length }} results | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
| @ -78,94 +76,36 @@ import { reactive, computed, h, onMounted } from "vue"; | |||||||
| import { NSelect, NDataTable, NPagination, NButton, NIcon } from "naive-ui"; | import { NSelect, NDataTable, NPagination, NButton, NIcon } from "naive-ui"; | ||||||
| import { useI18n } from "vue-i18n"; | import { useI18n } from "vue-i18n"; | ||||||
| import { useRouter } from "vue-router"; | import { useRouter } from "vue-router"; | ||||||
| 
 | import { fileList } from "@/dict/secFiles.js"; | ||||||
| const { t } = useI18n(); | const { t } = useI18n(); | ||||||
| const router = useRouter(); | const router = useRouter(); | ||||||
| import pdfFile from "@/assets/image/icon/icon-pdf.png"; | import iconLink from "@/assets/image/icon/icon-link.png"; | ||||||
| import wordFile from "@/assets/image/icon/icon-word.png"; |  | ||||||
| import excelFile from "@/assets/image/icon/icon-excel.png"; |  | ||||||
| import fileLink from "@/assets/image/icon/icon-link.png"; |  | ||||||
| // 使用 reactive 管理所有状态 | // 使用 reactive 管理所有状态 | ||||||
| const state = reactive({ | const state = reactive({ | ||||||
|   selectedYear: null, |   selectedYear: null, | ||||||
|   pageSize: 10, |   pageSize: 10, | ||||||
|   currentPage: 1, |   currentPage: 1, | ||||||
|   tableData: [], |  | ||||||
|   tableLoading: false, |  | ||||||
|   total: 0, |  | ||||||
|   sortParams: {}, |  | ||||||
| 
 | 
 | ||||||
|   // 年份选项 |   // 年份选项 | ||||||
|   yearOptions: [ |   yearOptions: [ | ||||||
|     { label: "- Any -", value: null }, |     { label: "- Any -", value: null }, | ||||||
|     { |     { label: "2025", value: 2025 }, | ||||||
|       label: "2025", |     { label: "2024", value: 2024 }, | ||||||
|       value: "2025", |     { label: "2023", value: 2023 }, | ||||||
|     }, |     { label: "2022", value: 2022 }, | ||||||
|     { |     { label: "2021", value: 2021 }, | ||||||
|       label: "2024", |     { label: "2020", value: 2020 }, | ||||||
|       value: "2024", |     { label: "2019", value: 2019 }, | ||||||
|     }, |     { label: "2018", value: 2018 }, | ||||||
|     { |     { label: "2017", value: 2017 }, | ||||||
|       label: "2023", |     { label: "2016", value: 2016 }, | ||||||
|       value: "2023", |     { label: "2015", value: 2015 }, | ||||||
|     }, |     { label: "2014", value: 2014 }, | ||||||
|     { |     { label: "2013", value: 2013 }, | ||||||
|       label: "2022", |     { label: "2012", value: 2012 }, | ||||||
|       value: "2022", |     { label: "2011", value: 2011 }, | ||||||
|     }, |     { label: "2010", value: 2010 }, | ||||||
|     { |     { label: "2009", value: 2009 }, | ||||||
|       label: "2021", |  | ||||||
|       value: "2021", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2020", |  | ||||||
|       value: "2020", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2019", |  | ||||||
|       value: "2019", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2018", |  | ||||||
|       value: "2018", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2017", |  | ||||||
|       value: "2017", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2016", |  | ||||||
|       value: "2016", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2015", |  | ||||||
|       value: "2015", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2014", |  | ||||||
|       value: "2014", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2013", |  | ||||||
|       value: "2013", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2012", |  | ||||||
|       value: "2012", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2011", |  | ||||||
|       value: "2011", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2010", |  | ||||||
|       value: "2010", |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       label: "2009", |  | ||||||
|       value: "2009", |  | ||||||
|     }, |  | ||||||
|   ], |   ], | ||||||
| 
 | 
 | ||||||
|   // 每页条数选项 |   // 每页条数选项 | ||||||
| @ -174,9 +114,13 @@ const state = reactive({ | |||||||
|     { label: "25", value: 25 }, |     { label: "25", value: 25 }, | ||||||
|     { label: "50", value: 50 }, |     { label: "50", value: 50 }, | ||||||
|   ], |   ], | ||||||
| }); |  | ||||||
| 
 | 
 | ||||||
| const monthNames = [ |   // SEC文件数据 | ||||||
|  |   secFilingsData: [], | ||||||
|  | }); | ||||||
|  | onMounted(() => { | ||||||
|  |   // 月份名称映射 | ||||||
|  |   const monthNames = [ | ||||||
|     "Jan", |     "Jan", | ||||||
|     "Feb", |     "Feb", | ||||||
|     "Mar", |     "Mar", | ||||||
| @ -189,28 +133,16 @@ const monthNames = [ | |||||||
|     "Oct", |     "Oct", | ||||||
|     "Nov", |     "Nov", | ||||||
|     "Dec", |     "Dec", | ||||||
| ]; |   ]; | ||||||
| onMounted(() => { | 
 | ||||||
|   getListData(); |   state.secFilingsData = fileList.map((item, index) => { | ||||||
| }); |     // 从 filingDate 中提取年份,支持两种格式: | ||||||
| import axios from "axios"; |     // 1. "Feb 04, 2019" 格式(英文) | ||||||
| const getListData = async () => { |     // 2. "2025-10-24" 格式(ISO格式)转换为英文格式 | ||||||
|   state.tableData = []; |  | ||||||
|   let url = "https://saas.fiee.com/api/fiee/sec-filing/web/list"; |  | ||||||
|   let params = { |  | ||||||
|     page: state.currentPage, |  | ||||||
|     pageSize: state.pageSize, |  | ||||||
|     year: state.selectedYear, |  | ||||||
|   }; |  | ||||||
|   Object.assign(params, state.sortParams); |  | ||||||
|   state.tableLoading = true; |  | ||||||
|   const res = await axios.post(url, params); |  | ||||||
|   if (res.data.status === 0) { |  | ||||||
|     let resData = res.data.data?.data || []; |  | ||||||
|     resData.forEach((item) => { |  | ||||||
|       if (item.filingDate) { |  | ||||||
|     let year = null; |     let year = null; | ||||||
|         let filingDate = item.filingDate; |     let formattedDate = item.filingDate; | ||||||
|  | 
 | ||||||
|  |     if (item.filingDate) { | ||||||
|       if (item.filingDate.includes(", ")) { |       if (item.filingDate.includes(", ")) { | ||||||
|         // "Feb 04, 2019" 格式,已经是英文格式,保持不变 |         // "Feb 04, 2019" 格式,已经是英文格式,保持不变 | ||||||
|         year = parseInt(item.filingDate.split(", ")[1]); |         year = parseInt(item.filingDate.split(", ")[1]); | ||||||
| @ -224,37 +156,29 @@ const getListData = async () => { | |||||||
|         year = yearPart; |         year = yearPart; | ||||||
|         const monthName = monthNames[monthPart - 1]; // 月份从1开始,数组从0开始 |         const monthName = monthNames[monthPart - 1]; // 月份从1开始,数组从0开始 | ||||||
|         const dayFormatted = dayPart.toString().padStart(2, "0"); |         const dayFormatted = dayPart.toString().padStart(2, "0"); | ||||||
|           filingDate = `${monthName} ${dayFormatted}, ${yearPart}`; |         formattedDate = `${monthName} ${dayFormatted}, ${yearPart}`; | ||||||
|           item.year = year; |  | ||||||
|           item.filingDate = filingDate; |  | ||||||
|           item.filing_date = filingDate; |  | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     return { | ||||||
|  |       ...item, | ||||||
|  |       formattedDate: formattedDate, // 更新为统一的英文格式 | ||||||
|  |       year: year, | ||||||
|  |     }; | ||||||
|   }); |   }); | ||||||
|     state.tableData = resData; | }); | ||||||
|     state.total = res.data.data?.total; |  | ||||||
|   } |  | ||||||
|   state.tableLoading = false; |  | ||||||
| }; |  | ||||||
| const handleSort = (sortData) => { |  | ||||||
|   state.sortParams = {}; |  | ||||||
|   if (sortData.order !== false) { |  | ||||||
|     state.sortParams["sortField"] = sortData.columnKey; |  | ||||||
|     state.sortParams["sortOrder"] = sortData.order.replace("end", ""); |  | ||||||
|   } |  | ||||||
|   getListData(); |  | ||||||
| }; |  | ||||||
| // 表格列定义 | // 表格列定义 | ||||||
| const columns = [ | const columns = [ | ||||||
|   { |   { | ||||||
|     title: "Filing Date", |     title: "Filing Date", | ||||||
|     key: "filing_date", |     key: "formattedDate", | ||||||
|     sorter: "default", |     sorter: "default", | ||||||
|     width: 150, |     width: 150, | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     title: "Form", |     title: "Form", | ||||||
|     key: "form", |     key: "form", | ||||||
|  |     sorter: "default", | ||||||
|     width: 120, |     width: 120, | ||||||
|     render: (row) => { |     render: (row) => { | ||||||
|       return h( |       return h( | ||||||
| @ -271,7 +195,7 @@ const columns = [ | |||||||
|             router.push({ |             router.push({ | ||||||
|               path: "/secfilingsDefail", |               path: "/secfilingsDefail", | ||||||
|               query: { |               query: { | ||||||
|                 filingKey: row.filingKey, |                 filingDate: row.filingDate, | ||||||
|               }, |               }, | ||||||
|             }); |             }); | ||||||
|           }, |           }, | ||||||
| @ -289,14 +213,14 @@ const columns = [ | |||||||
|   { |   { | ||||||
|     title: "Description", |     title: "Description", | ||||||
|     key: "description", |     key: "description", | ||||||
|  |     sorter: "default", | ||||||
|     ellipsis: { |     ellipsis: { | ||||||
|       tooltip: true, |       tooltip: true, | ||||||
|     }, |     }, | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     title: "View", |     title: "View", | ||||||
|     key: "fileLink", |     key: "view", | ||||||
|     width: 150, |  | ||||||
|     render: (row) => { |     render: (row) => { | ||||||
|       return h( |       return h( | ||||||
|         "div", |         "div", | ||||||
| @ -307,101 +231,7 @@ const columns = [ | |||||||
|           }, |           }, | ||||||
|         }, |         }, | ||||||
|         [ |         [ | ||||||
|           row.pdfFile |           h( | ||||||
|             ? h( |  | ||||||
|                 "a", |  | ||||||
|                 { |  | ||||||
|                   href: "javascript:void(0)", |  | ||||||
|                   style: { |  | ||||||
|                     color: "#0078d7", |  | ||||||
|                     textDecoration: "none", |  | ||||||
|                     fontSize: "12px", |  | ||||||
|                   }, |  | ||||||
|                   onClick: (e) => { |  | ||||||
|                     e.preventDefault(); |  | ||||||
|                     handleViewDocument(row.pdfFile, "pdf"); |  | ||||||
|                   }, |  | ||||||
|                   onMouseover: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "underline"; |  | ||||||
|                   }, |  | ||||||
|                   onMouseout: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "none"; |  | ||||||
|                   }, |  | ||||||
|                 }, |  | ||||||
|                 h("img", { |  | ||||||
|                   src: pdfFile, |  | ||||||
|                   alt: "link", |  | ||||||
|                   style: { |  | ||||||
|                     width: "24px", |  | ||||||
|                     height: "24px", |  | ||||||
|                   }, |  | ||||||
|                 }) |  | ||||||
|               ) |  | ||||||
|             : null, |  | ||||||
|           row.wordFile |  | ||||||
|             ? h( |  | ||||||
|                 "a", |  | ||||||
|                 { |  | ||||||
|                   href: "javascript:void(0)", |  | ||||||
|                   style: { |  | ||||||
|                     color: "#0078d7", |  | ||||||
|                     textDecoration: "none", |  | ||||||
|                     fontSize: "12px", |  | ||||||
|                   }, |  | ||||||
|                   onClick: (e) => { |  | ||||||
|                     e.preventDefault(); |  | ||||||
|                     handleViewDocument(row.wordFile, "word"); |  | ||||||
|                   }, |  | ||||||
|                   onMouseover: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "underline"; |  | ||||||
|                   }, |  | ||||||
|                   onMouseout: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "none"; |  | ||||||
|                   }, |  | ||||||
|                 }, |  | ||||||
|                 h("img", { |  | ||||||
|                   src: wordFile, |  | ||||||
|                   alt: "link", |  | ||||||
|                   style: { |  | ||||||
|                     width: "24px", |  | ||||||
|                     height: "24px", |  | ||||||
|                   }, |  | ||||||
|                 }) |  | ||||||
|               ) |  | ||||||
|             : null, |  | ||||||
|           row.excelFile |  | ||||||
|             ? h( |  | ||||||
|                 "a", |  | ||||||
|                 { |  | ||||||
|                   href: "javascript:void(0)", |  | ||||||
|                   style: { |  | ||||||
|                     color: "#0078d7", |  | ||||||
|                     textDecoration: "none", |  | ||||||
|                     fontSize: "12px", |  | ||||||
|                   }, |  | ||||||
|                   onClick: (e) => { |  | ||||||
|                     e.preventDefault(); |  | ||||||
|                     handleViewDocument(row.excelFile, "excel"); |  | ||||||
|                   }, |  | ||||||
|                   onMouseover: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "underline"; |  | ||||||
|                   }, |  | ||||||
|                   onMouseout: (e) => { |  | ||||||
|                     e.target.style.textDecoration = "none"; |  | ||||||
|                   }, |  | ||||||
|                 }, |  | ||||||
|                 h("img", { |  | ||||||
|                   src: excelFile, |  | ||||||
|                   alt: "link", |  | ||||||
|                   style: { |  | ||||||
|                     width: "24px", |  | ||||||
|                     height: "24px", |  | ||||||
|                   }, |  | ||||||
|                 }) |  | ||||||
|               ) |  | ||||||
|             : null, |  | ||||||
|           row.fileLink |  | ||||||
|             ? h( |  | ||||||
|             "a", |             "a", | ||||||
|             { |             { | ||||||
|               href: row.fileLink, |               href: row.fileLink, | ||||||
| @ -418,21 +248,43 @@ const columns = [ | |||||||
|               }, |               }, | ||||||
|             }, |             }, | ||||||
|             h("img", { |             h("img", { | ||||||
|                   src: fileLink, |               src: iconLink, | ||||||
|               alt: "link", |               alt: "link", | ||||||
|               style: { |               style: { | ||||||
|                 width: "24px", |                 width: "24px", | ||||||
|                 height: "24px", |                 height: "24px", | ||||||
|               }, |               }, | ||||||
|             }) |             }) | ||||||
|               ) |           ), | ||||||
|             : null, |  | ||||||
|         ] |         ] | ||||||
|       ); |       ); | ||||||
|     }, |     }, | ||||||
|   }, |   }, | ||||||
| ]; | ]; | ||||||
| 
 | 
 | ||||||
|  | // 筛选后的数据 | ||||||
|  | const filteredData = computed(() => { | ||||||
|  |   let data = state.secFilingsData; | ||||||
|  | 
 | ||||||
|  |   if (state.selectedYear) { | ||||||
|  |     data = data.filter((item) => item.year === state.selectedYear); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   return data; | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // 分页数据 | ||||||
|  | const paginatedData = computed(() => { | ||||||
|  |   const start = (state.currentPage - 1) * state.pageSize; | ||||||
|  |   const end = start + state.pageSize; | ||||||
|  |   return filteredData.value.slice(start, end); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // 总页数 | ||||||
|  | const totalPages = computed(() => { | ||||||
|  |   return Math.ceil(filteredData.value.length / state.pageSize); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
| // 当前页起始索引 | // 当前页起始索引 | ||||||
| const startIndex = computed(() => { | const startIndex = computed(() => { | ||||||
|   return (state.currentPage - 1) * state.pageSize + 1; |   return (state.currentPage - 1) * state.pageSize + 1; | ||||||
| @ -441,34 +293,24 @@ const startIndex = computed(() => { | |||||||
| // 当前页结束索引 | // 当前页结束索引 | ||||||
| const endIndex = computed(() => { | const endIndex = computed(() => { | ||||||
|   const end = state.currentPage * state.pageSize; |   const end = state.currentPage * state.pageSize; | ||||||
|   return Math.min(end, state.total); |   return Math.min(end, filteredData.value.length); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| // 处理年份变化 | // 处理年份变化 | ||||||
| const handleYearChange = (value) => { | const handleYearChange = (value) => { | ||||||
|   state.selectedYear = value; |   state.selectedYear = value; | ||||||
|   state.currentPage = 1; |   state.currentPage = 1; | ||||||
|   getListData(); |  | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // 处理页码变化 | // 处理页码变化 | ||||||
| const handlePageChange = (page) => { | const handlePageChange = (page) => { | ||||||
|   state.currentPage = page; |   state.currentPage = page; | ||||||
|   getListData(); |  | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // 处理每页条数变化 | // 处理每页条数变化 | ||||||
| const handlePageSizeChange = (size) => { | const handlePageSizeChange = (size) => { | ||||||
|   state.pageSize = size; |   state.pageSize = size; | ||||||
|   state.currentPage = 1; |   state.currentPage = 1; | ||||||
|   getListData(); |  | ||||||
| }; |  | ||||||
| // 查看文档 |  | ||||||
| const handleViewDocument = (val, type) => { |  | ||||||
|   window.open( |  | ||||||
|     `${import.meta.env.VITE_PAGE_URL}/office?url=${val}&attachmentName=${type}`, |  | ||||||
|     "_blank" |  | ||||||
|   ); |  | ||||||
| }; | }; | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -10,7 +10,7 @@ | |||||||
|         <div class="details-grid"> |         <div class="details-grid"> | ||||||
|           <div class="detail-item"> |           <div class="detail-item"> | ||||||
|             <span class="detail-label">Form:</span> |             <span class="detail-label">Form:</span> | ||||||
|             <a :href="filingData.fileLink" class="detail-value link">{{ |             <a :href="filingData.htmlLink" class="detail-value link">{{ | ||||||
|               filingData.form |               filingData.form | ||||||
|             }}</a> |             }}</a> | ||||||
|           </div> |           </div> | ||||||
| @ -37,39 +37,9 @@ | |||||||
|       <div class="section"> |       <div class="section"> | ||||||
|         <h2 class="section-title">Filing Formats</h2> |         <h2 class="section-title">Filing Formats</h2> | ||||||
|         <div class="formats-list"> |         <div class="formats-list"> | ||||||
|           <div class="format-item" v-if="filingData.pdfFile"> |           <div class="format-item"> | ||||||
|             <img :src="pdfFile" alt="link" class="format-icon" /> |             <img :src="iconLink" alt="link" class="format-icon" /> | ||||||
|             <a |             <a :href="filingData.htmlLink" class="format-link" target="_blank" | ||||||
|               href="javascript:void(0)" |  | ||||||
|               class="format-link" |  | ||||||
|               target="_blank" |  | ||||||
|               @click="handleViewDocument(filingData.pdfFile, 'pdf')" |  | ||||||
|               >View HTML</a |  | ||||||
|             > |  | ||||||
|           </div> |  | ||||||
|           <div class="format-item" v-if="filingData.wordFile"> |  | ||||||
|             <img :src="wordFile" alt="link" class="format-icon" /> |  | ||||||
|             <a |  | ||||||
|               href="javascript:void(0)" |  | ||||||
|               class="format-link" |  | ||||||
|               target="_blank" |  | ||||||
|               @click="handleViewDocument(filingData.wordFile, 'word')" |  | ||||||
|               >View HTML</a |  | ||||||
|             > |  | ||||||
|           </div> |  | ||||||
|           <div class="format-item" v-if="filingData.excelFile"> |  | ||||||
|             <img :src="excelFile" alt="link" class="format-icon" /> |  | ||||||
|             <a |  | ||||||
|               href="javascript:void(0)" |  | ||||||
|               class="format-link" |  | ||||||
|               target="_blank" |  | ||||||
|               @click="handleViewDocument(filingData.excelFile, 'excel')" |  | ||||||
|               >View HTML</a |  | ||||||
|             > |  | ||||||
|           </div> |  | ||||||
|           <div class="format-item" v-if="filingData.fileLink"> |  | ||||||
|             <img :src="fileLink" alt="link" class="format-icon" /> |  | ||||||
|             <a :href="filingData.fileLink" class="format-link" target="_blank" |  | ||||||
|               >View HTML</a |               >View HTML</a | ||||||
|             > |             > | ||||||
|           </div> |           </div> | ||||||
| @ -90,7 +60,7 @@ | |||||||
|             v-for="(item, idx) in filingData.dataFiles" |             v-for="(item, idx) in filingData.dataFiles" | ||||||
|             :key="idx" |             :key="idx" | ||||||
|           > |           > | ||||||
|             <img :src="fileLink" alt="link" class="format-icon" /> |             <img :src="iconLink" alt="link" class="format-icon" /> | ||||||
|             <a :href="item.fileUrl" class="format-link" target="_blank">{{ |             <a :href="item.fileUrl" class="format-link" target="_blank">{{ | ||||||
|               item.description |               item.description | ||||||
|             }}</a> |             }}</a> | ||||||
| @ -103,12 +73,8 @@ | |||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import { ref, onMounted } from "vue"; | import { ref, onMounted } from "vue"; | ||||||
| 
 | import iconLink from "@/assets/image/icon/icon-link.png"; | ||||||
| import pdfFile from "@/assets/image/icon/icon-pdf.png"; | import { fileList } from "@/dict/secFiles.js"; | ||||||
| import wordFile from "@/assets/image/icon/icon-word.png"; |  | ||||||
| import excelFile from "@/assets/image/icon/icon-excel.png"; |  | ||||||
| import fileLink from "@/assets/image/icon/icon-link.png"; |  | ||||||
| 
 |  | ||||||
| import { useRoute } from "vue-router"; | import { useRoute } from "vue-router"; | ||||||
| 
 | 
 | ||||||
| // 这里可以根据路由参数或props获取具体的文件详情 | // 这里可以根据路由参数或props获取具体的文件详情 | ||||||
| @ -118,48 +84,27 @@ const filingData = ref({ | |||||||
|   formDescription: "", |   formDescription: "", | ||||||
|   company: "", |   company: "", | ||||||
|   issuer: "", |   issuer: "", | ||||||
|   fileLink: "#", |   htmlLink: "#", | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| const route = useRoute(); | const route = useRoute(); | ||||||
| 
 | 
 | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   const { filingKey } = route.query; |   const { idx } = route.query; | ||||||
|   getPageData(filingKey); |   const file = fileList.find((item) => item.idx == idx); | ||||||
| }); |  | ||||||
| import axios from "axios"; |  | ||||||
| const getPageData = async (filingKey) => { |  | ||||||
|   let url = "https://saas.fiee.com/api/fiee/sec-filing/web/detail"; |  | ||||||
|   let params = { |  | ||||||
|     filingKey, |  | ||||||
|   }; |  | ||||||
|   const res = await axios.post(url, params); |  | ||||||
|   if (res.data.status === 0) { |  | ||||||
|     let file = res.data.data.data; |  | ||||||
|     console.log(file); |  | ||||||
|   if (file) { |   if (file) { | ||||||
|     filingData.value = { |     filingData.value = { | ||||||
|       form: file.form, |       form: file.form, | ||||||
|       filingDate: file.filingDate, |       filingDate: file.filingDate, | ||||||
|       formDescription: file.formDescription, |       formDescription: file.formDescription, | ||||||
|         fileLink: file.fileLink || "", |       htmlLink: file.fileLink || "#", | ||||||
|         pdfFile: file.pdfFile || "", |  | ||||||
|         wordFile: file.wordFile || "", |  | ||||||
|         excelFile: file.excelFile || "", |  | ||||||
|       dataFiles: file.dataFiles || [], |       dataFiles: file.dataFiles || [], | ||||||
|       company: "FiEE, Inc. ", |       company: "FiEE, Inc. ", | ||||||
|       issuer: "FiEE, Inc. ", |       issuer: "FiEE, Inc. ", | ||||||
|     }; |     }; | ||||||
|   } |   } | ||||||
|   } |   // console.log(filingData.value); | ||||||
| }; | }); | ||||||
| // 查看文档 |  | ||||||
| const handleViewDocument = (val, type) => { |  | ||||||
|   window.open( |  | ||||||
|     `${import.meta.env.VITE_PAGE_URL}/office?url=${val}&attachmentName=${type}`, |  | ||||||
|     "_blank" |  | ||||||
|   ); |  | ||||||
| }; |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
|  | |||||||
| @ -10,7 +10,7 @@ | |||||||
|         <div class="details-grid"> |         <div class="details-grid"> | ||||||
|           <div class="detail-item"> |           <div class="detail-item"> | ||||||
|             <span class="detail-label">Form:</span> |             <span class="detail-label">Form:</span> | ||||||
|             <a :href="filingData.fileLink" class="detail-value link">{{ |             <a :href="filingData.htmlLink" class="detail-value link">{{ | ||||||
|               filingData.form |               filingData.form | ||||||
|             }}</a> |             }}</a> | ||||||
|           </div> |           </div> | ||||||
| @ -37,39 +37,9 @@ | |||||||
|       <div class="section"> |       <div class="section"> | ||||||
|         <h2 class="section-title">Filing Formats</h2> |         <h2 class="section-title">Filing Formats</h2> | ||||||
|         <div class="formats-list"> |         <div class="formats-list"> | ||||||
|           <div class="format-item" v-if="filingData.pdfFile"> |           <div class="format-item"> | ||||||
|             <img :src="pdfFile" alt="link" class="format-icon" /> |             <img :src="iconLink" alt="link" class="format-icon" /> | ||||||
|             <a |             <a :href="filingData.htmlLink" class="format-link" target="_blank" | ||||||
|               href="javascript:void(0)" |  | ||||||
|               class="format-link" |  | ||||||
|               target="_blank" |  | ||||||
|               @click="handleViewDocument(filingData.pdfFile, 'pdf')" |  | ||||||
|               >View HTML</a |  | ||||||
|             > |  | ||||||
|           </div> |  | ||||||
|           <div class="format-item" v-if="filingData.wordFile"> |  | ||||||
|             <img :src="wordFile" alt="link" class="format-icon" /> |  | ||||||
|             <a |  | ||||||
|               href="javascript:void(0)" |  | ||||||
|               class="format-link" |  | ||||||
|               target="_blank" |  | ||||||
|               @click="handleViewDocument(filingData.wordFile, 'word')" |  | ||||||
|               >View HTML</a |  | ||||||
|             > |  | ||||||
|           </div> |  | ||||||
|           <div class="format-item" v-if="filingData.excelFile"> |  | ||||||
|             <img :src="excelFile" alt="link" class="format-icon" /> |  | ||||||
|             <a |  | ||||||
|               href="javascript:void(0)" |  | ||||||
|               class="format-link" |  | ||||||
|               target="_blank" |  | ||||||
|               @click="handleViewDocument(filingData.excelFile, 'excel')" |  | ||||||
|               >View HTML</a |  | ||||||
|             > |  | ||||||
|           </div> |  | ||||||
|           <div class="format-item" v-if="filingData.fileLink"> |  | ||||||
|             <img :src="fileLink" alt="link" class="format-icon" /> |  | ||||||
|             <a :href="filingData.fileLink" class="format-link" target="_blank" |  | ||||||
|               >View HTML</a |               >View HTML</a | ||||||
|             > |             > | ||||||
|           </div> |           </div> | ||||||
| @ -90,7 +60,7 @@ | |||||||
|             v-for="(item, idx) in filingData.dataFiles" |             v-for="(item, idx) in filingData.dataFiles" | ||||||
|             :key="idx" |             :key="idx" | ||||||
|           > |           > | ||||||
|             <img :src="fileLink" alt="link" class="format-icon" /> |             <img :src="iconLink" alt="link" class="format-icon" /> | ||||||
|             <a :href="item.fileUrl" class="format-link" target="_blank">{{ |             <a :href="item.fileUrl" class="format-link" target="_blank">{{ | ||||||
|               item.description |               item.description | ||||||
|             }}</a> |             }}</a> | ||||||
| @ -103,12 +73,8 @@ | |||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import { ref, onMounted } from "vue"; | import { ref, onMounted } from "vue"; | ||||||
| 
 | import iconLink from "@/assets/image/icon/icon-link.png"; | ||||||
| import pdfFile from "@/assets/image/icon/icon-pdf.png"; | import { fileList } from "@/dict/secFiles.js"; | ||||||
| import wordFile from "@/assets/image/icon/icon-word.png"; |  | ||||||
| import excelFile from "@/assets/image/icon/icon-excel.png"; |  | ||||||
| import fileLink from "@/assets/image/icon/icon-link.png"; |  | ||||||
| 
 |  | ||||||
| import { useRoute } from "vue-router"; | import { useRoute } from "vue-router"; | ||||||
| 
 | 
 | ||||||
| // 这里可以根据路由参数或props获取具体的文件详情 | // 这里可以根据路由参数或props获取具体的文件详情 | ||||||
| @ -118,48 +84,26 @@ const filingData = ref({ | |||||||
|   formDescription: "", |   formDescription: "", | ||||||
|   company: "", |   company: "", | ||||||
|   issuer: "", |   issuer: "", | ||||||
|   fileLink: "#", |   htmlLink: "#", | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| const route = useRoute(); | const route = useRoute(); | ||||||
| 
 | 
 | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   const { filingKey } = route.query; |   const { idx } = route.query; | ||||||
|   getPageData(filingKey); |   const file = fileList.find((item) => item.idx == idx); | ||||||
| }); |  | ||||||
| import axios from "axios"; |  | ||||||
| const getPageData = async (filingKey) => { |  | ||||||
|   let url = "https://saas.fiee.com/api/fiee/sec-filing/web/detail"; |  | ||||||
|   let params = { |  | ||||||
|     filingKey, |  | ||||||
|   }; |  | ||||||
|   const res = await axios.post(url, params); |  | ||||||
|   if (res.data.status === 0) { |  | ||||||
|     let file = res.data.data.data; |  | ||||||
|     console.log(file); |  | ||||||
|   if (file) { |   if (file) { | ||||||
|     filingData.value = { |     filingData.value = { | ||||||
|       form: file.form, |       form: file.form, | ||||||
|       filingDate: file.filingDate, |       filingDate: file.filingDate, | ||||||
|       formDescription: file.formDescription, |       formDescription: file.formDescription, | ||||||
|         fileLink: file.fileLink || "", |       htmlLink: file.fileLink || "#", | ||||||
|         pdfFile: file.pdfFile || "", |  | ||||||
|         wordFile: file.wordFile || "", |  | ||||||
|         excelFile: file.excelFile || "", |  | ||||||
|       dataFiles: file.dataFiles || [], |       dataFiles: file.dataFiles || [], | ||||||
|       company: "FiEE, Inc. ", |       company: "FiEE, Inc. ", | ||||||
|       issuer: "FiEE, Inc. ", |       issuer: "FiEE, Inc. ", | ||||||
|     }; |     }; | ||||||
|   } |   } | ||||||
|   } | }); | ||||||
| }; |  | ||||||
| // 查看文档 |  | ||||||
| const handleViewDocument = (val, type) => { |  | ||||||
|   window.open( |  | ||||||
|     `${import.meta.env.VITE_PAGE_URL}/office?url=${val}&attachmentName=${type}`, |  | ||||||
|     "_blank" |  | ||||||
|   ); |  | ||||||
| }; |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
|  | |||||||
| @ -10,7 +10,7 @@ | |||||||
|         <div class="details-grid"> |         <div class="details-grid"> | ||||||
|           <div class="detail-item"> |           <div class="detail-item"> | ||||||
|             <span class="detail-label">Form:</span> |             <span class="detail-label">Form:</span> | ||||||
|             <a :href="filingData.fileLink" class="detail-value link">{{ |             <a :href="filingData.htmlLink" class="detail-value link">{{ | ||||||
|               filingData.form |               filingData.form | ||||||
|             }}</a> |             }}</a> | ||||||
|           </div> |           </div> | ||||||
| @ -37,39 +37,9 @@ | |||||||
|       <div class="section"> |       <div class="section"> | ||||||
|         <h2 class="section-title">Filing Formats</h2> |         <h2 class="section-title">Filing Formats</h2> | ||||||
|         <div class="formats-list"> |         <div class="formats-list"> | ||||||
|           <div class="format-item" v-if="filingData.pdfFile"> |           <div class="format-item"> | ||||||
|             <img :src="pdfFile" alt="link" class="format-icon" /> |             <img :src="iconLink" alt="link" class="format-icon" /> | ||||||
|             <a |             <a :href="filingData.htmlLink" class="format-link" target="_blank" | ||||||
|               href="javascript:void(0)" |  | ||||||
|               class="format-link" |  | ||||||
|               target="_blank" |  | ||||||
|               @click="handleViewDocument(filingData.pdfFile, 'pdf')" |  | ||||||
|               >View HTML</a |  | ||||||
|             > |  | ||||||
|           </div> |  | ||||||
|           <div class="format-item" v-if="filingData.wordFile"> |  | ||||||
|             <img :src="wordFile" alt="link" class="format-icon" /> |  | ||||||
|             <a |  | ||||||
|               href="javascript:void(0)" |  | ||||||
|               class="format-link" |  | ||||||
|               target="_blank" |  | ||||||
|               @click="handleViewDocument(filingData.wordFile, 'word')" |  | ||||||
|               >View HTML</a |  | ||||||
|             > |  | ||||||
|           </div> |  | ||||||
|           <div class="format-item" v-if="filingData.excelFile"> |  | ||||||
|             <img :src="excelFile" alt="link" class="format-icon" /> |  | ||||||
|             <a |  | ||||||
|               href="javascript:void(0)" |  | ||||||
|               class="format-link" |  | ||||||
|               target="_blank" |  | ||||||
|               @click="handleViewDocument(filingData.excelFile, 'excel')" |  | ||||||
|               >View HTML</a |  | ||||||
|             > |  | ||||||
|           </div> |  | ||||||
|           <div class="format-item" v-if="filingData.fileLink"> |  | ||||||
|             <img :src="fileLink" alt="link" class="format-icon" /> |  | ||||||
|             <a :href="filingData.fileLink" class="format-link" target="_blank" |  | ||||||
|               >View HTML</a |               >View HTML</a | ||||||
|             > |             > | ||||||
|           </div> |           </div> | ||||||
| @ -90,7 +60,7 @@ | |||||||
|             v-for="(item, idx) in filingData.dataFiles" |             v-for="(item, idx) in filingData.dataFiles" | ||||||
|             :key="idx" |             :key="idx" | ||||||
|           > |           > | ||||||
|             <img :src="fileLink" alt="link" class="format-icon" /> |             <img :src="iconLink" alt="link" class="format-icon" /> | ||||||
|             <a :href="item.fileUrl" class="format-link" target="_blank">{{ |             <a :href="item.fileUrl" class="format-link" target="_blank">{{ | ||||||
|               item.description |               item.description | ||||||
|             }}</a> |             }}</a> | ||||||
| @ -103,12 +73,8 @@ | |||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import { ref, onMounted } from "vue"; | import { ref, onMounted } from "vue"; | ||||||
| 
 | import iconLink from "@/assets/image/icon/icon-link.png"; | ||||||
| import pdfFile from "@/assets/image/icon/icon-pdf.png"; | import { fileList } from "@/dict/secFiles.js"; | ||||||
| import wordFile from "@/assets/image/icon/icon-word.png"; |  | ||||||
| import excelFile from "@/assets/image/icon/icon-excel.png"; |  | ||||||
| import fileLink from "@/assets/image/icon/icon-link.png"; |  | ||||||
| 
 |  | ||||||
| import { useRoute } from "vue-router"; | import { useRoute } from "vue-router"; | ||||||
| 
 | 
 | ||||||
| // 这里可以根据路由参数或props获取具体的文件详情 | // 这里可以根据路由参数或props获取具体的文件详情 | ||||||
| @ -118,48 +84,27 @@ const filingData = ref({ | |||||||
|   formDescription: "", |   formDescription: "", | ||||||
|   company: "", |   company: "", | ||||||
|   issuer: "", |   issuer: "", | ||||||
|   fileLink: "#", |   htmlLink: "#", | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| const route = useRoute(); | const route = useRoute(); | ||||||
| 
 | 
 | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   const { filingKey } = route.query; |   const { idx } = route.query; | ||||||
|   getPageData(filingKey); |   const file = fileList.find((item) => item.idx == idx); | ||||||
| }); |  | ||||||
| import axios from "axios"; |  | ||||||
| const getPageData = async (filingKey) => { |  | ||||||
|   let url = "https://saas.fiee.com/api/fiee/sec-filing/web/detail"; |  | ||||||
|   let params = { |  | ||||||
|     filingKey, |  | ||||||
|   }; |  | ||||||
|   const res = await axios.post(url, params); |  | ||||||
|   if (res.data.status === 0) { |  | ||||||
|     let file = res.data.data.data; |  | ||||||
|     console.log(file); |  | ||||||
|   if (file) { |   if (file) { | ||||||
|     filingData.value = { |     filingData.value = { | ||||||
|       form: file.form, |       form: file.form, | ||||||
|       filingDate: file.filingDate, |       filingDate: file.filingDate, | ||||||
|       formDescription: file.formDescription, |       formDescription: file.formDescription, | ||||||
|         fileLink: file.fileLink || "", |       htmlLink: file.fileLink || "#", | ||||||
|         pdfFile: file.pdfFile || "", |  | ||||||
|         wordFile: file.wordFile || "", |  | ||||||
|         excelFile: file.excelFile || "", |  | ||||||
|       dataFiles: file.dataFiles || [], |       dataFiles: file.dataFiles || [], | ||||||
|       company: "FiEE, Inc. ", |       company: "FiEE, Inc. ", | ||||||
|       issuer: "FiEE, Inc. ", |       issuer: "FiEE, Inc. ", | ||||||
|     }; |     }; | ||||||
|   } |   } | ||||||
|   } |   // console.log(filingData.value); | ||||||
| }; | }); | ||||||
| // 查看文档 |  | ||||||
| const handleViewDocument = (val, type) => { |  | ||||||
|   window.open( |  | ||||||
|     `${import.meta.env.VITE_PAGE_URL}/office?url=${val}&attachmentName=${type}`, |  | ||||||
|     "_blank" |  | ||||||
|   ); |  | ||||||
| }; |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
|  | |||||||
| @ -10,7 +10,7 @@ | |||||||
|         <div class="details-grid"> |         <div class="details-grid"> | ||||||
|           <div class="detail-item"> |           <div class="detail-item"> | ||||||
|             <span class="detail-label">Form:</span> |             <span class="detail-label">Form:</span> | ||||||
|             <a :href="filingData.fileLink" class="detail-value link">{{ |             <a :href="filingData.htmlLink" class="detail-value link">{{ | ||||||
|               filingData.form |               filingData.form | ||||||
|             }}</a> |             }}</a> | ||||||
|           </div> |           </div> | ||||||
| @ -37,39 +37,9 @@ | |||||||
|       <div class="section"> |       <div class="section"> | ||||||
|         <h2 class="section-title">Filing Formats</h2> |         <h2 class="section-title">Filing Formats</h2> | ||||||
|         <div class="formats-list"> |         <div class="formats-list"> | ||||||
|           <div class="format-item" v-if="filingData.pdfFile"> |           <div class="format-item"> | ||||||
|             <img :src="pdfFile" alt="link" class="format-icon" /> |             <img :src="iconLink" alt="link" class="format-icon" /> | ||||||
|             <a |             <a :href="filingData.htmlLink" class="format-link" target="_blank" | ||||||
|               href="javascript:void(0)" |  | ||||||
|               class="format-link" |  | ||||||
|               target="_blank" |  | ||||||
|               @click="handleViewDocument(filingData.pdfFile, 'pdf')" |  | ||||||
|               >View HTML</a |  | ||||||
|             > |  | ||||||
|           </div> |  | ||||||
|           <div class="format-item" v-if="filingData.wordFile"> |  | ||||||
|             <img :src="wordFile" alt="link" class="format-icon" /> |  | ||||||
|             <a |  | ||||||
|               href="javascript:void(0)" |  | ||||||
|               class="format-link" |  | ||||||
|               target="_blank" |  | ||||||
|               @click="handleViewDocument(filingData.wordFile, 'word')" |  | ||||||
|               >View HTML</a |  | ||||||
|             > |  | ||||||
|           </div> |  | ||||||
|           <div class="format-item" v-if="filingData.excelFile"> |  | ||||||
|             <img :src="excelFile" alt="link" class="format-icon" /> |  | ||||||
|             <a |  | ||||||
|               href="javascript:void(0)" |  | ||||||
|               class="format-link" |  | ||||||
|               target="_blank" |  | ||||||
|               @click="handleViewDocument(filingData.excelFile, 'excel')" |  | ||||||
|               >View HTML</a |  | ||||||
|             > |  | ||||||
|           </div> |  | ||||||
|           <div class="format-item" v-if="filingData.fileLink"> |  | ||||||
|             <img :src="fileLink" alt="link" class="format-icon" /> |  | ||||||
|             <a :href="filingData.fileLink" class="format-link" target="_blank" |  | ||||||
|               >View HTML</a |               >View HTML</a | ||||||
|             > |             > | ||||||
|           </div> |           </div> | ||||||
| @ -90,7 +60,7 @@ | |||||||
|             v-for="(item, idx) in filingData.dataFiles" |             v-for="(item, idx) in filingData.dataFiles" | ||||||
|             :key="idx" |             :key="idx" | ||||||
|           > |           > | ||||||
|             <img :src="fileLink" alt="link" class="format-icon" /> |             <img :src="iconLink" alt="link" class="format-icon" /> | ||||||
|             <a :href="item.fileUrl" class="format-link" target="_blank">{{ |             <a :href="item.fileUrl" class="format-link" target="_blank">{{ | ||||||
|               item.description |               item.description | ||||||
|             }}</a> |             }}</a> | ||||||
| @ -103,12 +73,8 @@ | |||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import { ref, onMounted } from "vue"; | import { ref, onMounted } from "vue"; | ||||||
| 
 | import iconLink from "@/assets/image/icon/icon-link.png"; | ||||||
| import pdfFile from "@/assets/image/icon/icon-pdf.png"; | import { fileList } from "@/dict/secFiles.js"; | ||||||
| import wordFile from "@/assets/image/icon/icon-word.png"; |  | ||||||
| import excelFile from "@/assets/image/icon/icon-excel.png"; |  | ||||||
| import fileLink from "@/assets/image/icon/icon-link.png"; |  | ||||||
| 
 |  | ||||||
| import { useRoute } from "vue-router"; | import { useRoute } from "vue-router"; | ||||||
| 
 | 
 | ||||||
| // 这里可以根据路由参数或props获取具体的文件详情 | // 这里可以根据路由参数或props获取具体的文件详情 | ||||||
| @ -118,48 +84,27 @@ const filingData = ref({ | |||||||
|   formDescription: "", |   formDescription: "", | ||||||
|   company: "", |   company: "", | ||||||
|   issuer: "", |   issuer: "", | ||||||
|   fileLink: "#", |   htmlLink: "#", | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| const route = useRoute(); | const route = useRoute(); | ||||||
| 
 | 
 | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   const { filingKey } = route.query; |   const { idx } = route.query; | ||||||
|   getPageData(filingKey); |   const file = fileList.find((item) => item.idx == idx); | ||||||
| }); |  | ||||||
| import axios from "axios"; |  | ||||||
| const getPageData = async (filingKey) => { |  | ||||||
|   let url = "https://saas.fiee.com/api/fiee/sec-filing/web/detail"; |  | ||||||
|   let params = { |  | ||||||
|     filingKey, |  | ||||||
|   }; |  | ||||||
|   const res = await axios.post(url, params); |  | ||||||
|   if (res.data.status === 0) { |  | ||||||
|     let file = res.data.data.data; |  | ||||||
|     console.log(file); |  | ||||||
|   if (file) { |   if (file) { | ||||||
|     filingData.value = { |     filingData.value = { | ||||||
|       form: file.form, |       form: file.form, | ||||||
|       filingDate: file.filingDate, |       filingDate: file.filingDate, | ||||||
|       formDescription: file.formDescription, |       formDescription: file.formDescription, | ||||||
|         fileLink: file.fileLink || "", |       htmlLink: file.fileLink || "#", | ||||||
|         pdfFile: file.pdfFile || "", |  | ||||||
|         wordFile: file.wordFile || "", |  | ||||||
|         excelFile: file.excelFile || "", |  | ||||||
|       dataFiles: file.dataFiles || [], |       dataFiles: file.dataFiles || [], | ||||||
|       company: "FiEE, Inc. ", |       company: "FiEE, Inc. ", | ||||||
|       issuer: "FiEE, Inc. ", |       issuer: "FiEE, Inc. ", | ||||||
|     }; |     }; | ||||||
|   } |   } | ||||||
|   } |   // console.log(filingData.value); | ||||||
| }; | }); | ||||||
| // 查看文档 |  | ||||||
| const handleViewDocument = (val, type) => { |  | ||||||
|   window.open( |  | ||||||
|     `${import.meta.env.VITE_PAGE_URL}/office?url=${val}&attachmentName=${type}`, |  | ||||||
|     "_blank" |  | ||||||
|   ); |  | ||||||
| }; |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user