Compare commits
	
		
			No commits in common. "b184eba64d6a6191e0295736a2333466639e151b" and "c4a82718160bb0e4d0c938351f2b69d473cc76f5" have entirely different histories.
		
	
	
		
			b184eba64d
			...
			c4a8271816
		
	
		
| @ -560,7 +560,7 @@ export default { | ||||
|   HOME: { | ||||
|     CONTAIN: { | ||||
|       TITLEONE: { | ||||
|         TITLE: "Company Positioning", | ||||
|         TITLE: "Company positioning", | ||||
|         CONTENT: | ||||
|           "To empower global talents through innovative technology solutions", | ||||
|         CONTENTTWO: | ||||
| @ -569,7 +569,7 @@ export default { | ||||
|     }, | ||||
|     CONTAINY: { | ||||
|       STOCK_INFO: { | ||||
|         TITLE: "Stock Information", | ||||
|         TITLE: "Stock Info", | ||||
|         LAST_PRICE: "Last Price", | ||||
|         CHANGE: "Change", | ||||
|         STOCK_CODE: "Stock Code", | ||||
| @ -617,9 +617,9 @@ export default { | ||||
|     TITLETHREE: { | ||||
|       TITLE: "Our mission and vision", | ||||
|       CONTENT: | ||||
|         "• To empower global talents through innovative technology solutions", | ||||
|         "•To empower global talents through innovative technology solutions", | ||||
|       CONTENTTWO: | ||||
|         "• Leveraging IoT, connectivity, and artificial intelligence to create targeted, multilingual digital brands, fostering a global community of Key Opinion Leaders and providing unparalleled value throughout the digital content lifecycle", | ||||
|         "•Leveraging IoT, connectivity, and artificial intelligence to create targeted, multilingual digital brands, fostering a global community of Key Opinion Leaders and providing unparalleled value throughout the digital content lifecycle", | ||||
|     }, | ||||
|     TITLEFOUR: { | ||||
|       CONTENT: "", | ||||
| @ -632,7 +632,7 @@ export default { | ||||
|       }, | ||||
|       SUBHEADINGTWO: "2020 : Merger & AI Advancement", | ||||
|       paragraphTwo: { | ||||
|         ONE: "• November 2020: Merged with Minim Inc.; adopted Minim name/OTCQB ticker.", | ||||
|         ONE: "• November 2020: Merged with Minim Inc.; adopted Minim name/OTCQB ticker", | ||||
|         TWO: "• Rolled out AI-driven Wi-Fi management and IoT security platform.", | ||||
|         THREE: "", | ||||
|       }, | ||||
| @ -645,17 +645,17 @@ export default { | ||||
|       SUBHEADINGFOREFF: "2023 – 2024: Pivoting to A Software First Model", | ||||
|       paragraphFOUR: { | ||||
|         ONE: "• Enhanced its MinimOS cloud platform and API suite for ISPs/OEMs, with major deployments like Vox’s AI-driven Wi-Fi Home Manager.", | ||||
|         TWO: "• Signed a merger agreement with e2Companies to broaden its technology and revenue base.", | ||||
|         TWO: "• Signed a merger agreement with e2Companies to broaden its technology and revenue base", | ||||
|         THREE: "", | ||||
|       }, | ||||
|       SUBHEADINGFIVE: "2025 Rebranding & New C-Suite", | ||||
|       paragraphFIVE: { | ||||
|         ONE: "• Officially rebranded from Minim Inc. to FiEE, Inc.", | ||||
|         ONE: "• Officially rebranded from Minim Inc. to FiEE Inc.", | ||||
|         TWO: "• Appointed Li Wai Chung as CEO and Cao Yu as CFO.", | ||||
|         THREE: | ||||
|           "• Leverage on foundation in IoT, connectivity and AI to pursue new business opportunities.", | ||||
|         FOUR: "• Launched SaaS product in the market to generate recurring revenue streams.", | ||||
|         FIVE: "• Acquisition of  Suzhou Yixuntong Network Technology Co., Ltd., a high growth technology service provider in PRC.", | ||||
|         FOUR: "• Launched SaaS product in the market to generate recurring revenue streams", | ||||
|         FIVE: "• Acquisition of  Suzhou Yixuntong Network Technology Co., Ltd., a high growth technology service provider in PRC", | ||||
|       }, | ||||
|     }, | ||||
|     TITLEFIVE: { | ||||
| @ -676,29 +676,30 @@ export default { | ||||
|         paragraph: { | ||||
|           ONE: { | ||||
|             TITLE: "(1)Cloud-Managed Connectivity (WiFi) Platform: ", | ||||
|             CONTENT: "SaaS powering OS for consumers and SMBs ", | ||||
|             CONTENTTWO: "AI-driven threat protection, and over-the-air updates", | ||||
|             CONTENT: "•SaaS powering OS for consumers and SMBs ", | ||||
|             CONTENTTWO: | ||||
|               "•AI-driven threat protection, and over-the-air updates", | ||||
|           }, | ||||
|           TWO: { | ||||
|             TITLE: "(2)IoT Hardware Sales & Licensing: ", | ||||
|             CONTENT: | ||||
|               "IoT products and technologies, including developing VR/AR online sharing technologies", | ||||
|             CONTENTTWO: "IoT data collection, analysis and management", | ||||
|               "•IoT products and technologies, including developing VR/AR online sharing technologies", | ||||
|             CONTENTTWO: "•IoT data collection, analysis and management", | ||||
|           }, | ||||
|           THREE: { | ||||
|             TITLE: "(3)SAAS Solutions", | ||||
|             CONTENT: "Internet sales and IoT support", | ||||
|             CONTENTTWO: "KOL branding services", | ||||
|             CONTENT: "•Internet sales and IoT support", | ||||
|             CONTENTTWO: "•KOL branding services", | ||||
|             CONTENTTHREE: | ||||
|               "AI-enabled content creation and fans habit analysis solutions", | ||||
|               "•AI-enabled content creation and fans habit analysis solutions", | ||||
|           }, | ||||
|           FOUR: { | ||||
|             TITLE: "(4)Professional To-C and To-B Services & Support", | ||||
|             CONTENT: | ||||
|               "Managed-service agreements with ISPs and enterprise customers for network-support, security monitoring, and custom development", | ||||
|             CONTENTTWO: "KOL branding services", | ||||
|               "•Managed-service agreements with ISPs and enterprise customers for network-support, security monitoring, and custom development", | ||||
|             CONTENTTWO: "•KOL branding services", | ||||
|             CONTENTTHREE: | ||||
|               "AI-enabled content creation and fans habit analysis solutions", | ||||
|               "•AI-enabled content creation and fans habit analysis solutions", | ||||
|           }, | ||||
|         }, | ||||
|       }, | ||||
| @ -707,12 +708,11 @@ export default { | ||||
|   // 管理
 | ||||
|   MANAGEMENT: { | ||||
|     ONE: { | ||||
|       TITLE: "Wai Chung Li", | ||||
|       TITLE: "Wai Chung LI", | ||||
|       TITLETWO: "Chief Executive Officer and President", | ||||
|       CONTENT: | ||||
|         "Mr. Li is the Chief Executive Officer and President, with extensive experience in accounting, corporate management and finance management. His role encompasses the oversight of our daily business operations and plays a vital part in the overall management of our Group.With a track record spanning prestigious roles at Deloitte China, Shanghai Prime Machinery Company Limited, Lens Technology Co., Ltd., and more, Mr. Li brings invaluable expertise to lead the team.", | ||||
|       CONTENTTWO: | ||||
|         "He chaired Audit Committees for Fulu Holdings and Taizhou Water Group in Hong Kong, and Nedschroef in the Netherlands, showcasing his global leadership. Holding key positions in investment management, business consulting, and directorial roles in listedcompanies, his insights drive strategic decision-making.", | ||||
|         "Mr. Li is the Chief Executive Officer and President, with extensive experience in accounting, corporate management and finance management. His role encompasses the oversight of our daily business operations and plays a vital part in the overall management of our Group.With a track record spanning prestigious roles at Deloitte China, Shanghai Prime Machinery Company Limited, Lens Technology Co., Ltd., and more, Mr. Li brings invaluable expertise to lead the team. He chaired Audit Committees for Fulu Holdings and Taizhou Water Group in Hong Kong, and Nedschroef in the Netherlands, showcasing his global leadership. Holding key positions in investment management, business consulting, and directorial roles in listedcompanies, his insights drive strategic decision-making. ", | ||||
|       CONTENTTWO: "", | ||||
|       CONTENTTHREE: "", | ||||
|     }, | ||||
|     TWO: { | ||||
|  | ||||
| @ -4,47 +4,115 @@ | ||||
|       <!-- 渐变背景标题区 - 增加层次感 --> | ||||
|       <section class="hero-section"> | ||||
|         <div class="container"> | ||||
|           <div class="hero-title"> | ||||
|             {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.TITLE") }} | ||||
|           <div class="title-wrapper"> | ||||
|             <h1 class="hero-title"> | ||||
|               {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.TITLE") }} | ||||
|             </h1> | ||||
|           </div> | ||||
|           <div style="font-size: 18px" class="hero-description"> | ||||
|           <div class="hero-description"> | ||||
|             {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENT") }} | ||||
|           </div> | ||||
|         </div> | ||||
|       </section> | ||||
| 
 | ||||
|       <!-- 业务核心解决方案 --> | ||||
|       <main style="margin-top: 40px" class="container"> | ||||
|       <main class="container"> | ||||
|         <section> | ||||
|           <div class="hero-title"> | ||||
|           <h1 class="hero-title"> | ||||
|             {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENTTWO") }} | ||||
|           </div> | ||||
|           </h1> | ||||
|         </section> | ||||
| 
 | ||||
|         <!-- 解决方案网格 - 响应式弹性布局 --> | ||||
|         <div class="solution-grid"> | ||||
|           <!-- 统一使用弹性列布局,通过媒体查询控制排列方式 --> | ||||
|           <div | ||||
|             v-for="(solution, sIndex) in solutions" | ||||
|             :key="sIndex" | ||||
|             class="featured-solution" | ||||
|           > | ||||
|             <div | ||||
|               class="solution-card" | ||||
|               :style="{ '--delay': `${sIndex * 0.2}s` }" | ||||
|             > | ||||
|               <div class="card-header"> | ||||
|                 <div class="decorative-line"></div> | ||||
|                 <h2 class="card-title">{{ solution.title }}</h2> | ||||
|           <!-- 主推解决方案组 --> | ||||
|           <div class="solution-group"> | ||||
|             <div class="featured-solution"> | ||||
|               <div class="solution-card" :style="{ '--delay': '0s' }"> | ||||
|                 <div class="card-header"> | ||||
|                   <div class="decorative-line"></div> | ||||
|                   <h2 class="card-title">{{ solutions[0].title }}</h2> | ||||
|                 </div> | ||||
|                 <ul class="card-content"> | ||||
|                   <li | ||||
|                     v-for="(point, pIndex) in solutions[0].points" | ||||
|                     :key="pIndex" | ||||
|                     class="content-point" | ||||
|                   > | ||||
|                     <div class="point-icon">➤</div> | ||||
|                     <div class="point-text">{{ point }}</div> | ||||
|                   </li> | ||||
|                 </ul> | ||||
|               </div> | ||||
|             </div> | ||||
| 
 | ||||
|             <div class="featured-solution"> | ||||
|               <div class="solution-card" :style="{ '--delay': '0.2s' }"> | ||||
|                 <div class="card-header"> | ||||
|                   <div class="decorative-line"></div> | ||||
|                   <h2 class="card-title">{{ solutions[1].title }}</h2> | ||||
|                 </div> | ||||
|                 <ul class="card-content"> | ||||
|                   <li | ||||
|                     v-for="(point, pIndex) in solutions[1].points" | ||||
|                     :key="pIndex" | ||||
|                     class="content-point" | ||||
|                   > | ||||
|                     <div class="point-icon">➤</div> | ||||
|                     <div class="point-text">{{ point }}</div> | ||||
|                   </li> | ||||
|                 </ul> | ||||
|               </div> | ||||
|             </div> | ||||
|           </div> | ||||
| 
 | ||||
|           <!-- 次推解决方案组 --> | ||||
|           <div class="solution-group"> | ||||
|             <div class="featured-solution"> | ||||
|               <div | ||||
|                 class="solution-card" | ||||
|                 style="height: auto" | ||||
|                 :style="{ '--delay': '0.4s' }" | ||||
|               > | ||||
|                 <div class="card-header"> | ||||
|                   <div class="decorative-line"></div> | ||||
|                   <h2 class="card-title">{{ solutions[2].title }}</h2> | ||||
|                 </div> | ||||
|                 <ul class="card-content"> | ||||
|                   <li | ||||
|                     v-for="(point, pIndex) in solutions[2].points" | ||||
|                     :key="pIndex" | ||||
|                     class="content-point" | ||||
|                   > | ||||
|                     <div class="point-icon">➤</div> | ||||
|                     <div class="point-text">{{ point }}</div> | ||||
|                   </li> | ||||
|                   <li style="padding-bottom: 105px"></li> | ||||
|                 </ul> | ||||
|               </div> | ||||
|             </div> | ||||
| 
 | ||||
|             <div class="featured-solution"> | ||||
|               <div | ||||
|                 class="solution-card" | ||||
|                 style="height: auto" | ||||
|                 :style="{ '--delay': '0.6s' }" | ||||
|               > | ||||
|                 <div class="card-header"> | ||||
|                   <div class="decorative-line"></div> | ||||
|                   <h2 class="card-title">{{ solutions[3].title }}</h2> | ||||
|                 </div> | ||||
|                 <ul class="card-content"> | ||||
|                   <li | ||||
|                     v-for="(point, pIndex) in solutions[3].points" | ||||
|                     :key="pIndex" | ||||
|                     class="content-point" | ||||
|                   > | ||||
|                     <div class="point-icon">➤</div> | ||||
|                     <div class="point-text">{{ point }}</div> | ||||
|                   </li> | ||||
|                 </ul> | ||||
|               </div> | ||||
|               <ul class="card-content"> | ||||
|                 <li | ||||
|                   v-for="(point, pIndex) in solution.points" | ||||
|                   :key="pIndex" | ||||
|                   class="content-point" | ||||
|                 > | ||||
|                   <div class="point-icon">•</div> | ||||
|                   <div class="point-text">{{ point }}</div> | ||||
|                 </li> | ||||
|               </ul> | ||||
|             </div> | ||||
|           </div> | ||||
|         </div> | ||||
| @ -95,10 +163,34 @@ const solutions = computed(() => [ | ||||
| 
 | ||||
| <style scoped> | ||||
| /* 基础样式 */ | ||||
| .container { | ||||
|   max-width: 1280px; | ||||
|   margin: 0 auto; | ||||
|   padding: 0 2rem; | ||||
| } | ||||
| 
 | ||||
| /* 标题区样式 */ | ||||
| .hero-section { | ||||
|   background: linear-gradient(135deg, #f8fbfe 0%, #e6f0ff 100%); | ||||
|   padding: 8rem 0 6rem; | ||||
|   position: relative; | ||||
|   overflow: hidden; | ||||
| } | ||||
| 
 | ||||
| .hero-section::after { | ||||
|   content: ""; | ||||
|   position: absolute; | ||||
|   bottom: -50px; | ||||
|   left: 0; | ||||
|   width: 100%; | ||||
|   height: 100px; | ||||
|   background: white; | ||||
|   transform: skewY(-3deg); | ||||
| } | ||||
| 
 | ||||
| .hero-title { | ||||
|   font-size: 40px; | ||||
|   color: black; | ||||
|   color: #2c3e50; | ||||
|   margin-bottom: 2rem; | ||||
|   animation: slideIn 1s ease; | ||||
| } | ||||
| @ -107,7 +199,7 @@ const solutions = computed(() => [ | ||||
|   margin: 0 auto; | ||||
|   font-size: 1.1rem; | ||||
|   line-height: 1.8; | ||||
|   color: black; | ||||
|   color: #5a6d80; | ||||
| } | ||||
| 
 | ||||
| :root { | ||||
| @ -136,12 +228,22 @@ const solutions = computed(() => [ | ||||
| /* 标题区 - 紫色渐变 */ | ||||
| .hero-section { | ||||
|   background: var(--primary-gradient); | ||||
|   padding: 5rem 0 0rem; | ||||
|   padding: 10rem 0 8rem; | ||||
|   position: relative; | ||||
|   overflow: hidden; | ||||
|   color: white; | ||||
| } | ||||
| 
 | ||||
| .hero-section::before { | ||||
|   content: ""; | ||||
|   position: absolute; | ||||
|   top: 0; | ||||
|   left: 0; | ||||
|   width: 100%; | ||||
|   height: 100%; | ||||
|   background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" preserveAspectRatio="none"><path fill="rgba(255,255,255,0.05)" d="M0,0 L100,0 L100,100 Q50,80 0,100 Z"></path></svg>') | ||||
|     no-repeat bottom/100% 30%; | ||||
| } | ||||
| .title-decoration { | ||||
|   position: absolute; | ||||
|   bottom: -15px; | ||||
| @ -154,7 +256,7 @@ const solutions = computed(() => [ | ||||
| 
 | ||||
| /* 解决方案网格 */ | ||||
| .solution-grid { | ||||
|   padding: 0rem 0 4rem; | ||||
|   padding: 6rem 0 4rem; | ||||
| } | ||||
| 
 | ||||
| .solution-group { | ||||
| @ -173,7 +275,6 @@ const solutions = computed(() => [ | ||||
| 
 | ||||
|   .featured-solution { | ||||
|     flex: 1; | ||||
|     margin-top: 20px; | ||||
|   } | ||||
| 
 | ||||
|   .solution-card { | ||||
| @ -276,7 +377,7 @@ const solutions = computed(() => [ | ||||
| } | ||||
| 
 | ||||
| .point-icon { | ||||
|   color: #4a3a6b; | ||||
|   color: var(--primary-color); | ||||
|   font-size: 1.2rem; | ||||
|   flex-shrink: 0; | ||||
| } | ||||
|  | ||||
| @ -4,47 +4,115 @@ | ||||
|       <!-- 渐变背景标题区 - 增加层次感 --> | ||||
|       <section class="hero-section"> | ||||
|         <div class="container"> | ||||
|           <div class="hero-title"> | ||||
|             {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.TITLE") }} | ||||
|           <div class="title-wrapper"> | ||||
|             <h1 class="hero-title"> | ||||
|               {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.TITLE") }} | ||||
|             </h1> | ||||
|           </div> | ||||
|           <div style="font-size: 18px" class="hero-description"> | ||||
|           <div class="hero-description"> | ||||
|             {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENT") }} | ||||
|           </div> | ||||
|         </div> | ||||
|       </section> | ||||
| 
 | ||||
|       <!-- 业务核心解决方案 --> | ||||
|       <main style="margin-top: 40px" class="container"> | ||||
|       <main class="container"> | ||||
|         <section> | ||||
|           <div class="hero-title"> | ||||
|           <h1 class="hero-title"> | ||||
|             {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENTTWO") }} | ||||
|           </div> | ||||
|           </h1> | ||||
|         </section> | ||||
| 
 | ||||
|         <!-- 解决方案网格 - 响应式弹性布局 --> | ||||
|         <div class="solution-grid"> | ||||
|           <!-- 统一使用弹性列布局,通过媒体查询控制排列方式 --> | ||||
|           <div | ||||
|             v-for="(solution, sIndex) in solutions" | ||||
|             :key="sIndex" | ||||
|             class="featured-solution" | ||||
|           > | ||||
|             <div | ||||
|               class="solution-card" | ||||
|               :style="{ '--delay': `${sIndex * 0.2}s` }" | ||||
|             > | ||||
|               <div class="card-header"> | ||||
|                 <div class="decorative-line"></div> | ||||
|                 <h2 class="card-title">{{ solution.title }}</h2> | ||||
|           <!-- 主推解决方案组 --> | ||||
|           <div class="solution-group"> | ||||
|             <div class="featured-solution"> | ||||
|               <div class="solution-card" :style="{ '--delay': '0s' }"> | ||||
|                 <div class="card-header"> | ||||
|                   <div class="decorative-line"></div> | ||||
|                   <h2 class="card-title">{{ solutions[0].title }}</h2> | ||||
|                 </div> | ||||
|                 <ul class="card-content"> | ||||
|                   <li | ||||
|                     v-for="(point, pIndex) in solutions[0].points" | ||||
|                     :key="pIndex" | ||||
|                     class="content-point" | ||||
|                   > | ||||
|                     <div class="point-icon">➤</div> | ||||
|                     <div class="point-text">{{ point }}</div> | ||||
|                   </li> | ||||
|                 </ul> | ||||
|               </div> | ||||
|             </div> | ||||
| 
 | ||||
|             <div class="featured-solution"> | ||||
|               <div class="solution-card" :style="{ '--delay': '0.2s' }"> | ||||
|                 <div class="card-header"> | ||||
|                   <div class="decorative-line"></div> | ||||
|                   <h2 class="card-title">{{ solutions[1].title }}</h2> | ||||
|                 </div> | ||||
|                 <ul class="card-content"> | ||||
|                   <li | ||||
|                     v-for="(point, pIndex) in solutions[1].points" | ||||
|                     :key="pIndex" | ||||
|                     class="content-point" | ||||
|                   > | ||||
|                     <div class="point-icon">➤</div> | ||||
|                     <div class="point-text">{{ point }}</div> | ||||
|                   </li> | ||||
|                 </ul> | ||||
|               </div> | ||||
|             </div> | ||||
|           </div> | ||||
| 
 | ||||
|           <!-- 次推解决方案组 --> | ||||
|           <div class="solution-group"> | ||||
|             <div class="featured-solution"> | ||||
|               <div | ||||
|                 class="solution-card" | ||||
|                 style="height: auto" | ||||
|                 :style="{ '--delay': '0.4s' }" | ||||
|               > | ||||
|                 <div class="card-header"> | ||||
|                   <div class="decorative-line"></div> | ||||
|                   <h2 class="card-title">{{ solutions[2].title }}</h2> | ||||
|                 </div> | ||||
|                 <ul class="card-content"> | ||||
|                   <li | ||||
|                     v-for="(point, pIndex) in solutions[2].points" | ||||
|                     :key="pIndex" | ||||
|                     class="content-point" | ||||
|                   > | ||||
|                     <div class="point-icon">➤</div> | ||||
|                     <div class="point-text">{{ point }}</div> | ||||
|                   </li> | ||||
|                   <li style="padding-bottom: 45px"></li> | ||||
|                 </ul> | ||||
|               </div> | ||||
|             </div> | ||||
| 
 | ||||
|             <div class="featured-solution"> | ||||
|               <div | ||||
|                 class="solution-card" | ||||
|                 style="height: auto" | ||||
|                 :style="{ '--delay': '0.6s' }" | ||||
|               > | ||||
|                 <div class="card-header"> | ||||
|                   <div class="decorative-line"></div> | ||||
|                   <h2 class="card-title">{{ solutions[3].title }}</h2> | ||||
|                 </div> | ||||
|                 <ul class="card-content"> | ||||
|                   <li | ||||
|                     v-for="(point, pIndex) in solutions[3].points" | ||||
|                     :key="pIndex" | ||||
|                     class="content-point" | ||||
|                   > | ||||
|                     <div class="point-icon">➤</div> | ||||
|                     <div class="point-text">{{ point }}</div> | ||||
|                   </li> | ||||
|                 </ul> | ||||
|               </div> | ||||
|               <ul class="card-content"> | ||||
|                 <li | ||||
|                   v-for="(point, pIndex) in solution.points" | ||||
|                   :key="pIndex" | ||||
|                   class="content-point" | ||||
|                 > | ||||
|                   <div class="point-icon">•</div> | ||||
|                   <div class="point-text">{{ point }}</div> | ||||
|                 </li> | ||||
|               </ul> | ||||
|             </div> | ||||
|           </div> | ||||
|         </div> | ||||
| @ -95,10 +163,34 @@ const solutions = computed(() => [ | ||||
| 
 | ||||
| <style scoped> | ||||
| /* 基础样式 */ | ||||
| .container { | ||||
|   max-width: 1280px; | ||||
|   margin: 0 auto; | ||||
|   padding: 0 2rem; | ||||
| } | ||||
| 
 | ||||
| /* 标题区样式 */ | ||||
| .hero-section { | ||||
|   background: linear-gradient(135deg, #f8fbfe 0%, #e6f0ff 100%); | ||||
|   padding: 8rem 0 6rem; | ||||
|   position: relative; | ||||
|   overflow: hidden; | ||||
| } | ||||
| 
 | ||||
| .hero-section::after { | ||||
|   content: ""; | ||||
|   position: absolute; | ||||
|   bottom: -50px; | ||||
|   left: 0; | ||||
|   width: 100%; | ||||
|   height: 100px; | ||||
|   background: white; | ||||
|   transform: skewY(-3deg); | ||||
| } | ||||
| 
 | ||||
| .hero-title { | ||||
|   font-size: 40px; | ||||
|   color: black; | ||||
|   color: #2c3e50; | ||||
|   margin-bottom: 2rem; | ||||
|   animation: slideIn 1s ease; | ||||
| } | ||||
| @ -107,7 +199,7 @@ const solutions = computed(() => [ | ||||
|   margin: 0 auto; | ||||
|   font-size: 1.1rem; | ||||
|   line-height: 1.8; | ||||
|   color: black; | ||||
|   color: #5a6d80; | ||||
| } | ||||
| 
 | ||||
| :root { | ||||
| @ -136,12 +228,22 @@ const solutions = computed(() => [ | ||||
| /* 标题区 - 紫色渐变 */ | ||||
| .hero-section { | ||||
|   background: var(--primary-gradient); | ||||
|   padding: 5rem 0 0rem; | ||||
|   padding: 10rem 0 8rem; | ||||
|   position: relative; | ||||
|   overflow: hidden; | ||||
|   color: white; | ||||
| } | ||||
| 
 | ||||
| .hero-section::before { | ||||
|   content: ""; | ||||
|   position: absolute; | ||||
|   top: 0; | ||||
|   left: 0; | ||||
|   width: 100%; | ||||
|   height: 100%; | ||||
|   background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" preserveAspectRatio="none"><path fill="rgba(255,255,255,0.05)" d="M0,0 L100,0 L100,100 Q50,80 0,100 Z"></path></svg>') | ||||
|     no-repeat bottom/100% 30%; | ||||
| } | ||||
| .title-decoration { | ||||
|   position: absolute; | ||||
|   bottom: -15px; | ||||
| @ -154,7 +256,7 @@ const solutions = computed(() => [ | ||||
| 
 | ||||
| /* 解决方案网格 */ | ||||
| .solution-grid { | ||||
|   padding: 0rem 0 4rem; | ||||
|   padding: 6rem 0 4rem; | ||||
| } | ||||
| 
 | ||||
| .solution-group { | ||||
| @ -173,7 +275,6 @@ const solutions = computed(() => [ | ||||
| 
 | ||||
|   .featured-solution { | ||||
|     flex: 1; | ||||
|     margin-top: 20px; | ||||
|   } | ||||
| 
 | ||||
|   .solution-card { | ||||
| @ -276,7 +377,7 @@ const solutions = computed(() => [ | ||||
| } | ||||
| 
 | ||||
| .point-icon { | ||||
|   color: #4a3a6b; | ||||
|   color: var(--primary-color); | ||||
|   font-size: 1.2rem; | ||||
|   flex-shrink: 0; | ||||
| } | ||||
|  | ||||
| @ -1,51 +1,118 @@ | ||||
| <template> | ||||
|   <div class="home-page"> | ||||
|     <div class="business-page"> | ||||
|       <!-- 渐变背景标题区 --> | ||||
|       <!-- 渐变背景标题区 - 增加层次感 --> | ||||
|       <section class="hero-section"> | ||||
|         <div class="container"> | ||||
|           <div style="font-size: 40px" class="hero-title"> | ||||
|             {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.TITLE") }} | ||||
|           <div class="title-wrapper"> | ||||
|             <h1 class="hero-title"> | ||||
|               {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.TITLE") }} | ||||
|             </h1> | ||||
|           </div> | ||||
|           <div style="font-size: 18px" class="hero-description"> | ||||
|           <div class="hero-description"> | ||||
|             {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENT") }} | ||||
|           </div> | ||||
|         </div> | ||||
|       </section> | ||||
| 
 | ||||
|       <!-- 业务核心解决方案 --> | ||||
|       <main style="margin-top: 40px" class="container"> | ||||
|       <main class="container"> | ||||
|         <section> | ||||
|           <div style="font-size: 40px" class="hero-title"> | ||||
|           <h1 class="hero-title"> | ||||
|             {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENTTWO") }} | ||||
|           </div> | ||||
|           </h1> | ||||
|         </section> | ||||
| 
 | ||||
|         <!-- 解决方案网格 - 响应式弹性布局 --> | ||||
|         <div class="solution-grid"> | ||||
|           <!-- 统一使用弹性列布局,通过媒体查询控制排列方式 --> | ||||
|           <div | ||||
|             v-for="(solution, sIndex) in solutions" | ||||
|             :key="sIndex" | ||||
|             class="featured-solution" | ||||
|           > | ||||
|             <div | ||||
|               class="solution-card" | ||||
|               :style="{ '--delay': `${sIndex * 0.2}s` }" | ||||
|             > | ||||
|               <div class="card-header"> | ||||
|                 <div class="decorative-line"></div> | ||||
|                 <h2 class="card-title">{{ solution.title }}</h2> | ||||
|           <!-- 主推解决方案组 --> | ||||
|           <div class="solution-group"> | ||||
|             <div class="featured-solution"> | ||||
|               <div class="solution-card" :style="{ '--delay': '0s' }"> | ||||
|                 <div class="card-header"> | ||||
|                   <div class="decorative-line"></div> | ||||
|                   <h2 class="card-title">{{ solutions[0].title }}</h2> | ||||
|                 </div> | ||||
|                 <ul class="card-content"> | ||||
|                   <li | ||||
|                     v-for="(point, pIndex) in solutions[0].points" | ||||
|                     :key="pIndex" | ||||
|                     class="content-point" | ||||
|                   > | ||||
|                     <div class="point-icon">➤</div> | ||||
|                     <div class="point-text">{{ point }}</div> | ||||
|                   </li> | ||||
|                 </ul> | ||||
|               </div> | ||||
|             </div> | ||||
| 
 | ||||
|             <div class="featured-solution"> | ||||
|               <div class="solution-card" :style="{ '--delay': '0.2s' }"> | ||||
|                 <div class="card-header"> | ||||
|                   <div class="decorative-line"></div> | ||||
|                   <h2 class="card-title">{{ solutions[1].title }}</h2> | ||||
|                 </div> | ||||
|                 <ul class="card-content"> | ||||
|                   <li | ||||
|                     v-for="(point, pIndex) in solutions[1].points" | ||||
|                     :key="pIndex" | ||||
|                     class="content-point" | ||||
|                   > | ||||
|                     <div class="point-icon">➤</div> | ||||
|                     <div class="point-text">{{ point }}</div> | ||||
|                   </li> | ||||
|                 </ul> | ||||
|               </div> | ||||
|             </div> | ||||
|           </div> | ||||
| 
 | ||||
|           <!-- 次推解决方案组 --> | ||||
|           <div class="solution-group"> | ||||
|             <div class="featured-solution"> | ||||
|               <div | ||||
|                 class="solution-card" | ||||
|                 style="height: auto" | ||||
|                 :style="{ '--delay': '0.4s' }" | ||||
|               > | ||||
|                 <div class="card-header"> | ||||
|                   <div class="decorative-line"></div> | ||||
|                   <h2 class="card-title">{{ solutions[2].title }}</h2> | ||||
|                 </div> | ||||
|                 <ul class="card-content"> | ||||
|                   <li | ||||
|                     v-for="(point, pIndex) in solutions[2].points" | ||||
|                     :key="pIndex" | ||||
|                     class="content-point" | ||||
|                   > | ||||
|                     <div class="point-icon">➤</div> | ||||
|                     <div class="point-text">{{ point }}</div> | ||||
|                   </li> | ||||
|                   <li style="padding-bottom: 45px"></li> | ||||
|                 </ul> | ||||
|               </div> | ||||
|             </div> | ||||
| 
 | ||||
|             <div class="featured-solution"> | ||||
|               <div | ||||
|                 class="solution-card" | ||||
|                 style="height: auto" | ||||
|                 :style="{ '--delay': '0.6s' }" | ||||
|               > | ||||
|                 <div class="card-header"> | ||||
|                   <div class="decorative-line"></div> | ||||
|                   <h2 class="card-title">{{ solutions[3].title }}</h2> | ||||
|                 </div> | ||||
|                 <ul class="card-content"> | ||||
|                   <li | ||||
|                     v-for="(point, pIndex) in solutions[3].points" | ||||
|                     :key="pIndex" | ||||
|                     class="content-point" | ||||
|                   > | ||||
|                     <div class="point-icon">➤</div> | ||||
|                     <div class="point-text">{{ point }}</div> | ||||
|                   </li> | ||||
|                 </ul> | ||||
|               </div> | ||||
|               <ul class="card-content"> | ||||
|                 <li | ||||
|                   v-for="(point, pIndex) in solution.points" | ||||
|                   :key="pIndex" | ||||
|                   class="content-point" | ||||
|                 > | ||||
|                   <div class="point-icon">•</div> | ||||
|                   <div class="point-text">{{ point }}</div> | ||||
|                 </li> | ||||
|               </ul> | ||||
|             </div> | ||||
|           </div> | ||||
|         </div> | ||||
| @ -95,23 +162,34 @@ const solutions = computed(() => [ | ||||
| </script> | ||||
| 
 | ||||
| <style scoped> | ||||
| /* 基础样式 */ | ||||
| .container { | ||||
|   margin: 0 auto; | ||||
|   padding: 0 2rem; | ||||
| } | ||||
| 
 | ||||
| /* 标题区 - 紫色渐变 */ | ||||
| /* 标题区样式 */ | ||||
| .hero-section { | ||||
|   background: var(--primary-gradient); | ||||
|   padding: 5rem 0 0rem; | ||||
|   background: linear-gradient(135deg, #f8fbfe 0%, #e6f0ff 100%); | ||||
|   padding: 8rem 0 6rem; | ||||
|   position: relative; | ||||
|   overflow: hidden; | ||||
|   color: white; | ||||
| } | ||||
| 
 | ||||
| .hero-section::after { | ||||
|   content: ""; | ||||
|   position: absolute; | ||||
|   bottom: -50px; | ||||
|   left: 0; | ||||
|   width: 100%; | ||||
|   height: 100px; | ||||
|   background: white; | ||||
|   transform: skewY(-3deg); | ||||
| } | ||||
| 
 | ||||
| .hero-title { | ||||
|   font-size: 40px; | ||||
|   color: black; | ||||
|   color: #2c3e50; | ||||
|   margin-bottom: 2rem; | ||||
|   animation: slideIn 1s ease; | ||||
| } | ||||
| @ -120,7 +198,7 @@ const solutions = computed(() => [ | ||||
|   margin: 0 auto; | ||||
|   font-size: 1.1rem; | ||||
|   line-height: 1.8; | ||||
|   color: black; | ||||
|   color: #5a6d80; | ||||
| } | ||||
| 
 | ||||
| :root { | ||||
| @ -133,7 +211,6 @@ const solutions = computed(() => [ | ||||
|     var(--primary-color) 100% | ||||
|   ); | ||||
| } | ||||
| 
 | ||||
| .home-page { | ||||
|   background-image: url("@/assets/image/bg-mobile.png"); | ||||
|   background-size: 100% 100%; | ||||
| @ -141,29 +218,99 @@ const solutions = computed(() => [ | ||||
|   background-repeat: no-repeat; | ||||
| } | ||||
| 
 | ||||
| /* 解决方案网格 - 响应式布局 */ | ||||
| .container { | ||||
|   margin: 0 auto; | ||||
|   padding: 0 2rem; | ||||
| } | ||||
| 
 | ||||
| /* 标题区 - 紫色渐变 */ | ||||
| .hero-section { | ||||
|   background: var(--primary-gradient); | ||||
|   padding: 10rem 0 8rem; | ||||
|   position: relative; | ||||
|   overflow: hidden; | ||||
|   color: white; | ||||
| } | ||||
| 
 | ||||
| .hero-section::before { | ||||
|   content: ""; | ||||
|   position: absolute; | ||||
|   top: 0; | ||||
|   left: 0; | ||||
|   width: 100%; | ||||
|   height: 100%; | ||||
|   background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" preserveAspectRatio="none"><path fill="rgba(255,255,255,0.05)" d="M0,0 L100,0 L100,100 Q50,80 0,100 Z"></path></svg>') | ||||
|     no-repeat bottom/100% 30%; | ||||
| } | ||||
| .title-decoration { | ||||
|   position: absolute; | ||||
|   bottom: -15px; | ||||
|   left: 0; | ||||
|   width: 80%; | ||||
|   height: 4px; | ||||
|   background: rgba(255, 255, 255, 0.5); | ||||
|   border-radius: 2px; | ||||
| } | ||||
| 
 | ||||
| /* 解决方案网格 */ | ||||
| .solution-grid { | ||||
|   padding: 0rem 0 4rem; | ||||
|   display: grid; | ||||
|   grid-template-columns: 1fr; /* 默认单列(移动端) */ | ||||
|   padding: 6rem 0 4rem; | ||||
| } | ||||
| 
 | ||||
| .solution-group { | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
|   gap: 3rem; | ||||
|   margin-bottom: 4rem; | ||||
| } | ||||
| 
 | ||||
| /* 中等屏幕(768px-1439px) - 单列布局 */ | ||||
| @media (min-width: 768px) and (max-width: 1439px) { | ||||
|   .solution-grid { | ||||
|     grid-template-columns: 1fr; | ||||
| /* 桌面端布局(>=768px) */ | ||||
| @media (min-width: 768px) { | ||||
|   .solution-group { | ||||
|     flex-direction: row; | ||||
|     gap: 4rem; | ||||
|   } | ||||
| 
 | ||||
|   .featured-solution { | ||||
|     flex: 1; | ||||
|   } | ||||
| 
 | ||||
|   .solution-card { | ||||
|     height: 350px; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /* 大屏幕(≥1440px) - 双列布局 */ | ||||
| @media (min-width: 1440px) { | ||||
|   .solution-grid { | ||||
|     grid-template-columns: 1fr 1fr; | ||||
| /* 移动端布局(<768px) */ | ||||
| @media (max-width: 767px) { | ||||
|   .home-page { | ||||
|     background-image: url("@/assets/image/bg-mobile.png"); | ||||
|   } | ||||
| 
 | ||||
|   .hero-title { | ||||
|     font-size: 1.8rem; | ||||
|   } | ||||
| 
 | ||||
|   .solution-group { | ||||
|     flex-direction: column; | ||||
|     gap: 2rem; | ||||
|   } | ||||
| 
 | ||||
|   .featured-solution { | ||||
|     width: 100% !important; /* 强制占满容器 */ | ||||
|     margin-bottom: 2rem; | ||||
|   } | ||||
| 
 | ||||
|   .solution-card { | ||||
|     padding: 2rem; | ||||
|     height: auto; | ||||
|   } | ||||
| 
 | ||||
|   .content-point { | ||||
|     padding: 1rem 0; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /* 卡片样式 */ | ||||
| /* 卡片公共样式 */ | ||||
| .solution-card { | ||||
|   background: white; | ||||
|   border-radius: 16px; | ||||
| @ -175,17 +322,22 @@ const solutions = computed(() => [ | ||||
|   position: relative; | ||||
|   overflow: hidden; | ||||
|   border: 1px solid rgba(137, 91, 255, 0.2); | ||||
|   transition: all 0.3s ease; | ||||
|   background: linear-gradient(135deg, #f9f6ff 0%, #f0e9ff 100%); | ||||
| } | ||||
| 
 | ||||
| .solution-card::before { | ||||
| .solution-card::after { | ||||
|   content: ""; | ||||
|   position: absolute; | ||||
|   top: 0; | ||||
|   left: 0; | ||||
|   width: 100%; | ||||
|   height: 4px; | ||||
|   background: var(--primary-gradient); | ||||
|   height: 100%; | ||||
|   background: linear-gradient( | ||||
|     135deg, | ||||
|     rgba(137, 91, 255, 0.03) 0%, | ||||
|     rgba(137, 91, 255, 0) 100% | ||||
|   ); | ||||
|   z-index: -1; | ||||
| } | ||||
| 
 | ||||
| .solution-card:hover { | ||||
| @ -203,7 +355,6 @@ const solutions = computed(() => [ | ||||
|   background: var(--primary-gradient); | ||||
|   margin-bottom: 1rem; | ||||
|   border-radius: 3px; | ||||
|   transition: width 0.3s ease; | ||||
| } | ||||
| 
 | ||||
| .solution-card:hover .decorative-line { | ||||
| @ -223,12 +374,8 @@ const solutions = computed(() => [ | ||||
|   border-bottom: 1px solid rgba(137, 91, 255, 0.1); | ||||
| } | ||||
| 
 | ||||
| .content-point:last-child { | ||||
|   border-bottom: none; | ||||
| } | ||||
| 
 | ||||
| .point-icon { | ||||
|   color: #4a3a6b; | ||||
|   color: var(--primary-color); | ||||
|   font-size: 1.2rem; | ||||
|   flex-shrink: 0; | ||||
| } | ||||
|  | ||||
| @ -4,20 +4,23 @@ | ||||
|       <!-- 渐变背景标题区 --> | ||||
|       <section class="hero-section"> | ||||
|         <div class="container"> | ||||
|           <div style="font-size: 40px" class="hero-title"> | ||||
|             {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.TITLE") }} | ||||
|           <div class="title-wrapper"> | ||||
|             <h1 class="hero-title"> | ||||
|               {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.TITLE") }} | ||||
|             </h1> | ||||
|           </div> | ||||
|           <div style="font-size: 18px" class="hero-description"> | ||||
|           <div class="hero-description"> | ||||
|             {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENT") }} | ||||
|           </div> | ||||
|         </div> | ||||
|       </section> | ||||
| 
 | ||||
|       <!-- 业务核心解决方案 --> | ||||
|       <main style="margin-top: 40px" class="container"> | ||||
|       <main class="container"> | ||||
|         <section> | ||||
|           <div style="font-size: 40px" class="hero-title"> | ||||
|           <h1 class="hero-title"> | ||||
|             {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENTTWO") }} | ||||
|           </div> | ||||
|           </h1> | ||||
|         </section> | ||||
| 
 | ||||
|         <!-- 解决方案网格 - 响应式弹性布局 --> | ||||
| @ -42,7 +45,7 @@ | ||||
|                   :key="pIndex" | ||||
|                   class="content-point" | ||||
|                 > | ||||
|                   <div class="point-icon">•</div> | ||||
|                   <div class="point-icon">➤</div> | ||||
|                   <div class="point-text">{{ point }}</div> | ||||
|                 </li> | ||||
|               </ul> | ||||
| @ -95,33 +98,56 @@ const solutions = computed(() => [ | ||||
| </script> | ||||
| 
 | ||||
| <style scoped> | ||||
| /* 基础样式 */ | ||||
| .container { | ||||
|   max-width: 1280px; | ||||
|   margin: 0 auto; | ||||
|   padding: 0 2rem; | ||||
|   max-width: 1600px; | ||||
| } | ||||
| 
 | ||||
| /* 标题区 - 紫色渐变 */ | ||||
| /* 标题区样式 */ | ||||
| .hero-section { | ||||
|   background: var(--primary-gradient); | ||||
|   padding: 5rem 0 0rem; | ||||
|   background: linear-gradient(135deg, #f8fbfe 0%, #e6f0ff 100%); | ||||
|   padding: 8rem 0 6rem; | ||||
|   position: relative; | ||||
|   overflow: hidden; | ||||
|   color: white; | ||||
| } | ||||
| 
 | ||||
| .hero-section::after { | ||||
|   content: ""; | ||||
|   position: absolute; | ||||
|   bottom: -50px; | ||||
|   left: 0; | ||||
|   width: 100%; | ||||
|   height: 100px; | ||||
|   background: white; | ||||
|   transform: skewY(-3deg); | ||||
| } | ||||
| 
 | ||||
| .hero-title { | ||||
|   font-size: 40px; | ||||
|   color: black; | ||||
|   font-size: 2.5rem; | ||||
|   color: #2c3e50; | ||||
|   margin-bottom: 2rem; | ||||
|   animation: slideIn 1s ease; | ||||
|   position: relative; | ||||
| } | ||||
| 
 | ||||
| .hero-title::after { | ||||
|   content: ""; | ||||
|   position: absolute; | ||||
|   bottom: -10px; | ||||
|   left: 0; | ||||
|   width: 80px; | ||||
|   height: 4px; | ||||
|   background: linear-gradient(135deg, #895bff 0%, #6a11cb 100%); | ||||
|   border-radius: 2px; | ||||
| } | ||||
| 
 | ||||
| .hero-description { | ||||
|   max-width: 1000px; | ||||
|   margin: 0 auto; | ||||
|   font-size: 1.1rem; | ||||
|   line-height: 1.8; | ||||
|   color: black; | ||||
|   color: #5a6d80; | ||||
| } | ||||
| 
 | ||||
| :root { | ||||
| @ -144,7 +170,7 @@ const solutions = computed(() => [ | ||||
| 
 | ||||
| /* 解决方案网格 - 响应式布局 */ | ||||
| .solution-grid { | ||||
|   padding: 0rem 0 4rem; | ||||
|   padding: 6rem 0; | ||||
|   display: grid; | ||||
|   grid-template-columns: 1fr; /* 默认单列(移动端) */ | ||||
|   gap: 3rem; | ||||
| @ -229,7 +255,7 @@ const solutions = computed(() => [ | ||||
| } | ||||
| 
 | ||||
| .point-icon { | ||||
|   color: #4a3a6b; | ||||
|   color: var(--primary-color); | ||||
|   font-size: 1.2rem; | ||||
|   flex-shrink: 0; | ||||
| } | ||||
|  | ||||
| @ -1,18 +1,26 @@ | ||||
| <template> | ||||
|   <div class="home-page"> | ||||
|     <div class="company-overview"> | ||||
|       <!-- 顶部大图区域 --> | ||||
|       <div class="hero-section"> | ||||
|         <transition name="fade-up" appear> | ||||
|           <n-h1 class="hero-title">{{ | ||||
|             $t("COMPANYOVERVIEW.TITLETWO.TITLE") | ||||
|           }}</n-h1> | ||||
|         </transition> | ||||
|       </div> | ||||
| 
 | ||||
|       <!-- 公司简介部分 --> | ||||
|       <!-- 公司概况 --> | ||||
|       <section | ||||
|         class="company-overview" | ||||
|         style="max-width: 1200px; margin: 60px auto" | ||||
|         style="max-width: 1200px; margin: 60px auto; padding: 0 40px" | ||||
|       > | ||||
|         <h2 class="section-title"> | ||||
|           {{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }} | ||||
|         </h2> | ||||
|         <div class="content-block"> | ||||
|           <div style="font-size: 18px"> | ||||
|             {{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }} | ||||
|           </div> | ||||
|           <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}</p> | ||||
|           <!-- <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENTTWO") }}</p> | ||||
|           <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENTTHREE") }}</p> --> | ||||
|         </div> | ||||
| @ -25,13 +33,16 @@ | ||||
|             <n-h3 class="card-title">{{ | ||||
|               $t("COMPANYOVERVIEW.TITLETHREE.TITLE") | ||||
|             }}</n-h3> | ||||
|             <br /> | ||||
|             <n-p style="font-size: 18px" class="card-content">{{ | ||||
|             <n-p class="card-content">{{ | ||||
|               $t("COMPANYOVERVIEW.TITLETHREE.CONTENT") | ||||
|             }}</n-p> | ||||
|             <br /> | ||||
|           </n-card> | ||||
| 
 | ||||
|             <n-p style="font-size: 18px" class="card-content">{{ | ||||
|           <n-card hoverable class="mission-card" v-motion-pop> | ||||
|             <n-h3 class="card-title">{{ | ||||
|               $t("COMPANYOVERVIEW.TITLETHREE.TITLE") | ||||
|             }}</n-h3> | ||||
|             <n-p class="card-content">{{ | ||||
|               $t("COMPANYOVERVIEW.TITLETHREE.CONTENTTWO") | ||||
|             }}</n-p> | ||||
|           </n-card> | ||||
| @ -53,12 +64,12 @@ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADING") | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraph.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraph.TWO") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -73,12 +84,12 @@ | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTwo.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTwo.TWO") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -93,12 +104,12 @@ | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTHREE.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTHREE.TWO") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -113,12 +124,12 @@ | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFOUR.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFOUR.TWO") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -133,27 +144,27 @@ | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.TWO") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.THREE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.FOUR") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.FIVE") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -168,7 +179,7 @@ | ||||
|         }}</n-h2> | ||||
|         <br /> | ||||
| 
 | ||||
|         <n-p style="font-size: 18px" class="section-content">{{ | ||||
|         <n-p class="section-content">{{ | ||||
|           $t("COMPANYOVERVIEW.TITLEFIVE.CONTENT") | ||||
|         }}</n-p> | ||||
|       </section> | ||||
|  | ||||
| @ -1,18 +1,26 @@ | ||||
| <template> | ||||
|   <div class="home-page"> | ||||
|     <div class="company-overview"> | ||||
|       <!-- 顶部大图区域 --> | ||||
|       <div class="hero-section"> | ||||
|         <transition name="fade-up" appear> | ||||
|           <n-h1 class="hero-title">{{ | ||||
|             $t("COMPANYOVERVIEW.TITLETWO.TITLE") | ||||
|           }}</n-h1> | ||||
|         </transition> | ||||
|       </div> | ||||
| 
 | ||||
|       <!-- 公司简介部分 --> | ||||
|       <!-- 公司概况 --> | ||||
|       <section | ||||
|         class="company-overview" | ||||
|         style="max-width: 1200px; margin: 60px auto" | ||||
|         style="max-width: 1200px; margin: 60px auto; padding: 0 40px" | ||||
|       > | ||||
|         <h2 class="section-title"> | ||||
|           {{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }} | ||||
|         </h2> | ||||
|         <div class="content-block"> | ||||
|           <div style="font-size: 18px"> | ||||
|             {{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }} | ||||
|           </div> | ||||
|           <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}</p> | ||||
|           <!-- <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENTTWO") }}</p> | ||||
|           <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENTTHREE") }}</p> --> | ||||
|         </div> | ||||
| @ -25,13 +33,16 @@ | ||||
|             <n-h3 class="card-title">{{ | ||||
|               $t("COMPANYOVERVIEW.TITLETHREE.TITLE") | ||||
|             }}</n-h3> | ||||
|             <br /> | ||||
|             <n-p style="font-size: 18px" class="card-content">{{ | ||||
|             <n-p class="card-content">{{ | ||||
|               $t("COMPANYOVERVIEW.TITLETHREE.CONTENT") | ||||
|             }}</n-p> | ||||
|             <br /> | ||||
|           </n-card> | ||||
| 
 | ||||
|             <n-p style="font-size: 18px" class="card-content">{{ | ||||
|           <n-card hoverable class="mission-card" v-motion-pop> | ||||
|             <n-h3 class="card-title">{{ | ||||
|               $t("COMPANYOVERVIEW.TITLETHREE.TITLE") | ||||
|             }}</n-h3> | ||||
|             <n-p class="card-content">{{ | ||||
|               $t("COMPANYOVERVIEW.TITLETHREE.CONTENTTWO") | ||||
|             }}</n-p> | ||||
|           </n-card> | ||||
| @ -53,12 +64,12 @@ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADING") | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraph.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraph.TWO") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -73,12 +84,12 @@ | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTwo.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTwo.TWO") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -93,12 +104,12 @@ | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTHREE.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTHREE.TWO") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -113,12 +124,12 @@ | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFOUR.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFOUR.TWO") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -133,27 +144,27 @@ | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.TWO") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.THREE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.FOUR") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.FIVE") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -168,7 +179,7 @@ | ||||
|         }}</n-h2> | ||||
|         <br /> | ||||
| 
 | ||||
|         <n-p style="font-size: 18px" class="section-content">{{ | ||||
|         <n-p class="section-content">{{ | ||||
|           $t("COMPANYOVERVIEW.TITLEFIVE.CONTENT") | ||||
|         }}</n-p> | ||||
|       </section> | ||||
|  | ||||
| @ -1,18 +1,26 @@ | ||||
| <template> | ||||
|   <div class="home-page"> | ||||
|     <div class="company-overview"> | ||||
|       <!-- 顶部大图区域 --> | ||||
|       <div class="hero-section"> | ||||
|         <transition name="fade-up" appear> | ||||
|           <n-h1 class="hero-title">{{ | ||||
|             $t("COMPANYOVERVIEW.TITLETWO.TITLE") | ||||
|           }}</n-h1> | ||||
|         </transition> | ||||
|       </div> | ||||
| 
 | ||||
|       <!-- 公司简介部分 --> | ||||
|       <!-- 公司概况 --> | ||||
|       <section | ||||
|         class="company-overview" | ||||
|         style="max-width: 1200px; margin: 60px auto" | ||||
|         style="max-width: 1200px; margin: 60px auto; padding: 0 40px" | ||||
|       > | ||||
|         <h2 class="section-title"> | ||||
|           {{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }} | ||||
|         </h2> | ||||
|         <div class="content-block"> | ||||
|           <div style="font-size: 18px"> | ||||
|             {{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }} | ||||
|           </div> | ||||
|           <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}</p> | ||||
|           <!-- <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENTTWO") }}</p> | ||||
|           <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENTTHREE") }}</p> --> | ||||
|         </div> | ||||
| @ -25,13 +33,16 @@ | ||||
|             <n-h3 class="card-title">{{ | ||||
|               $t("COMPANYOVERVIEW.TITLETHREE.TITLE") | ||||
|             }}</n-h3> | ||||
|             <br /> | ||||
|             <n-p style="font-size: 18px" class="card-content">{{ | ||||
|             <n-p class="card-content">{{ | ||||
|               $t("COMPANYOVERVIEW.TITLETHREE.CONTENT") | ||||
|             }}</n-p> | ||||
|             <br /> | ||||
|           </n-card> | ||||
| 
 | ||||
|             <n-p style="font-size: 18px" class="card-content">{{ | ||||
|           <n-card hoverable class="mission-card" v-motion-pop> | ||||
|             <n-h3 class="card-title">{{ | ||||
|               $t("COMPANYOVERVIEW.TITLETHREE.TITLE") | ||||
|             }}</n-h3> | ||||
|             <n-p class="card-content">{{ | ||||
|               $t("COMPANYOVERVIEW.TITLETHREE.CONTENTTWO") | ||||
|             }}</n-p> | ||||
|           </n-card> | ||||
| @ -53,12 +64,12 @@ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADING") | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraph.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraph.TWO") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -73,12 +84,12 @@ | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTwo.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTwo.TWO") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -93,12 +104,12 @@ | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTHREE.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTHREE.TWO") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -113,12 +124,12 @@ | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFOUR.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFOUR.TWO") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -133,27 +144,27 @@ | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.TWO") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.THREE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.FOUR") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.FIVE") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -168,7 +179,7 @@ | ||||
|         }}</n-h2> | ||||
|         <br /> | ||||
| 
 | ||||
|         <n-p style="font-size: 18px" class="section-content">{{ | ||||
|         <n-p class="section-content">{{ | ||||
|           $t("COMPANYOVERVIEW.TITLEFIVE.CONTENT") | ||||
|         }}</n-p> | ||||
|       </section> | ||||
| @ -198,7 +209,7 @@ const stats = ref([ | ||||
| } | ||||
| .company-overview { | ||||
|   margin: 0 auto; | ||||
|   padding: 0 20px; | ||||
|   padding: 20px; | ||||
| } | ||||
| 
 | ||||
| /* 顶部大图区域 */ | ||||
|  | ||||
| @ -1,18 +1,26 @@ | ||||
| <template> | ||||
|   <div class="home-page"> | ||||
|     <div class="company-overview"> | ||||
|       <!-- 顶部大图区域 --> | ||||
|       <div class="hero-section"> | ||||
|         <transition name="fade-up" appear> | ||||
|           <n-h1 class="hero-title">{{ | ||||
|             $t("COMPANYOVERVIEW.TITLETWO.TITLE") | ||||
|           }}</n-h1> | ||||
|         </transition> | ||||
|       </div> | ||||
| 
 | ||||
|       <!-- 公司简介部分 --> | ||||
|       <!-- 公司概况 --> | ||||
|       <section | ||||
|         class="company-overview" | ||||
|         style="max-width: 1200px; margin: 60px auto" | ||||
|         style="max-width: 1200px; margin: 60px auto; padding: 0 40px" | ||||
|       > | ||||
|         <h2 class="section-title"> | ||||
|           {{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }} | ||||
|         </h2> | ||||
|         <div class="content-block"> | ||||
|           <div style="font-size: 18px"> | ||||
|             {{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }} | ||||
|           </div> | ||||
|           <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}</p> | ||||
|           <!-- <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENTTWO") }}</p> | ||||
|           <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENTTHREE") }}</p> --> | ||||
|         </div> | ||||
| @ -25,13 +33,16 @@ | ||||
|             <n-h3 class="card-title">{{ | ||||
|               $t("COMPANYOVERVIEW.TITLETHREE.TITLE") | ||||
|             }}</n-h3> | ||||
|             <br /> | ||||
|             <n-p style="font-size: 18px" class="card-content">{{ | ||||
|             <n-p class="card-content">{{ | ||||
|               $t("COMPANYOVERVIEW.TITLETHREE.CONTENT") | ||||
|             }}</n-p> | ||||
|             <br /> | ||||
|           </n-card> | ||||
| 
 | ||||
|             <n-p style="font-size: 18px" class="card-content">{{ | ||||
|           <n-card hoverable class="mission-card" v-motion-pop> | ||||
|             <n-h3 class="card-title">{{ | ||||
|               $t("COMPANYOVERVIEW.TITLETHREE.TITLE") | ||||
|             }}</n-h3> | ||||
|             <n-p class="card-content">{{ | ||||
|               $t("COMPANYOVERVIEW.TITLETHREE.CONTENTTWO") | ||||
|             }}</n-p> | ||||
|           </n-card> | ||||
| @ -53,12 +64,12 @@ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADING") | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraph.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraph.TWO") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -73,12 +84,12 @@ | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTwo.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTwo.TWO") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -93,12 +104,12 @@ | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTHREE.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTHREE.TWO") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -113,12 +124,12 @@ | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFOUR.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFOUR.TWO") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -133,27 +144,27 @@ | ||||
|               }}</n-h3> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.ONE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.TWO") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.THREE") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.FOUR") | ||||
|               }}</n-p> | ||||
|               <br /> | ||||
| 
 | ||||
|               <n-p style="font-size: 18px" class="timeline-desc">{{ | ||||
|               <n-p class="timeline-desc">{{ | ||||
|                 $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.FIVE") | ||||
|               }}</n-p> | ||||
|             </div> | ||||
| @ -168,7 +179,7 @@ | ||||
|         }}</n-h2> | ||||
|         <br /> | ||||
| 
 | ||||
|         <n-p style="font-size: 18px" class="section-content">{{ | ||||
|         <n-p class="section-content">{{ | ||||
|           $t("COMPANYOVERVIEW.TITLEFIVE.CONTENT") | ||||
|         }}</n-p> | ||||
|       </section> | ||||
| @ -198,7 +209,7 @@ const stats = ref([ | ||||
| } | ||||
| .company-overview { | ||||
|   margin: 0 auto; | ||||
|   padding: 0 20px; | ||||
|   padding: 20px; | ||||
| } | ||||
| 
 | ||||
| /* 顶部大图区域 */ | ||||
|  | ||||
| @ -105,6 +105,7 @@ const getInitials = (name) => { | ||||
|   color: white; | ||||
|   padding: 120px 0; | ||||
|   text-align: center; | ||||
|   margin-bottom: 60px; | ||||
|   border-radius: 8px; | ||||
| } | ||||
| /* 动画 */ | ||||
|  | ||||
| @ -105,6 +105,7 @@ const getInitials = (name) => { | ||||
|   color: white; | ||||
|   padding: 120px 0; | ||||
|   text-align: center; | ||||
|   margin-bottom: 60px; | ||||
|   border-radius: 8px; | ||||
| } | ||||
| /* 动画 */ | ||||
|  | ||||
| @ -25,8 +25,7 @@ | ||||
|       class="company-overview" | ||||
|       style="max-width: 1200px; margin: 60px auto; padding: 0 40px" | ||||
|     > | ||||
|       <h1 class="section-titles">Company Profile</h1> | ||||
| 
 | ||||
|       <h1 class="section-titles">Company profile</h1> | ||||
|       <h3 class="section-title">{{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }}</h3> | ||||
|       <div class="content-block"> | ||||
|         <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}</p> | ||||
| @ -40,6 +39,84 @@ | ||||
|         <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENTTHREE") }}</p> | ||||
|       </div> | ||||
|     </section> | ||||
| 
 | ||||
|     <!-- 使命与愿景 --> | ||||
|     <!-- <section | ||||
|       class="mission-vision" | ||||
|       style=" | ||||
|         max-width: 1200px; | ||||
|         margin: 60px auto; | ||||
|         padding: 0 40px; | ||||
|         background: #f8fafc; | ||||
|       " | ||||
|     > | ||||
|       <h2 class="section-titles"> | ||||
|         {{ $t("COMPANYOVERVIEW.TITLETHREE.TITLE") }} | ||||
|       </h2> | ||||
|       <div class="mission-content"> | ||||
|         <ul> | ||||
|           <li> | ||||
|             {{ $t("COMPANYOVERVIEW.TITLETHREE.CONTENT").replace("•", "") }} | ||||
|           </li> | ||||
|           <li> | ||||
|             {{ $t("COMPANYOVERVIEW.TITLETHREE.CONTENTTWO").replace("•", "") }} | ||||
|           </li> | ||||
|         </ul> | ||||
|       </div> | ||||
|     </section> --> | ||||
| 
 | ||||
|     <!-- 企业里程碑 --> | ||||
|     <section | ||||
|       class="milestones" | ||||
|       style="max-width: 1200px; margin: 60px auto; padding: 0 40px" | ||||
|     > | ||||
|       <h2 class="section-titles"> | ||||
|         {{ $t("COMPANYOVERVIEW.TITLEFOUR.TITLE") }} | ||||
|       </h2> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADING") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraph.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraph.TWO") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGTWO") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTwo.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTwo.TWO") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGTHREE") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTHREE.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTHREE.TWO") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGFOREFF") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFOUR.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFOUR.TWO") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGFIVE") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.TWO") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.THREE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.FOUR") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.FIVE") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
|     </section> | ||||
|     <!-- 突出成就 --> | ||||
|     <section | ||||
|       class="achievements" | ||||
| @ -66,19 +143,19 @@ | ||||
|       <div class="news-card"> | ||||
|         <!-- <div class="news-date">De 15. 2023</div> --> | ||||
|         <!-- <h3 class="news-title">{{ $t("HOME.CONTAINY.NEWS.LATEST_TITLE") }}</h3> --> | ||||
|         <p style="font-size: 18px"> | ||||
|         <p class="news-excerpt"> | ||||
|           {{ $t("HOME.CONTAINY.NEWS.TITLETWO") }} | ||||
|         </p> | ||||
|         <p style="font-size: 18px"> | ||||
|         <p class="news-excerpt"> | ||||
|           {{ $t("HOME.CONTAINY.NEWS.TITLETHTEE") }} | ||||
|         </p> | ||||
|         <p style="font-size: 18px"> | ||||
|         <p class="news-excerpt"> | ||||
|           {{ $t("HOME.CONTAINY.NEWS.CONTENTTHREE") }} | ||||
|         </p> | ||||
|         <p style="font-size: 18px"> | ||||
|         <p class="news-excerpt"> | ||||
|           {{ $t("HOME.CONTAINY.NEWS.CONTENTFOUR") }} | ||||
|         </p> | ||||
|         <p style="font-size: 18px"> | ||||
|         <p class="news-excerpt"> | ||||
|           {{ $t("HOME.CONTAINY.NEWS.CONTENTFIVE") }} | ||||
|         </p> | ||||
|         <!-- <a href="#" class="news-link" | ||||
| @ -97,50 +174,36 @@ | ||||
|           <h2 class="card-title">{{ $t("HOME.CONTAINY.STOCK_INFO.TITLE") }}</h2> | ||||
|           <div class="stock-data"> | ||||
|             <div class="data-row"> | ||||
|               <span style="font-size: 18px" class="data-label"> Time </span> | ||||
|               <span style="font-size: 18px" class="data-value">{{ | ||||
|                 formattedDate | ||||
|               }}</span> | ||||
|             </div> | ||||
|             <div class="data-row"> | ||||
|               <span style="font-size: 18px" class="data-label">{{ | ||||
|               <span class="data-label">{{ | ||||
|                 $t("HOME.CONTAINY.STOCK_INFO.LAST_PRICE") | ||||
|               }}</span> | ||||
|               <span style="font-size: 18px" class="data-value" | ||||
|                 >${{ stockQuote.Open }}</span | ||||
|               > | ||||
|               <span class="data-value">${{ stockQuote.Open }}</span> | ||||
|             </div> | ||||
|             <div class="data-row"> | ||||
|               <span style="font-size: 18px" class="data-label">{{ | ||||
|               <span class="data-label">{{ | ||||
|                 $t("HOME.CONTAINY.STOCK_INFO.CHANGE") | ||||
|               }}</span> | ||||
|               <span style="font-size: 18px" class="data-value positive" | ||||
|               <span class="data-value positive" | ||||
|                 >{{ stockQuote.change[0] }}{{ stockQuote.change[1] }}</span | ||||
|               > | ||||
|             </div> | ||||
|             <div class="data-row"> | ||||
|               <span style="font-size: 18px" class="data-label">{{ | ||||
|               <span class="data-label">{{ | ||||
|                 $t("HOME.CONTAINY.STOCK_INFO.STOCK_CODE") | ||||
|               }}</span> | ||||
|               <span style="font-size: 18px" class="data-value" | ||||
|                 >NASDAQ: MINM</span | ||||
|               > | ||||
|               <span class="data-value">NASDAQ: MINM</span> | ||||
|             </div> | ||||
|             <div class="data-row"> | ||||
|               <span style="font-size: 18px" class="data-label">{{ | ||||
|               <span class="data-label">{{ | ||||
|                 $t("HOME.CONTAINY.STOCK_INFO.VOLUME") | ||||
|               }}</span> | ||||
|               <span style="font-size: 18px" class="data-value">{{ | ||||
|                 stockQuote.Volume | ||||
|               }}</span> | ||||
|               <span class="data-value">{{ stockQuote.Volume }}</span> | ||||
|             </div> | ||||
|             <div class="data-row"> | ||||
|               <span style="font-size: 18px" class="data-label">{{ | ||||
|               <span class="data-label">{{ | ||||
|                 $t("HOME.CONTAINY.STOCK_INFO.MARKET_CAP") | ||||
|               }}</span> | ||||
|               <span style="font-size: 18px" class="data-value" | ||||
|                 >${{ stockQuote.MarketCap }}</span | ||||
|               > | ||||
|               <span class="data-value">${{ stockQuote.MarketCap }}</span> | ||||
|             </div> | ||||
|           </div> | ||||
|         </div> | ||||
| @ -192,52 +255,13 @@ | ||||
| </template> | ||||
| 
 | ||||
| <script setup> | ||||
| import { onMounted, ref, onUnmounted, computed } from "vue"; | ||||
| import { onMounted, ref, onUnmounted } from "vue"; | ||||
| import { useI18n } from "vue-i18n"; | ||||
| import { useStockQuote } from "@/store/stock-quote/index.js"; | ||||
| const { getStockQuate, stockQuote, formatted } = useStockQuote(); | ||||
| const { getStockQuate, stockQuote } = useStockQuote(); | ||||
| 
 | ||||
| getStockQuate(); | ||||
| 
 | ||||
| const formatCustomDate = (dateString, timeZone = "EDT") => { | ||||
|   const date = new Date(dateString); | ||||
| 
 | ||||
|   // 验证日期有效性 | ||||
|   if (isNaN(date.getTime())) { | ||||
|     return "Invalid Date"; | ||||
|   } | ||||
| 
 | ||||
|   // 保留原始小时数用于AM/PM判断 | ||||
|   const originalHours = date.getHours(); | ||||
| 
 | ||||
|   // 转换为12小时制 | ||||
|   let displayHours = originalHours % 12; | ||||
|   displayHours = displayHours ? displayHours : 12; // 0应显示为12 | ||||
| 
 | ||||
|   // 格式化分钟 | ||||
|   const minutes = date.getMinutes().toString().padStart(2, "0"); | ||||
| 
 | ||||
|   // 判断AM/PM | ||||
|   const period = originalHours >= 12 ? "PM" : "AM"; | ||||
| 
 | ||||
|   // 时间部分 (8:10PM) | ||||
|   const timePart = `${displayHours}:${minutes}${period}`; | ||||
| 
 | ||||
|   // 日期部分 (EDT23/15/25) | ||||
|   const month = (date.getMonth() + 1).toString().padStart(2, "0"); | ||||
|   const day = date.getDate().toString().padStart(2, "0"); | ||||
|   const year = date.getFullYear().toString().slice(2); // 取后两位 | ||||
| 
 | ||||
|   const datePart = `${timeZone} ${day}/${month}/${year}`; | ||||
| 
 | ||||
|   // 组合最终结果 | ||||
|   return `As of ${timePart} ${datePart}`; | ||||
| }; | ||||
| 
 | ||||
| // 示例数据 | ||||
| const sampleDate = ref("May 26, 2025, 2:44 AM EDT"); | ||||
| const formattedDate = computed(() => formatCustomDate(sampleDate.value)); | ||||
| 
 | ||||
| const { t: $t } = useI18n(); | ||||
| const contentRef = ref(null); | ||||
| const isInView = ref(false); | ||||
| @ -278,7 +302,7 @@ onUnmounted(() => { | ||||
| 
 | ||||
| <style scoped> | ||||
| .home-page { | ||||
|   background-image: url("@/assets/image/bg-mobile.png"); | ||||
|   background-image: url("@/assets/image/bg.png"); | ||||
|   background-size: 100% 100%; | ||||
|   background-position: center; | ||||
|   background-repeat: no-repeat; | ||||
|  | ||||
| @ -25,7 +25,7 @@ | ||||
|       class="company-overview" | ||||
|       style="max-width: 1200px; margin: 60px auto; padding: 0 40px" | ||||
|     > | ||||
|       <h1 class="section-titles">Company Profile</h1> | ||||
|       <h1 class="section-titles">Company profile</h1> | ||||
|       <h3 class="section-title">{{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }}</h3> | ||||
|       <div class="content-block"> | ||||
|         <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}</p> | ||||
| @ -39,6 +39,84 @@ | ||||
|         <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENTTHREE") }}</p> | ||||
|       </div> | ||||
|     </section> | ||||
| 
 | ||||
|     <!-- 使命与愿景 --> | ||||
|     <!-- <section | ||||
|       class="mission-vision" | ||||
|       style=" | ||||
|         max-width: 1200px; | ||||
|         margin: 60px auto; | ||||
|         padding: 0 40px; | ||||
|         background: #f8fafc; | ||||
|       " | ||||
|     > | ||||
|       <h2 class="section-titles"> | ||||
|         {{ $t("COMPANYOVERVIEW.TITLETHREE.TITLE") }} | ||||
|       </h2> | ||||
|       <div class="mission-content"> | ||||
|         <ul> | ||||
|           <li> | ||||
|             {{ $t("COMPANYOVERVIEW.TITLETHREE.CONTENT").replace("•", "") }} | ||||
|           </li> | ||||
|           <li> | ||||
|             {{ $t("COMPANYOVERVIEW.TITLETHREE.CONTENTTWO").replace("•", "") }} | ||||
|           </li> | ||||
|         </ul> | ||||
|       </div> | ||||
|     </section> --> | ||||
| 
 | ||||
|     <!-- 企业里程碑 --> | ||||
|     <section | ||||
|       class="milestones" | ||||
|       style="max-width: 1200px; margin: 60px auto; padding: 0 40px" | ||||
|     > | ||||
|       <h2 class="section-titles"> | ||||
|         {{ $t("COMPANYOVERVIEW.TITLEFOUR.TITLE") }} | ||||
|       </h2> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADING") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraph.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraph.TWO") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGTWO") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTwo.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTwo.TWO") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGTHREE") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTHREE.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTHREE.TWO") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGFOREFF") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFOUR.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFOUR.TWO") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGFIVE") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.TWO") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.THREE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.FOUR") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.FIVE") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
|     </section> | ||||
|     <!-- 突出成就 --> | ||||
|     <section | ||||
|       class="achievements" | ||||
| @ -95,10 +173,6 @@ | ||||
|         <div class="info-card stock-card"> | ||||
|           <h2 class="card-title">{{ $t("HOME.CONTAINY.STOCK_INFO.TITLE") }}</h2> | ||||
|           <div class="stock-data"> | ||||
|             <div class="data-row"> | ||||
|               <span class="data-label"> Time </span> | ||||
|               <span class="data-value">{{ formattedDate }}</span> | ||||
|             </div> | ||||
|             <div class="data-row"> | ||||
|               <span class="data-label">{{ | ||||
|                 $t("HOME.CONTAINY.STOCK_INFO.LAST_PRICE") | ||||
| @ -181,55 +255,18 @@ | ||||
| </template> | ||||
| 
 | ||||
| <script setup> | ||||
| import { onMounted, ref, onUnmounted, computed } from "vue"; | ||||
| import { onMounted, ref, onUnmounted } from "vue"; | ||||
| import { useI18n } from "vue-i18n"; | ||||
| import { useStockQuote } from "@/store/stock-quote/index.js"; | ||||
| const { getStockQuate, stockQuote, formatted } = useStockQuote(); | ||||
| const { getStockQuate, stockQuote } = useStockQuote(); | ||||
| 
 | ||||
| getStockQuate(); | ||||
| 
 | ||||
| const formatCustomDate = (dateString, timeZone = "EDT") => { | ||||
|   const date = new Date(dateString); | ||||
| 
 | ||||
|   // 验证日期有效性 | ||||
|   if (isNaN(date.getTime())) { | ||||
|     return "Invalid Date"; | ||||
|   } | ||||
| 
 | ||||
|   // 保留原始小时数用于AM/PM判断 | ||||
|   const originalHours = date.getHours(); | ||||
| 
 | ||||
|   // 转换为12小时制 | ||||
|   let displayHours = originalHours % 12; | ||||
|   displayHours = displayHours ? displayHours : 12; // 0应显示为12 | ||||
| 
 | ||||
|   // 格式化分钟 | ||||
|   const minutes = date.getMinutes().toString().padStart(2, "0"); | ||||
| 
 | ||||
|   // 判断AM/PM | ||||
|   const period = originalHours >= 12 ? "PM" : "AM"; | ||||
| 
 | ||||
|   // 时间部分 (8:10PM) | ||||
|   const timePart = `${displayHours}:${minutes}${period}`; | ||||
| 
 | ||||
|   // 日期部分 (EDT23/15/25) | ||||
|   const month = (date.getMonth() + 1).toString().padStart(2, "0"); | ||||
|   const day = date.getDate().toString().padStart(2, "0"); | ||||
|   const year = date.getFullYear().toString().slice(2); // 取后两位 | ||||
| 
 | ||||
|   const datePart = `${timeZone} ${day}/${month}/${year}`; | ||||
| 
 | ||||
|   // 组合最终结果 | ||||
|   return `As of ${timePart} ${datePart}`; | ||||
| }; | ||||
| 
 | ||||
| // 示例数据 | ||||
| const sampleDate = ref("May 26, 2025, 2:44 AM EDT"); | ||||
| const formattedDate = computed(() => formatCustomDate(sampleDate.value)); | ||||
| const { t: $t } = useI18n(); | ||||
| const contentRef = ref(null); | ||||
| const isInView = ref(false); | ||||
| let observer = null; | ||||
| 
 | ||||
| onMounted(() => { | ||||
|   if (contentRef.value && "IntersectionObserver" in window) { | ||||
|     observer = new IntersectionObserver( | ||||
|  | ||||
| @ -25,8 +25,7 @@ | ||||
|       class="company-overview" | ||||
|       style="max-width: 1200px; margin: 60px auto; padding: 0 40px" | ||||
|     > | ||||
|       <h1 class="section-titles">Company Profile</h1> | ||||
| 
 | ||||
|       <h1 class="section-titles">Company profile</h1> | ||||
|       <h3 class="section-title">{{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }}</h3> | ||||
|       <div class="content-block"> | ||||
|         <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}</p> | ||||
| @ -41,6 +40,83 @@ | ||||
|       </div> | ||||
|     </section> | ||||
| 
 | ||||
|     <!-- 使命与愿景 --> | ||||
|     <!-- <section | ||||
|       class="mission-vision" | ||||
|       style=" | ||||
|         max-width: 1200px; | ||||
|         margin: 60px auto; | ||||
|         padding: 0 40px; | ||||
|         background: #f8fafc; | ||||
|       " | ||||
|     > | ||||
|       <h2 class="section-titles"> | ||||
|         {{ $t("COMPANYOVERVIEW.TITLETHREE.TITLE") }} | ||||
|       </h2> | ||||
|       <div class="mission-content"> | ||||
|         <ul> | ||||
|           <li> | ||||
|             {{ $t("COMPANYOVERVIEW.TITLETHREE.CONTENT").replace("•", "") }} | ||||
|           </li> | ||||
|           <li> | ||||
|             {{ $t("COMPANYOVERVIEW.TITLETHREE.CONTENTTWO").replace("•", "") }} | ||||
|           </li> | ||||
|         </ul> | ||||
|       </div> | ||||
|     </section> --> | ||||
| 
 | ||||
|     <!-- 企业里程碑 --> | ||||
|     <section | ||||
|       class="milestones" | ||||
|       style="max-width: 1200px; margin: 60px auto; padding: 0 40px" | ||||
|     > | ||||
|       <h2 class="section-titles"> | ||||
|         {{ $t("COMPANYOVERVIEW.TITLEFOUR.TITLE") }} | ||||
|       </h2> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADING") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraph.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraph.TWO") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGTWO") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTwo.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTwo.TWO") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGTHREE") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTHREE.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTHREE.TWO") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGFOREFF") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFOUR.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFOUR.TWO") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGFIVE") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.TWO") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.THREE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.FOUR") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.FIVE") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
|     </section> | ||||
|     <!-- 突出成就 --> | ||||
|     <section | ||||
|       class="achievements" | ||||
| @ -65,19 +141,21 @@ | ||||
|     > | ||||
|       <h2 class="section-titles">{{ $t("HOME.CONTAINY.NEWS.TITLE") }}</h2> | ||||
|       <div class="news-card"> | ||||
|         <p style="font-size: 18px"> | ||||
|         <!-- <div class="news-date">De 15. 2023</div> --> | ||||
|         <!-- <h3 class="news-title">{{ $t("HOME.CONTAINY.NEWS.LATEST_TITLE") }}</h3> --> | ||||
|         <p class="news-excerpt"> | ||||
|           {{ $t("HOME.CONTAINY.NEWS.TITLETWO") }} | ||||
|         </p> | ||||
|         <p style="font-size: 18px"> | ||||
|         <p class="news-excerpt"> | ||||
|           {{ $t("HOME.CONTAINY.NEWS.TITLETHTEE") }} | ||||
|         </p> | ||||
|         <p style="font-size: 18px"> | ||||
|         <p class="news-excerpt"> | ||||
|           {{ $t("HOME.CONTAINY.NEWS.CONTENTTHREE") }} | ||||
|         </p> | ||||
|         <p style="font-size: 18px"> | ||||
|         <p class="news-excerpt"> | ||||
|           {{ $t("HOME.CONTAINY.NEWS.CONTENTFOUR") }} | ||||
|         </p> | ||||
|         <p style="font-size: 18px"> | ||||
|         <p class="news-excerpt"> | ||||
|           {{ $t("HOME.CONTAINY.NEWS.CONTENTFIVE") }} | ||||
|         </p> | ||||
|         <!-- <a href="#" class="news-link" | ||||
| @ -96,50 +174,36 @@ | ||||
|           <h2 class="card-title">{{ $t("HOME.CONTAINY.STOCK_INFO.TITLE") }}</h2> | ||||
|           <div class="stock-data"> | ||||
|             <div class="data-row"> | ||||
|               <span style="font-size: 18px" class="data-label"> Time </span> | ||||
|               <span style="font-size: 18px" class="data-value">{{ | ||||
|                 formattedDate | ||||
|               }}</span> | ||||
|             </div> | ||||
|             <div class="data-row"> | ||||
|               <span style="font-size: 18px" class="data-label">{{ | ||||
|               <span class="data-label">{{ | ||||
|                 $t("HOME.CONTAINY.STOCK_INFO.LAST_PRICE") | ||||
|               }}</span> | ||||
|               <span style="font-size: 18px" class="data-value" | ||||
|                 >${{ stockQuote.Open }}</span | ||||
|               > | ||||
|               <span class="data-value">${{ stockQuote.Open }}</span> | ||||
|             </div> | ||||
|             <div class="data-row"> | ||||
|               <span style="font-size: 18px" class="data-label">{{ | ||||
|               <span class="data-label">{{ | ||||
|                 $t("HOME.CONTAINY.STOCK_INFO.CHANGE") | ||||
|               }}</span> | ||||
|               <span style="font-size: 18px" class="data-value positive" | ||||
|               <span class="data-value positive" | ||||
|                 >{{ stockQuote.change[0] }}{{ stockQuote.change[1] }}</span | ||||
|               > | ||||
|             </div> | ||||
|             <div class="data-row"> | ||||
|               <span style="font-size: 18px" class="data-label">{{ | ||||
|               <span class="data-label">{{ | ||||
|                 $t("HOME.CONTAINY.STOCK_INFO.STOCK_CODE") | ||||
|               }}</span> | ||||
|               <span style="font-size: 18px" class="data-value" | ||||
|                 >NASDAQ: MINM</span | ||||
|               > | ||||
|               <span class="data-value">NASDAQ: MINM</span> | ||||
|             </div> | ||||
|             <div class="data-row"> | ||||
|               <span style="font-size: 18px" class="data-label">{{ | ||||
|               <span class="data-label">{{ | ||||
|                 $t("HOME.CONTAINY.STOCK_INFO.VOLUME") | ||||
|               }}</span> | ||||
|               <span style="font-size: 18px" class="data-value">{{ | ||||
|                 stockQuote.Volume | ||||
|               }}</span> | ||||
|               <span class="data-value">{{ stockQuote.Volume }}</span> | ||||
|             </div> | ||||
|             <div class="data-row"> | ||||
|               <span style="font-size: 18px" class="data-label">{{ | ||||
|               <span class="data-label">{{ | ||||
|                 $t("HOME.CONTAINY.STOCK_INFO.MARKET_CAP") | ||||
|               }}</span> | ||||
|               <span style="font-size: 18px" class="data-value" | ||||
|                 >${{ stockQuote.MarketCap }}</span | ||||
|               > | ||||
|               <span class="data-value">${{ stockQuote.MarketCap }}</span> | ||||
|             </div> | ||||
|           </div> | ||||
|         </div> | ||||
| @ -191,52 +255,13 @@ | ||||
| </template> | ||||
| 
 | ||||
| <script setup> | ||||
| import { onMounted, ref, onUnmounted, computed } from "vue"; | ||||
| import { onMounted, ref, onUnmounted } from "vue"; | ||||
| import { useI18n } from "vue-i18n"; | ||||
| import { useStockQuote } from "@/store/stock-quote/index.js"; | ||||
| const { getStockQuate, stockQuote, formatted } = useStockQuote(); | ||||
| const { getStockQuate, stockQuote } = useStockQuote(); | ||||
| 
 | ||||
| getStockQuate(); | ||||
| 
 | ||||
| const formatCustomDate = (dateString, timeZone = "EDT") => { | ||||
|   const date = new Date(dateString); | ||||
| 
 | ||||
|   // 验证日期有效性 | ||||
|   if (isNaN(date.getTime())) { | ||||
|     return "Invalid Date"; | ||||
|   } | ||||
| 
 | ||||
|   // 保留原始小时数用于AM/PM判断 | ||||
|   const originalHours = date.getHours(); | ||||
| 
 | ||||
|   // 转换为12小时制 | ||||
|   let displayHours = originalHours % 12; | ||||
|   displayHours = displayHours ? displayHours : 12; // 0应显示为12 | ||||
| 
 | ||||
|   // 格式化分钟 | ||||
|   const minutes = date.getMinutes().toString().padStart(2, "0"); | ||||
| 
 | ||||
|   // 判断AM/PM | ||||
|   const period = originalHours >= 12 ? "PM" : "AM"; | ||||
| 
 | ||||
|   // 时间部分 (8:10PM) | ||||
|   const timePart = `${displayHours}:${minutes}${period}`; | ||||
| 
 | ||||
|   // 日期部分 (EDT23/15/25) | ||||
|   const month = (date.getMonth() + 1).toString().padStart(2, "0"); | ||||
|   const day = date.getDate().toString().padStart(2, "0"); | ||||
|   const year = date.getFullYear().toString().slice(2); // 取后两位 | ||||
| 
 | ||||
|   const datePart = `${timeZone} ${day}/${month}/${year}`; | ||||
| 
 | ||||
|   // 组合最终结果 | ||||
|   return `As of ${timePart} ${datePart}`; | ||||
| }; | ||||
| 
 | ||||
| // 示例数据 | ||||
| const sampleDate = ref("May 26, 2025, 2:44 AM EDT"); | ||||
| const formattedDate = computed(() => formatCustomDate(sampleDate.value)); | ||||
| 
 | ||||
| const { t: $t } = useI18n(); | ||||
| const contentRef = ref(null); | ||||
| const isInView = ref(false); | ||||
|  | ||||
| @ -25,8 +25,7 @@ | ||||
|       class="company-overview" | ||||
|       style="max-width: 1200px; margin: 60px auto; padding: 0 40px" | ||||
|     > | ||||
|       <h1 class="section-titles">Company Profile</h1> | ||||
| 
 | ||||
|       <h1 class="section-titles">Company profile</h1> | ||||
|       <h3 class="section-title">{{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }}</h3> | ||||
|       <div class="content-block"> | ||||
|         <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}</p> | ||||
| @ -41,6 +40,83 @@ | ||||
|       </div> | ||||
|     </section> | ||||
| 
 | ||||
|     <!-- 使命与愿景 --> | ||||
|     <!-- <section | ||||
|       class="mission-vision" | ||||
|       style=" | ||||
|         max-width: 1200px; | ||||
|         margin: 60px auto; | ||||
|         padding: 0 40px; | ||||
|         background: #f8fafc; | ||||
|       " | ||||
|     > | ||||
|       <h2 class="section-titles"> | ||||
|         {{ $t("COMPANYOVERVIEW.TITLETHREE.TITLE") }} | ||||
|       </h2> | ||||
|       <div class="mission-content"> | ||||
|         <ul> | ||||
|           <li> | ||||
|             {{ $t("COMPANYOVERVIEW.TITLETHREE.CONTENT").replace("•", "") }} | ||||
|           </li> | ||||
|           <li> | ||||
|             {{ $t("COMPANYOVERVIEW.TITLETHREE.CONTENTTWO").replace("•", "") }} | ||||
|           </li> | ||||
|         </ul> | ||||
|       </div> | ||||
|     </section> --> | ||||
| 
 | ||||
|     <!-- 企业里程碑 --> | ||||
|     <section | ||||
|       class="milestones" | ||||
|       style="max-width: 1200px; margin: 60px auto; padding: 0 40px" | ||||
|     > | ||||
|       <h2 class="section-titles"> | ||||
|         {{ $t("COMPANYOVERVIEW.TITLEFOUR.TITLE") }} | ||||
|       </h2> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADING") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraph.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraph.TWO") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGTWO") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTwo.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTwo.TWO") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGTHREE") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTHREE.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphTHREE.TWO") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGFOREFF") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFOUR.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFOUR.TWO") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
| 
 | ||||
|       <div class="milestone-item"> | ||||
|         <h3>{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGFIVE") }}</h3> | ||||
|         <ul> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.ONE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.TWO") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.THREE") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.FOUR") }}</li> | ||||
|           <li>{{ $t("COMPANYOVERVIEW.TITLEFOUR.paragraphFIVE.FIVE") }}</li> | ||||
|         </ul> | ||||
|       </div> | ||||
|     </section> | ||||
|     <!-- 突出成就 --> | ||||
|     <section | ||||
|       class="achievements" | ||||
| @ -67,19 +143,19 @@ | ||||
|       <div class="news-card"> | ||||
|         <!-- <div class="news-date">De 15. 2023</div> --> | ||||
|         <!-- <h3 class="news-title">{{ $t("HOME.CONTAINY.NEWS.LATEST_TITLE") }}</h3> --> | ||||
|         <p style="font-size: 18px"> | ||||
|         <p class="news-excerpt"> | ||||
|           {{ $t("HOME.CONTAINY.NEWS.TITLETWO") }} | ||||
|         </p> | ||||
|         <p style="font-size: 18px"> | ||||
|         <p class="news-excerpt"> | ||||
|           {{ $t("HOME.CONTAINY.NEWS.TITLETHTEE") }} | ||||
|         </p> | ||||
|         <p style="font-size: 18px"> | ||||
|         <p class="news-excerpt"> | ||||
|           {{ $t("HOME.CONTAINY.NEWS.CONTENTTHREE") }} | ||||
|         </p> | ||||
|         <p style="font-size: 18px"> | ||||
|         <p class="news-excerpt"> | ||||
|           {{ $t("HOME.CONTAINY.NEWS.CONTENTFOUR") }} | ||||
|         </p> | ||||
|         <p style="font-size: 18px"> | ||||
|         <p class="news-excerpt"> | ||||
|           {{ $t("HOME.CONTAINY.NEWS.CONTENTFIVE") }} | ||||
|         </p> | ||||
|         <!-- <a href="#" class="news-link" | ||||
| @ -98,50 +174,36 @@ | ||||
|           <h2 class="card-title">{{ $t("HOME.CONTAINY.STOCK_INFO.TITLE") }}</h2> | ||||
|           <div class="stock-data"> | ||||
|             <div class="data-row"> | ||||
|               <span style="font-size: 18px" class="data-label"> Time </span> | ||||
|               <span style="font-size: 18px" class="data-value">{{ | ||||
|                 formattedDate | ||||
|               }}</span> | ||||
|             </div> | ||||
|             <div class="data-row"> | ||||
|               <span style="font-size: 18px" class="data-label">{{ | ||||
|               <span class="data-label">{{ | ||||
|                 $t("HOME.CONTAINY.STOCK_INFO.LAST_PRICE") | ||||
|               }}</span> | ||||
|               <span style="font-size: 18px" class="data-value" | ||||
|                 >${{ stockQuote.Open }}</span | ||||
|               > | ||||
|               <span class="data-value">${{ stockQuote.Open }}</span> | ||||
|             </div> | ||||
|             <div class="data-row"> | ||||
|               <span style="font-size: 18px" class="data-label">{{ | ||||
|               <span class="data-label">{{ | ||||
|                 $t("HOME.CONTAINY.STOCK_INFO.CHANGE") | ||||
|               }}</span> | ||||
|               <span style="font-size: 18px" class="data-value positive" | ||||
|               <span class="data-value positive" | ||||
|                 >{{ stockQuote.change[0] }}{{ stockQuote.change[1] }}</span | ||||
|               > | ||||
|             </div> | ||||
|             <div class="data-row"> | ||||
|               <span style="font-size: 18px" class="data-label">{{ | ||||
|               <span class="data-label">{{ | ||||
|                 $t("HOME.CONTAINY.STOCK_INFO.STOCK_CODE") | ||||
|               }}</span> | ||||
|               <span style="font-size: 18px" class="data-value" | ||||
|                 >NASDAQ: MINM</span | ||||
|               > | ||||
|               <span class="data-value">NASDAQ: MINM</span> | ||||
|             </div> | ||||
|             <div class="data-row"> | ||||
|               <span style="font-size: 18px" class="data-label">{{ | ||||
|               <span class="data-label">{{ | ||||
|                 $t("HOME.CONTAINY.STOCK_INFO.VOLUME") | ||||
|               }}</span> | ||||
|               <span style="font-size: 18px" class="data-value">{{ | ||||
|                 stockQuote.Volume | ||||
|               }}</span> | ||||
|               <span class="data-value">{{ stockQuote.Volume }}</span> | ||||
|             </div> | ||||
|             <div class="data-row"> | ||||
|               <span style="font-size: 18px" class="data-label">{{ | ||||
|               <span class="data-label">{{ | ||||
|                 $t("HOME.CONTAINY.STOCK_INFO.MARKET_CAP") | ||||
|               }}</span> | ||||
|               <span style="font-size: 18px" class="data-value" | ||||
|                 >${{ stockQuote.MarketCap }}</span | ||||
|               > | ||||
|               <span class="data-value">${{ stockQuote.MarketCap }}</span> | ||||
|             </div> | ||||
|           </div> | ||||
|         </div> | ||||
| @ -193,52 +255,13 @@ | ||||
| </template> | ||||
| 
 | ||||
| <script setup> | ||||
| import { onMounted, ref, onUnmounted, computed } from "vue"; | ||||
| import { onMounted, ref, onUnmounted } from "vue"; | ||||
| import { useI18n } from "vue-i18n"; | ||||
| import { useStockQuote } from "@/store/stock-quote/index.js"; | ||||
| const { getStockQuate, stockQuote, formatted } = useStockQuote(); | ||||
| const { getStockQuate, stockQuote } = useStockQuote(); | ||||
| 
 | ||||
| getStockQuate(); | ||||
| 
 | ||||
| const formatCustomDate = (dateString, timeZone = "EDT") => { | ||||
|   const date = new Date(dateString); | ||||
| 
 | ||||
|   // 验证日期有效性 | ||||
|   if (isNaN(date.getTime())) { | ||||
|     return "Invalid Date"; | ||||
|   } | ||||
| 
 | ||||
|   // 保留原始小时数用于AM/PM判断 | ||||
|   const originalHours = date.getHours(); | ||||
| 
 | ||||
|   // 转换为12小时制 | ||||
|   let displayHours = originalHours % 12; | ||||
|   displayHours = displayHours ? displayHours : 12; // 0应显示为12 | ||||
| 
 | ||||
|   // 格式化分钟 | ||||
|   const minutes = date.getMinutes().toString().padStart(2, "0"); | ||||
| 
 | ||||
|   // 判断AM/PM | ||||
|   const period = originalHours >= 12 ? "PM" : "AM"; | ||||
| 
 | ||||
|   // 时间部分 (8:10PM) | ||||
|   const timePart = `${displayHours}:${minutes}${period}`; | ||||
| 
 | ||||
|   // 日期部分 (EDT23/15/25) | ||||
|   const month = (date.getMonth() + 1).toString().padStart(2, "0"); | ||||
|   const day = date.getDate().toString().padStart(2, "0"); | ||||
|   const year = date.getFullYear().toString().slice(2); // 取后两位 | ||||
| 
 | ||||
|   const datePart = `${timeZone} ${day}/${month}/${year}`; | ||||
| 
 | ||||
|   // 组合最终结果 | ||||
|   return `As of ${timePart} ${datePart}`; | ||||
| }; | ||||
| 
 | ||||
| // 示例数据 | ||||
| const sampleDate = ref("May 26, 2025, 2:44 AM EDT"); | ||||
| const formattedDate = computed(() => formatCustomDate(sampleDate.value)); | ||||
| 
 | ||||
| const { t: $t } = useI18n(); | ||||
| const contentRef = ref(null); | ||||
| const isInView = ref(false); | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user