Compare commits
	
		
			No commits in common. "b184eba64d6a6191e0295736a2333466639e151b" and "28f6123e930fcd7b52c909e12d027cc8619e483e" have entirely different histories.
		
	
	
		
			b184eba64d
			...
			28f6123e93
		
	
		
| @ -18,7 +18,6 @@ | |||||||
|     "axios": "^1.7.3", |     "axios": "^1.7.3", | ||||||
|     "cnjm-postcss-px-to-viewport": "^1.0.1", |     "cnjm-postcss-px-to-viewport": "^1.0.1", | ||||||
|     "countup.js": "^2.8.2", |     "countup.js": "^2.8.2", | ||||||
|     "dayjs": "^1.11.13", |  | ||||||
|     "echarts": "^5.6.0", |     "echarts": "^5.6.0", | ||||||
|     "gsap": "^3.12.5", |     "gsap": "^3.12.5", | ||||||
|     "jsdom": "^24.0.0", |     "jsdom": "^24.0.0", | ||||||
|  | |||||||
| @ -29,9 +29,6 @@ importers: | |||||||
|       countup.js: |       countup.js: | ||||||
|         specifier: ^2.8.2 |         specifier: ^2.8.2 | ||||||
|         version: 2.8.2 |         version: 2.8.2 | ||||||
|       dayjs: |  | ||||||
|         specifier: ^1.11.13 |  | ||||||
|         version: 1.11.13 |  | ||||||
|       echarts: |       echarts: | ||||||
|         specifier: ^5.6.0 |         specifier: ^5.6.0 | ||||||
|         version: 5.6.0 |         version: 5.6.0 | ||||||
| @ -2071,9 +2068,6 @@ packages: | |||||||
|   date-fns@3.6.0: |   date-fns@3.6.0: | ||||||
|     resolution: {integrity: sha512-fRHTG8g/Gif+kSh50gaGEdToemgfj74aRX3swtiouboip5JDLAyDE9F11nHMIcvOaXeOC6D7SpNhi7uFyB7Uww==} |     resolution: {integrity: sha512-fRHTG8g/Gif+kSh50gaGEdToemgfj74aRX3swtiouboip5JDLAyDE9F11nHMIcvOaXeOC6D7SpNhi7uFyB7Uww==} | ||||||
| 
 | 
 | ||||||
|   dayjs@1.11.13: |  | ||||||
|     resolution: {integrity: sha512-oaMBel6gjolK862uaPQOVTA7q3TZhuSvuMQAAglQDOWYO9A91IrAOUJEyKVlqJlHE0vq5p5UXxzdPfMH/x6xNg==} |  | ||||||
| 
 |  | ||||||
|   debug@4.3.6: |   debug@4.3.6: | ||||||
|     resolution: {integrity: sha512-O/09Bd4Z1fBrU4VzkhFqVgpPzaGbw6Sm9FEkBT1A/YBXQFGuuSxa1dN2nxgxS34JmKXqYx8CZAwEVoJFImUXIg==} |     resolution: {integrity: sha512-O/09Bd4Z1fBrU4VzkhFqVgpPzaGbw6Sm9FEkBT1A/YBXQFGuuSxa1dN2nxgxS34JmKXqYx8CZAwEVoJFImUXIg==} | ||||||
|     engines: {node: '>=6.0'} |     engines: {node: '>=6.0'} | ||||||
| @ -6484,8 +6478,6 @@ snapshots: | |||||||
| 
 | 
 | ||||||
|   date-fns@3.6.0: {} |   date-fns@3.6.0: {} | ||||||
| 
 | 
 | ||||||
|   dayjs@1.11.13: {} |  | ||||||
| 
 |  | ||||||
|   debug@4.3.6: |   debug@4.3.6: | ||||||
|     dependencies: |     dependencies: | ||||||
|       ms: 2.1.2 |       ms: 2.1.2 | ||||||
|  | |||||||
| @ -1,9 +1,6 @@ | |||||||
| import { ref } from 'vue' | import { ref } from 'vue' | ||||||
| import { createGlobalState, useLocalStorage } from '@vueuse/core' | import { createGlobalState, useLocalStorage } from '@vueuse/core' | ||||||
| import axios from 'axios' | import axios from 'axios' | ||||||
| import dayjs from 'dayjs' |  | ||||||
| import utc from 'dayjs/plugin/utc' |  | ||||||
| import timezone from 'dayjs/plugin/timezone' |  | ||||||
| 
 | 
 | ||||||
