Compare commits
	
		
			No commits in common. "15a11041e71aae66ad0dc61919085cb5995a6695" and "40e2c0554d05887db3c1c6f1c3895667c7af7b73" have entirely different histories.
		
	
	
		
			15a11041e7
			...
			40e2c0554d
		
	
		
| @ -13,6 +13,7 @@ | |||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@fingerprintjs/fingerprintjs": "^4.4.3", |     "@fingerprintjs/fingerprintjs": "^4.4.3", | ||||||
|     "@unocss/reset": "^0.61.9", |     "@unocss/reset": "^0.61.9", | ||||||
|  |     "@vueuse/core": "^10.11.0", | ||||||
|     "axios": "^1.7.3", |     "axios": "^1.7.3", | ||||||
|     "cnjm-postcss-px-to-viewport": "^1.0.1", |     "cnjm-postcss-px-to-viewport": "^1.0.1", | ||||||
|     "gsap": "^3.12.5", |     "gsap": "^3.12.5", | ||||||
| @ -37,7 +38,6 @@ | |||||||
|     "@vant/auto-import-resolver": "^1.2.1", |     "@vant/auto-import-resolver": "^1.2.1", | ||||||
|     "@vitejs/plugin-legacy": "^5.3.0", |     "@vitejs/plugin-legacy": "^5.3.0", | ||||||
|     "@vitejs/plugin-vue": "^5.0.5", |     "@vitejs/plugin-vue": "^5.0.5", | ||||||
|     "@vueuse/core": "^10.11.0", |  | ||||||
|     "autoprefixer": "^10.4.20", |     "autoprefixer": "^10.4.20", | ||||||
|     "babel-plugin-transform-react-jsx": "^6.24.1", |     "babel-plugin-transform-react-jsx": "^6.24.1", | ||||||
|     "postcss": "^8.4.40", |     "postcss": "^8.4.40", | ||||||
| @ -45,7 +45,6 @@ | |||||||
|     "unocss": "^0.61.9", |     "unocss": "^0.61.9", | ||||||
|     "unplugin-auto-import": "^0.18.2", |     "unplugin-auto-import": "^0.18.2", | ||||||
|     "unplugin-vue-components": "^0.27.3", |     "unplugin-vue-components": "^0.27.3", | ||||||
|     "vite": "^5.3.4", |     "vite": "^5.3.4" | ||||||
|     "vite-plugin-imagemin": "^0.6.1" |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										2475
									
								
								pnpm-lock.yaml
									
									
									
									
									
								
							
							
						
						| Before Width: | Height: | Size: 260 KiB | 
| Before Width: | Height: | Size: 9.3 KiB | 
| Before Width: | Height: | Size: 815 KiB | 
| Before Width: | Height: | Size: 649 B | 
| Before Width: | Height: | Size: 281 KiB | 
| Before Width: | Height: | Size: 263 KiB | 
| Before Width: | Height: | Size: 104 KiB | 
| Before Width: | Height: | Size: 436 B | 
| Before Width: | Height: | Size: 80 KiB | 
| Before Width: | Height: | Size: 269 KiB | 
| Before Width: | Height: | Size: 66 KiB | 
| Before Width: | Height: | Size: 313 KiB | 
| Before Width: | Height: | Size: 8.5 KiB | 
| Before Width: | Height: | Size: 77 KiB | 
| Before Width: | Height: | Size: 33 KiB | 
| Before Width: | Height: | Size: 8.9 KiB | 
| Before Width: | Height: | Size: 8.7 KiB | 
| Before Width: | Height: | Size: 276 B | 
| Before Width: | Height: | Size: 649 B | 
| Before Width: | Height: | Size: 322 B | 
| Before Width: | Height: | Size: 1.6 KiB | 
| Before Width: | Height: | Size: 1.8 KiB | 
| Before Width: | Height: | Size: 464 B | 
| Before Width: | Height: | Size: 419 B | 
| Before Width: | Height: | Size: 400 KiB | 
| Before Width: | Height: | Size: 372 KiB | 
| Before Width: | Height: | Size: 151 KiB | 
| Before Width: | Height: | Size: 425 KiB | 
| Before Width: | Height: | Size: 22 KiB | 
| Before Width: | Height: | Size: 151 KiB | 
| Before Width: | Height: | Size: 80 KiB | 
| Before Width: | Height: | Size: 8.5 KiB | 
| Before Width: | Height: | Size: 8.2 KiB | 
| Before Width: | Height: | Size: 276 B | 
| Before Width: | Height: | Size: 649 B | 
| Before Width: | Height: | Size: 322 B | 
| Before Width: | Height: | Size: 1.6 KiB | 
| Before Width: | Height: | Size: 1.8 KiB | 
| Before Width: | Height: | Size: 464 B | 
| Before Width: | Height: | Size: 530 B | 
| Before Width: | Height: | Size: 281 KiB | 
| Before Width: | Height: | Size: 263 KiB | 
| Before Width: | Height: | Size: 104 KiB | 
| Before Width: | Height: | Size: 983 KiB | 
| Before Width: | Height: | Size: 530 B | 
| Before Width: | Height: | Size: 9.6 KiB | 
| Before Width: | Height: | Size: 347 KiB | 
| Before Width: | Height: | Size: 146 KiB | 
| @ -75,18 +75,6 @@ | |||||||
|             /> |             /> | ||||||
|           </div> |           </div> | ||||||
| 
 | 
 | ||||||
|           <div class="divider3"></div> |  | ||||||
|           <div |  | ||||||
|             class="w-full flex justify-between px-[130px] pt-[102px] pb-[80px] items-center" |  | ||||||
|             @click="handleTabClick('investor')" |  | ||||||
|           > |  | ||||||
|             {{ t("home.nav.investor") }} |  | ||||||
|             <img |  | ||||||
|               src="@/assets/image/home/375/icon-menu-right.png" |  | ||||||
|               class="w-[44px] h-[79px]" |  | ||||||
|             /> |  | ||||||
|           </div> |  | ||||||
| 
 |  | ||||||
|           <div class="divider3"></div> |           <div class="divider3"></div> | ||||||
|         </div> |         </div> | ||||||
|       </n-drawer-content> |       </n-drawer-content> | ||||||
|  | |||||||
| @ -75,18 +75,6 @@ | |||||||
|             /> |             /> | ||||||
|           </div> |           </div> | ||||||
| 
 | 
 | ||||||
|           <div class="divider3"></div> |  | ||||||
|           <div |  | ||||||
|             class="w-full flex justify-between px-[188px] pt-[50px] pb-[46px] items-center" |  | ||||||
|             @click="handleTabClick('investor')" |  | ||||||
|           > |  | ||||||
|             {{ t("home.nav.investor") }} |  | ||||||
|             <img |  | ||||||
|               src="@/assets/image/home/768/icon-menu-right.png" |  | ||||||
|               class="w-[22px] h-[38px]" |  | ||||||
|             /> |  | ||||||
|           </div> |  | ||||||
| 
 |  | ||||||
|           <div class="divider3"></div> |           <div class="divider3"></div> | ||||||
|         </div> |         </div> | ||||||
|       </n-drawer-content> |       </n-drawer-content> | ||||||
|  | |||||||
| @ -17,8 +17,7 @@ export default { | |||||||
|       company: 'Unternehmensprofil', |       company: 'Unternehmensprofil', | ||||||
|       businessintroduction: 'Geschäftsvorstellung', |       businessintroduction: 'Geschäftsvorstellung', | ||||||
|       please_select: 'Bitte auswählen', |       please_select: 'Bitte auswählen', | ||||||
|       confirm_select: 'Bestätigen Sie die Auswahl', |       confirm_select: 'Bestätigen Sie die Auswahl' | ||||||
|       investor: 'Investor Guide' |  | ||||||
|     }, |     }, | ||||||
|     scroll: { |     scroll: { | ||||||
|       tip: 'Nach unten scrollen' |       tip: 'Nach unten scrollen' | ||||||
| @ -347,109 +346,5 @@ export default { | |||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   }, |  | ||||||
|   investor: { |  | ||||||
|     title: 'Investor Relations', |  | ||||||
|     subtitle: 'Finanzstatus von Minim (NASDAQ: MINM)', |  | ||||||
|     latest_news: { |  | ||||||
|       title: 'Aktuelle Nachrichten', |  | ||||||
|       financial: { |  | ||||||
|         title: 'Aktuelle Finanzdaten', |  | ||||||
|         date: '29. März 2023', |  | ||||||
|         content: 'Ergebnisse für das vierte Quartal 2022 und das Gesamtjahr 2022', |  | ||||||
|         link: 'Ergebnisbericht' |  | ||||||
|       }, |  | ||||||
|       events: { |  | ||||||
|         title: 'Aktuelle Ereignisse', |  | ||||||
|         date: '13. März 2024', |  | ||||||
|         content: 'Minim gibt Vereinbarung zur Fusion mit e2Companies bekannt', |  | ||||||
|         link: 'Fusionsvereinbarung - Endgültige Pressemitteilung 3. Dezember 2024' |  | ||||||
|       }, |  | ||||||
|       stock: { |  | ||||||
|         title: 'Aktienkurs', |  | ||||||
|         content: 'MINM-Kurs auf TradingView', |  | ||||||
|         link: 'MINM-Kurs' |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     financial_data: { |  | ||||||
|       title: 'Finanzdaten', |  | ||||||
|       years: { |  | ||||||
|         year2023: '2023', |  | ||||||
|         year2022: '2022', |  | ||||||
|         year2021: '2021' |  | ||||||
|       }, |  | ||||||
|       reports: { |  | ||||||
|         profit_report: 'Gewinnbericht', |  | ||||||
|         earnings_report: 'Ergebnisbericht', |  | ||||||
|         earnings_call: 'Ergebnispräsentation', |  | ||||||
|         sec_filings: '10-Q/10-K', |  | ||||||
|         annual_report: 'Jahresbericht', |  | ||||||
|         annual_meeting: 'Jahreshauptversammlung', |  | ||||||
|         special_meeting: 'Außerordentliche Hauptversammlung', |  | ||||||
|         proxy_statement: 'Vollmachtserklärung' |  | ||||||
|       }, |  | ||||||
|       investor_guide: 'Leitfaden für die Kommunikation mit Investoren' |  | ||||||
|     }, |  | ||||||
|     market_trends: { |  | ||||||
|       title: 'Markttrends', |  | ||||||
|       sec_description1: 'SEC-Einreichungen sind Dokumente, die bei der US-Börsenaufsichtsbehörde (SEC) eingereicht werden. Börsennotierte Unternehmen und bestimmte Insider sind verpflichtet, regelmäßig bei der SEC einzureichen. Diese Dokumente sind über die Online-Datenbank der SEC verfügbar.', |  | ||||||
|       sec_description2: 'Durch die Auswahl unten verlassen Sie die Website von Minim. Minim gibt keine Zusicherungen bezüglich anderer Websites, die Sie über diese Seite aufrufen können. Wenn Sie eine Nicht-Minim-Website aufrufen, auch eine, die das Minim-Logo enthalten könnte, verstehen Sie bitte, dass diese unabhängig von Minim ist und Minim keinen Einfluss auf den Inhalt dieser Website hat. Darüber hinaus bedeutet ein Link zu einer Nicht-Minim-Website nicht, dass Minim den Inhalt oder die Nutzung dieser Website befürwortet oder dafür verantwortlich ist.', |  | ||||||
|       view_all_sec: 'Alle SEC-Einreichungen anzeigen' |  | ||||||
|     }, |  | ||||||
|     board_of_directors: { |  | ||||||
|       title: 'Vorstand', |  | ||||||
|       directors: { |  | ||||||
|         patrick: { |  | ||||||
|           name: 'Patrick Rivard', |  | ||||||
|           position: 'Vorstandsmitglied,CFO bei U.S. Wealth Protection', |  | ||||||
|           position1: 'Vorstandsmitglied', |  | ||||||
|           position2: 'Partner & CFO bei U.S. Wealth Protection' |  | ||||||
|         }, |  | ||||||
|         andrew: { |  | ||||||
|           name: 'Andrew Papanikolaou', |  | ||||||
|           position: 'Vorstandsmitglied, Finanzmanager bei Raytheon', |  | ||||||
|           position1: 'Vorstandsmitglied', |  | ||||||
|           position2: 'Finanzmanager bei Raytheon' |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     governance: { |  | ||||||
|       title: 'Governance, Diversität und Ausschussrichtlinien', |  | ||||||
|       documents: { |  | ||||||
|         ethics_code: 'Ethikrichtlinie für leitende Finanzbeamte', |  | ||||||
|         conflict_minerals: 'Konfliktmineralien-Erklärung', |  | ||||||
|         business_conduct: 'Ethik- und Geschäftsverhaltenskodex', |  | ||||||
|         audit_committee: 'Prüfungsausschussrichtlinie', |  | ||||||
|         whistleblower: 'Hinweisgeberrichtlinie', |  | ||||||
|         compensation_committee: 'Vergütungsausschussrichtlinie', |  | ||||||
|         related_party: 'Richtlinie für Geschäfte mit Nahestehenden', |  | ||||||
|         nomination_committee: 'Nominierungs- und Governance-Ausschuss', |  | ||||||
|         diversity_matrix_2022: 'Diversitätsmatrix 2022', |  | ||||||
|         diversity_matrix_2023: 'Diversitätsmatrix 2023' |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   investorhandbook: { |  | ||||||
|     title: 'Mindestkommunikationsrichtlinien mit der Investorengemeinschaft', |  | ||||||
|     authorized_speakers: { |  | ||||||
|       title: 'Befugte Sprecher', |  | ||||||
|       desc: 'Die folgenden Minim-Vertreter sind befugt, mit der Investorengemeinschaft, einschließlich Analysten, Börsenmaklern sowie privaten und institutionellen Aktionären, zu kommunizieren:', |  | ||||||
|       items: [ |  | ||||||
|         'Präsident', |  | ||||||
|         'Präsident und Chief Marketing Officer', |  | ||||||
|         'Chief Financial Officer' |  | ||||||
|       ], |  | ||||||
|       note: 'In diesem Leitfaden werden diese Vertreter als "Befugte IR-Kontakte" bezeichnet.' |  | ||||||
|     }, |  | ||||||
|     quarterly_communications: { |  | ||||||
|       title: 'Kommunikation und Besprechungen zum Quartalsende', |  | ||||||
|       items: [ |  | ||||||
|         '1. Ruhefrist — Das Unternehmen beachtet eine "Ruhefrist", die vom Quartalsende bis zur Veröffentlichung der Ergebnisse reicht. Während dieser Zeit wird das Management des Unternehmens keine 1:1-Treffen mit Analysten oder Investoren durchführen. Auf Anfrage können jedoch sachliche öffentliche Informationen an Investoren bereitgestellt und von befugten Investor Relations-Kontakten analysiert werden.', |  | ||||||
|         '2. Analystenmeetings/Telefonkonferenzen — Alle Analystenmeetings oder -anrufe, in denen vierteljährliche oder jährliche Finanz- und Geschäftsinformationen diskutiert werden, sollten gleichzeitig über das Internet oder eine Telefonkonferenz an alle interessierten Mitglieder der Öffentlichkeit übertragen werden. Eine angemessene Vorankündigung und gleichzeitige Übertragung der Besprechung sollte über eine Pressemitteilung oder andere Kommunikationsmethoden erfolgen, die der Verordnung FD entsprechen.', |  | ||||||
|         '3. Ergebnis-Pressemitteilung — Die Ergebnis-Pressemitteilung wird zu Beginn oder vor der Besprechung oder Telefonkonferenz, wie von der Investor Relations-Abteilung und dem Chief Financial Officer festgelegt, gemäß den geltenden SEC- und NASDAQ-Regeln über den Nachrichtendienst veröffentlicht. Sie wird auch bei der SEC auf Formular 8-K eingereicht und auf der Unternehmenswebsite veröffentlicht.', |  | ||||||
|         '4. Eine jährliche Leitlinie zum anfänglichen Abonnementumsatz und zum EPS-Bereich kann in der Ergebnis-Pressemitteilung bereitgestellt werden, und falls erforderlich, können Aktualisierungen der Leitlinie in jeder Quartals-Ergebnis-Pressemitteilung bereitgestellt werden. In der Regel wird das Unternehmen diese Leitlinie während des Quartals nicht aktualisieren oder zusätzliche Leitlinien bereitstellen, es sei denn, der VP Finance/CFO hält dies für notwendig, und dies nur in einem öffentlichen Forum, das der Verordnung FD entspricht.' |  | ||||||
|       ], |  | ||||||
|       note: 'Minim-Vertreter (außer befugte Sprecher), die Anfragen von Medien, Marktprofis oder Aktionären erhalten, sollten solche Anfragen nicht beantworten, sondern den Anfragenden an einen befugten Sprecher verweisen. Minim-Vertreter, die den Investor Relations- und Marketingteams zugewiesen sind, können jedoch routinemäßige Anfragen zu öffentlichen Informationen gemäß den von befugten Sprechern festgelegten Richtlinien beantworten.' |  | ||||||
|     } |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @ -17,8 +17,7 @@ export default { | |||||||
|       company: 'Company Overview', |       company: 'Company Overview', | ||||||
|       businessintroduction: 'Business Introduction', |       businessintroduction: 'Business Introduction', | ||||||
|       please_select: 'Please Select', |       please_select: 'Please Select', | ||||||
|       confirm_select: 'Confirm Selection', |       confirm_select: 'Confirm Selection' | ||||||
|       investor: 'Investor Guide' |  | ||||||
|     }, |     }, | ||||||
|     scroll: { |     scroll: { | ||||||
|       tip: 'Scroll Down' |       tip: 'Scroll Down' | ||||||
| @ -359,109 +358,5 @@ export default { | |||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   }, |  | ||||||
|   investor: { |  | ||||||
|     title: 'Investor Relations', |  | ||||||
|     subtitle: 'Minim (NASDAQ: MINM) Financial Status', |  | ||||||
|     latest_news: { |  | ||||||
|       title: 'Latest News', |  | ||||||
|       financial: { |  | ||||||
|         title: 'Latest Financials', |  | ||||||
|         date: 'March 29, 2023', |  | ||||||
|         content: '2022 Q4 and Full Year 2022 Earnings Results', |  | ||||||
|         link: 'Earnings Release' |  | ||||||
|       }, |  | ||||||
|       events: { |  | ||||||
|         title: 'Recent Events', |  | ||||||
|         date: 'March 13, 2024', |  | ||||||
|         content: 'Minim Announces Merger Agreement with e2Companies', |  | ||||||
|         link: 'Merger Agreement - Final Press Release December 3, 2024' |  | ||||||
|       }, |  | ||||||
|       stock: { |  | ||||||
|         title: 'Stock Quote', |  | ||||||
|         content: 'MINM Quote on TradingView', |  | ||||||
|         link: 'MINM Quote' |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     financial_data: { |  | ||||||
|       title: 'Financial Data', |  | ||||||
|       years: { |  | ||||||
|         year2023: '2023', |  | ||||||
|         year2022: '2022', |  | ||||||
|         year2021: '2021' |  | ||||||
|       }, |  | ||||||
|       reports: { |  | ||||||
|         profit_report: 'Profit Report', |  | ||||||
|         earnings_report: 'Earnings Report', |  | ||||||
|         earnings_call: 'Earnings Call', |  | ||||||
|         sec_filings: '10-Q/10-K', |  | ||||||
|         annual_report: 'Annual Report', |  | ||||||
|         annual_meeting: 'Annual Meeting', |  | ||||||
|         special_meeting: 'Special Shareholder Meeting', |  | ||||||
|         proxy_statement: 'Proxy Statement' |  | ||||||
|       }, |  | ||||||
|       investor_guide: 'Investor Guide' |  | ||||||
|     }, |  | ||||||
|     market_trends: { |  | ||||||
|       title: 'Market Trends', |  | ||||||
|       sec_description1: 'SEC filings are documents submitted to the U.S. Securities and Exchange Commission (SEC). Public companies and certain insiders are required to file regularly with the SEC. These documents are available through the SEC\'s online database.', |  | ||||||
|       sec_description2: 'By selecting below, you will leave the Minim website. Minim makes no representations regarding any other websites you may access through this site. When you access a non-Minim website, even one that may contain the Minim logo, please understand that it is independent of Minim, and Minim has no control over the content of that website. Additionally, a link to a non-Minim website does not mean that Minim endorses or accepts any responsibility for the content or use of such website.', |  | ||||||
|       view_all_sec: 'View All SEC Filings' |  | ||||||
|     }, |  | ||||||
|     board_of_directors: { |  | ||||||
|       title: 'Board of Directors', |  | ||||||
|       directors: { |  | ||||||
|         patrick: { |  | ||||||
|           name: 'Patrick Rivard', |  | ||||||
|           position: 'Board Director, Partner & CFO at U.S. Wealth Protection', |  | ||||||
|           position1: 'Board Director', |  | ||||||
|           position2: 'Partner & CFO at U.S. Wealth Protection' |  | ||||||
|         }, |  | ||||||
|         andrew: { |  | ||||||
|           name: 'Andrew Papanikolaou', |  | ||||||
|           position: 'Board Director, Finance Manager at Raytheon', |  | ||||||
|           position1: 'Board Director', |  | ||||||
|           position2: 'Finance Manager at Raytheon' |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     governance: { |  | ||||||
|       title: 'Governance, Diversity, and Committee Charters', |  | ||||||
|       documents: { |  | ||||||
|         ethics_code: 'Code of Ethics for Senior Financial Officers', |  | ||||||
|         conflict_minerals: 'Conflict Minerals Statement', |  | ||||||
|         business_conduct: 'Code of Ethics and Business Conduct', |  | ||||||
|         audit_committee: 'Audit Committee Charter', |  | ||||||
|         whistleblower: 'Whistleblower Policy', |  | ||||||
|         compensation_committee: 'Compensation Committee Charter', |  | ||||||
|         related_party: 'Related Party Transactions Policy', |  | ||||||
|         nomination_committee: 'Nominating&Governance Committee Charter', |  | ||||||
|         diversity_matrix_2022: '2022 Diversity Matrix', |  | ||||||
|         diversity_matrix_2023: '2023 Diversity Matrix' |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   investorhandbook: { |  | ||||||
|     title: 'Minimum Communication Guidelines with the Investor Community', |  | ||||||
|     authorized_speakers: { |  | ||||||
|       title: 'Authorized Speakers', |  | ||||||
|       desc: 'The following Minim representatives are authorized to communicate with the investment community, including analysts, stockbrokers, and individual and institutional shareholders:', |  | ||||||
|       items: [ |  | ||||||
|         'President', |  | ||||||
|         'President and Chief Marketing Officer', |  | ||||||
|         'Chief Financial Officer' |  | ||||||
|       ], |  | ||||||
|       note: 'In this guide, these representatives are referred to as "Authorized IR Contacts".' |  | ||||||
|     }, |  | ||||||
|     quarterly_communications: { |  | ||||||
|       title: 'Quarter-End Communications and Meetings', |  | ||||||
|       items: [ |  | ||||||
|         '1. Quiet Period — The company observes a "Quiet Period" starting from the quarter-end date until the earnings release. During this period, company management will not conduct 1:1 meetings with analysts or investors. However, upon request, factual public information may be provided to investors and analyzed by authorized Investor Relations contacts.', |  | ||||||
|         '2. Analyst Meetings/Conference Calls — All analyst meetings or calls discussing quarterly or annual financial and business information should be broadcast simultaneously to all interested members of the public via the internet or conference call. Appropriate advance notice and simultaneous broadcast of the meeting should be provided via press release or other communication methods compliant with Regulation FD.', |  | ||||||
|         '3. Earnings Press Release — The earnings press release will be issued on the wire service at the beginning or prior to the meeting or conference call, as determined by the Investor Relations department and the Chief Financial Officer, in accordance with applicable SEC and NASDAQ rules. It will also be filed with the SEC on Form 8-K and posted on the company website.', |  | ||||||
|         '4. Annual guidance on initial subscription revenue and EPS range may be provided in the earnings press release, and if necessary, updates to the guidance may be provided in each quarter\'s earnings press release. Generally, the company will not update this guidance or provide additional guidance during the quarter unless deemed necessary by the VP of Finance/CFO, and only in a public forum compliant with Regulation FD.' |  | ||||||
|       ], |  | ||||||
|       note: 'Minim representatives (other than authorized speakers) who receive inquiries from the media, market professionals, or shareholders should not respond to such inquiries but should refer the inquirer to an authorized speaker. However, Minim representatives assigned to the Investor Relations and Marketing teams may respond to routine inquiries about public information in accordance with guidelines established by authorized speakers from time to time.' |  | ||||||
|     } |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @ -17,8 +17,7 @@ export default { | |||||||
|       "company": "会社概要", |       "company": "会社概要", | ||||||
|       "businessintroduction": "業務紹介", |       "businessintroduction": "業務紹介", | ||||||
|       "please_select": "選択してください", |       "please_select": "選択してください", | ||||||
|       "confirm_select": "確認選択", |       "confirm_select": "確認選択" | ||||||
|       "investor": "投資家ガイド" |  | ||||||
|     }, |     }, | ||||||
|     "scroll": { |     "scroll": { | ||||||
|       "tip": "下にスクロール" |       "tip": "下にスクロール" | ||||||
| @ -347,109 +346,5 @@ export default { | |||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   }, |  | ||||||
|   investor: { |  | ||||||
|     title: '投資家向け情報', |  | ||||||
|     subtitle: 'Minim(NASDAQ: MINM)財務状況', |  | ||||||
|     latest_news: { |  | ||||||
|       title: '最新ニュース', |  | ||||||
|       financial: { |  | ||||||
|         title: '最新財務情報', |  | ||||||
|         date: '2023年3月29日', |  | ||||||
|         content: '2022年第四四半期および2022年通期の決算結果', |  | ||||||
|         link: '決算発表' |  | ||||||
|       }, |  | ||||||
|       events: { |  | ||||||
|         title: '最近のイベント', |  | ||||||
|         date: '2024年3月13日', |  | ||||||
|         content: 'Minim、e2Companiesとの合併契約を発表', |  | ||||||
|         link: '合併契約-最終プレスリリース2024年12月3日' |  | ||||||
|       }, |  | ||||||
|       stock: { |  | ||||||
|         title: '株価情報', |  | ||||||
|         content: 'TradingViewのMINM株価', |  | ||||||
|         link: 'MINM株価' |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     financial_data: { |  | ||||||
|       title: '財務データ', |  | ||||||
|       years: { |  | ||||||
|         year2023: '2023年', |  | ||||||
|         year2022: '2022年', |  | ||||||
|         year2021: '2021年' |  | ||||||
|       }, |  | ||||||
|       reports: { |  | ||||||
|         profit_report: '利益レポート', |  | ||||||
|         earnings_report: '決算レポート', |  | ||||||
|         earnings_call: '決算説明会', |  | ||||||
|         sec_filings: '10-Q/10-K', |  | ||||||
|         annual_report: '年次報告書', |  | ||||||
|         annual_meeting: '年次総会', |  | ||||||
|         special_meeting: '臨時株主総会', |  | ||||||
|         proxy_statement: '委任状' |  | ||||||
|       }, |  | ||||||
|       investor_guide: '投資家向けコミュニケーション指南' |  | ||||||
|     }, |  | ||||||
|     market_trends: { |  | ||||||
|       title: '市場動向', |  | ||||||
|       sec_description1: 'SECファイルは、米国証券取引委員会(SEC)に提出される文書です。上場企業および特定の内部関係者は、定期的にSECに提出する必要があります。これらの文書は、SECのオンラインデータベースを通じて入手できます。', |  | ||||||
|       sec_description2: '以下を選択すると、Minimのウェブサイトから離れます。Minimは、このサイトを通じてアクセスできる他のウェブサイトについて一切の表明を行いません。Minim以外のウェブサイトにアクセスする場合、Minimのロゴが含まれている場合でも、それがMinimとは独立していることを理解してください。Minimはそのウェブサイトの内容を管理できません。さらに、Minim以外のウェブサイトへのリンクは、Minimがそのウェブサイトの内容または使用について責任を負うことを意味するものではありません。', |  | ||||||
|       view_all_sec: 'すべてのSECファイルを表示' |  | ||||||
|     }, |  | ||||||
|     board_of_directors: { |  | ||||||
|       title: '取締役会', |  | ||||||
|       directors: { |  | ||||||
|         patrick: { |  | ||||||
|           name: 'パトリック・リバード', |  | ||||||
|           position: '取締役、米国ウェルスプロテクション社パートナー兼CFO', |  | ||||||
|           position1: '取締役', |  | ||||||
|           position2: '米国ウェルスプロテクション社パートナー兼CFO' |  | ||||||
|         }, |  | ||||||
|         andrew: { |  | ||||||
|           name: 'アンドリュー・パパニコラウ', |  | ||||||
|           position: '取締役、レイセオン社財務マネージャー', |  | ||||||
|           position1: '取締役', |  | ||||||
|           position2: 'レイセオン社財務マネージャー' |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     governance: { |  | ||||||
|       title: 'ガバナンス、多様性、委員会規程', |  | ||||||
|       documents: { |  | ||||||
|         ethics_code: '上級財務責任者の倫理規定', |  | ||||||
|         conflict_minerals: '紛争鉱物声明', |  | ||||||
|         business_conduct: '倫理およびビジネス行動規範', |  | ||||||
|         audit_committee: '監査委員会規程', |  | ||||||
|         whistleblower: '内部告発者ポリシー', |  | ||||||
|         compensation_committee: '報酬委員会規程', |  | ||||||
|         related_party: '関連当事者取引ポリシー', |  | ||||||
|         nomination_committee: '指名およびガバナンス委員会規程', |  | ||||||
|         diversity_matrix_2022: '2022年多様性マトリックス', |  | ||||||
|         diversity_matrix_2023: '2023年多様性マトリックス' |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   investorhandbook: { |  | ||||||
|     title: '投資家コミュニティとの最低限のコミュニケーションガイドライン', |  | ||||||
|     authorized_speakers: { |  | ||||||
|       title: '承認されたスピーカー', |  | ||||||
|       desc: '以下のMinim代表者は、アナリスト、株式ブローカー、個人および機関投資家を含む投資家コミュニティとコミュニケーションを取る権限を持っています:', |  | ||||||
|       items: [ |  | ||||||
|         '社長', |  | ||||||
|         '社長兼最高マーケティング責任者', |  | ||||||
|         '最高財務責任者' |  | ||||||
|       ], |  | ||||||
|       note: 'このガイドでは、これらの代表者を「承認されたIR連絡先」と呼びます。' |  | ||||||
|     }, |  | ||||||
|     quarterly_communications: { |  | ||||||
|       title: '四半期末のコミュニケーションと会議', |  | ||||||
|       items: [ |  | ||||||
|         '1. 静寂期間 — 会社は、四半期末から決算発表まで「静寂期間」を遵守します。この期間中、会社の経営陣はアナリストや投資家との1対1の会議を行いません。ただし、要求に応じて、事実に基づく公開情報を投資家に提供し、承認された投資家関係連絡先が分析することができます。', |  | ||||||
|         '2. アナリスト会議/電話会議 — 四半期または年度の財務およびビジネス情報について議論するすべてのアナリスト会議または電話会議は、インターネットまたは電話会議を通じて、すべての関心を持つ一般公衆に同時に放送されるべきです。会議の適切な事前通知と同時放送は、プレスリリースまたは規制FDに準拠した他の通信方法で提供されるべきです。', |  | ||||||
|         '3. 決算プレスリリース — 決算プレスリリースは、投資家関係部門および最高財務責任者が決定した会議または電話会議の開始時または前に、適用されるSECおよびNASDAQ規則に従って、ワイヤーサービスで発表されます。また、8-KフォームとしてSECに提出され、会社のウェブサイトに掲載されます。', |  | ||||||
|         '4. 年間の初回購読収益およびEPS範囲に関するガイダンスは、決算プレスリリースで提供される場合があり、必要に応じて、各四半期の決算プレスリリースでガイダンスの更新が提供される場合があります。一般的に、会社は四半期中にこのガイダンスを更新したり、追加のガイダンスを提供したりすることはありませんが、財務担当副社長/最高財務責任者が必要と判断し、規制FDに準拠した公開フォーラムでのみ提供される場合を除きます。' |  | ||||||
|       ], |  | ||||||
|       note: 'メディア、市場専門家、または株主からの問い合わせを受けたMinim代表者(承認されたスピーカーを除く)は、そのような問い合わせに応答せず、問い合わせ者を承認されたスピーカーに紹介する必要があります。ただし、Minimの投資家関係およびマーケティングチームに割り当てられたMinim代表者は、承認されたスピーカーが随時定めるガイドラインに従って、公開情報に関する日常的な問い合わせに応答することができます。' |  | ||||||
|     } |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @ -17,8 +17,7 @@ export default { | |||||||
|       "company": "公司概況", |       "company": "公司概況", | ||||||
|       "businessintroduction": "業務介紹", |       "businessintroduction": "業務介紹", | ||||||
|       "please_select": "請選擇", |       "please_select": "請選擇", | ||||||
|       "confirm_select": "確認選擇", |       "confirm_select": "確認選擇" | ||||||
|       "investor": "投資家指南" |  | ||||||
|     }, |     }, | ||||||
|     "scroll": { |     "scroll": { | ||||||
|       "tip": "向下滑動" |       "tip": "向下滑動" | ||||||
| @ -343,109 +342,5 @@ export default { | |||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   }, |  | ||||||
|   investor: { |  | ||||||
|     title: '投資者關係', |  | ||||||
|     subtitle: 'Minim(納斯達克股票代碼:MINM)財務狀況', |  | ||||||
|     latest_news: { |  | ||||||
|       title: '最新動態', |  | ||||||
|       financial: { |  | ||||||
|         title: '最新財務', |  | ||||||
|         date: '2023年3月29日', |  | ||||||
|         content: '2022年第四季度和2022年全年收益結果', |  | ||||||
|         link: '收益公布' |  | ||||||
|       }, |  | ||||||
|       events: { |  | ||||||
|         title: '最近的事件', |  | ||||||
|         date: '2024年3月13日', |  | ||||||
|         content: 'Minim宣布與e2Companies達成合併協議', |  | ||||||
|         link: '合併協議-新聞稿最終稿2024年12月3日' |  | ||||||
|       }, |  | ||||||
|       stock: { |  | ||||||
|         title: '股票報價', |  | ||||||
|         content: 'TradingView的MINM報價', |  | ||||||
|         link: 'MINM報價' |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     financial_data: { |  | ||||||
|       title: '財務數據', |  | ||||||
|       years: { |  | ||||||
|         year2023: '2023年', |  | ||||||
|         year2022: '2022年', |  | ||||||
|         year2021: '2021年' |  | ||||||
|       }, |  | ||||||
|       reports: { |  | ||||||
|         profit_report: '利潤報告', |  | ||||||
|         earnings_report: '收益報告', |  | ||||||
|         earnings_call: '財報電話會議', |  | ||||||
|         sec_filings: '10-Q/10-K', |  | ||||||
|         annual_report: '年度報告', |  | ||||||
|         annual_meeting: '年度會議', |  | ||||||
|         special_meeting: '特別股東大會', |  | ||||||
|         proxy_statement: '委託書' |  | ||||||
|       }, |  | ||||||
|       investor_guide: '投資者溝通指南' |  | ||||||
|     }, |  | ||||||
|     market_trends: { |  | ||||||
|       title: '行情走勢', |  | ||||||
|       sec_description1: 'SEC文件是提交給美國證券交易委員會(SEC)的文件。上市公司和某些內部人士必須定期向美國證券交易委員會提交文件。這些文件可以通過美國證券交易委員會的在線數據庫獲得。', |  | ||||||
|       sec_description2: '通過在下面進行選擇,您將離開Minim網站。Minim對您可以通過此網站訪問的任何其他網站不作任何陳述。當您訪問非Minim網站時,即使是可能包含Minim徽標的網站,請理解它獨立於Minim,Minim無法控制該網站上的內容。此外,鏈接到非Minim網站並不意味著Minim認可或接受對該網站的內容或使用的任何責任。', |  | ||||||
|       view_all_sec: '查看所有SEC文件' |  | ||||||
|     }, |  | ||||||
|     board_of_directors: { |  | ||||||
|       title: '董事會', |  | ||||||
|       directors: { |  | ||||||
|         patrick: { |  | ||||||
|           name: '帕特里克·里瓦德', |  | ||||||
|           position: '董事會董事、美國財富保護公司合夥人兼首席財務官', |  | ||||||
|           position1: '董事會董事', |  | ||||||
|           position2: '美國財富保護公司合夥人兼首席財務官' |  | ||||||
|         }, |  | ||||||
|         andrew: { |  | ||||||
|           name: '安德魯·帕帕尼科勞', |  | ||||||
|           position: '董事會董事、雷神公司財務經理', |  | ||||||
|           position1: '董事會董事', |  | ||||||
|           position2: '雷神公司財務經理' |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     governance: { |  | ||||||
|       title: '治理、多樣性和委員會章程', |  | ||||||
|       documents: { |  | ||||||
|         ethics_code: '高級財務人員道德守則', |  | ||||||
|         conflict_minerals: '衝突礦產聲明', |  | ||||||
|         business_conduct: '道德和商業行為準則', |  | ||||||
|         audit_committee: '審計委員會章程', |  | ||||||
|         whistleblower: '舉報人政策', |  | ||||||
|         compensation_committee: '薪酬委員會章程', |  | ||||||
|         related_party: '關聯方交易政策', |  | ||||||
|         nomination_committee: '提名和治理委員會章程', |  | ||||||
|         diversity_matrix_2022: '2022年多樣性矩陣', |  | ||||||
|         diversity_matrix_2023: '2023年多樣性矩陣' |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   investorhandbook: { |  | ||||||
|     title: '與投資者社區的最低溝通指南', |  | ||||||
|     authorized_speakers: { |  | ||||||
|       title: '授權發言人', |  | ||||||
|       desc: '以下Minim代表有權與分析師、股票經紀人、個人和機構股東的投資界進行溝通:', |  | ||||||
|       items: [ |  | ||||||
|         '總裁', |  | ||||||
|         '總裁兼首席營銷官', |  | ||||||
|         '首席財務官' |  | ||||||
|       ], |  | ||||||
|       note: '在本指南中,這些代表被稱為"授權IR聯繫人"。' |  | ||||||
|     }, |  | ||||||
|     quarterly_communications: { |  | ||||||
|       title: '季度末溝通和會議', |  | ||||||
|       items: [ |  | ||||||
|         '1. 靜默期——公司遵守"靜默期",從季度末日期開始,到收益發布時結束。在此期間,企業管理層將不會與分析師或投資者進行1:1的會面。然而,根據要求,可向投資者提供基於事實的公共信息,並由授權投資者關係聯繫人進行分析。', |  | ||||||
|         '2. 分析師會議/電話會議——所有討論季度、年度財務和業務信息的分析師會議或通話應通過互聯網或電話會議同時向所有感興趣的公眾廣播。會議的適當提前通知和同步廣播應通過新聞稿或符合FD條例的其他通信方式進行。', |  | ||||||
|         '3. 收益新聞稿——收益新聞稿將在投資者關係部和首席財務官確定的會議或電話會議開始時或之前,按照適用的美國證券交易委員會和納斯達克規則,在新聞專線上發布,以8-K表格的形式提供給美國證券交易會,並發布在公司網站上。', |  | ||||||
|         '4. 有關年度首次認購收入和每股收益範圍的指導意見,可在收益新聞稿中提供,如有必要,可在每個季度的收益新聞稿上提供對指導意見的修改。一般來說,公司不會在本季度更新本指南或提供額外指南,除非財務副總裁/首席財務官認為有必要,並且只能根據FD條例在公開論壇上提供。' |  | ||||||
|       ], |  | ||||||
|       note: '收到媒體、市場專業人士或股東任何詢問的Minim代表(授權發言人除外)不得回覆此類詢問,但應將提問者轉介給授權發言人。然而,分配給Minim投資者關係和營銷團隊的Minim代表可以按照授權發言人不時制定的指導方針,對公開信息的例行詢問作出回應。' |  | ||||||
|     } |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @ -16,7 +16,6 @@ export default { | |||||||
|       home: '首页', |       home: '首页', | ||||||
|       company: '公司概况', |       company: '公司概况', | ||||||
|       businessintroduction: '业务介绍', |       businessintroduction: '业务介绍', | ||||||
|       investor: '投资者关系', |  | ||||||
|       language_change: '语言切换', |       language_change: '语言切换', | ||||||
|       please_select: '请选择', |       please_select: '请选择', | ||||||
|       confirm_select: '确认选择' |       confirm_select: '确认选择' | ||||||
| @ -348,109 +347,5 @@ export default { | |||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   }, |  | ||||||
|   investor: { |  | ||||||
|     title: '投资者关系', |  | ||||||
|     subtitle: 'Minim(纳斯达克股票代码:MINM)财务状况', |  | ||||||
|     latest_news: { |  | ||||||
|       title: '最新动态', |  | ||||||
|       financial: { |  | ||||||
|         title: '最新财务', |  | ||||||
|         date: '2023年3月29日', |  | ||||||
|         content: '2022年第四季度和2022年全年收益结果', |  | ||||||
|         link: '收益公布' |  | ||||||
|       }, |  | ||||||
|       events: { |  | ||||||
|         title: '最近的事件', |  | ||||||
|         date: '2024年3月13日', |  | ||||||
|         content: 'Minim宣布与e2Companies达成合并协议', |  | ||||||
|         link: '合并协议-新闻稿最终稿2024年12月3日' |  | ||||||
|       }, |  | ||||||
|       stock: { |  | ||||||
|         title: '股票报价', |  | ||||||
|         content: 'TradingView的MINM报价', |  | ||||||
|         link: 'MINM报价' |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     financial_data: { |  | ||||||
|       title: '财务数据', |  | ||||||
|       years: { |  | ||||||
|         year2023: '2023年', |  | ||||||
|         year2022: '2022年', |  | ||||||
|         year2021: '2021年' |  | ||||||
|       }, |  | ||||||
|       reports: { |  | ||||||
|         profit_report: '利润报告', |  | ||||||
|         earnings_report: '收益报告', |  | ||||||
|         earnings_call: '财报电话会议', |  | ||||||
|         sec_filings: '10-Q/10-K', |  | ||||||
|         annual_report: '年度报告', |  | ||||||
|         annual_meeting: '年度会议', |  | ||||||
|         special_meeting: '特别股东大会', |  | ||||||
|         proxy_statement: '委托书' |  | ||||||
|       }, |  | ||||||
|       investor_guide: '投资者沟通指南' |  | ||||||
|     }, |  | ||||||
|     market_trends: { |  | ||||||
|       title: '行情走势', |  | ||||||
|       sec_description1: 'SEC文件是提交给美国证券交易委员会(SEC)的文件。上市公司和某些内部人士必须定期向美国证券交易委员会提交文件。这些文件可以通过美国证券交易委员会的在线数据库获得。', |  | ||||||
|       sec_description2: '通过在下面进行选择,您将离开Minim网站。Minim对您可以通过此网站访问的任何其他网站不作任何陈述。当您访问非Minim网站时,即使是可能包含Minim徽标的网站,请理解它独立于Minim,Minim无法控制该网站上的内容。此外,链接到非Minim网站并不意味着Minim认可或接受对该网站的内容或使用的任何责任。', |  | ||||||
|       view_all_sec: '查看所有SEC文件' |  | ||||||
|     }, |  | ||||||
|     board_of_directors: { |  | ||||||
|       title: '董事会', |  | ||||||
|       directors: { |  | ||||||
|         patrick: { |  | ||||||
|           name: '帕特里克·里瓦德', |  | ||||||
|           position: '董事会董事、美国财富保护公司合伙人兼首席财务官', |  | ||||||
|           position1: '董事会董事', |  | ||||||
|           position2: '美国财富保护公司合伙人兼首席财务官' |  | ||||||
|         }, |  | ||||||
|         andrew: { |  | ||||||
|           name: '安德鲁·帕帕尼科劳', |  | ||||||
|           position: '董事会董事、雷神公司财务经理', |  | ||||||
|           position1: '董事会董事', |  | ||||||
|           position2: '雷神公司财务经理' |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     governance: { |  | ||||||
|       title: '治理、多样性和委员会章程', |  | ||||||
|       documents: { |  | ||||||
|         ethics_code: '高级财务人员道德守则', |  | ||||||
|         conflict_minerals: '冲突矿产声明', |  | ||||||
|         business_conduct: '道德和商业行为准则', |  | ||||||
|         audit_committee: '审计委员会章程', |  | ||||||
|         whistleblower: '举报人政策', |  | ||||||
|         compensation_committee: '薪酬委员会章程', |  | ||||||
|         related_party: '关联方交易政策', |  | ||||||
|         nomination_committee: '提名和治理委员会章程', |  | ||||||
|         diversity_matrix_2022: '2022年多样性矩阵', |  | ||||||
|         diversity_matrix_2023: '2023年多样性矩阵' |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   investorhandbook:{ |  | ||||||
|     title: '与投资者社区的最低沟通指南', |  | ||||||
|     authorized_speakers: { |  | ||||||
|       title: '授权发言人', |  | ||||||
|       desc: '以下Minim代表有权与分析师、股票经纪人、个人和机构股东的投资界进行沟通:', |  | ||||||
|       items: [ |  | ||||||
|         '总裁', |  | ||||||
|         '总裁兼首席营销官', |  | ||||||
|         '首席财务官' |  | ||||||
|       ], |  | ||||||
|       note: '在本指南中,这些代表被称为"授权IR联系人"' |  | ||||||
|     }, |  | ||||||
|     quarterly_communications: { |  | ||||||
|       title: '季度末沟通和会议', |  | ||||||
|       items: [ |  | ||||||
|         '1.静默期——公司遵守"静默期",从季度末日期开始,到收益发布时结束。在此期间,企业管理层将不会与分析师或投资者进行1:1的会面。然而,根据要求,可向投资者提供基于事实的公共信息,并由授权投资者关系联系人进行分析。', |  | ||||||
|         '2.分析师会议/电话会议——所有讨论季度、年度财务和业务信息的分析师会议或通话应通过互联网或电话会议同时向所有感兴趣的公众广播。会议的适当提前通知和同步广播应通过新闻稿或符合FD条例的其他通信方式进行。', |  | ||||||
|         '3.收益新闻稿——收益新闻稿将在投资者关系部和首席财务官确定的会议或电话会议开始时或之前,按照适用的美国证券交易委员会和纳斯达克规则,在新闻专线上发布,以8-K表格的形式提供给美国证券交易会,并发布在公司网站上。', |  | ||||||
|         '4.有关年度首次认购收入和每股收益范围的指导意见,可在收益新闻稿中提供,如有必要,可在每个季度的收益新闻稿上提供对指导意见的修改。一般来说,公司不会在本季度更新本指南或提供额外指南,除非财务副总裁/首席财务官认为有必要,并且只能根据FD条例在公开论坛上提供。' |  | ||||||
|       ], |  | ||||||
|       note: '收到媒体、市场专业人士或股东任何询问的Minim代表(授权发言人除外)不得回复此类询问,但应将提问者转介给授权发言人。然而,分配给Minim投资者关系和营销团队的Minim代表可以按照授权发言人不时制定的指导方针,对公开信息的例行询问作出回应。' |  | ||||||
|     } |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @ -32,16 +32,6 @@ const routes = [ | |||||||
|         name: 'Businessintroduction', |         name: 'Businessintroduction', | ||||||
|         component: () => import('@/views/businessintroduction/index.vue'), |         component: () => import('@/views/businessintroduction/index.vue'), | ||||||
|     }, |     }, | ||||||
|     { |  | ||||||
|         path: '/investor', |  | ||||||
|         name: 'Investor', |  | ||||||
|         component: () => import('@/views/investor/index.vue'), |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|         path: '/investorhandbook', |  | ||||||
|         name: 'Investorhandbook', |  | ||||||
|         component: () => import('@/views/investorhandbook/index.vue'), |  | ||||||
|     }, |  | ||||||
| ]; | ]; | ||||||
| 
 | 
 | ||||||
| const router = createRouter({ | const router = createRouter({ | ||||||
|  | |||||||
| @ -151,14 +151,6 @@ onUnmounted(() => { | |||||||
|         "> |         "> | ||||||
|         {{ t("home.nav.businessintroduction") }} |         {{ t("home.nav.businessintroduction") }} | ||||||
|       </div> |       </div> | ||||||
|       <div class="tab-item" :class="{ |  | ||||||
|         active: |  | ||||||
|           currentTab === 'investor', |  | ||||||
|       }" @click=" |  | ||||||
|         handleTabClick('investor') |  | ||||||
|         "> |  | ||||||
|         {{ t("home.nav.investor") }} |  | ||||||
|       </div> |  | ||||||
|       <div class="tab-item"> |       <div class="tab-item"> | ||||||
|         <n-popselect v-model:value="currentLanguage" :options="languageOptions"  |         <n-popselect v-model:value="currentLanguage" :options="languageOptions"  | ||||||
|           @update:value="changeLanguage"> |           @update:value="changeLanguage"> | ||||||
|  | |||||||
| @ -151,14 +151,6 @@ onUnmounted(() => { | |||||||
|         "> |         "> | ||||||
|         {{ t("home.nav.businessintroduction") }} |         {{ t("home.nav.businessintroduction") }} | ||||||
|       </div> |       </div> | ||||||
|       <div class="tab-item" :class="{ |  | ||||||
|         active: |  | ||||||
|           currentTab === 'investor', |  | ||||||
|       }" @click=" |  | ||||||
|         handleTabClick('investor') |  | ||||||
|         "> |  | ||||||
|         {{ t("home.nav.investor") }} |  | ||||||
|       </div> |  | ||||||
|       <div class="tab-item"> |       <div class="tab-item"> | ||||||
|         <n-popselect v-model:value="currentLanguage" :options="languageOptions"  |         <n-popselect v-model:value="currentLanguage" :options="languageOptions"  | ||||||
|           @update:value="changeLanguage"> |           @update:value="changeLanguage"> | ||||||
|  | |||||||
| @ -307,14 +307,6 @@ onUnmounted(() => { | |||||||
|         "> |         "> | ||||||
|         {{ t("home.nav.businessintroduction") }} |         {{ t("home.nav.businessintroduction") }} | ||||||
|       </div> |       </div> | ||||||
|       <div class="tab-item" :class="{ |  | ||||||
|         active: |  | ||||||
|           currentTab === 'investor', |  | ||||||
|       }" @click=" |  | ||||||
|         handleTabClick('investor') |  | ||||||
|         "> |  | ||||||
|         {{ t("home.nav.investor") }} |  | ||||||
|       </div> |  | ||||||
|       <div class="tab-item"> |       <div class="tab-item"> | ||||||
|         <n-popselect v-model:value="currentLanguage" :options="languageOptions"  |         <n-popselect v-model:value="currentLanguage" :options="languageOptions"  | ||||||
|           @update:value="changeLanguage"> |           @update:value="changeLanguage"> | ||||||
|  | |||||||
| @ -307,14 +307,6 @@ onUnmounted(() => { | |||||||
|         "> |         "> | ||||||
|         {{ t("home.nav.businessintroduction") }} |         {{ t("home.nav.businessintroduction") }} | ||||||
|       </div> |       </div> | ||||||
|       <div class="tab-item" :class="{ |  | ||||||
|         active: |  | ||||||
|           currentTab === 'investor', |  | ||||||
|       }" @click=" |  | ||||||
|         handleTabClick('investor') |  | ||||||
|         "> |  | ||||||
|         {{ t("home.nav.investor") }} |  | ||||||
|       </div> |  | ||||||
|       <div class="tab-item"> |       <div class="tab-item"> | ||||||
|         <n-popselect v-model:value="currentLanguage" :options="languageOptions"  |         <n-popselect v-model:value="currentLanguage" :options="languageOptions"  | ||||||
|           @update:value="changeLanguage"> |           @update:value="changeLanguage"> | ||||||
|  | |||||||
| @ -34,14 +34,6 @@ | |||||||
|         "> |         "> | ||||||
|         {{ t("home.nav.businessintroduction") }} |         {{ t("home.nav.businessintroduction") }} | ||||||
|       </div> |       </div> | ||||||
|       <div class="tab-item" :class="{ |  | ||||||
|         active: |  | ||||||
|           currentTab === 'investor', |  | ||||||
|       }" @click=" |  | ||||||
|         handleTabClick('investor') |  | ||||||
|         "> |  | ||||||
|         {{ t("home.nav.investor") }} |  | ||||||
|       </div> |  | ||||||
|       <div class="tab-item"> |       <div class="tab-item"> | ||||||
|         <n-popselect v-model:value="currentLanguage" :options="languageOptions"  |         <n-popselect v-model:value="currentLanguage" :options="languageOptions"  | ||||||
|           @update:value="changeLanguage"> |           @update:value="changeLanguage"> | ||||||
|  | |||||||
| @ -34,14 +34,6 @@ | |||||||
|         "> |         "> | ||||||
|         {{ t("home.nav.businessintroduction") }} |         {{ t("home.nav.businessintroduction") }} | ||||||
|       </div> |       </div> | ||||||
|       <div class="tab-item" :class="{ |  | ||||||
|         active: |  | ||||||
|           currentTab === 'investor', |  | ||||||
|       }" @click=" |  | ||||||
|         handleTabClick('investor') |  | ||||||
|         "> |  | ||||||
|         {{ t("home.nav.investor") }} |  | ||||||
|       </div> |  | ||||||
|       <div class="tab-item"> |       <div class="tab-item"> | ||||||
|         <n-popselect v-model:value="currentLanguage" :options="languageOptions"  |         <n-popselect v-model:value="currentLanguage" :options="languageOptions"  | ||||||
|           @update:value="changeLanguage"> |           @update:value="changeLanguage"> | ||||||
|  | |||||||
| @ -435,14 +435,6 @@ watch( | |||||||
|         "> |         "> | ||||||
|         {{ t("home.nav.businessintroduction") }} |         {{ t("home.nav.businessintroduction") }} | ||||||
|       </div> |       </div> | ||||||
|       <div class="tab-item" :class="{ |  | ||||||
|         active: |  | ||||||
|           currentTab === 'investor', |  | ||||||
|       }" @click=" |  | ||||||
|         handleTabClick('investor') |  | ||||||
|         "> |  | ||||||
|         {{ t("home.nav.investor") }} |  | ||||||
|       </div> |  | ||||||
|       <div class="tab-item"> |       <div class="tab-item"> | ||||||
|         <n-popselect v-model:value="currentLanguage" :options="languageOptions"  |         <n-popselect v-model:value="currentLanguage" :options="languageOptions"  | ||||||
|           @update:value="changeLanguage"> |           @update:value="changeLanguage"> | ||||||
|  | |||||||
| @ -425,14 +425,6 @@ watch( | |||||||
|         "> |         "> | ||||||
|         {{ t("home.nav.businessintroduction") }} |         {{ t("home.nav.businessintroduction") }} | ||||||
|       </div> |       </div> | ||||||
|       <div class="tab-item" :class="{ |  | ||||||
|         active: |  | ||||||
|           currentTab === 'investor', |  | ||||||
|       }" @click=" |  | ||||||
|         handleTabClick('investor') |  | ||||||
|         "> |  | ||||||
|         {{ t("home.nav.investor") }} |  | ||||||
|       </div> |  | ||||||
|       <div class="tab-item"> |       <div class="tab-item"> | ||||||
|         <n-popselect v-model:value="currentLanguage" :options="languageOptions"  |         <n-popselect v-model:value="currentLanguage" :options="languageOptions"  | ||||||
|           @update:value="changeLanguage"> |           @update:value="changeLanguage"> | ||||||
|  | |||||||
| @ -1,35 +0,0 @@ | |||||||
| <script setup> |  | ||||||
| import { computed } from "vue"; |  | ||||||
| import { useWindowSize } from "@vueuse/core"; |  | ||||||
| 
 |  | ||||||
| import size375 from "@/views/investor/size375/index.vue"; |  | ||||||
| import size768 from "@/views/investor/size768/index.vue"; |  | ||||||
| import size1920 from "@/views/investor/size1920/index.vue"; |  | ||||||
| import size1440 from "@/views/investor/size1440/index.vue"; |  | ||||||
| 
 |  | ||||||
| import { useRouter } from "vue-router"; |  | ||||||
| import { useI18n } from "vue-i18n"; |  | ||||||
| 
 |  | ||||||
| const router = useRouter(); |  | ||||||
| const { width } = useWindowSize(); |  | ||||||
| const { t } = useI18n(); |  | ||||||
| 
 |  | ||||||
| const viewComponent = computed(() => { |  | ||||||
|   const viewWidth = width.value; |  | ||||||
|   if (viewWidth <= 450) { |  | ||||||
|     return size375; |  | ||||||
|   } else if (viewWidth <= 1100) { |  | ||||||
|     return size768; |  | ||||||
|   } else if (viewWidth <= 1500) { |  | ||||||
|     return size1440; |  | ||||||
|   } else if (viewWidth <= 1920 || viewWidth > 1920) { |  | ||||||
|     return size1920; |  | ||||||
|   } |  | ||||||
| }); |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <template> |  | ||||||
|   <component :is="viewComponent" /> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <style scoped lang="scss"></style> |  | ||||||
| @ -1,34 +0,0 @@ | |||||||
| <script setup> |  | ||||||
| import { computed } from "vue"; |  | ||||||
| import { useWindowSize } from "@vueuse/core"; |  | ||||||
| 
 |  | ||||||
| import size375 from "@/views/investorhandbook/size375/index.vue"; |  | ||||||
| import size768 from "@/views/investorhandbook/size768/index.vue"; |  | ||||||
| import size1440 from "@/views/investorhandbook/size1440/index.vue"; |  | ||||||
| import size1920 from "@/views/investorhandbook/size1920/index.vue"; |  | ||||||
| import { useRouter } from "vue-router"; |  | ||||||
| import { useI18n } from "vue-i18n"; |  | ||||||
| 
 |  | ||||||
| const router = useRouter(); |  | ||||||
| const { width } = useWindowSize(); |  | ||||||
| const { t } = useI18n(); |  | ||||||
| 
 |  | ||||||
| const viewComponent = computed(() => { |  | ||||||
|   const viewWidth = width.value; |  | ||||||
|   if (viewWidth <= 450) { |  | ||||||
|     return size375; |  | ||||||
|   } else if (viewWidth <= 1100) { |  | ||||||
|     return size768; |  | ||||||
|   } else if (viewWidth <= 1500) { |  | ||||||
|     return size1440; |  | ||||||
|   } else if (viewWidth <= 1920 || viewWidth > 1920) { |  | ||||||
|     return size1920; |  | ||||||
|   } |  | ||||||
| }); |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <template> |  | ||||||
|   <component :is="viewComponent" /> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <style scoped lang="scss"></style> |  | ||||||
| @ -1,333 +0,0 @@ | |||||||
| <template> |  | ||||||
|   <div class="page-container"> |  | ||||||
|     <header className="header"> |  | ||||||
|       <div class="logo"> |  | ||||||
|         <img src="@/assets/image/logo.png" alt="logo" /> |  | ||||||
|       </div> |  | ||||||
|       <div class="tabs"> |  | ||||||
|         <div |  | ||||||
|           class="tab-item" |  | ||||||
|           :class="{ |  | ||||||
|             active: currentTab === 'home', |  | ||||||
|           }" |  | ||||||
|           @click="handleTabClick('home')" |  | ||||||
|         > |  | ||||||
|           {{ t("home.nav.home") }} |  | ||||||
|         </div> |  | ||||||
|         <div |  | ||||||
|           class="tab-item" |  | ||||||
|           :class="{ |  | ||||||
|             active: currentTab === 'companyprofil', |  | ||||||
|           }" |  | ||||||
|           @click="handleTabClick('companyprofil')" |  | ||||||
|         > |  | ||||||
|           {{ t("home.nav.company") }} |  | ||||||
|         </div> |  | ||||||
|         <div |  | ||||||
|           class="tab-item" |  | ||||||
|           :class="{ |  | ||||||
|             active: currentTab === 'businessintroduction', |  | ||||||
|           }" |  | ||||||
|           @click="handleTabClick('businessintroduction')" |  | ||||||
|         > |  | ||||||
|           {{ t("home.nav.businessintroduction") }} |  | ||||||
|         </div> |  | ||||||
|         <div |  | ||||||
|           class="tab-item" |  | ||||||
|           :class="{ |  | ||||||
|             active: currentTab === 'investor', |  | ||||||
|           }" |  | ||||||
|           @click="handleTabClick('investor')" |  | ||||||
|         > |  | ||||||
|           {{ t("home.nav.investor") }} |  | ||||||
|         </div> |  | ||||||
|         <div class="tab-item"> |  | ||||||
|           <n-popselect |  | ||||||
|             v-model:value="currentLanguage" |  | ||||||
|             :options="languageOptions" |  | ||||||
|             @update:value="changeLanguage" |  | ||||||
|           > |  | ||||||
|             <div class="language-display"> |  | ||||||
|               {{ currentLanguageLabel }} |  | ||||||
|               <span class="language-arrow">▼</span> |  | ||||||
|             </div> |  | ||||||
|           </n-popselect> |  | ||||||
|         </div> |  | ||||||
|       </div> |  | ||||||
|     </header> |  | ||||||
|     <main> |  | ||||||
|       <section className="section-first relative" style="background: #fff"> |  | ||||||
|         <n-divider class="divider1" vertical /> |  | ||||||
|         <div class="divider2" style=""></div> |  | ||||||
|         <div class="divider3" style=""></div> |  | ||||||
|         <div class="divider4" style=""></div> |  | ||||||
|         <n-divider class="divider5" vertical /> |  | ||||||
|         <div |  | ||||||
|           class="flex flex-wrap justify-center tracking-[4px] leading-[40px]" |  | ||||||
|         > |  | ||||||
|           <div class="w-full title mt-[108px] px-[400px] text-center"> |  | ||||||
|             {{ t("investorhandbook.title") }} |  | ||||||
|           </div> |  | ||||||
|           <div |  | ||||||
|             class="w-full flex flex-wrap px-[363px] text-[#455363] text-[21px] mb-[275px]" |  | ||||||
|           > |  | ||||||
|             <div class="w-full font-semibold mt-[63px] text-[24px]"> |  | ||||||
|               <img |  | ||||||
|                 class="w-[16px] h-[16px] mr-[4px]" |  | ||||||
|                 src="@/assets/image/icon-c.png" |  | ||||||
|                 alt="logo" |  | ||||||
|               /> |  | ||||||
|               {{ t("investorhandbook.authorized_speakers.title") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[27px]"> |  | ||||||
|               {{ t("investorhandbook.authorized_speakers.desc") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full"> |  | ||||||
|               · {{ t("investorhandbook.authorized_speakers.items.0") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full"> |  | ||||||
|               · {{ t("investorhandbook.authorized_speakers.items.1") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full"> |  | ||||||
|               · {{ t("investorhandbook.authorized_speakers.items.2") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full"> |  | ||||||
|               {{ t("investorhandbook.authorized_speakers.note") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full font-semibold mt-[53px] text-[24px]"> |  | ||||||
|               <img |  | ||||||
|                 class="w-[16px] h-[16px] mr-[4px]" |  | ||||||
|                 src="@/assets/image/icon-c.png" |  | ||||||
|                 alt="logo" |  | ||||||
|               /> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.title") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[27px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.items.0") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[27px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.items.1") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[27px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.items.2") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[27px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.items.3") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[27px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.note") }} |  | ||||||
|             </div> |  | ||||||
|           </div> |  | ||||||
|         </div> |  | ||||||
|       </section> |  | ||||||
| 
 |  | ||||||
|       <section |  | ||||||
|         style="background: #fff" |  | ||||||
|         className="flex flex-wrap justify-center" |  | ||||||
|       > |  | ||||||
|         <img |  | ||||||
|           class="w-[309px] h-[29px] my-[85px]" |  | ||||||
|           src="@/assets/image/image-footer.png" |  | ||||||
|           alt="logo" |  | ||||||
|         /> |  | ||||||
|       </section> |  | ||||||
|     </main> |  | ||||||
|   </div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script setup> |  | ||||||
| import { |  | ||||||
|   onUnmounted, |  | ||||||
|   ref, |  | ||||||
|   onMounted, |  | ||||||
|   reactive, |  | ||||||
|   nextTick, |  | ||||||
|   watch, |  | ||||||
|   onBeforeMount, |  | ||||||
| } from "vue"; |  | ||||||
| import { NDivider, NPopselect, NGrid, NGi, NButton } from "naive-ui"; |  | ||||||
| import { useTransitionComposable } from "@/composables/transition-composable"; |  | ||||||
| import { useHome } from "@/store/home/index.js"; |  | ||||||
| import { useLanguage } from "@/utils/changeLanguage.js"; |  | ||||||
| import { useRoute, useRouter } from "vue-router"; |  | ||||||
| import { useI18n } from "vue-i18n"; |  | ||||||
| 
 |  | ||||||
| const { currentTab } = useHome(); |  | ||||||
| const router = useRouter(); |  | ||||||
| const { transitionState } = useTransitionComposable(); |  | ||||||
| const main = ref(); |  | ||||||
| let ctx; |  | ||||||
| const { |  | ||||||
|   languageOptions, |  | ||||||
|   currentLanguage, |  | ||||||
|   currentLanguageLabel, |  | ||||||
|   changeLanguage, |  | ||||||
|   initLanguage, |  | ||||||
|   currentLang, |  | ||||||
|   currentBannerImages, |  | ||||||
|   t, |  | ||||||
| } = useLanguage(); |  | ||||||
| const handleTabClick = (tab) => { |  | ||||||
|   currentTab.value = tab; |  | ||||||
|   router.push("/" + tab); |  | ||||||
| }; |  | ||||||
| onBeforeMount(() => {}); |  | ||||||
| onMounted(() => {}); |  | ||||||
| onUnmounted(() => {}); |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <style scoped lang="scss"> |  | ||||||
| .header { |  | ||||||
|   width: 100%; |  | ||||||
|   height: 65px; |  | ||||||
|   display: flex; |  | ||||||
|   justify-content: space-between; |  | ||||||
|   align-items: flex-end; |  | ||||||
|   position: fixed; |  | ||||||
|   z-index: 10; |  | ||||||
|   top: 0; |  | ||||||
|   left: 0; |  | ||||||
|   right: 0; |  | ||||||
|   padding: 0 10rem; |  | ||||||
|   padding-bottom: 10px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .logo { |  | ||||||
|   img { |  | ||||||
|     width: 108px; |  | ||||||
|     height: 33px; |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .tabs { |  | ||||||
|   display: flex; |  | ||||||
|   gap: 32px; |  | ||||||
|   margin-right: 32px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .tab-item { |  | ||||||
|   font-size: 16px; |  | ||||||
|   color: #000000; |  | ||||||
|   cursor: pointer; |  | ||||||
|   transition: color 0.3s ease; |  | ||||||
|   padding: 4px 8px; |  | ||||||
| 
 |  | ||||||
|   &.active { |  | ||||||
|     color: #8b59fa; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   &:hover { |  | ||||||
|     color: #8b59fa; |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .head { |  | ||||||
|   width: 100%; |  | ||||||
|   background-color: #f8f9ff; |  | ||||||
| 
 |  | ||||||
|   img { |  | ||||||
|     width: 100%; |  | ||||||
|     height: 100%; |  | ||||||
|     object-fit: cover; |  | ||||||
|     image-rendering: -webkit-optimize-contrast; |  | ||||||
|     image-rendering: crisp-edges; |  | ||||||
|     -webkit-backface-visibility: hidden; |  | ||||||
|     backface-visibility: hidden; |  | ||||||
|     transform: translateZ(0); |  | ||||||
|     -webkit-font-smoothing: antialiased; |  | ||||||
|     -moz-osx-font-smoothing: grayscale; |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| .divider1 { |  | ||||||
|   position: absolute; |  | ||||||
|   z-index: 3; |  | ||||||
|   left: 482px; |  | ||||||
|   width: 2px; |  | ||||||
|   height: 100%; |  | ||||||
|   background-color: rgba(230, 234, 238, 0.5) !important; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .divider2 { |  | ||||||
|   position: absolute; |  | ||||||
|   z-index: 3; |  | ||||||
|   left: 720px; |  | ||||||
|   width: 2px; |  | ||||||
|   height: 100%; |  | ||||||
|   background-image: linear-gradient( |  | ||||||
|     to bottom, |  | ||||||
|     rgb(150 165 181 / 50%), |  | ||||||
|     transparent 50% |  | ||||||
|   ); |  | ||||||
|   background-size: 1px 12px; // 第一个值是宽度,第二个值是虚线的总长度(实线+空白) |  | ||||||
|   background-repeat: repeat-y; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .divider3 { |  | ||||||
|   position: absolute; |  | ||||||
|   z-index: 3; |  | ||||||
|   left: 952px; |  | ||||||
|   width: 2px; |  | ||||||
|   height: 100%; |  | ||||||
|   background-image: linear-gradient( |  | ||||||
|     to bottom, |  | ||||||
|     rgb(150 165 181 / 50%), |  | ||||||
|     transparent 50% |  | ||||||
|   ); |  | ||||||
|   background-size: 1px 12px; // 第一个值是宽度,第二个值是虚线的总长度(实线+空白) |  | ||||||
|   background-repeat: repeat-y; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .divider4 { |  | ||||||
|   position: absolute; |  | ||||||
|   z-index: 3; |  | ||||||
|   left: 1182px; |  | ||||||
|   width: 2px; |  | ||||||
|   height: 100%; |  | ||||||
|   background-image: linear-gradient( |  | ||||||
|     to bottom, |  | ||||||
|     rgb(150 165 181 / 50%), |  | ||||||
|     transparent 50% |  | ||||||
|   ); |  | ||||||
|   background-size: 1px 15px; // 第一个值是宽度,第二个值是虚线的总长度(实线+空白) |  | ||||||
|   background-repeat: repeat-y; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .divider5 { |  | ||||||
|   position: absolute; |  | ||||||
|   z-index: 3; |  | ||||||
|   left: 1406px; |  | ||||||
|   width: 2px; |  | ||||||
|   height: 100%; |  | ||||||
|   background-color: rgba(230, 234, 238, 0.5) !important; |  | ||||||
| } |  | ||||||
| .footer-content { |  | ||||||
|   height: 90px; |  | ||||||
|   display: flex; |  | ||||||
|   justify-content: center; |  | ||||||
|   align-items: center; |  | ||||||
| 
 |  | ||||||
|   .copyright { |  | ||||||
|     width: 232px; |  | ||||||
|     height: 22pxpx; |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .page-container { |  | ||||||
|   width: 100%; |  | ||||||
|   overflow: hidden; |  | ||||||
|   position: relative; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .title { |  | ||||||
|   font-size: 53px; |  | ||||||
|   font-weight: 600; |  | ||||||
|   line-height: 110px; |  | ||||||
|   color: #10253e; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .page-container { |  | ||||||
|   width: 100%; |  | ||||||
|   overflow-x: hidden; |  | ||||||
|   position: relative; |  | ||||||
| } |  | ||||||
| </style> |  | ||||||
| @ -1,321 +0,0 @@ | |||||||
| <template> |  | ||||||
|   <div class="page-container"> |  | ||||||
|     <header className="header"> |  | ||||||
|       <div class="logo"> |  | ||||||
|         <img src="@/assets/image/logo.png" alt="logo" /> |  | ||||||
|       </div> |  | ||||||
|       <div class="tabs"> |  | ||||||
|         <div |  | ||||||
|           class="tab-item" |  | ||||||
|           :class="{ |  | ||||||
|             active: currentTab === 'home', |  | ||||||
|           }" |  | ||||||
|           @click="handleTabClick('home')" |  | ||||||
|         > |  | ||||||
|           {{ t("home.nav.home") }} |  | ||||||
|         </div> |  | ||||||
|         <div |  | ||||||
|           class="tab-item" |  | ||||||
|           :class="{ |  | ||||||
|             active: currentTab === 'companyprofil', |  | ||||||
|           }" |  | ||||||
|           @click="handleTabClick('companyprofil')" |  | ||||||
|         > |  | ||||||
|           {{ t("home.nav.company") }} |  | ||||||
|         </div> |  | ||||||
|         <div |  | ||||||
|           class="tab-item" |  | ||||||
|           :class="{ |  | ||||||
|             active: currentTab === 'businessintroduction', |  | ||||||
|           }" |  | ||||||
|           @click="handleTabClick('businessintroduction')" |  | ||||||
|         > |  | ||||||
|           {{ t("home.nav.businessintroduction") }} |  | ||||||
|         </div> |  | ||||||
|         <div |  | ||||||
|           class="tab-item" |  | ||||||
|           :class="{ |  | ||||||
|             active: currentTab === 'investor', |  | ||||||
|           }" |  | ||||||
|           @click="handleTabClick('investor')" |  | ||||||
|         > |  | ||||||
|           {{ t("home.nav.investor") }} |  | ||||||
|         </div> |  | ||||||
|         <div class="tab-item"> |  | ||||||
|           <n-popselect |  | ||||||
|             v-model:value="currentLanguage" |  | ||||||
|             :options="languageOptions" |  | ||||||
|             @update:value="changeLanguage" |  | ||||||
|           > |  | ||||||
|             <div class="language-display"> |  | ||||||
|               {{ currentLanguageLabel }} |  | ||||||
|               <span class="language-arrow">▼</span> |  | ||||||
|             </div> |  | ||||||
|           </n-popselect> |  | ||||||
|         </div> |  | ||||||
|       </div> |  | ||||||
|     </header> |  | ||||||
|     <main> |  | ||||||
|       <section className="section-first relative" style="background: #fff"> |  | ||||||
|         <n-divider class="divider1" vertical /> |  | ||||||
|         <div class="divider2" style=""></div> |  | ||||||
|         <div class="divider3" style=""></div> |  | ||||||
|         <div class="divider4" style=""></div> |  | ||||||
|         <n-divider class="divider5" vertical /> |  | ||||||
|         <div |  | ||||||
|           class="flex flex-wrap justify-center tracking-[4px] leading-[40px]" |  | ||||||
|         > |  | ||||||
|           <div class="w-full title mt-[108px] px-[180px] text-center"> |  | ||||||
|             {{ t("investorhandbook.title") }} |  | ||||||
|           </div> |  | ||||||
|           <div |  | ||||||
|             class="w-full flex flex-wrap px-[363px] text-[#455363] text-[21px] mb-[275px]" |  | ||||||
|           > |  | ||||||
|             <div class="w-full font-semibold mt-[63px] text-[24px]"> |  | ||||||
|               <img |  | ||||||
|                 class="w-[16px] h-[16px] mr-[4px]" |  | ||||||
|                 src="@/assets/image/icon-c.png" |  | ||||||
|                 alt="logo" |  | ||||||
|               /> |  | ||||||
|               {{ t("investorhandbook.authorized_speakers.title") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[27px]"> |  | ||||||
|               {{ t("investorhandbook.authorized_speakers.desc") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full"> |  | ||||||
|               · {{ t("investorhandbook.authorized_speakers.items.0") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full"> |  | ||||||
|               · {{ t("investorhandbook.authorized_speakers.items.1") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full"> |  | ||||||
|               · {{ t("investorhandbook.authorized_speakers.items.2") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full"> |  | ||||||
|               {{ t("investorhandbook.authorized_speakers.note") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full font-semibold mt-[53px] text-[24px]"> |  | ||||||
|               <img |  | ||||||
|                 class="w-[16px] h-[16px] mr-[4px]" |  | ||||||
|                 src="@/assets/image/icon-c.png" |  | ||||||
|                 alt="logo" |  | ||||||
|               /> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.title") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[27px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.items.0") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[27px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.items.1") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[27px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.items.2") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[27px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.items.3") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[27px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.note") }} |  | ||||||
|             </div> |  | ||||||
|           </div> |  | ||||||
|         </div> |  | ||||||
|       </section> |  | ||||||
| 
 |  | ||||||
|       <section |  | ||||||
|         style="background: #fff" |  | ||||||
|         className="flex flex-wrap justify-center" |  | ||||||
|       > |  | ||||||
|         <img |  | ||||||
|           class="w-[309px] h-[29px] my-[85px]" |  | ||||||
|           src="@/assets/image/image-footer.png" |  | ||||||
|           alt="logo" |  | ||||||
|         /> |  | ||||||
|       </section> |  | ||||||
|     </main> |  | ||||||
|   </div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script setup> |  | ||||||
| import { |  | ||||||
|   onUnmounted, |  | ||||||
|   ref, |  | ||||||
|   onMounted, |  | ||||||
|   reactive, |  | ||||||
|   nextTick, |  | ||||||
|   watch, |  | ||||||
|   onBeforeMount, |  | ||||||
| } from "vue"; |  | ||||||
| import { NDivider, NPopselect, NGrid, NGi, NButton } from "naive-ui"; |  | ||||||
| import { useTransitionComposable } from "@/composables/transition-composable"; |  | ||||||
| import { useHome } from "@/store/home/index.js"; |  | ||||||
| import { useLanguage } from "@/utils/changeLanguage.js"; |  | ||||||
| import { useRoute, useRouter } from "vue-router"; |  | ||||||
| import { useI18n } from "vue-i18n"; |  | ||||||
| 
 |  | ||||||
| const { currentTab } = useHome(); |  | ||||||
| const router = useRouter(); |  | ||||||
| const { transitionState } = useTransitionComposable(); |  | ||||||
| const main = ref(); |  | ||||||
| let ctx; |  | ||||||
| const { |  | ||||||
|   languageOptions, |  | ||||||
|   currentLanguage, |  | ||||||
|   currentLanguageLabel, |  | ||||||
|   changeLanguage, |  | ||||||
|   initLanguage, |  | ||||||
|   currentLang, |  | ||||||
|   currentBannerImages, |  | ||||||
|   t, |  | ||||||
| } = useLanguage(); |  | ||||||
| const handleTabClick = (tab) => { |  | ||||||
|   currentTab.value = tab; |  | ||||||
|   router.push("/" + tab); |  | ||||||
| }; |  | ||||||
| onBeforeMount(() => {}); |  | ||||||
| onMounted(() => {}); |  | ||||||
| onUnmounted(() => {}); |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <style scoped lang="scss"> |  | ||||||
| .header { |  | ||||||
|   width: 100%; |  | ||||||
|   height: 65px; |  | ||||||
|   display: flex; |  | ||||||
|   justify-content: space-between; |  | ||||||
|   align-items: flex-end; |  | ||||||
|   position: fixed; |  | ||||||
|   z-index: 10; |  | ||||||
|   top: 0; |  | ||||||
|   left: 0; |  | ||||||
|   right: 0; |  | ||||||
|   padding: 0 10rem; |  | ||||||
|   padding-bottom: 10px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .logo { |  | ||||||
|   img { |  | ||||||
|     width: 108px; |  | ||||||
|     height: 33px; |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .tabs { |  | ||||||
|   display: flex; |  | ||||||
|   gap: 32px; |  | ||||||
|   margin-right: 32px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .tab-item { |  | ||||||
|   font-size: 16px; |  | ||||||
|   color: #000000; |  | ||||||
|   cursor: pointer; |  | ||||||
|   transition: color 0.3s ease; |  | ||||||
|   padding: 4px 8px; |  | ||||||
| 
 |  | ||||||
|   &.active { |  | ||||||
|     color: #8b59fa; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   &:hover { |  | ||||||
|     color: #8b59fa; |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .head { |  | ||||||
|   width: 100%; |  | ||||||
|   background-color: #f8f9ff; |  | ||||||
| 
 |  | ||||||
|   img { |  | ||||||
|     width: 100%; |  | ||||||
|     height: 100%; |  | ||||||
|     object-fit: cover; |  | ||||||
|     image-rendering: -webkit-optimize-contrast; |  | ||||||
|     image-rendering: crisp-edges; |  | ||||||
|     -webkit-backface-visibility: hidden; |  | ||||||
|     backface-visibility: hidden; |  | ||||||
|     transform: translateZ(0); |  | ||||||
|     -webkit-font-smoothing: antialiased; |  | ||||||
|     -moz-osx-font-smoothing: grayscale; |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| .page-container { |  | ||||||
|   width: 100%; |  | ||||||
|   overflow: hidden; |  | ||||||
|   position: relative; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .title { |  | ||||||
|   font-size: 53px; |  | ||||||
|   font-weight: 600; |  | ||||||
|   line-height: 110px; |  | ||||||
|   color: #10253e; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .divider1 { |  | ||||||
|   position: absolute; |  | ||||||
|   z-index: 3; |  | ||||||
|   left: 482px; |  | ||||||
|   width: 1px; |  | ||||||
|   height: 100%; |  | ||||||
|   background-color: rgba(230, 234, 238, 0.5) !important; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .divider2 { |  | ||||||
|   position: absolute; |  | ||||||
|   z-index: 3; |  | ||||||
|   left: 720px; |  | ||||||
|   width: 1px; |  | ||||||
|   height: 100%; |  | ||||||
|   background-image: linear-gradient( |  | ||||||
|     to bottom, |  | ||||||
|     rgb(150 165 181 / 50%), |  | ||||||
|     transparent 50% |  | ||||||
|   ); |  | ||||||
|   background-size: 1px 12px; // 第一个值是宽度,第二个值是虚线的总长度(实线+空白) |  | ||||||
|   background-repeat: repeat-y; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .divider3 { |  | ||||||
|   position: absolute; |  | ||||||
|   z-index: 3; |  | ||||||
|   left: 952px; |  | ||||||
|   width: 1px; |  | ||||||
|   height: 100%; |  | ||||||
|   background-image: linear-gradient( |  | ||||||
|     to bottom, |  | ||||||
|     rgb(150 165 181 / 50%), |  | ||||||
|     transparent 50% |  | ||||||
|   ); |  | ||||||
|   background-size: 1px 12px; // 第一个值是宽度,第二个值是虚线的总长度(实线+空白) |  | ||||||
|   background-repeat: repeat-y; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .divider4 { |  | ||||||
|   position: absolute; |  | ||||||
|   z-index: 3; |  | ||||||
|   left: 1182px; |  | ||||||
|   width: 1px; |  | ||||||
|   height: 100%; |  | ||||||
|   background-image: linear-gradient( |  | ||||||
|     to bottom, |  | ||||||
|     rgb(150 165 181 / 50%), |  | ||||||
|     transparent 50% |  | ||||||
|   ); |  | ||||||
|   background-size: 1px 15px; // 第一个值是宽度,第二个值是虚线的总长度(实线+空白) |  | ||||||
|   background-repeat: repeat-y; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .divider5 { |  | ||||||
|   position: absolute; |  | ||||||
|   z-index: 3; |  | ||||||
|   left: 1406px; |  | ||||||
|   width: 1px; |  | ||||||
|   height: 100%; |  | ||||||
|   background-color: rgba(230, 234, 238, 0.5) !important; |  | ||||||
| } |  | ||||||
| .page-container { |  | ||||||
|   width: 100%; |  | ||||||
|   overflow-x: hidden; |  | ||||||
|   position: relative; |  | ||||||
| } |  | ||||||
| </style> |  | ||||||
| @ -1,134 +0,0 @@ | |||||||
| <template> |  | ||||||
|   <div class="page-container"> |  | ||||||
|     <n-divider class="divider1" vertical /> |  | ||||||
|     <n-divider class="divider5" vertical /> |  | ||||||
|     <AppHeader /> |  | ||||||
| 
 |  | ||||||
|     <main> |  | ||||||
|       <section className="section-first" style="background: #fff"> |  | ||||||
|         <div class="flex flex-wrap justify-center leading-[143px]"> |  | ||||||
|           <div class="w-full title mt-[460px] px-[180px] text-center"> |  | ||||||
|             {{ t("investorhandbook.title") }} |  | ||||||
|           </div> |  | ||||||
|           <div |  | ||||||
|             class="w-full flex flex-wrap px-[184px] text-[#455363] text-[72px] mb-[445px]" |  | ||||||
|           > |  | ||||||
|             <div class="w-full font-semibold mt-[297px] text-[82px]"> |  | ||||||
|               <img |  | ||||||
|                 class="w-[61px] h-[61px] mr-[4px]" |  | ||||||
|                 src="@/assets/image/icon-c.png" |  | ||||||
|                 alt="logo" |  | ||||||
|               /> |  | ||||||
|               {{ t("investorhandbook.authorized_speakers.title") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[113px]"> |  | ||||||
|               {{ t("investorhandbook.authorized_speakers.desc") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full"> |  | ||||||
|               · {{ t("investorhandbook.authorized_speakers.items[0]") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full"> |  | ||||||
|               · {{ t("investorhandbook.authorized_speakers.items[1]") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full"> |  | ||||||
|               · {{ t("investorhandbook.authorized_speakers.items[2]") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full"> |  | ||||||
|               {{ t("investorhandbook.authorized_speakers.note") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full font-semibold mt-[100px] text-[82px]"> |  | ||||||
|               <img |  | ||||||
|                 class="w-[61px] h-[61px] mr-[4px]" |  | ||||||
|                 src="@/assets/image/icon-c.png" |  | ||||||
|                 alt="logo" |  | ||||||
|               /> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.title") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[113px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.items[0]") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[113px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.items[1]") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[113px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.items[2]") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[113px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.items[3]") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[113px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.note") }} |  | ||||||
|             </div> |  | ||||||
|           </div> |  | ||||||
|         </div> |  | ||||||
|       </section> |  | ||||||
| 
 |  | ||||||
|       <section |  | ||||||
|         style="background: #fff" |  | ||||||
|         className="flex flex-wrap justify-center" |  | ||||||
|       > |  | ||||||
|         <img |  | ||||||
|           class="w-[891px] h-[87px] mt-[61px] mb-[56px]" |  | ||||||
|           src="@/assets/image/image-footer.png" |  | ||||||
|           alt="logo" |  | ||||||
|         /> |  | ||||||
|       </section> |  | ||||||
|     </main> |  | ||||||
|   </div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script setup> |  | ||||||
| import { NDivider } from "naive-ui"; |  | ||||||
| import { |  | ||||||
|   onUnmounted, |  | ||||||
|   ref, |  | ||||||
|   onMounted, |  | ||||||
|   reactive, |  | ||||||
|   nextTick, |  | ||||||
|   watch, |  | ||||||
|   onBeforeMount, |  | ||||||
| } from "vue"; |  | ||||||
| import AppHeader from "@/components/AppHeader/index.vue"; |  | ||||||
| import { useHome } from "@/store/home/index.js"; |  | ||||||
| 
 |  | ||||||
| import { useRoute, useRouter } from "vue-router"; |  | ||||||
| import { useI18n } from "vue-i18n"; |  | ||||||
| const { t } = useI18n(); |  | ||||||
| 
 |  | ||||||
| onBeforeMount(() => {}); |  | ||||||
| onMounted(() => {}); |  | ||||||
| onUnmounted(() => {}); |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <style scoped lang="scss"> |  | ||||||
| .page-container { |  | ||||||
|   width: 100%; |  | ||||||
|   overflow-x: hidden; |  | ||||||
|   position: relative; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .title { |  | ||||||
|   font-size: 113px; |  | ||||||
|   font-weight: 600; |  | ||||||
|   line-height: 143px; |  | ||||||
|   color: #10253e; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .divider1 { |  | ||||||
|   position: absolute; |  | ||||||
|   z-index: 3; |  | ||||||
|   background-color: rgba(230, 234, 238, 0.5) !important; |  | ||||||
|   left: 64px; |  | ||||||
|   width: 1px; |  | ||||||
|   height: 100%; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .divider5 { |  | ||||||
|   position: absolute; |  | ||||||
|   z-index: 3; |  | ||||||
|   background-color: rgba(230, 234, 238, 0.5) !important; |  | ||||||
|   right: 60px; |  | ||||||
|   width: 1px; |  | ||||||
|   height: 100%; |  | ||||||
| } |  | ||||||
| </style> |  | ||||||
| @ -1,136 +0,0 @@ | |||||||
| <template> |  | ||||||
|   <div class="page-container"> |  | ||||||
|     <n-divider class="divider1" vertical /> |  | ||||||
|     <n-divider class="divider5" vertical /> |  | ||||||
|     <AppHeader /> |  | ||||||
| 
 |  | ||||||
|     <main> |  | ||||||
|       <section className="section-first" style="background: #fff"> |  | ||||||
|         <div |  | ||||||
|           class="flex flex-wrap justify-center tracking-[4px] leading-[75px]" |  | ||||||
|         > |  | ||||||
|           <div class="w-full title mt-[298px] px-[180px] text-center"> |  | ||||||
|             {{ t("investorhandbook.title") }} |  | ||||||
|           </div> |  | ||||||
|           <div |  | ||||||
|             class="w-full flex flex-wrap px-[188px] text-[#455363] text-[40px] mb-[275px]" |  | ||||||
|           > |  | ||||||
|             <div class="w-full font-semibold mt-[63px] text-[45px]"> |  | ||||||
|               <img |  | ||||||
|                 class="w-[30px] h-[30px] mr-[4px]" |  | ||||||
|                 src="@/assets/image/icon-c.png" |  | ||||||
|                 alt="logo" |  | ||||||
|               /> |  | ||||||
|               {{ t("investorhandbook.authorized_speakers.title") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[50px]"> |  | ||||||
|               {{ t("investorhandbook.authorized_speakers.desc") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full"> |  | ||||||
|               · {{ t("investorhandbook.authorized_speakers.items[0]") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full"> |  | ||||||
|               · {{ t("investorhandbook.authorized_speakers.items[1]") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full"> |  | ||||||
|               · {{ t("investorhandbook.authorized_speakers.items[2]") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full"> |  | ||||||
|               {{ t("investorhandbook.authorized_speakers.note") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full font-semibold mt-[100px] text-[45px]"> |  | ||||||
|               <img |  | ||||||
|                 class="w-[30px] h-[30px] mr-[4px]" |  | ||||||
|                 src="@/assets/image/icon-c.png" |  | ||||||
|                 alt="logo" |  | ||||||
|               /> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.title") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[50px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.items[0]") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[50px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.items[1]") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[50px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.items[2]") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[50px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.items[3]") }} |  | ||||||
|             </div> |  | ||||||
|             <div class="w-full mt-[50px]"> |  | ||||||
|               {{ t("investorhandbook.quarterly_communications.note") }} |  | ||||||
|             </div> |  | ||||||
|           </div> |  | ||||||
|         </div> |  | ||||||
|       </section> |  | ||||||
| 
 |  | ||||||
|       <section |  | ||||||
|         style="background: #fff" |  | ||||||
|         className="flex flex-wrap justify-center" |  | ||||||
|       > |  | ||||||
|         <img |  | ||||||
|           class="w-[580px] h-[55px] my-[85px]" |  | ||||||
|           src="@/assets/image/image-footer.png" |  | ||||||
|           alt="logo" |  | ||||||
|         /> |  | ||||||
|       </section> |  | ||||||
|     </main> |  | ||||||
|   </div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script setup> |  | ||||||
| import { NDivider } from "naive-ui"; |  | ||||||
| import { |  | ||||||
|   onUnmounted, |  | ||||||
|   ref, |  | ||||||
|   onMounted, |  | ||||||
|   reactive, |  | ||||||
|   nextTick, |  | ||||||
|   watch, |  | ||||||
|   onBeforeMount, |  | ||||||
| } from "vue"; |  | ||||||
| import AppHeader from "@/components/AppHeader/index.vue"; |  | ||||||
| import { useHome } from "@/store/home/index.js"; |  | ||||||
| 
 |  | ||||||
| import { useRoute, useRouter } from "vue-router"; |  | ||||||
| import { useI18n } from "vue-i18n"; |  | ||||||
| const { t } = useI18n(); |  | ||||||
| 
 |  | ||||||
| onBeforeMount(() => {}); |  | ||||||
| onMounted(() => {}); |  | ||||||
| onUnmounted(() => {}); |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <style scoped lang="scss"> |  | ||||||
| .page-container { |  | ||||||
|   width: 100%; |  | ||||||
|   overflow-x: hidden; |  | ||||||
|   position: relative; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .title { |  | ||||||
|   font-size: 85px; |  | ||||||
|   font-weight: 600; |  | ||||||
|   line-height: 110px; |  | ||||||
|   color: #10253e; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .divider1 { |  | ||||||
|   position: absolute; |  | ||||||
|   z-index: 3; |  | ||||||
|   background-color: rgba(230, 234, 238, 0.5) !important; |  | ||||||
|   left: 116px; |  | ||||||
|   width: 1px; |  | ||||||
|   height: 100%; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .divider5 { |  | ||||||
|   position: absolute; |  | ||||||
|   z-index: 3; |  | ||||||
|   background-color: rgba(230, 234, 238, 0.5) !important; |  | ||||||
|   right: 116px; |  | ||||||
|   width: 1px; |  | ||||||
|   height: 100%; |  | ||||||
| } |  | ||||||
| </style> |  | ||||||
| @ -5,7 +5,6 @@ import AutoImport from 'unplugin-auto-import/vite'; | |||||||
| import Components from 'unplugin-vue-components/vite'; | import Components from 'unplugin-vue-components/vite'; | ||||||
| import {VantResolver} from '@vant/auto-import-resolver'; | import {VantResolver} from '@vant/auto-import-resolver'; | ||||||
| import UnoCSS from 'unocss/vite' | import UnoCSS from 'unocss/vite' | ||||||
| import viteImagemin from 'vite-plugin-imagemin' |  | ||||||
| // https://vitejs.dev/config/
 | // https://vitejs.dev/config/
 | ||||||
| export default defineConfig({ | export default defineConfig({ | ||||||
|     envDir: './env', // 自定义env目录
 |     envDir: './env', // 自定义env目录
 | ||||||
| @ -30,37 +29,6 @@ export default defineConfig({ | |||||||
|         Components({ |         Components({ | ||||||
|             resolvers: [VantResolver()], |             resolvers: [VantResolver()], | ||||||
|         }), |         }), | ||||||
|         viteImagemin({ |  | ||||||
|             // 无损压缩配置
 |  | ||||||
|             optipng: { |  | ||||||
|                 optimizationLevel: 7 |  | ||||||
|             }, |  | ||||||
|             // 有损压缩配置
 |  | ||||||
|             pngquant: { |  | ||||||
|                 quality: [0.8, 0.9], |  | ||||||
|                 speed: 4 |  | ||||||
|             }, |  | ||||||
|             // svg 优化
 |  | ||||||
|             svgo: { |  | ||||||
|                 plugins: [ |  | ||||||
|                     { |  | ||||||
|                         name: 'removeViewBox' |  | ||||||
|                     }, |  | ||||||
|                     { |  | ||||||
|                         name: 'removeEmptyAttrs', |  | ||||||
|                         active: false |  | ||||||
|                     } |  | ||||||
|                 ] |  | ||||||
|             }, |  | ||||||
|             // jpg 优化
 |  | ||||||
|             mozjpeg: { |  | ||||||
|                 quality: 80 |  | ||||||
|             }, |  | ||||||
|             // webp 优化
 |  | ||||||
|             webp: { |  | ||||||
|                 quality: 80 |  | ||||||
|             } |  | ||||||
|         }) |  | ||||||
|     ], |     ], | ||||||
|     resolve: { |     resolve: { | ||||||
|         alias: [ |         alias: [ | ||||||
|  | |||||||