| export const useStockQuote = createGlobalState(() => { | export const useStockQuote = createGlobalState(() => { | ||||||
|   const stockQuote = useLocalStorage('stockQuote', { |   const stockQuote = useLocalStorage('stockQuote', { | ||||||
| @ -29,27 +26,7 @@ const options = { | |||||||
|   timeZoneName: 'short' |   timeZoneName: 'short' | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| dayjs.extend(utc) | const formatted = ref(date.toLocaleString('en-US', options)) | ||||||
| dayjs.extend(timezone) |  | ||||||
| 
 |  | ||||||
| const getFormattedFriday = () => { |  | ||||||
|   const now = dayjs().tz('America/New_York') |  | ||||||
|   // 本周五16:00
 |  | ||||||
|   const thisFriday = now.day() >= 5 |  | ||||||
|     ? now.day(5).hour(16).minute(0).second(0).millisecond(0) |  | ||||||
|     : now.day(5 - 7).hour(16).minute(0).second(0).millisecond(0) |  | ||||||
|   // 判断当前是否已到本周五16:00
 |  | ||||||
|   let showFriday |  | ||||||
|   if (now.isAfter(thisFriday)) { |  | ||||||
|     showFriday = thisFriday |  | ||||||
|   } else { |  | ||||||
|     // 上周五16:00
 |  | ||||||
|     showFriday = thisFriday.subtract(7, 'day') |  | ||||||
|   } |  | ||||||
|   return showFriday.format('MMM D, YYYY, h:mm A [EDT]') |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const formatted = ref(getFormattedFriday()) |  | ||||||
| const getStockQuate= async()=>{ | const getStockQuate= async()=>{ | ||||||
|     const res = await axios.get('https://saas-test.szjixun.cn/api/chart/forward/test') |     const res = await axios.get('https://saas-test.szjixun.cn/api/chart/forward/test') | ||||||
|     stockQuote.value=res.data |     stockQuote.value=res.data | ||||||
|  | |||||||
| @ -25,17 +25,13 @@ | |||||||
|         class="result-item" |         class="result-item" | ||||||
|       > |       > | ||||||
|         <div class="content"> |         <div class="content"> | ||||||
|           <p class="result-title subtitle">{{ item.title }}</p> |           <a :href="item.url" class="result-title subtitle">{{ item.title }}</a> | ||||||
|           <p class="result-description content-text">{{ item.description }}</p> |           <p class="result-description content-text">{{ item.description }}</p> | ||||||
|         </div> |         </div> | ||||||
| 
 |         <div class="pdf-icon"> | ||||||
|         <div |           <a :href="item.url" target="_blank"> | ||||||
|           class="pdf-icon" |             <img src="@/assets/image/pdf.png" alt="PDF" /> | ||||||
|           @click="downloadPdf(item.url)" |           </a> | ||||||
|           style="color: #2979ff; cursor: pointer" |  | ||||||
|         > |  | ||||||
|           <img src="@/assets/image/pdf.png" alt="PDF" /> |  | ||||||
|           {{ t("financialinformation.quarterlyresults.download") }} |  | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
| @ -345,31 +341,6 @@ const handleSearch = () => { | |||||||
|   // 搜索处理逻辑 |   // 搜索处理逻辑 | ||||||
|   console.log("搜索:", searchQuery.value); |   console.log("搜索:", searchQuery.value); | ||||||
| }; | }; | ||||||
| const downloadPdf = async (pdfResource, filename = "") => { |  | ||||||
|   try { |  | ||||||
|     // 获取PDF文件 |  | ||||||
|     const response = await fetch(pdfResource); |  | ||||||
|     const blob = await response.blob(); |  | ||||||
| 
 |  | ||||||
|     // 创建Blob URL |  | ||||||
|     const blobUrl = URL.createObjectURL(blob); |  | ||||||
| 
 |  | ||||||
|     // 创建下载链接 |  | ||||||
|     const a = document.createElement("a"); |  | ||||||
|     a.href = blobUrl; |  | ||||||
|     a.download = filename || pdfResource.split("/").pop() || "download.pdf"; |  | ||||||
| 
 |  | ||||||
|     // 触发下载 |  | ||||||
|     document.body.appendChild(a); |  | ||||||
|     a.click(); |  | ||||||
|     document.body.removeChild(a); |  | ||||||
| 
 |  | ||||||
|     // 释放Blob URL |  | ||||||
|     URL.revokeObjectURL(blobUrl); |  | ||||||
|   } catch (error) { |  | ||||||
|     console.error("下载PDF文件失败:", error); |  | ||||||
|   } |  | ||||||
| }; |  | ||||||
| </script> | </script> | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
| .title { | .title { | ||||||
| @ -416,7 +387,7 @@ const downloadPdf = async (pdfResource, filename = "") => { | |||||||
| .result-item { | .result-item { | ||||||
|   display: flex; |   display: flex; | ||||||
|   justify-content: space-between; |   justify-content: space-between; | ||||||
|   align-items: center; |   align-items: flex-start; | ||||||
|   padding: 15px 0; |   padding: 15px 0; | ||||||
|   border-bottom: 1px solid #eee; |   border-bottom: 1px solid #eee; | ||||||
| } | } | ||||||
| @ -430,6 +401,10 @@ const downloadPdf = async (pdfResource, filename = "") => { | |||||||
|   text-decoration: none; |   text-decoration: none; | ||||||
|   display: block; |   display: block; | ||||||
|   margin-bottom: 5px; |   margin-bottom: 5px; | ||||||
|  | 
 | ||||||
|  |   &:hover { | ||||||
|  |     text-decoration: underline; | ||||||
|  |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .result-description { | .result-description { | ||||||
|  | |||||||
| @ -25,16 +25,13 @@ | |||||||
|         class="result-item" |         class="result-item" | ||||||
|       > |       > | ||||||
|         <div class="content"> |         <div class="content"> | ||||||
|           <p class="result-title subtitle">{{ item.title }}</p> |           <a :href="item.url" class="result-title subtitle">{{ item.title }}</a> | ||||||
|           <p class="result-description content-text">{{ item.description }}</p> |           <p class="result-description content-text">{{ item.description }}</p> | ||||||
|         </div> |         </div> | ||||||
|         <div |         <div class="pdf-icon"> | ||||||
|           class="pdf-icon" |           <a :href="item.url" target="_blank"> | ||||||
|           @click="downloadPdf(item.url)" |             <img src="@/assets/image/pdf.png" alt="PDF" /> | ||||||
|           style="color: #2979ff; cursor: pointer" |           </a> | ||||||
|         > |  | ||||||
|           <img src="@/assets/image/pdf.png" alt="PDF" /> |  | ||||||
|           {{ t("financialinformation.quarterlyresults.download") }} |  | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
| @ -344,32 +341,6 @@ const handleSearch = () => { | |||||||
|   // 搜索处理逻辑 |   // 搜索处理逻辑 | ||||||
|   console.log("搜索:", searchQuery.value); |   console.log("搜索:", searchQuery.value); | ||||||
| }; | }; | ||||||
| 
 |  | ||||||
| const downloadPdf = async (pdfResource, filename = "") => { |  | ||||||
|   try { |  | ||||||
|     // 获取PDF文件 |  | ||||||
|     const response = await fetch(pdfResource); |  | ||||||
|     const blob = await response.blob(); |  | ||||||
| 
 |  | ||||||
|     // 创建Blob URL |  | ||||||
|     const blobUrl = URL.createObjectURL(blob); |  | ||||||
| 
 |  | ||||||
|     // 创建下载链接 |  | ||||||
|     const a = document.createElement("a"); |  | ||||||
|     a.href = blobUrl; |  | ||||||
|     a.download = filename || pdfResource.split("/").pop() || "download.pdf"; |  | ||||||
| 
 |  | ||||||
|     // 触发下载 |  | ||||||
|     document.body.appendChild(a); |  | ||||||
|     a.click(); |  | ||||||
|     document.body.removeChild(a); |  | ||||||
| 
 |  | ||||||
|     // 释放Blob URL |  | ||||||
|     URL.revokeObjectURL(blobUrl); |  | ||||||
|   } catch (error) { |  | ||||||
|     console.error("下载PDF文件失败:", error); |  | ||||||
|   } |  | ||||||
| }; |  | ||||||
| </script> | </script> | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
| .title { | .title { | ||||||
| @ -416,7 +387,7 @@ const downloadPdf = async (pdfResource, filename = "") => { | |||||||
| .result-item { | .result-item { | ||||||
|   display: flex; |   display: flex; | ||||||
|   justify-content: space-between; |   justify-content: space-between; | ||||||
|   align-items: center; |   align-items: flex-start; | ||||||
|   padding: 15px 0; |   padding: 15px 0; | ||||||
|   border-bottom: 1px solid #eee; |   border-bottom: 1px solid #eee; | ||||||
| } | } | ||||||
| @ -430,6 +401,10 @@ const downloadPdf = async (pdfResource, filename = "") => { | |||||||
|   text-decoration: none; |   text-decoration: none; | ||||||
|   display: block; |   display: block; | ||||||
|   margin-bottom: 5px; |   margin-bottom: 5px; | ||||||
|  | 
 | ||||||
|  |   &:hover { | ||||||
|  |     text-decoration: underline; | ||||||
|  |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .result-description { | .result-description { | ||||||
|  | |||||||
| @ -36,7 +36,7 @@ | |||||||
|         <img |         <img | ||||||
|           src="@/assets/image/download.svg" |           src="@/assets/image/download.svg" | ||||||
|           style="width: 20px; height: 20px" |           style="width: 20px; height: 20px" | ||||||
|           @click="downloadPdf(item.url)" |           @click="handleDownload(item.url)" | ||||||
|         /> |         /> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
| @ -345,29 +345,55 @@ const handleSearch = () => { | |||||||
|   console.log("搜索:", searchQuery.value); |   console.log("搜索:", searchQuery.value); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| const downloadPdf = async (pdfResource, filename = "") => { | const handleDownload = (url) => { | ||||||
|   try { |   // 下载处理逻辑 | ||||||
|     // 获取PDF文件 |   console.log("下载:", url); | ||||||
|     const response = await fetch(pdfResource); |  | ||||||
|     const blob = await response.blob(); |  | ||||||
| 
 | 
 | ||||||
|     // 创建Blob URL |   // 创建一个隐藏的a元素 | ||||||
|     const blobUrl = URL.createObjectURL(blob); |   const link = document.createElement("a"); | ||||||
|  |   link.href = url; | ||||||
| 
 | 
 | ||||||
|     // 创建下载链接 |   // 修复文件名提取逻辑 | ||||||
|     const a = document.createElement("a"); |   let fileName = url.split("/").pop(); | ||||||
|     a.href = blobUrl; |   // 移除可能存在的查询参数 | ||||||
|     a.download = filename || pdfResource.split("/").pop() || "download.pdf"; |   if (fileName.includes("?") || fileName.includes("_t=")) { | ||||||
|  |     fileName = fileName.split(/[?_]/)[0]; | ||||||
|  |   } | ||||||
|  |   link.download = fileName; | ||||||
|  |   link.target = "_blank"; | ||||||
| 
 | 
 | ||||||
|     // 触发下载 |   // 对于移动设备,我们需要特殊处理 | ||||||
|     document.body.appendChild(a); |   const isMobile = | ||||||
|     a.click(); |     /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test( | ||||||
|     document.body.removeChild(a); |       navigator.userAgent | ||||||
|  |     ); | ||||||
| 
 | 
 | ||||||
|     // 释放Blob URL |   if (isMobile) { | ||||||
|     URL.revokeObjectURL(blobUrl); |     // 在移动设备上,可能需要使用fetch下载文件并创建blob | ||||||
|   } catch (error) { |     fetch(url) | ||||||
|     console.error("下载PDF文件失败:", error); |       .then((response) => response.blob()) | ||||||
|  |       .then((blob) => { | ||||||
|  |         const objectUrl = URL.createObjectURL(blob); | ||||||
|  |         link.href = objectUrl; | ||||||
|  |         document.body.appendChild(link); | ||||||
|  |         link.click(); | ||||||
|  | 
 | ||||||
|  |         // 清理 | ||||||
|  |         setTimeout(() => { | ||||||
|  |           document.body.removeChild(link); | ||||||
|  |           URL.revokeObjectURL(objectUrl); | ||||||
|  |         }, 100); | ||||||
|  |       }) | ||||||
|  |       .catch((error) => { | ||||||
|  |         console.error("下载文件时出错:", error); | ||||||
|  |         // 如果fetch失败,回退到window.open | ||||||
|  |         window.open(url, "_blank"); | ||||||
|  |       }); | ||||||
|  |   } else { | ||||||
|  |     // 桌面设备上直接点击链接 | ||||||
|  |     document.body.appendChild(link); | ||||||
|  |     link.click(); | ||||||
|  |     document.body.removeChild(link); | ||||||
|   } |   } | ||||||
| }; | }; | ||||||
| </script> | </script> | ||||||
| @ -449,6 +475,10 @@ const downloadPdf = async (pdfResource, filename = "") => { | |||||||
|   margin-bottom: 8px; |   margin-bottom: 8px; | ||||||
|   font-size: 92px; |   font-size: 92px; | ||||||
|   font-weight: 600; |   font-weight: 600; | ||||||
|  | 
 | ||||||
|  |   &:hover { | ||||||
|  |     text-decoration: underline; | ||||||
|  |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .result-description { | .result-description { | ||||||
|  | |||||||
| @ -36,7 +36,7 @@ | |||||||
|         <img |         <img | ||||||
|           src="@/assets/image/download.svg" |           src="@/assets/image/download.svg" | ||||||
|           style="width: 20px; height: 20px" |           style="width: 20px; height: 20px" | ||||||
|           @click="downloadPdf(item.url)" |           @click="handleDownload(item.url)" | ||||||
|         /> |         /> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
| @ -345,29 +345,55 @@ const handleSearch = () => { | |||||||
|   console.log("搜索:", searchQuery.value); |   console.log("搜索:", searchQuery.value); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| const downloadPdf = async (pdfResource, filename = "") => { | const handleDownload = (url) => { | ||||||
|   try { |   // 下载处理逻辑 | ||||||
|     // 获取PDF文件 |   console.log("下载:", url); | ||||||
|     const response = await fetch(pdfResource); |  | ||||||
|     const blob = await response.blob(); |  | ||||||
| 
 | 
 | ||||||
|     // 创建Blob URL |   // 创建一个隐藏的a元素 | ||||||
|     const blobUrl = URL.createObjectURL(blob); |   const link = document.createElement("a"); | ||||||
|  |   link.href = url; | ||||||
| 
 | 
 | ||||||
|     // 创建下载链接 |   // 修复文件名提取逻辑 | ||||||
|     const a = document.createElement("a"); |   let fileName = url.split("/").pop(); | ||||||
|     a.href = blobUrl; |   // 移除可能存在的查询参数 | ||||||
|     a.download = filename || pdfResource.split("/").pop() || "download.pdf"; |   if (fileName.includes("?") || fileName.includes("_t=")) { | ||||||
|  |     fileName = fileName.split(/[?_]/)[0]; | ||||||
|  |   } | ||||||
|  |   link.download = fileName; | ||||||
|  |   link.target = "_blank"; | ||||||
| 
 | 
 | ||||||
|     // 触发下载 |   // 对于移动设备,我们需要特殊处理 | ||||||
|     document.body.appendChild(a); |   const isMobile = | ||||||
|     a.click(); |     /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test( | ||||||
|     document.body.removeChild(a); |       navigator.userAgent | ||||||
|  |     ); | ||||||
| 
 | 
 | ||||||
|     // 释放Blob URL |   if (isMobile) { | ||||||
|     URL.revokeObjectURL(blobUrl); |     // 在移动设备上,可能需要使用fetch下载文件并创建blob | ||||||
|   } catch (error) { |     fetch(url) | ||||||
|     console.error("下载PDF文件失败:", error); |       .then((response) => response.blob()) | ||||||
|  |       .then((blob) => { | ||||||
|  |         const objectUrl = URL.createObjectURL(blob); | ||||||
|  |         link.href = objectUrl; | ||||||
|  |         document.body.appendChild(link); | ||||||
|  |         link.click(); | ||||||
|  | 
 | ||||||
|  |         // 清理 | ||||||
|  |         setTimeout(() => { | ||||||
|  |           document.body.removeChild(link); | ||||||
|  |           URL.revokeObjectURL(objectUrl); | ||||||
|  |         }, 100); | ||||||
|  |       }) | ||||||
|  |       .catch((error) => { | ||||||
|  |         console.error("下载文件时出错:", error); | ||||||
|  |         // 如果fetch失败,回退到window.open | ||||||
|  |         window.open(url, "_blank"); | ||||||
|  |       }); | ||||||
|  |   } else { | ||||||
|  |     // 桌面设备上直接点击链接 | ||||||
|  |     document.body.appendChild(link); | ||||||
|  |     link.click(); | ||||||
|  |     document.body.removeChild(link); | ||||||
|   } |   } | ||||||
| }; | }; | ||||||
| </script> | </script> | ||||||
| @ -449,6 +475,10 @@ const downloadPdf = async (pdfResource, filename = "") => { | |||||||
|   margin-bottom: 8px; |   margin-bottom: 8px; | ||||||
|   font-size: 50px; |   font-size: 50px; | ||||||
|   font-weight: 600; |   font-weight: 600; | ||||||
|  | 
 | ||||||
|  |   &:hover { | ||||||
|  |     text-decoration: underline; | ||||||
|  |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .result-description { | .result-description { | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user