Merge branch 'newmain-20250926' of https://gitea-inner.fontree.cn/scout666/fiee-official-website into newmain-20250926

This commit is contained in:
yuanshan 2025-10-23 13:56:29 +08:00
commit fc3ea34dcb
36 changed files with 1566 additions and 167 deletions

2
env/.env.test vendored
View File

@ -2,7 +2,7 @@
NODE_ENV = 'test' NODE_ENV = 'test'
# 是否去除console 和 debugger # 是否去除console 和 debugger
VITE_DELETE_CONSOLE = false VITE_DELETE_CONSOLE = false
VITE_BASEURL = '//kid-art-test.szjixun.cn' VITE_BASEURL = '//114.218.158.24:9020'
# 文档查看 # 文档查看
VITE_PAGE_URL="http://172.16.100.22:8045" VITE_PAGE_URL="http://172.16.100.22:8045"

View File

@ -89,3 +89,40 @@ export const viewOpenId = (data) => {
data data
}) })
} }
// 年度报告展示
export const annualReport = (data) => {
return request({
url: '/api/fiee/reports/annual/display',
method: 'POST',
data,
})
}
// 季度报告展示
// 部门管理展示
export const departmentManagement = (data) => {
return request({
url: '/api/fiee/members/management/display',
method: 'POST',
data,
})
}
// 董事会展示
export const boardManagement = (data) => {
return request({
url: '/api/fiee/members/boardofdirectors/display',
method: 'POST',
data,
})
}
// 委员会展示
export const committeeManagement = (data) => {
return request({
url: '/api/fiee/members/committeeappointments/display',
method: 'POST',
data,
})
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 19 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 32 KiB

View File

@ -15,7 +15,180 @@ export default {
investor: "Investor Guide", investor: "Investor Guide",
}, },
}, },
HOME: {
CONTAIN: {
TITLEONE: {
TITLE: "Company Positioning",
CONTENT: "",
CONTENTTWO:
"Leveraging IoT, connectivity, and Al to create targeted, multilingual digital brands, fostering a global community of Key Opinion Leaders and providing unparalleled value throughout the digital content lifecycle",
},
},
CONTAINY: {
STOCK_INFO: {
TITLE: "Stock Information",
LAST_PRICE: "Price",
CHANGE: "% Change",
STOCK_CODE: "Stock Code",
VOLUME: "Volume",
MARKET_CAP: "Market Cap",
},
UPCOMING_EVENTS: {
TITLE: "Upcoming Events",
EVENT_NAME: "International New Energy & Emerging Industries Tech Expo",
DATE: "Date",
VENUE: "Venue",
AREA: "Area",
BOOTHS: "Booths",
LEARN_MORE: "Learn More",
},
NEWS: {
TITLE: "Recent News",
LATEST_TITLE: "Company Announces Breakthrough in AI Technology",
LATEST_CONTENT:
"Ucommune Regains Compliance with Nasdag MinimuBid Price Requirement",
READ_MORE: "Read more",
TITLETWO:
"Exhibition Theme: International New Energy and Emerging Industry Technology Exhibition",
TITLETHTEE:
"Exhibition time: August 12, 2025 (Tuesday) ~ August 14, 2025;",
CONTENTTHREE:
"Exhibition venue: Shenzhen International Exhibition Center, Shenzhen, China",
CONTENTFOUR: "Venue: Hall B of Hall 6, with an area of about 10,000m;",
CONTENTFIVE: "Number of booths: about 500 standard booths.",
},
},
},
Governance: {
TITLE: "Governance",
},
SECFILINGS: {
TITLE: "SEC Filings",
FILTERlABEL1: "Filing year",
FILTERlABEL2: "Items per page",
},
// 公司概括
COMPANYOVERVIEW: {
Company: "Company Profile",
TITLETWO: {
TITLE: "About FiEE, Inc.",
CONTENT:
'FiEE, Inc. (NASDAQ: FIEE), formerly Minim, Inc., was founded in 1977. We have a historical track record of delivering a comprehensive WiFi/Software as a Service platform in the market. After years of development, we made the strategic decision to transition to a Software First Model in 2023 to expand our technology portfolio and revenue streams. In 2025, we rebranded ourselves as a technology company leveraging our expertise in IoT, connectivity, and artificial intelligence ("AI") to explore new business prospects and extend our global footprint.',
CONTENTTWO:
'into four key categories: Cloud-Managed Connectivity (WiFi) Platform, IoT Hardware Sales & Licensing, SAAS Solutions, and Professional To-C and To-B Services & Support. Notably, we have introduced our innovative Software as a Service ("SaaS") solutions, which integrate our AI and data analytics capabilities into content creation and brand management. This initiative has led to the nurturing of a robust pool of Key Opinion Leaders (KOLs) on major social media platforms worldwide, assisting them in developing, managing, and optimizing their digital presence across global platforms. Our services include customized graphics and posts, short videos, and editorial calendars tailored to align with brand objectives.',
CONTENTTHREE:
"Powered by IoT-enabled Connectivity Solutions, we are empowering talents with value throughout the entire lifecycle. We are committed to ongoing investments in AI technology for data analysis and fan behavior insights to develop highly targeted multimedia and multilingual content. Our goal is to expand our solutions and services to reach a broader global audience.",
CONTENTTWOTITLE: "Our services are structured",
},
TITLETHREE: {
TITLE: "Our Mission and Vision",
CONTENT:
"• 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",
},
TITLEFOUR: {
CONTENT: "",
TITLE: "Corporate Milestones",
SUBHEADING: "1977 2015 : Founding & Licensing",
paragraph: {
ONE: "• Founded as Zoom Telephonics in 1977. ",
TWO: "• Secured a five-year Motorola home-network license effective 1 Jan, 2016. ",
},
SUBHEADINGTWO: "2020 : Merger & AI Advancement",
paragraphTwo: {
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: "",
},
SUBHEADINGTHREE: "2021: NASDAQ Listing",
paragraphTHREE: {
ONE: "• Transitioned from OTCQB to NASDAQ Capital Market on 7 July, 2021, under ticker MINM.",
TWO: "• Raised $25 M in a public offering to fund expansion.",
THREE: "",
},
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 Voxs AI-driven Wi-Fi Home Manager.",
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.",
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.",
},
},
TITLEFIVE: {
CONTENT:
"•We developed our own AI-driven cloud software platform and applications, providing efficient and high-quality network management and security solutions for home and business users, as well as the service providers that assisted them.",
TITLE: "Outstanding Achievements",
},
},
// 业务介绍
BusinessiIntroduction: {
CONTAIN: {
TITLEONE: {
TITLE: "Business Introduction",
CONTENT:
"We provide digital content management solutions and brand growth strategies primarily through digital account management, content operations and growth analytics, and community engagement and creator partnerships. These services are structured to support clients at varying stages of digital development, from initial account setup to multi-platform brand promotion.",
CONTENTTWO:
"FiEE, Inc.s core solutions encompass the following four major categories.",
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",
},
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",
},
THREE: {
TITLE: "(3) SAAS Solutions",
CONTENT: "Internet sales and IoT support",
CONTENTTWO: "KOL branding services",
CONTENTTHREE:
"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",
CONTENTTHREE:
"AI-enabled content creation and fans habit analysis solutions",
},
},
},
},
},
financialinformation: { financialinformation: {
secfilings: {
title: "Financials",
overview: {
title: "Company Financial Overview",
desc: "This page offers access to our <strong>Annual Reports</strong>. These sections provide key financial data and regulatory documents, keeping you informed about our financial performance and compliance.",
},
annual_reports: {
title: "Annual Reports",
file_name: "File Name",
view: "View",
date: "Date",
},
sec: {
title: "SEC Filings",
desc: "To access all of our filings with the SEC, please",
click_here: "click here",
},
},
quarterlyreports: { quarterlyreports: {
title: "Quarterly Reports", title: "Quarterly Reports",
search: { search: {
@ -31,6 +204,39 @@ export default {
}, },
}, },
}, },
boarddirectors: {
title: "Board of Directors",
},
committeeComposition: {
title: "Committee Composition",
position1: "Member",
position2: "Chair",
tableKey1: "Audit Committee",
tableKey2: "Compensation Committee",
tableKey3: "Nominating and Corporate Governance Committee",
},
// 管理
MANAGEMENT: {
TITLE:
"FiEE, Inc. has a team of capable senior management with extensive professional experience",
ONE: {
TITLE: "Li Wai Chung",
TITLETWO: "Chief Executive Officer",
CONTENT:
"Mr. Li is our Chief Executive Officer. Mr. Li has 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 our team.",
CONTENTTWO:
"He served as chair of the Audit Committees for Fulu Holdings and Taizhou Water Group in Hong Kong, and Nedschroef in the Netherlands, showcasing his global leadership. Mr. Li has previously held key positions in investment management, business consulting, and directorial roles in publicly listed companies.",
CONTENTTHREE: "",
},
TWO: {
TITLE: "Cao Yu",
TITLETWO: "Chief Financial Officer, Secretary, Treasurer and Director",
CONTENTONE:
"Ms. Cao is our Chief Financial Officer, Secretary, Treasurer and Director. Ms. Cao has a wealth of experience in financial management. She oversees financial operations, strategic planning, risk management, and reporting to ensure our financial health and compliance with regulations.",
CONTENTTWO:
"Ms. Cao previously served as the treasury director of Taifeng Cultural Communication Co., Ltd where she oversaw its financial matters from November 2018 to November 2024. Prior to that, Ms. Cao served as a business manager of Yangfeng Art Exchange Co., Ltd from February 2016 to October 2018. From March 2011 to January 2016, she served as the treasury officer of financial department of Suzhou Industrial Park Xinfushida Plastic Profile Products Co., Ltd.",
},
},
stock_quote: { stock_quote: {
title: "Stock Quote", title: "Stock Quote",
nasdaq: "NASDAQ: FIEE", nasdaq: "NASDAQ: FIEE",
@ -171,7 +377,7 @@ export default {
"Efficiently connect high-quality business cooperation opportunities and complete the entire process management from order acceptance to publication within the platform.", "Efficiently connect high-quality business cooperation opportunities and complete the entire process management from order acceptance to publication within the platform.",
sol_content: "Professional Content Creation Support", sol_content: "Professional Content Creation Support",
sol_content_desc: sol_content_desc:
"Connect professional shooting and post production teams for you, create high-quality \"art+story\" content, and strengthen IP influence.", 'Connect professional shooting and post production teams for you, create high-quality "art+story" content, and strengthen IP influence.',
sol_ops: "Account Operation and Hosting Services", sol_ops: "Account Operation and Hosting Services",
sol_ops_desc: sol_ops_desc:
"From 0 to 1 account positioning, follower growth strategy to monetization cycle, operation experts provide full cycle running and hosting services.", "From 0 to 1 account positioning, follower growth strategy to monetization cycle, operation experts provide full cycle running and hosting services.",
@ -186,8 +392,7 @@ export default {
adv_consistent_desc: adv_consistent_desc:
"Ensure that brand information is presented uniformly on all platforms.", "Ensure that brand information is presented uniformly on all platforms.",
adv_data: "Data Driven", adv_data: "Data Driven",
adv_data_desc: adv_data_desc: "Optimizing Content Strategies Based on Actual Performance.",
"Optimizing Content Strategies Based on Actual Performance.",
adv_easy: "Easy to Use", adv_easy: "Easy to Use",
adv_easy_desc: adv_easy_desc:
"Intuitive interface design, no need for professional technical background.", "Intuitive interface design, no need for professional technical background.",

View File

@ -198,6 +198,228 @@ export default {
investor_relations: "投資家関係", investor_relations: "投資家関係",
email_label: "メール:", email_label: "メール:",
}, },
HOME: {
CONTAIN: {
TITLEONE: {
TITLE: "企業ポジショニング",
CONTENT: "",
CONTENTTWO:
"IoT、コネクティビティ、AIを活用して、ターゲットを絞った多言語デジタルブランドを創造し、世界中の意見指導者KOLコミュニティを育成し、デジタルコンテンツのライフサイクル全体を通して類を見ない価値を提供します",
},
},
CONTAINY: {
STOCK_INFO: {
TITLE: "株式情報",
LAST_PRICE: "価格",
CHANGE: "%変動",
STOCK_CODE: "銘柄コード",
VOLUME: "出来高",
MARKET_CAP: "時価総額",
},
UPCOMING_EVENTS: {
TITLE: "開催予定のイベント",
EVENT_NAME: "国際新エネルギー・新興産業テクノロジー博覧会",
DATE: "日付",
VENUE: "会場",
AREA: "面積",
BOOTHS: "ブース",
LEARN_MORE: "詳細を見る",
},
NEWS: {
TITLE: "最近のニュース",
LATEST_TITLE: "AIテクロジーにおけるブレークスルーを発表",
LATEST_CONTENT:
"Ucommune、ナスダック最低入札価格要件を満たすことに成功",
READ_MORE: "続きを読む",
TITLETWO:
"展示テーマ:国際新エネルギー・新興産業テクノロジー博覧会",
TITLETHTEE:
"開催期間2025年8月12日火曜日2025年8月14日",
CONTENTTHREE:
"開催場所:中国・深圳国際会展センター",
CONTENTFOUR: "会場6号館Bホール、面積約10,000m²",
CONTENTFIVE: "ブース数約500標準ブース",
},
},
},
Governance: {
TITLE: "ガバナンス",
},
SECFILINGS: {
TITLE: "SEC提出書類",
FILTERlABEL1: "提出年",
FILTERlABEL2: "1ページあたりのアイテム数",
},
// 会社概要
COMPANYOVERVIEW: {
Company: "会社概要",
TITLETWO: {
TITLE: "FiEE, Inc.について",
CONTENT:
"FiEE, Inc.ナスダックFIEEは、以前のMinim, Inc.であり、1977年に設立されました。当社は市場で包括的なWiFi/Software as a Serviceプラットフォームを提供する実績があります。長年の発展を経て、2023年にテクロジーポートフォリオと収益源を拡大するためにSoftware First Modelへの戦略的変更を決定しました。2025年には、IoT、コネクティビティ、人工知能AIに関する専門知識を活かして、新たな事業機会を模索し、世界的なフットプリントを拡大するテクロジー企業としてブランドを刷新しました。",
CONTENTTWO:
"当社のサービスは、クラウド管理コネクティビティWiFiプラットフォーム、IoTハードウェア販売・ライセンシング、SaaSソリューション、プロフェッショナルなTo-C及びTo-Bサービス・サポートの4つの主要カテゴリーに分かれています。特筆すべきは、AIとデータ分析機能をコンテンツ作成とブランド管理に統合した革新的なSoftware as a ServiceSaaSソリューションを導入しました。この取り組みにより、世界中の主要ソーシャルメディアプラットフォームで強力な意見指導者KOLプールを育成し、グローバルプラットフォーム全体でデジタルプレゼンスの開発、管理、最適化を支援しています。当社のサービスには、ブランド目標に合わせてカスタマイズされたグラフィック、投稿、ショートビデオ、編集カレンダーが含まれます。",
CONTENTTHREE:
"IoT対応のコネクティビティソリューションを活用し、タレントに対してライフサイクル全体で価値を提供しています。当社は、ターゲットを絞ったマルチメディア・多言語コンテンツを開発するために、データ分析とファン行動分析のためのAI技術への継続的な投資に取り組んでいます。当社の目標は、より広範なグローバルオーディエンスにリーチするために、ソリューションとサービスを拡大することです。",
CONTENTTWOTITLE: "当社のサービスは以下のように構成されています",
},
TITLETHREE: {
TITLE: "当社の使命とビジョン",
CONTENT:
"• 革新的なテクノロジーソリューションを通じて世界中のタレントに力を与える",
CONTENTTWO:
"• IoT、コネクティビティ、人工知能を活用して、ターゲットを絞った多言語デジタルブランドを創造し、世界中の意見指導者KOLコミュニティを育成し、デジタルコンテンツのライフサイクル全体を通して類を見ない価値を提供します",
},
TITLEFOUR: {
CONTENT: "",
TITLE: "企業のマイルストーン",
SUBHEADING: "1977年 - 2015年設立とライセンス取得",
paragraph: {
ONE: "• 1977年にZoom Telephonicsとして設立されました。 ",
TWO: "• 2016年1月1日より効力発生の5年間のMotorolaホームネットワークライセンスを取得しました。 ",
},
SUBHEADINGTWO: "2020年合併とAIの進歩",
paragraphTwo: {
ONE: "• 2020年11月Minim Inc.と合併。Minim名前/OTCQBティッカーを採用。",
TWO: "• AI駆動のWi-Fi管理およびIoTセキュリティプラットフォームを導入。",
THREE: "",
},
SUBHEADINGTHREE: "2021年NASDAQ上場",
paragraphTHREE: {
ONE: "• 2021年7月7日にOTCQBからNASDAQ Capital Marketに移行。ティッカーはMINM。",
TWO: "• 拡大のための資金調達として2500万ドルの公募を実施。",
THREE: "",
},
SUBHEADINGFOREFF: "2023年 - 2024年Software First Modelへの転換",
paragraphFOUR: {
ONE: "• VoxのAI駆動Wi-Fi Home Managerなどの主要展開を含む、ISP/OEM向けMinimOSクラウドプラットフォームとAPIスイートを強化。",
TWO: "• テクロジーと収益基盤を拡大するためにe2Companiesとの合併協定を締結。",
THREE: "",
},
SUBHEADINGFIVE: "2025年リブランドと新C-Suite",
paragraphFIVE: {
ONE: "• Minim Inc.からFiEE, Inc.に正式にリブランド。",
TWO: "• CEOとしてLi Wai Chungを、CFOとしてCao Yuを任命。",
THREE:
"• IoT、コネクティビティ、AIの基盤を活かして新たな事業機会を追求。",
FOUR: "• 継続的な収益源を生み出すためにSaaS製品を市場に投入。",
FIVE: "• 中国本土で高成長するテクノロジーサービスプロバイダーである蘇州易迅通ネットワーク技術有限公司を買収。",
},
},
TITLEFIVE: {
CONTENT:
"•当社は独自のAI駆動クラウドソフトウェアプラットフォームとアプリケーションを開発し、家庭やビジネスユーザー、およびそれらを支援するサービスプロバイダーに効率的で高品質なネットワーク管理とセキュリティソリューションを提供しています。",
TITLE: "傑出した業績",
},
},
// 業務紹介
BusinessiIntroduction: {
CONTAIN: {
TITLEONE: {
TITLE: "業務紹介",
CONTENT:
"当社は、主にデジタルアカウント管理、コンテンツ運用と成長分析、コミュニティ参加とクリエイターパートナーシップを通じて、デジタルコンテンツ管理ソリューションとブランド成長戦略を提供しています。これらのサービスは、初期アカウント設定からマルチプラットフォームブランドプロモーションまで、デジタル発展の様々な段階にある顧客をサポートするように構成されています。",
CONTENTTWO:
"FiEE, Inc.の中核ソリューションは、以下の4つの主要カテゴリーを含みます。",
paragraph: {
ONE: {
TITLE: "(1) クラウド管理コネクティビティWiFiプラットフォーム ",
CONTENT: "消費者と中小企業向けのOSを駆動するSaaS ",
CONTENTTWO: "AI駆動の脅威保護、およびOTAアップデート",
},
TWO: {
TITLE: "(2) IoTハードウェア販売・ライセンシング ",
CONTENT:
"IoT製品と技術、VR/ARオンライン共有技術の開発を含む",
CONTENTTWO: "IoTデータ収集、分析、管理",
},
THREE: {
TITLE: "(3) SaaSソリューション",
CONTENT: "インターネット販売とIoTサポート",
CONTENTTWO: "KOLブランドサービス",
CONTENTTHREE:
"AI対応のコンテンツ作成とファンの習慣分析ソリューション",
},
FOUR: {
TITLE: "(4) プロフェッショナルなTo-C及びTo-Bサービス・サポート",
CONTENT:
"ISPおよび企業顧客とのネットワークサポート、セキュリティ監視、カスタム開発のためのマネージドサービス契約",
CONTENTTWO: "KOLブランドサービス",
CONTENTTHREE:
"AI対応のコンテンツ作成とファンの習慣分析ソリューション",
},
},
},
},
},
boarddirectors: {
title: "取締役会",
},
committeeComposition: {
title: "委員会構成",
position1: "委員",
position2: "委員長",
tableKey1: "監査委員会",
tableKey2: "報酬委員会",
tableKey3: "指名及び企業統治委員会",
},
// 管理
MANAGEMENT: {
TITLE:
"FiEE, Inc.は豊富な専門経験を持つ有能な上級管理陣を拥しています",
ONE: {
TITLE: "Li Wai Chung",
TITLETWO: "最高経営責任者CEO",
CONTENT:
"Li氏は当社の最高経営責任者CEOです。Li氏は会計、企業管理、財務管理において豊富な経験を持っています。彼の役割は、日常の事業運営の監督を含み、当社グループの全体管理において重要な役割を果たしています。Deloitte China、Shanghai Prime Machinery Company Limited、Lens Technology Co., Ltd.などでの著名な役職を歴任した実績を持ち、Li氏は当社チームに貴重な専門知識をもたらしています。",
CONTENTTWO:
"彼は香港のFulu Holdingsや台州水道集団、オランダのNedschroefで監査委員会委員長を務め、グローバルリーダーシップを示しました。Li氏は以前、投資管理、ビジネスコンサルティング、上場企業の取締役職などの重要なポジションを歴任しています。",
CONTENTTHREE: "",
},
TWO: {
TITLE: "Cao Yu",
TITLETWO: "最高財務責任者CFO、秘書、財務長、取締役",
CONTENTONE:
"Cao女士は当社の最高財務責任者CFO、秘書、財務長、取締役です。Cao女士は財務管理において豊富な経験を持っています。彼女は財務運営、戦略計画、リスク管理、レポート作成を監督し、当社の財務健全性と規制遵守を確保しています。",
CONTENTTWO:
"Cao女士は以前、2018年11月から2024年11月まで太風文化伝播有限公司の財務部長として財務業務を監督していました。それ以前は、2016年2月から2018年10月まで揚風美術交換有限公司のビジネスマネージャーを務め、2011年3月から2016年1月まで蘇州工業園区新福士達プラスチックプロファイル製品有限公司の財務部財務担当者を務めました。",
},
},
financialinformation: {
secfilings: {
title: "財務情報",
overview: {
title: "企業財務概要",
desc: "このページでは<strong>年次報告書</strong>にアクセスできます。これらのセクションでは、財務パフォーマンスとコンプライアンスに関する重要な財務データと規制文書を提供し、情報を提供します。",
},
annual_reports: {
title: "年次報告書",
file_name: "ファイル名",
view: "表示",
date: "日付",
},
sec: {
title: "SEC提出書類",
desc: "SECへのすべての提出書類にアクセスするには、以下を",
click_here: "クリック",
},
},
quarterlyreports: {
title: '四半期報告書',
search: {
placeholder: '検索',
button: '検索',
},
download: "ダウンロード",
pdfDownload: 'PDFダウンロード',
pagination: {
displaying: '{total}件中 {start} - {end}件を表示',
perPage: '{size}/ページ',
goto: 'ジャンプ',
},
},
},
email_alerts: { email_alerts: {
title: "メールアラート", title: "メールアラート",
required_fields: "* 必須項目", required_fields: "* 必須項目",

View File

@ -195,6 +195,228 @@ export default {
investor_relations: "投資者關係", investor_relations: "投資者關係",
email_label: "郵箱:", email_label: "郵箱:",
}, },
HOME: {
CONTAIN: {
TITLEONE: {
TITLE: "公司定位",
CONTENT: "",
CONTENTTWO:
"利用物聯網、連接性和人工智能,打造有針對性的多語言數位品牌,培養全球意見領袖(KOL)社群,為數位內容全生命周期提供無與倫比的價值",
},
},
CONTAINY: {
STOCK_INFO: {
TITLE: "股票資訊",
LAST_PRICE: "價格",
CHANGE: "%漲跌幅",
STOCK_CODE: "股票代碼",
VOLUME: "成交量",
MARKET_CAP: "市值",
},
UPCOMING_EVENTS: {
TITLE: "即將舉行的活動",
EVENT_NAME: "國際新能源與新興產業科技博覽會",
DATE: "日期",
VENUE: "會場",
AREA: "面積",
BOOTHS: "展位",
LEARN_MORE: "了解更多",
},
NEWS: {
TITLE: "最新消息",
LATEST_TITLE: "公司宣佈人工智能技術重大突破",
LATEST_CONTENT:
"優客工場成功重新符合納斯達克最低競價價格要求",
READ_MORE: "閱讀更多",
TITLETWO:
"展覽主題:國際新能源與新興產業科技博覽會",
TITLETHTEE:
"展覽時間2025年8月12日星期二2025年8月14日",
CONTENTTHREE:
"展覽地點:中國深圳國際會展中心",
CONTENTFOUR: "場館6號館B廳面積約10,000平方米",
CONTENTFIVE: "展位數約500個標準展位",
},
},
},
Governance: {
TITLE: "公司治理",
},
SECFILINGS: {
TITLE: "SEC文件",
FILTERlABEL1: "申報年度",
FILTERlABEL2: "每頁顯示數量",
},
// 公司概況
COMPANYOVERVIEW: {
Company: "公司簡介",
TITLETWO: {
TITLE: "關於FiEE, Inc.",
CONTENT:
"FiEE, Inc.納斯達克代碼FIEE前身为Minim, Inc.成立於1977年。我們在市場上提供全面的WiFi/Software as a Service平台方面擁有歷史悠久的業績。經過多年發展我們在2023年做出戰略性決定轉向Software First Model以擴大我們的技術組合和收入來源。2025年我們利用在物聯網、連接性和人工智能AI方面的專業知識重新打造品牌形象探索新的商業機遇並擴大全球業務範圍。",
CONTENTTWO:
"我們的服務分為四大核心類別雲端管理連接性WiFi平台、物聯網硬件銷售與授權、SaaS解決方案、以及專業的To-C和To-B服務與支持。值得一提的是我們推出了創新的Software as a ServiceSaaS解決方案將AI和數據分析能力整合到內容創作和品牌管理中。這一舉措使我們在全球主要社交媒體平台上培養了強大的意見領袖KOL資源協助他們在全球平台上開發、管理和優化數位形象。我們的服務包括根據品牌目標定製的圖文、帖文、短視頻和編輯日程表。",
CONTENTTHREE:
"通過物聯網驅動的連接性解決方案我們為人才提供全生命周期的價值。我們致力於持續投資AI技術用於數據分析和粉絲行為洞察以開發高度有針對性的多媒體和多語言內容。我們的目標是擴大解決方案和服務以覆蓋更廣泛的全球受眾。",
CONTENTTWOTITLE: "我們的服務結構如下",
},
TITLETHREE: {
TITLE: "我們的使命與願景",
CONTENT:
"• 通過創新技術解決方案賦能全球人才",
CONTENTTWO:
"• 利用物聯網、連接性和人工智能,打造有針對性的多語言數位品牌,培養全球意見領袖(KOL)社群,為數位內容全生命周期提供無與倫比的價值",
},
TITLEFOUR: {
CONTENT: "",
TITLE: "企業里程碑",
SUBHEADING: "1977年 - 2015年成立與授權",
paragraph: {
ONE: "• 1977年成立原名Zoom Telephonics。 ",
TWO: "• 獲得為期五年的摩托羅拉家庭網絡授權有效期自2016年1月1日起。 ",
},
SUBHEADINGTWO: "2020年合併與AI進步",
paragraphTwo: {
ONE: "• 2020年11月與Minim Inc.合併採用Minim名稱/OTCQB股票代碼。",
TWO: "• 推出AI驅動的Wi-Fi管理和物聯網安全平台。",
THREE: "",
},
SUBHEADINGTHREE: "2021年納斯達克上市",
paragraphTHREE: {
ONE: "• 2021年7月7日從OTCQB轉至納斯達克資本市場股票代碼MINM。",
TWO: "• 進行公募籌集2500萬美元用於業務擴展。",
THREE: "",
},
SUBHEADINGFOREFF: "2023年 - 2024年轉向Software First Model",
paragraphFOUR: {
ONE: "• 增強面向ISP/OEM的MinimOS雲平台和API套件包括Vox的AI驅動Wi-Fi Home Manager等重大部署。",
TWO: "• 與e2Companies簽署合併協議以擴大技術和收入基礎。",
THREE: "",
},
SUBHEADINGFIVE: "2025年品牌重塑與新管理層",
paragraphFIVE: {
ONE: "• 正式從Minim Inc.更名為FiEE, Inc.。",
TWO: "• 任命Li Wai Chung為首席執行官Cao Yu為首席財務官。",
THREE:
"• 利用物聯網、連接性和AI方面的基礎探索新的業務機遇。",
FOUR: "• 推出SaaS產品進入市場產生持續收入來源。",
FIVE: "• 收購蘇州易迅通網絡技術有限公司,一家在中國快速成長的技術服務提供商。",
},
},
TITLEFIVE: {
CONTENT:
"•我們開發了自己的AI驅動雲軟件平台和應用程序為家庭和企業用戶以及協助他們的服務提供商提供高效、高質量的網絡管理和安全解決方案。",
TITLE: "傑出成就",
},
},
// 業務介紹
BusinessiIntroduction: {
CONTAIN: {
TITLEONE: {
TITLE: "業務介紹",
CONTENT:
"我們主要通過數位賬號管理、內容運營與增長分析,以及社群參與和創作者合作,提供數位內容管理解決方案和品牌增長策略。這些服務旨在支持客戶在數位發展的不同階段,從初始賬號設置到多平台品牌推廣。",
CONTENTTWO:
"FiEE, Inc.的核心解決方案包含以下四大類別。",
paragraph: {
ONE: {
TITLE: "(1) 雲端管理連接性WiFi平台 ",
CONTENT: "為消費者和中小企業提供OS驅動的SaaS ",
CONTENTTWO: "AI驅動的威脅防禦以及無線更新",
},
TWO: {
TITLE: "(2) 物聯網硬件銷售與授權: ",
CONTENT:
"物聯網產品和技術包括開發VR/AR在線共享技術",
CONTENTTWO: "物聯網數據收集、分析和管理",
},
THREE: {
TITLE: "(3) SaaS解決方案",
CONTENT: "網絡銷售和物聯網支持",
CONTENTTWO: "KOL品牌服務",
CONTENTTHREE:
"AI支持的內容創作和粉絲習慣分析解決方案",
},
FOUR: {
TITLE: "(4) 專業的To-C和To-B服務與支持",
CONTENT:
"與ISP和企業客戶簽署的網絡支持、安全監控和定制開發託管服務協議",
CONTENTTWO: "KOL品牌服務",
CONTENTTHREE:
"AI支持的內容創作和粉絲習慣分析解決方案",
},
},
},
},
},
boarddirectors: {
title: "董事會",
},
committeeComposition: {
title: "委員會組成",
position1: "委員",
position2: "主席",
tableKey1: "審計委員會",
tableKey2: "薪酬委員會",
tableKey3: "提名與公司治理委員會",
},
// 管理層
MANAGEMENT: {
TITLE:
"FiEE, Inc.擁有一支經驗豐富、能力出色的高級管理團隊",
ONE: {
TITLE: "Li Wai Chung",
TITLETWO: "首席執行官",
CONTENT:
"Li先生是我們的首席執行官。Li先生在會計、企業管理和財務管理方面擁有豐富經驗。他的職責包括監督日常業務運營並在集團整體管理中發揮重要作用。憑藉在德勤中國、上海普邁機械有限公司、藍思科技股份有限公司等擔任要職的經歷Li先生為我們的團隊帶來了寶貴的專業知識。",
CONTENTTWO:
"他曾擔任香港富祿控股、台州水務集團和荷蘭Nedschroef的審計委員會主席展現了全球領導力。Li先生此前曾在投資管理、商業諮詢和上市公司董事職位等重要崗位任職。",
CONTENTTHREE: "",
},
TWO: {
TITLE: "Cao Yu",
TITLETWO: "首席財務官、公司秘書、財務總監兼董事",
CONTENTONE:
"Cao女士是我們的首席財務官、公司秘書、財務總監兼董事。Cao女士在財務管理方面擁有豐富經驗。她負責監督財務運營、戰略規劃、風險管理和報告確保我們的財務健康和法規遵循。",
CONTENTTWO:
"Cao女士此前於2018年11月至2024年11月擔任太風文化傳播有限公司的財務總監負責監督其財務事務。在此之前Cao女士於2016年2月至2018年10月擔任揚風美術交流有限公司的業務經理並於2011年3月至2016年1月擔任蘇州工業園區新福士達塑料型材製品有限公司財務部財務主管。",
},
},
financialinformation: {
secfilings: {
title: "財務信息",
overview: {
title: "公司財務概覽",
desc: "本頁提供對<strong>年度報告</strong>的訪問。這些部分提供關鍵財務數據和監管文件,讓您了解我們的財務表現和合規情況。",
},
annual_reports: {
title: "年度報告",
file_name: "文件名",
view: "查看",
date: "日期",
},
sec: {
title: "SEC文件",
desc: "要訪問我們向SEC提交的所有文件請",
click_here: "點擊此處",
},
},
quarterlyreports: {
title: '季度報告',
search: {
placeholder: '搜索',
button: '開始',
},
download: "下載",
pdfDownload: 'PDF 下載',
pagination: {
displaying: '顯示第 {start} - {end} 條,共 {total} 條',
perPage: '{size}/頁',
goto: '前往',
},
},
},
email_alerts: { email_alerts: {
title: "郵件提醒", title: "郵件提醒",
required_fields: "* 必填欄位", required_fields: "* 必填欄位",

View File

@ -195,6 +195,228 @@ export default {
investor_relations: "投资者关系", investor_relations: "投资者关系",
email_label: "邮箱:", email_label: "邮箱:",
}, },
HOME: {
CONTAIN: {
TITLEONE: {
TITLE: "公司定位",
CONTENT: "",
CONTENTTWO:
"利用物联网、连接性和人工智能,打造有针对性的多语言数字品牌,培养全球意见领袖(KOL)社群,为数字内容全生命周期提供无与伦比的价值",
},
},
CONTAINY: {
STOCK_INFO: {
TITLE: "股票信息",
LAST_PRICE: "价格",
CHANGE: "%涨跌幅",
STOCK_CODE: "股票代码",
VOLUME: "成交量",
MARKET_CAP: "市值",
},
UPCOMING_EVENTS: {
TITLE: "即将举行的活动",
EVENT_NAME: "国际新能源与新兴产业科技博览会",
DATE: "日期",
VENUE: "会场",
AREA: "面积",
BOOTHS: "展位",
LEARN_MORE: "了解更多",
},
NEWS: {
TITLE: "最新消息",
LATEST_TITLE: "公司宣布人工智能技术重大突破",
LATEST_CONTENT:
"优客工场成功重新符合纳斯达克最低竞价价格要求",
READ_MORE: "阅读更多",
TITLETWO:
"展览主题:国际新能源与新兴产业科技博览会",
TITLETHTEE:
"展览时间2025年8月12日星期二2025年8月14日",
CONTENTTHREE:
"展览地点:中国深圳国际会展中心",
CONTENTFOUR: "场馆6号馆B厅面积约10,000平方米",
CONTENTFIVE: "展位数约500个标准展位",
},
},
},
Governance: {
TITLE: "公司治理",
},
SECFILINGS: {
TITLE: "SEC文件",
FILTERlABEL1: "申报年度",
FILTERlABEL2: "每页显示数量",
},
// 公司概况
COMPANYOVERVIEW: {
Company: "公司简介",
TITLETWO: {
TITLE: "关于FiEE, Inc.",
CONTENT:
"FiEE, Inc.纳斯达克代码FIEE前身为Minim, Inc.成立于1977年。我们在市场上提供全面的WiFi/Software as a Service平台方面拥有历史悠久的业绩。经过多年发展我们在2023年做出战略性决定转向Software First Model以扩大我们的技术组合和收入来源。2025年我们利用在物联网、连接性和人工智能AI方面的专业知识重新打造品牌形象探索新的商业机遇并扩大全球业务范围。",
CONTENTTWO:
"我们的服务分为四大核心类别云端管理连接性WiFi平台、物联网硬件销售与授权、SaaS解决方案、以及专业的To-C和To-B服务与支持。值得一提的是我们推出了创新的Software as a ServiceSaaS解决方案将AI和数据分析能力整合到内容创作和品牌管理中。这一举措使我们在全球主要社交媒体平台上培养了强大的意见领袖KOL资源协助他们在全球平台上开发、管理和优化数字形象。我们的服务包括根据品牌目标定制的图文、帖文、短视频和编辑日程表。",
CONTENTTHREE:
"通过物联网驱动的连接性解决方案我们为人才提供全生命周期的价值。我们致力于持续投资AI技术用于数据分析和粉丝行为洞察以开发高度有针对性的多媒体和多语言内容。我们的目标是扩大解决方案和服务以覆盖更广泛的全球受众。",
CONTENTTWOTITLE: "我们的服务结构如下",
},
TITLETHREE: {
TITLE: "我们的使命与愿景",
CONTENT:
"• 通过创新技术解决方案赋能全球人才",
CONTENTTWO:
"• 利用物联网、连接性和人工智能,打造有针对性的多语言数字品牌,培养全球意见领袖(KOL)社群,为数字内容全生命周期提供无与伦比的价值",
},
TITLEFOUR: {
CONTENT: "",
TITLE: "企业里程碑",
SUBHEADING: "1977年 - 2015年成立与授权",
paragraph: {
ONE: "• 1977年成立原名Zoom Telephonics。 ",
TWO: "• 获得为期五年的摩托罗拉家庭网络授权有效期自2016年1月1日起。 ",
},
SUBHEADINGTWO: "2020年合并与AI进步",
paragraphTwo: {
ONE: "• 2020年11月与Minim Inc.合并采用Minim名称/OTCQB股票代码。",
TWO: "• 推出AI驱动的Wi-Fi管理和物联网安全平台。",
THREE: "",
},
SUBHEADINGTHREE: "2021年纳斯达克上市",
paragraphTHREE: {
ONE: "• 2021年7月7日从OTCQB转至纳斯达克资本市场股票代码MINM。",
TWO: "• 进行公募筹集2500万美元用于业务扩展。",
THREE: "",
},
SUBHEADINGFOREFF: "2023年 - 2024年转向Software First Model",
paragraphFOUR: {
ONE: "• 增强面向ISP/OEM的MinimOS云平台和API套件包括Vox的AI驱动Wi-Fi Home Manager等重大部署。",
TWO: "• 与e2Companies签署合并协议以扩大技术和收入基础。",
THREE: "",
},
SUBHEADINGFIVE: "2025年品牌重塑与新管理层",
paragraphFIVE: {
ONE: "• 正式从Minim Inc.更名为FiEE, Inc.。",
TWO: "• 任命Li Wai Chung为首席执行官Cao Yu为首席财务官。",
THREE:
"• 利用物联网、连接性和AI方面的基础探索新的业务机遇。",
FOUR: "• 推出SaaS产品进入市场产生持续收入来源。",
FIVE: "• 收购苏州易迅通网络技术有限公司,一家在中国快速成长的技术服务提供商。",
},
},
TITLEFIVE: {
CONTENT:
"•我们开发了自己的AI驱动云软件平台和应用程序为家庭和企业用户以及协助他们的服务提供商提供高效、高质量的网络管理和安全解决方案。",
TITLE: "杰出成就",
},
},
// 业务介绍
BusinessiIntroduction: {
CONTAIN: {
TITLEONE: {
TITLE: "业务介绍",
CONTENT:
"我们主要通过数字账号管理、内容运营与增长分析,以及社群参与和创作者合作,提供数字内容管理解决方案和品牌增长策略。这些服务旨在支持客户在数字发展的不同阶段,从初始账号设置到多平台品牌推广。",
CONTENTTWO:
"FiEE, Inc.的核心解决方案包含以下四大类别。",
paragraph: {
ONE: {
TITLE: "(1) 云端管理连接性WiFi平台 ",
CONTENT: "为消费者和中小企业提供OS驱动的SaaS ",
CONTENTTWO: "AI驱动的威胁防御以及无线更新",
},
TWO: {
TITLE: "(2) 物联网硬件销售与授权: ",
CONTENT:
"物联网产品和技术包括开发VR/AR在线共享技术",
CONTENTTWO: "物联网数据收集、分析和管理",
},
THREE: {
TITLE: "(3) SaaS解决方案",
CONTENT: "网络销售和物联网支持",
CONTENTTWO: "KOL品牌服务",
CONTENTTHREE:
"AI支持的内容创作和粉丝习惯分析解决方案",
},
FOUR: {
TITLE: "(4) 专业的To-C和To-B服务与支持",
CONTENT:
"与ISP和企业客户签署的网络支持、安全监控和定制开发托管服务协议",
CONTENTTWO: "KOL品牌服务",
CONTENTTHREE:
"AI支持的内容创作和粉丝习惯分析解决方案",
},
},
},
},
},
boarddirectors: {
title: "董事会",
},
committeeComposition: {
title: "委员会组成",
position1: "委员",
position2: "主席",
tableKey1: "审计委员会",
tableKey2: "薪酬委员会",
tableKey3: "提名与公司治理委员会",
},
// 管理层
MANAGEMENT: {
TITLE:
"FiEE, Inc.拥有一支经验丰富、能力出色的高级管理团队",
ONE: {
TITLE: "Li Wai Chung",
TITLETWO: "首席执行官",
CONTENT:
"李先生是我们的首席执行官。李先生在会计、企业管理和财务管理方面拥有丰富经验。他的职责包括监督日常业务运营,并在集团整体管理中发挥重要作用。凭借在德勤中国、上海普迈机械有限公司、蓝思科技股份有限公司等担任要职的经历,李先生为我们的团队带来了宝贵的专业知识。",
CONTENTTWO:
"他曾担任香港富禄控股、台州水务集团和荷兰Nedschroef的审计委员会主席展现了全球领导力。李先生此前曾在投资管理、商业咨询和上市公司董事职位等重要岗位任职。",
CONTENTTHREE: "",
},
TWO: {
TITLE: "Cao Yu",
TITLETWO: "首席财务官、公司秘书、财务总监兼董事",
CONTENTONE:
"曹女士是我们的首席财务官、公司秘书、财务总监兼董事。曹女士在财务管理方面拥有丰富经验。她负责监督财务运营、战略规划、风险管理和报告,确保我们的财务健康和法规遵循。",
CONTENTTWO:
"曹女士此前于2018年11月至2024年11月担任太风文化传播有限公司的财务总监负责监督其财务事务。在此之前曹女士于2016年2月至2018年10月担任扬风美术交流有限公司的业务经理并于2011年3月至2016年1月担任苏州工业园区新福士达塑料型材制品有限公司财务部财务主管。",
},
},
financialinformation: {
secfilings: {
title: "财务信息",
overview: {
title: "公司财务概览",
desc: "本页提供对<strong>年度报告</strong>的访问。这些部分提供关键财务数据和监管文件,让您了解我们的财务表现和合规情况。",
},
annual_reports: {
title: "年度报告",
file_name: "文件名",
view: "查看",
date: "日期",
},
sec: {
title: "SEC文件",
desc: "要访问我们向SEC提交的所有文件请",
click_here: "点击此处",
},
},
quarterlyreports: {
title: '季度报告',
search: {
placeholder: '搜索',
button: '开始',
},
download: "下载",
pdfDownload: 'PDF 下载',
pagination: {
displaying: '显示第 {start} - {end} 条,共 {total} 条',
perPage: '{size}/页',
goto: '前往',
},
},
},
email_alerts: { email_alerts: {
title: "邮件提醒", title: "邮件提醒",
required_fields: "* 必填字段", required_fields: "* 必填字段",

View File

@ -20,7 +20,9 @@
</div> </div>
<!-- 标题区 --> <!-- 标题区 -->
<div class="title w-[900PX] mx-auto pl-[15PX] mb-[50px] text-left"> <div class="title w-[900PX] mx-auto pl-[15PX] mb-[50px] text-left">
<h1 style="font-size: 40px; margin-top: 60px">Committee Composition</h1> <h1 style="font-size: 40px; margin-top: 60px">
{{ t("committeeComposition.title") }}
</h1>
</div> </div>
<div <div
class="w-[900PX] mx-auto overflow-hidden p-[10PX] relative z-99" class="w-[900PX] mx-auto overflow-hidden p-[10PX] relative z-99"
@ -32,7 +34,7 @@
> >
<n-data-table <n-data-table
:columns="columns" :columns="columns"
:data="data" :data="committeeData"
virtual-scroll-y virtual-scroll-y
:bordered="false" :bordered="false"
:bottom-bordered="false" :bottom-bordered="false"
@ -46,6 +48,17 @@
<script setup lang="jsx"> <script setup lang="jsx">
import { NDataTable } from "naive-ui"; import { NDataTable } from "naive-ui";
import { committeeManagement } from "@/api/auth";
import { ref } from "vue";
import { useI18n } from "vue-i18n";
const { t } = useI18n();
const committeeData = ref([]);
const getData = async () => {
const res = await committeeManagement({});
committeeData.value = res.data?.item || [];
};
getData();
const columns = [ const columns = [
{ {
@ -55,7 +68,6 @@ const columns = [
fixed: "left", fixed: "left",
align: "center", align: "center",
className: "name", className: "name",
render(row) { render(row) {
return ( return (
<router-link <router-link
@ -74,19 +86,26 @@ const columns = [
minWidth: 200, minWidth: 200,
className: "auditCommittee", className: "auditCommittee",
title() { title() {
return <h3>Audit Committee</h3>; return <h3>{t("committeeComposition.tableKey1")}</h3>;
}, },
render(row) { render(row) {
return ( return (
<div style={{ borderLeft: "1px dashed #E7E7E7" }}> <div style={{ borderLeft: "1px dashed #E7E7E7" }}>
<row.auditCommittee /> {/* <row.auditCommittee /> */}
{+row.auditCommittee === 1 ? (
t("committeeComposition.position1")
) : (
<span class="text-[#6CC7DC]">
{t("committeeComposition.position2")}
</span>
)}
</div> </div>
); );
}, },
}, },
{ {
title() { title() {
return <h3>Compensation Committee</h3>; return <h3>{t("committeeComposition.tableKey2")}</h3>;
}, },
align: "center", align: "center",
key: "compensationCommittee", key: "compensationCommittee",
@ -95,14 +114,21 @@ const columns = [
render(row) { render(row) {
return ( return (
<div style={{ borderLeft: "1px dashed #E7E7E7" }}> <div style={{ borderLeft: "1px dashed #E7E7E7" }}>
<row.compensationCommittee /> {/* <row.compensationCommittee /> */}
{+row.compensationCommittee === 1 ? (
t("committeeComposition.position1")
) : (
<span class="text-[#6CC7DC]">
{t("committeeComposition.position2")}
</span>
)}
</div> </div>
); );
}, },
}, },
{ {
title() { title() {
return <h3>Nominating and Corporate Governance Committee</h3>; return <h3>{t("committeeComposition.tableKey3")}</h3>;
}, },
key: "governanceCommittee", key: "governanceCommittee",
align: "center", align: "center",
@ -111,7 +137,14 @@ const columns = [
render(row) { render(row) {
return ( return (
<div style={{ borderLeft: "1px dashed #E7E7E7" }}> <div style={{ borderLeft: "1px dashed #E7E7E7" }}>
<row.governanceCommittee /> {/* <row.governanceCommittee /> */}
{row.nominatingCommittee === 1 ? (
t("committeeComposition.position1")
) : (
<span class="text-[#6CC7DC]">
{t("committeeComposition.position2")}
</span>
)}
</div> </div>
); );
}, },

View File

@ -20,7 +20,9 @@
</div> </div>
<!-- 标题区 --> <!-- 标题区 -->
<div class="title w-[900PX] mx-auto pl-[15PX] mb-[50px] text-left"> <div class="title w-[900PX] mx-auto pl-[15PX] mb-[50px] text-left">
<h1 style="font-size: 40px; margin-top: 60px">Committee Composition</h1> <h1 style="font-size: 40px; margin-top: 60px">
{{ t("committeeComposition.title") }}
</h1>
</div> </div>
<div <div
class="w-[900PX] mx-auto overflow-hidden p-[10PX] relative z-99" class="w-[900PX] mx-auto overflow-hidden p-[10PX] relative z-99"
@ -32,7 +34,7 @@
> >
<n-data-table <n-data-table
:columns="columns" :columns="columns"
:data="data" :data="committeeData"
virtual-scroll-y virtual-scroll-y
:bordered="false" :bordered="false"
:bottom-bordered="false" :bottom-bordered="false"
@ -46,6 +48,17 @@
<script setup lang="jsx"> <script setup lang="jsx">
import { NDataTable } from "naive-ui"; import { NDataTable } from "naive-ui";
import { committeeManagement } from "@/api/auth";
import { ref } from "vue";
import { useI18n } from "vue-i18n";
const { t } = useI18n();
const committeeData = ref([]);
const getData = async () => {
const res = await committeeManagement({});
committeeData.value = res.data?.item || [];
};
getData();
const columns = [ const columns = [
{ {
@ -55,7 +68,6 @@ const columns = [
fixed: "left", fixed: "left",
align: "center", align: "center",
className: "name", className: "name",
render(row) { render(row) {
return ( return (
<router-link <router-link
@ -74,19 +86,26 @@ const columns = [
minWidth: 200, minWidth: 200,
className: "auditCommittee", className: "auditCommittee",
title() { title() {
return <h3>Audit Committee</h3>; return <h3>{t("committeeComposition.tableKey1")}</h3>;
}, },
render(row) { render(row) {
return ( return (
<div style={{ borderLeft: "1px dashed #E7E7E7" }}> <div style={{ borderLeft: "1px dashed #E7E7E7" }}>
<row.auditCommittee /> {/* <row.auditCommittee /> */}
{+row.auditCommittee === 1 ? (
t("committeeComposition.position1")
) : (
<span class="text-[#6CC7DC]">
{t("committeeComposition.position2")}
</span>
)}
</div> </div>
); );
}, },
}, },
{ {
title() { title() {
return <h3>Compensation Committee</h3>; return <h3>{t("committeeComposition.tableKey2")}</h3>;
}, },
align: "center", align: "center",
key: "compensationCommittee", key: "compensationCommittee",
@ -95,14 +114,21 @@ const columns = [
render(row) { render(row) {
return ( return (
<div style={{ borderLeft: "1px dashed #E7E7E7" }}> <div style={{ borderLeft: "1px dashed #E7E7E7" }}>
<row.compensationCommittee /> {/* <row.compensationCommittee /> */}
{+row.compensationCommittee === 1 ? (
t("committeeComposition.position1")
) : (
<span class="text-[#6CC7DC]">
{t("committeeComposition.position2")}
</span>
)}
</div> </div>
); );
}, },
}, },
{ {
title() { title() {
return <h3>Nominating and Corporate Governance Committee</h3>; return <h3>{t("committeeComposition.tableKey3")}</h3>;
}, },
key: "governanceCommittee", key: "governanceCommittee",
align: "center", align: "center",
@ -111,7 +137,14 @@ const columns = [
render(row) { render(row) {
return ( return (
<div style={{ borderLeft: "1px dashed #E7E7E7" }}> <div style={{ borderLeft: "1px dashed #E7E7E7" }}>
<row.governanceCommittee /> {/* <row.governanceCommittee /> */}
{row.nominatingCommittee === 1 ? (
t("committeeComposition.position1")
) : (
<span class="text-[#6CC7DC]">
{t("committeeComposition.position2")}
</span>
)}
</div> </div>
); );
}, },

View File

@ -20,7 +20,9 @@
</div> </div>
<!-- 标题区 --> <!-- 标题区 -->
<div class="title w-[343PX] mx-auto pl-[15PX] mb-[50px] text-leftPX] mx-auto pl-[15PX] mb-[50px] text-left"> <div class="title w-[343PX] mx-auto pl-[15PX] mb-[50px] text-leftPX] mx-auto pl-[15PX] mb-[50px] text-left">
<h1 style="font-size: 24px; margin-top: 60px">Committee Composition</h1> <h1 style="font-size: 24px; margin-top: 60px">
{{ t("committeeComposition.title") }}
</h1>
</div> </div>
<div <div
class="w-[343PX] mx-auto overflow-hidden p-[10PX] relative z-99" class="w-[343PX] mx-auto overflow-hidden p-[10PX] relative z-99"
@ -32,7 +34,7 @@
> >
<n-data-table <n-data-table
:columns="columns" :columns="columns"
:data="data" :data="committeeData"
virtual-scroll-y virtual-scroll-y
:bordered="false" :bordered="false"
:bottom-bordered="false" :bottom-bordered="false"
@ -46,16 +48,26 @@
<script setup lang="jsx"> <script setup lang="jsx">
import { NDataTable } from "naive-ui"; import { NDataTable } from "naive-ui";
import { committeeManagement } from "@/api/auth";
import { ref } from "vue";
import { useI18n } from "vue-i18n";
const { t } = useI18n();
const committeeData = ref([]);
const getData = async () => {
const res = await committeeManagement({});
committeeData.value = res.data?.item || [];
};
getData();
const columns = [ const columns = [
{ {
title: "", title: "",
key: "name", key: "name",
minWidth: 100, minWidth: 200,
fixed: "left", fixed: "left",
align: "center", align: "center",
className: "name", className: "name",
render(row) { render(row) {
return ( return (
<router-link <router-link
@ -74,19 +86,26 @@ const columns = [
minWidth: 200, minWidth: 200,
className: "auditCommittee", className: "auditCommittee",
title() { title() {
return <h3>Audit Committee</h3>; return <h3>{t("committeeComposition.tableKey1")}</h3>;
}, },
render(row) { render(row) {
return ( return (
<div style={{ borderLeft: "1px dashed #E7E7E7" }}> <div style={{ borderLeft: "1px dashed #E7E7E7" }}>
<row.auditCommittee /> {/* <row.auditCommittee /> */}
{+row.auditCommittee === 1 ? (
t("committeeComposition.position1")
) : (
<span class="text-[#6CC7DC]">
{t("committeeComposition.position2")}
</span>
)}
</div> </div>
); );
}, },
}, },
{ {
title() { title() {
return <h3>Compensation Committee</h3>; return <h3>{t("committeeComposition.tableKey2")}</h3>;
}, },
align: "center", align: "center",
key: "compensationCommittee", key: "compensationCommittee",
@ -95,14 +114,21 @@ const columns = [
render(row) { render(row) {
return ( return (
<div style={{ borderLeft: "1px dashed #E7E7E7" }}> <div style={{ borderLeft: "1px dashed #E7E7E7" }}>
<row.compensationCommittee /> {/* <row.compensationCommittee /> */}
{+row.compensationCommittee === 1 ? (
t("committeeComposition.position1")
) : (
<span class="text-[#6CC7DC]">
{t("committeeComposition.position2")}
</span>
)}
</div> </div>
); );
}, },
}, },
{ {
title() { title() {
return <h3>Nominating and Corporate Governance Committee</h3>; return <h3>{t("committeeComposition.tableKey3")}</h3>;
}, },
key: "governanceCommittee", key: "governanceCommittee",
align: "center", align: "center",
@ -111,7 +137,14 @@ const columns = [
render(row) { render(row) {
return ( return (
<div style={{ borderLeft: "1px dashed #E7E7E7" }}> <div style={{ borderLeft: "1px dashed #E7E7E7" }}>
<row.governanceCommittee /> {/* <row.governanceCommittee /> */}
{row.nominatingCommittee === 1 ? (
t("committeeComposition.position1")
) : (
<span class="text-[#6CC7DC]">
{t("committeeComposition.position2")}
</span>
)}
</div> </div>
); );
}, },

View File

@ -20,7 +20,9 @@
</div> </div>
<!-- 标题区 --> <!-- 标题区 -->
<div class="title w-[618PX] mx-auto pl-[15PX] mb-[50px] text-left"> <div class="title w-[618PX] mx-auto pl-[15PX] mb-[50px] text-left">
<h1 style="font-size: 32px; margin-top: 60px">Committee Composition</h1> <h1 style="font-size: 32px; margin-top: 60px">
{{ t("committeeComposition.title") }}
</h1>
</div> </div>
<div <div
class="w-[618PX] mx-auto overflow-hidden p-[10PX] relative z-99" class="w-[618PX] mx-auto overflow-hidden p-[10PX] relative z-99"
@ -32,7 +34,7 @@
> >
<n-data-table <n-data-table
:columns="columns" :columns="columns"
:data="data" :data="committeeData"
virtual-scroll-y virtual-scroll-y
:bordered="false" :bordered="false"
:bottom-bordered="false" :bottom-bordered="false"
@ -46,6 +48,17 @@
<script setup lang="jsx"> <script setup lang="jsx">
import { NDataTable } from "naive-ui"; import { NDataTable } from "naive-ui";
import { committeeManagement } from "@/api/auth";
import { ref } from "vue";
import { useI18n } from "vue-i18n";
const { t } = useI18n();
const committeeData = ref([]);
const getData = async () => {
const res = await committeeManagement({});
committeeData.value = res.data?.item || [];
};
getData();
const columns = [ const columns = [
{ {
@ -55,7 +68,6 @@ const columns = [
fixed: "left", fixed: "left",
align: "center", align: "center",
className: "name", className: "name",
render(row) { render(row) {
return ( return (
<router-link <router-link
@ -74,19 +86,26 @@ const columns = [
minWidth: 200, minWidth: 200,
className: "auditCommittee", className: "auditCommittee",
title() { title() {
return <h3>Audit Committee</h3>; return <h3>{t("committeeComposition.tableKey1")}</h3>;
}, },
render(row) { render(row) {
return ( return (
<div style={{ borderLeft: "1px dashed #E7E7E7" }}> <div style={{ borderLeft: "1px dashed #E7E7E7" }}>
<row.auditCommittee /> {/* <row.auditCommittee /> */}
{+row.auditCommittee === 1 ? (
t("committeeComposition.position1")
) : (
<span class="text-[#6CC7DC]">
{t("committeeComposition.position2")}
</span>
)}
</div> </div>
); );
}, },
}, },
{ {
title() { title() {
return <h3>Compensation Committee</h3>; return <h3>{t("committeeComposition.tableKey2")}</h3>;
}, },
align: "center", align: "center",
key: "compensationCommittee", key: "compensationCommittee",
@ -95,14 +114,21 @@ const columns = [
render(row) { render(row) {
return ( return (
<div style={{ borderLeft: "1px dashed #E7E7E7" }}> <div style={{ borderLeft: "1px dashed #E7E7E7" }}>
<row.compensationCommittee /> {/* <row.compensationCommittee /> */}
{+row.compensationCommittee === 1 ? (
t("committeeComposition.position1")
) : (
<span class="text-[#6CC7DC]">
{t("committeeComposition.position2")}
</span>
)}
</div> </div>
); );
}, },
}, },
{ {
title() { title() {
return <h3>Nominating and Corporate Governance Committee</h3>; return <h3>{t("committeeComposition.tableKey3")}</h3>;
}, },
key: "governanceCommittee", key: "governanceCommittee",
align: "center", align: "center",
@ -111,7 +137,14 @@ const columns = [
render(row) { render(row) {
return ( return (
<div style={{ borderLeft: "1px dashed #E7E7E7" }}> <div style={{ borderLeft: "1px dashed #E7E7E7" }}>
<row.governanceCommittee /> {/* <row.governanceCommittee /> */}
{row.nominatingCommittee === 1 ? (
t("committeeComposition.position1")
) : (
<span class="text-[#6CC7DC]">
{t("committeeComposition.position2")}
</span>
)}
</div> </div>
); );
}, },

View File

@ -15,17 +15,17 @@
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" /> <img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div> </div>
<div class="directors-page relative z-[-15]" style="width: 900px"> <div class="directors-page relative z-[-15]" style="width: 900px">
<h1 class="page-title">Board of Directors</h1> <h1 class="page-title">{{ t('boarddirectors.title') }}</h1>
<div class="directors-list"> <div class="directors-list">
<div <div
v-for="(director, index) in otherDirectors" v-for="(director, index) in data"
:key="index" :key="index"
class="director-item" class="director-item"
> >
<n-h2 class="director-name">{{ director.name }}</n-h2> <n-h2 class="director-name">{{ director.name }}</n-h2>
<n-text class="director-title">{{ director.title }}</n-text> <n-text class="director-title">{{ director.brief }}</n-text>
<n-p class="director-bio">{{ director.contain }}</n-p> <n-p class="director-bio">{{ director.introduction }}</n-p>
</div> </div>
</div> </div>
</div> </div>
@ -33,6 +33,18 @@
</template> </template>
<script setup> <script setup>
import { boardManagement } from "@/api/auth";
import { ref } from "vue";
import { useI18n } from "vue-i18n";
const { t } = useI18n();
const data = ref([]);
const getData = async () => {
const res = await boardManagement({});
data.value = res.data.item || [];
};
getData();
const otherDirectors = [ const otherDirectors = [
{ {
name: "Hu Bin", name: "Hu Bin",

View File

@ -15,17 +15,17 @@
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" /> <img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div> </div>
<div class="directors-page relative z-[-15]" style="width: 900px"> <div class="directors-page relative z-[-15]" style="width: 900px">
<h1 class="page-title">Board of Directors</h1> <h1 class="page-title">{{ t('boarddirectors.title') }}</h1>
<div class="directors-list"> <div class="directors-list">
<div <div
v-for="(director, index) in otherDirectors" v-for="(director, index) in data"
:key="index" :key="index"
class="director-item" class="director-item"
> >
<n-h2 class="director-name">{{ director.name }}</n-h2> <n-h2 class="director-name">{{ director.name }}</n-h2>
<n-text class="director-title">{{ director.title }}</n-text> <n-text class="director-title">{{ director.brief }}</n-text>
<n-p class="director-bio">{{ director.contain }}</n-p> <n-p class="director-bio">{{ director.introduction }}</n-p>
</div> </div>
</div> </div>
</div> </div>
@ -33,6 +33,18 @@
</template> </template>
<script setup> <script setup>
import { boardManagement } from "@/api/auth";
import { ref } from "vue";
import { useI18n } from "vue-i18n";
const { t } = useI18n();
const data = ref([]);
const getData = async () => {
const res = await boardManagement({});
data.value = res.data.item || [];
};
getData();
const otherDirectors = [ const otherDirectors = [
{ {
name: "Hu Bin", name: "Hu Bin",

View File

@ -15,17 +15,17 @@
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" /> <img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div> </div>
<div class="directors-page relative z-[-15]" style="width: 311px"> <div class="directors-page relative z-[-15]" style="width: 311px">
<h1 class="page-title">Board of Directors</h1> <h1 class="page-title">{{ t('boarddirectors.title') }}</h1>
<div class="directors-list"> <div class="directors-list">
<div <div
v-for="(director, index) in otherDirectors" v-for="(director, index) in data"
:key="index" :key="index"
class="director-item" class="director-item"
> >
<n-h2 class="director-name">{{ director.name }}</n-h2> <n-h2 class="director-name">{{ director.name }}</n-h2>
<n-text class="director-title">{{ director.title }}</n-text> <n-text class="director-title">{{ director.brief }}</n-text>
<n-p class="director-bio">{{ director.contain }}</n-p> <n-p class="director-bio">{{ director.introduction }}</n-p>
</div> </div>
</div> </div>
</div> </div>
@ -33,6 +33,17 @@
</template> </template>
<script setup> <script setup>
import { boardManagement } from "@/api/auth";
import { ref } from "vue";
import { useI18n } from "vue-i18n";
const { t } = useI18n();
const data = ref([]);
const getData = async () => {
const res = await boardManagement({});
data.value = res.data.item || [];
};
getData();
const otherDirectors = [ const otherDirectors = [
{ {
name: "Hu Bin", name: "Hu Bin",

View File

@ -15,17 +15,17 @@
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" /> <img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div> </div>
<div class="directors-page relative z-[-15]" style="width: 600px"> <div class="directors-page relative z-[-15]" style="width: 600px">
<h1 class="page-title">Board of Directors</h1> <h1 class="page-title">{{ t('boarddirectors.title') }}</h1>
<div class="directors-list"> <div class="directors-list">
<div <div
v-for="(director, index) in otherDirectors" v-for="(director, index) in data"
:key="index" :key="index"
class="director-item" class="director-item"
> >
<n-h2 class="director-name">{{ director.name }}</n-h2> <n-h2 class="director-name">{{ director.name }}</n-h2>
<n-text class="director-title">{{ director.title }}</n-text> <n-text class="director-title">{{ director.brief }}</n-text>
<n-p class="director-bio">{{ director.contain }}</n-p> <n-p class="director-bio">{{ director.introduction }}</n-p>
</div> </div>
</div> </div>
</div> </div>
@ -33,6 +33,17 @@
</template> </template>
<script setup> <script setup>
import { boardManagement } from "@/api/auth";
import { ref } from "vue";
import { useI18n } from "vue-i18n";
const { t } = useI18n();
const data = ref([]);
const getData = async () => {
const res = await boardManagement({});
data.value = res.data.item || [];
};
getData();
const otherDirectors = [ const otherDirectors = [
{ {
name: "Hu Bin", name: "Hu Bin",

View File

@ -1,7 +1,7 @@
<template> <template>
<div class="page-container relative overflow-hidden z-[11] bg-[#ffffff]"> <div class="page-container min-h-[100vh] relative overflow-hidden z-[11] bg-[#ffffff]">
<div <div
class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-[1]" class="fixed w-[100vw] h-[100vh] left-[50%] translate-x-[-50%] z-[1]"
style="width: 900px; pointer-events: none; mix-blend-mode: multiply" style="width: 900px; pointer-events: none; mix-blend-mode: multiply"
> >
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" /> <img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
@ -45,14 +45,39 @@
> >
<n-data-table <n-data-table
:columns="columns" :columns="columns"
:data="annualReports" :data="annualReportsData"
:bordered="false" :bordered="false"
:scrollbar-props="{ :scrollbar-props="{
trigger: 'none', trigger: 'none',
}" }"
/> />
</div> </div>
<!-- 分页器 -->
<div
class="pagination-container flex items-center justify-center mt-[15PX]"
>
<div class="pagination-info text-[#455363] mr-[15PX]">
Displaying {{ startIndex }} - {{ endIndex }} of
{{ state.total }} results
</div>
<n-pagination
v-model:page="state.currentPage"
v-model:page-size="state.pageSize"
show-size-picker
show-quick-jumper
:item-count="state.total"
:page-sizes="[10, 25, 50]"
@update:page="handlePageChange"
@update:page-size="handlePageSizeChange"
>
<!-- <template #prev>
<span> Previous</span>
</template>
<template #next>
<span>Next </span>
</template> -->
</n-pagination>
</div>
<!-- 报告表格 --> <!-- 报告表格 -->
<div class="reports-table" v-if="0"> <div class="reports-table" v-if="0">
<div class="table-header"> <div class="table-header">
@ -90,11 +115,40 @@
</template> </template>
<script setup lang="jsx"> <script setup lang="jsx">
import { ref } from "vue"; import { reactive, ref } from "vue";
import { useI18n } from "vue-i18n"; import { useI18n } from "vue-i18n";
import { NSelect, NDataTable, NPagination, NButton, NIcon } from "naive-ui"; import { NSelect, NDataTable, NPagination, NButton, NIcon } from "naive-ui";
import fileLink from "@/assets/image/content/icon-link.png"; import fileLink from "@/assets/image/content/icon-link.png";
import { annualReport } from "@/api/auth";
const state = reactive({
currentPage: 1,
pageSize: 10,
total: 0,
});
const annualReportsData = ref([]);
//
const handlePageChange = (page) => {
state.currentPage = page;
getListData();
};
//
const handlePageSizeChange = (size) => {
state.pageSize = size;
state.currentPage = 1;
getListData();
};
const getListData = async () => {
const res = await annualReport({
page: state.currentPage,
pageSize: state.pageSize,
});
state.total = res.data.total;
annualReportsData.value = res.data.Item;
};
getListData();
const columns = [ const columns = [
{ {
// title: "File Name", // title: "File Name",
@ -134,7 +188,7 @@ const columns = [
render: (row) => { render: (row) => {
return ( return (
<div> <div>
<a href={row.downloadUrl} class="download-link"> <a href={row.fileUrl} class="download-link">
{/* {t("financialinformation.secfilings.annual_reports.view")} */} {/* {t("financialinformation.secfilings.annual_reports.view")} */}
<img src={fileLink} alt="" class="w-[24PX] h-[24PX]" /> <img src={fileLink} alt="" class="w-[24PX] h-[24PX]" />
</a> </a>
@ -296,7 +350,7 @@ const annualReports = ref([
.financials-container { .financials-container {
// max-width: 1200px; // max-width: 1200px;
margin: 0 auto; margin: 0 auto;
padding-bottom: 60PX; padding-bottom: 60px;
// padding: 20px; // padding: 20px;
} }
@ -304,19 +358,18 @@ const annualReports = ref([
// font-size: 40px; // font-size: 40px;
// text-align: center; // text-align: center;
margin-bottom: 60px; margin-bottom: 60px;
margin-top: 60PX margin-top: 60px;
;
color: #333; color: #333;
position: relative; position: relative;
} }
.financials-title::before { .financials-title::before {
content: ""; content: "";
position: absolute; position: absolute;
top: -5PX; top: -5px;
bottom: -10px; bottom: -10px;
width: 60PX; width: 60px;
height: 5PX; height: 5px;
background-color: #FF7BAC; background-color: #ff7bac;
} }
.section { .section {

View File

@ -1,7 +1,7 @@
<template> <template>
<div class="page-container relative overflow-hidden z-[11] bg-[#ffffff]"> <div class="page-container min-h-[100vh] relative overflow-hidden z-[11] bg-[#ffffff]">
<div <div
class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-[1]" class="fixed w-[100vw] h-[100vh] left-[50%] translate-x-[-50%] z-[1]"
style="width: 900px; pointer-events: none; mix-blend-mode: multiply" style="width: 900px; pointer-events: none; mix-blend-mode: multiply"
> >
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" /> <img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
@ -45,14 +45,39 @@
> >
<n-data-table <n-data-table
:columns="columns" :columns="columns"
:data="annualReports" :data="annualReportsData"
:bordered="false" :bordered="false"
:scrollbar-props="{ :scrollbar-props="{
trigger: 'none', trigger: 'none',
}" }"
/> />
</div> </div>
<!-- 分页器 -->
<div
class="pagination-container flex items-center justify-center mt-[15PX]"
>
<div class="pagination-info text-[#455363] mr-[15PX]">
Displaying {{ startIndex }} - {{ endIndex }} of
{{ state.total }} results
</div>
<n-pagination
v-model:page="state.currentPage"
v-model:page-size="state.pageSize"
show-size-picker
show-quick-jumper
:item-count="state.total"
:page-sizes="[10, 25, 50]"
@update:page="handlePageChange"
@update:page-size="handlePageSizeChange"
>
<!-- <template #prev>
<span> Previous</span>
</template>
<template #next>
<span>Next </span>
</template> -->
</n-pagination>
</div>
<!-- 报告表格 --> <!-- 报告表格 -->
<div class="reports-table" v-if="0"> <div class="reports-table" v-if="0">
<div class="table-header"> <div class="table-header">
@ -90,11 +115,40 @@
</template> </template>
<script setup lang="jsx"> <script setup lang="jsx">
import { ref } from "vue"; import { reactive, ref } from "vue";
import { useI18n } from "vue-i18n"; import { useI18n } from "vue-i18n";
import { NSelect, NDataTable, NPagination, NButton, NIcon } from "naive-ui"; import { NSelect, NDataTable, NPagination, NButton, NIcon } from "naive-ui";
import fileLink from "@/assets/image/content/icon-link.png"; import fileLink from "@/assets/image/content/icon-link.png";
import { annualReport } from "@/api/auth";
const state = reactive({
currentPage: 1,
pageSize: 10,
total: 0,
});
const annualReportsData = ref([]);
//
const handlePageChange = (page) => {
state.currentPage = page;
getListData();
};
//
const handlePageSizeChange = (size) => {
state.pageSize = size;
state.currentPage = 1;
getListData();
};
const getListData = async () => {
const res = await annualReport({
page: state.currentPage,
pageSize: state.pageSize,
});
state.total = res.data.total;
annualReportsData.value = res.data.Item;
};
getListData();
const columns = [ const columns = [
{ {
// title: "File Name", // title: "File Name",
@ -134,7 +188,7 @@ const columns = [
render: (row) => { render: (row) => {
return ( return (
<div> <div>
<a href={row.downloadUrl} class="download-link"> <a href={row.fileUrl} class="download-link">
{/* {t("financialinformation.secfilings.annual_reports.view")} */} {/* {t("financialinformation.secfilings.annual_reports.view")} */}
<img src={fileLink} alt="" class="w-[24PX] h-[24PX]" /> <img src={fileLink} alt="" class="w-[24PX] h-[24PX]" />
</a> </a>
@ -296,7 +350,7 @@ const annualReports = ref([
.financials-container { .financials-container {
// max-width: 1200px; // max-width: 1200px;
margin: 0 auto; margin: 0 auto;
padding-bottom: 60PX; padding-bottom: 60px;
// padding: 20px; // padding: 20px;
} }
@ -304,19 +358,18 @@ const annualReports = ref([
// font-size: 40px; // font-size: 40px;
// text-align: center; // text-align: center;
margin-bottom: 60px; margin-bottom: 60px;
margin-top: 60PX margin-top: 60px;
;
color: #333; color: #333;
position: relative; position: relative;
} }
.financials-title::before { .financials-title::before {
content: ""; content: "";
position: absolute; position: absolute;
top: -5PX; top: -5px;
bottom: -10px; bottom: -10px;
width: 60PX; width: 60px;
height: 5PX; height: 5px;
background-color: #FF7BAC; background-color: #ff7bac;
} }
.section { .section {

View File

@ -15,24 +15,24 @@
</div> </div>
<div class="financials-container w-[318PX] relative z-99"> <div class="financials-container w-[318PX] relative z-99">
<!-- 标题 --> <!-- 标题 -->
<div class="financials-title text-left font-bold text-[40PX] ml-[20PX]"> <div class="financials-title text-left font-bold text-[36PX] ml-[20PX]">
{{ t("financialinformation.secfilings.title") }} {{ t("financialinformation.secfilings.title") }}
</div> </div>
<!-- 公司财务概览 --> <!-- 公司财务概览 -->
<section class="section"> <section class="section">
<div class="section-title font-bold pl-[20PX] text-[20PX]"> <div class="section-title font-bold pl-[20PX] text-[18PX]">
{{ t("financialinformation.secfilings.overview.title") }} {{ t("financialinformation.secfilings.overview.title") }}
</div> </div>
<p <p
class="overview-text pl-[20PX] text-[#455363] text-[14PX]" class="overview-text pl-[20PX] text-[#455363] text-[13PX]"
v-html="t('financialinformation.secfilings.overview.desc')" v-html="t('financialinformation.secfilings.overview.desc')"
></p> ></p>
</section> </section>
<!-- 年度报告 --> <!-- 年度报告 -->
<section class="section"> <section class="section">
<div class="section-title font-bold pl-[20PX] text-[20PX]"> <div class="section-title font-bold pl-[20PX] text-[18PX]">
{{ t("financialinformation.secfilings.annual_reports.title") }} {{ t("financialinformation.secfilings.annual_reports.title") }}
</div> </div>
<div <div
@ -45,13 +45,40 @@
> >
<n-data-table <n-data-table
:columns="columns" :columns="columns"
:data="annualReports" :data="annualReportsData"
:bordered="false" :bordered="false"
:scrollbar-props="{ :scrollbar-props="{
trigger: 'none', trigger: 'none',
}" }"
/> />
</div> </div>
<!-- 分页器 -->
<div
class="pagination-container flex flex-col items-center justify-center mt-[15PX]"
>
<n-pagination
v-model:page="state.currentPage"
v-model:page-size="state.pageSize"
show-size-picker
show-quick-jumper
:item-count="state.total"
:page-sizes="[10, 25, 50]"
:page-slot="3"
@update:page="handlePageChange"
@update:page-size="handlePageSizeChange"
>
<!-- <template #prev>
<span> Previous</span>
</template>
<template #next>
<span>Next </span>
</template> -->
</n-pagination>
<div class="pagination-info text-[#455363] mr-[15PX]">
Displaying {{ startIndex }} - {{ endIndex }} of
{{ state.total }} results
</div>
</div>
<!-- 报告表格 --> <!-- 报告表格 -->
<div class="reports-table" v-if="0"> <div class="reports-table" v-if="0">
@ -90,11 +117,39 @@
</template> </template>
<script setup lang="jsx"> <script setup lang="jsx">
import { ref } from "vue"; import { reactive, ref } from "vue";
import { useI18n } from "vue-i18n"; import { useI18n } from "vue-i18n";
import { NSelect, NDataTable, NPagination, NButton, NIcon } from "naive-ui"; import { NSelect, NDataTable, NPagination, NButton, NIcon } from "naive-ui";
import fileLink from "@/assets/image/content/icon-link.png"; import fileLink from "@/assets/image/content/icon-link.png";
import { annualReport } from "@/api/auth";
const state = reactive({
currentPage: 1,
pageSize: 10,
total: 0,
});
const annualReportsData = ref([]);
//
const handlePageChange = (page) => {
state.currentPage = page;
getListData();
};
//
const handlePageSizeChange = (size) => {
state.pageSize = size;
state.currentPage = 1;
getListData();
};
const getListData = async () => {
const res = await annualReport({
page: state.currentPage,
pageSize: state.pageSize,
});
state.total = res.data.total;
annualReportsData.value = res.data.Item;
};
getListData();
const columns = [ const columns = [
{ {
// title: "File Name", // title: "File Name",
@ -299,7 +354,7 @@ const annualReports = ref([
.financials-container { .financials-container {
// max-width: 1200px; // max-width: 1200px;
margin: 0 auto; margin: 0 auto;
padding-bottom: 60PX; padding-bottom: 60px;
// padding: 20px; // padding: 20px;
} }
@ -307,8 +362,7 @@ const annualReports = ref([
// font-size: 40px; // font-size: 40px;
// text-align: center; // text-align: center;
margin-bottom: 60px; margin-bottom: 60px;
margin-top: 60PX margin-top: 60px;
;
color: #333; color: #333;
position: relative; position: relative;
} }
@ -316,10 +370,10 @@ const annualReports = ref([
content: ""; content: "";
position: absolute; position: absolute;
top: -5PX; top: -5PX;
bottom: -10px; bottom: -10PX;
width: 60PX; width: 60PX;
height: 5PX; height: 5PX;
background-color: #FF7BAC; background-color: #ff7bac;
} }
.section { .section {
@ -421,4 +475,3 @@ const annualReports = ref([
} }
} }
</style> </style>

View File

@ -1,7 +1,7 @@
<template> <template>
<div class="page-container relative overflow-hidden z-[11] bg-[#ffffff]"> <div class="page-container min-h-[100vh] relative overflow-hidden z-[11] bg-[#ffffff]">
<div <div
class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-[1]" class="fixed w-[100vw] h-[100vh] left-[50%] translate-x-[-50%] z-[1]"
style="width: 618px; pointer-events: none; mix-blend-mode: multiply" style="width: 618px; pointer-events: none; mix-blend-mode: multiply"
> >
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" /> <img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
@ -25,7 +25,7 @@
{{ t("financialinformation.secfilings.overview.title") }} {{ t("financialinformation.secfilings.overview.title") }}
</div> </div>
<p <p
class="overview-text pl-[20PX] text-[#455363] text-[14PX]" class="overview-text pl-[20PX] text-[#455363] text-[16PX]"
v-html="t('financialinformation.secfilings.overview.desc')" v-html="t('financialinformation.secfilings.overview.desc')"
></p> ></p>
</section> </section>
@ -45,14 +45,39 @@
> >
<n-data-table <n-data-table
:columns="columns" :columns="columns"
:data="annualReports" :data="annualReportsData"
:bordered="false" :bordered="false"
:scrollbar-props="{ :scrollbar-props="{
trigger: 'none', trigger: 'none',
}" }"
/> />
</div> </div>
<!-- 分页器 -->
<div
class="pagination-container flex items-center justify-center mt-[15PX]"
>
<div class="pagination-info text-[#455363] mr-[15PX]">
Displaying {{ startIndex }} - {{ endIndex }} of
{{ state.total }} results
</div>
<n-pagination
v-model:page="state.currentPage"
v-model:page-size="state.pageSize"
show-size-picker
show-quick-jumper
:item-count="state.total"
:page-sizes="[10, 25, 50]"
@update:page="handlePageChange"
@update:page-size="handlePageSizeChange"
>
<!-- <template #prev>
<span> Previous</span>
</template>
<template #next>
<span>Next </span>
</template> -->
</n-pagination>
</div>
<!-- 报告表格 --> <!-- 报告表格 -->
<div class="reports-table" v-if="0"> <div class="reports-table" v-if="0">
<div class="table-header"> <div class="table-header">
@ -90,11 +115,40 @@
</template> </template>
<script setup lang="jsx"> <script setup lang="jsx">
import { ref } from "vue"; import { reactive, ref } from "vue";
import { useI18n } from "vue-i18n"; import { useI18n } from "vue-i18n";
import { NSelect, NDataTable, NPagination, NButton, NIcon } from "naive-ui"; import { NSelect, NDataTable, NPagination, NButton, NIcon } from "naive-ui";
import fileLink from "@/assets/image/content/icon-link.png"; import fileLink from "@/assets/image/content/icon-link.png";
import { annualReport } from "@/api/auth";
const state = reactive({
currentPage: 1,
pageSize: 10,
total: 0,
});
const annualReportsData = ref([]);
//
const handlePageChange = (page) => {
state.currentPage = page;
getListData();
};
//
const handlePageSizeChange = (size) => {
state.pageSize = size;
state.currentPage = 1;
getListData();
};
const getListData = async () => {
const res = await annualReport({
page: state.currentPage,
pageSize: state.pageSize,
});
state.total = res.data.total;
annualReportsData.value = res.data.Item;
};
getListData();
const columns = [ const columns = [
{ {
// title: "File Name", // title: "File Name",
@ -134,7 +188,7 @@ const columns = [
render: (row) => { render: (row) => {
return ( return (
<div> <div>
<a href={row.downloadUrl} class="download-link"> <a href={row.fileUrl} class="download-link">
{/* {t("financialinformation.secfilings.annual_reports.view")} */} {/* {t("financialinformation.secfilings.annual_reports.view")} */}
<img src={fileLink} alt="" class="w-[24PX] h-[24PX]" /> <img src={fileLink} alt="" class="w-[24PX] h-[24PX]" />
</a> </a>
@ -296,7 +350,7 @@ const annualReports = ref([
.financials-container { .financials-container {
// max-width: 1200px; // max-width: 1200px;
margin: 0 auto; margin: 0 auto;
padding-bottom: 60PX; padding-bottom: 60px;
// padding: 20px; // padding: 20px;
} }
@ -304,8 +358,7 @@ const annualReports = ref([
// font-size: 40px; // font-size: 40px;
// text-align: center; // text-align: center;
margin-bottom: 60px; margin-bottom: 60px;
margin-top: 60PX margin-top: 60px;
;
color: #333; color: #333;
position: relative; position: relative;
} }
@ -313,10 +366,10 @@ const annualReports = ref([
content: ""; content: "";
position: absolute; position: absolute;
top: -5PX; top: -5PX;
bottom: -10px; bottom: -10PX;
width: 60PX; width: 60PX;
height: 5PX; height: 5PX;
background-color: #FF7BAC; background-color: #ff7bac;
} }
.section { .section {
@ -418,4 +471,3 @@ const annualReports = ref([
} }
} }
</style> </style>

View File

@ -15,12 +15,12 @@
</div> </div>
<div class="sec-filings-container relative z-10 !w-[900PX] !p-0 !pb-[60PX]"> <div class="sec-filings-container relative z-10 !w-[900PX] !p-0 !pb-[60PX]">
<!-- 标题 --> <!-- 标题 -->
<div class="page-title ml-[30PX] mt-[50PX]">SEC Filings</div> <div class="page-title ml-[30PX] mt-[50PX]">{{ $t("SECFILINGS.TITLE") }}</div>
<!-- 筛选器 --> <!-- 筛选器 -->
<div class="filters flex px-[30PX]"> <div class="filters flex px-[30PX]">
<div class="filter-group flex-1 flex"> <div class="filter-group flex-1 flex">
<label class="filter-label">Filing year</label> <label class="filter-label">{{ $t("SECFILINGS.FILTERlABEL1") }}</label>
<n-select <n-select
v-model:value="state.selectedYear" v-model:value="state.selectedYear"
:options="state.yearOptions" :options="state.yearOptions"
@ -32,7 +32,7 @@
</div> </div>
<div class="filter-group flex-1 flex"> <div class="filter-group flex-1 flex">
<label class="filter-label">Items per page:</label> <label class="filter-label">{{ $t("SECFILINGS.FILTERlABEL2") }}</label>
<n-select <n-select
v-model:value="state.pageSize" v-model:value="state.pageSize"
:options="state.pageSizeOptions" :options="state.pageSizeOptions"

View File

@ -15,12 +15,12 @@
</div> </div>
<div class="sec-filings-container relative z-10 !w-[900PX] !p-0 !pb-[60PX]"> <div class="sec-filings-container relative z-10 !w-[900PX] !p-0 !pb-[60PX]">
<!-- 标题 --> <!-- 标题 -->
<div class="page-title ml-[30PX] mt-[50PX]">SEC Filings</div> <div class="page-title ml-[30PX] mt-[50PX]">{{ $t("SECFILINGS.TITLE") }}</div>
<!-- 筛选器 --> <!-- 筛选器 -->
<div class="filters flex px-[30PX]"> <div class="filters flex px-[30PX]">
<div class="filter-group flex-1 flex"> <div class="filter-group flex-1 flex">
<label class="filter-label">Filing year</label> <label class="filter-label">{{ $t("SECFILINGS.FILTERlABEL1") }}</label>
<n-select <n-select
v-model:value="state.selectedYear" v-model:value="state.selectedYear"
:options="state.yearOptions" :options="state.yearOptions"
@ -32,7 +32,7 @@
</div> </div>
<div class="filter-group flex-1 flex"> <div class="filter-group flex-1 flex">
<label class="filter-label">Items per page:</label> <label class="filter-label">{{ $t("SECFILINGS.FILTERlABEL2") }}</label>
<n-select <n-select
v-model:value="state.pageSize" v-model:value="state.pageSize"
:options="state.pageSizeOptions" :options="state.pageSizeOptions"

View File

@ -15,12 +15,12 @@
</div> </div>
<div class="sec-filings-container relative z-10 !w-[311PX] !p-0 !pb-[60PX]"> <div class="sec-filings-container relative z-10 !w-[311PX] !p-0 !pb-[60PX]">
<!-- 标题 --> <!-- 标题 -->
<div class="page-title ml-[30PX] mt-[50PX]">SEC Filings</div> <div class="page-title ml-[30PX] mt-[50PX]">{{ $t("SECFILINGS.TITLE") }}</div>
<!-- 筛选器 --> <!-- 筛选器 -->
<div class="filters flex px-[30PX] flex-col"> <div class="filters flex px-[30PX] flex-col">
<div class="filter-group flex-1 flex justify-between"> <div class="filter-group flex-1 flex justify-between">
<label class="filter-label">Filing year</label> <label class="filter-label">{{ $t("SECFILINGS.FILTERlABEL1") }}</label>
<n-select <n-select
v-model:value="state.selectedYear" v-model:value="state.selectedYear"
:options="state.yearOptions" :options="state.yearOptions"
@ -32,7 +32,7 @@
</div> </div>
<div class="filter-group flex-1 flex justify-between"> <div class="filter-group flex-1 flex justify-between">
<label class="filter-label">Items per page</label> <label class="filter-label">{{ $t("SECFILINGS.FILTERlABEL2") }}</label>
<n-select <n-select
v-model:value="state.pageSize" v-model:value="state.pageSize"
:options="state.pageSizeOptions" :options="state.pageSizeOptions"

View File

@ -15,12 +15,12 @@
</div> </div>
<div class="sec-filings-container relative z-10 !w-[618PX] !p-0 !pb-[60PX]"> <div class="sec-filings-container relative z-10 !w-[618PX] !p-0 !pb-[60PX]">
<!-- 标题 --> <!-- 标题 -->
<div class="page-title ml-[30PX] mt-[50PX]">SEC Filings</div> <div class="page-title ml-[30PX] mt-[50PX]">{{ $t("SECFILINGS.TITLE") }}</div>
<!-- 筛选器 --> <!-- 筛选器 -->
<div class="filters flex px-[30PX] flex-col"> <div class="filters flex px-[30PX] flex-col">
<div class="filter-group flex-1 flex justify-between"> <div class="filter-group flex-1 flex justify-between">
<label class="filter-label">Filing year</label> <label class="filter-label">{{ $t("SECFILINGS.FILTERlABEL1") }}</label>
<n-select <n-select
v-model:value="state.selectedYear" v-model:value="state.selectedYear"
:options="state.yearOptions" :options="state.yearOptions"
@ -32,7 +32,7 @@
</div> </div>
<div class="filter-group flex-1 flex justify-between"> <div class="filter-group flex-1 flex justify-between">
<label class="filter-label">Items per page:</label> <label class="filter-label">{{ $t("SECFILINGS.FILTERlABEL2") }}</label>
<n-select <n-select
v-model:value="state.pageSize" v-model:value="state.pageSize"
:options="state.pageSizeOptions" :options="state.pageSizeOptions"

View File

@ -20,7 +20,7 @@
</div> </div>
<div class="w-[900PX] mx-auto relative z-11"> <div class="w-[900PX] mx-auto relative z-11">
<div class="title mb-[50px] text-center text-left"> <div class="title mb-[50px] text-center text-left">
<h1 style="font-size: 40px; margin-top: 60px">Governance</h1> <h1 style="font-size: 40px; margin-top: 60px">{{ $t("GOVERNANCE.TITLE") }}</h1>
</div> </div>
<div <div
v-for="(item, index) in state.list" v-for="(item, index) in state.list"

View File

@ -20,7 +20,7 @@
</div> </div>
<div class="w-[900PX] mx-auto relative z-11"> <div class="w-[900PX] mx-auto relative z-11">
<div class="title mb-[50px] text-center text-left"> <div class="title mb-[50px] text-center text-left">
<h1 style="font-size: 40px; margin-top: 60px">Governance</h1> <h1 style="font-size: 40px; margin-top: 60px">{{ $t("GOVERNANCE.TITLE") }}</h1>
</div> </div>
<div <div
v-for="(item, index) in state.list" v-for="(item, index) in state.list"

View File

@ -20,7 +20,7 @@
</div> </div>
<div class="w-[327PX] mx-auto relative z-11"> <div class="w-[327PX] mx-auto relative z-11">
<div class="title mb-[50px] text-center text-left"> <div class="title mb-[50px] text-center text-left">
<h1 style="font-size: 24px; margin-top: 60px">Governance</h1> <h1 style="font-size: 24px; margin-top: 60px">{{ $t("GOVERNANCE.TITLE") }}</h1>
</div> </div>
<div <div
v-for="(item, index) in state.list" v-for="(item, index) in state.list"

View File

@ -20,7 +20,7 @@
</div> </div>
<div class="w-[618PX] mx-auto relative z-11"> <div class="w-[618PX] mx-auto relative z-11">
<div class="title mb-[50px] text-center text-left"> <div class="title mb-[50px] text-center text-left">
<h1 style="font-size: 40px; margin-top: 60px">Governance</h1> <h1 style="font-size: 40px; margin-top: 60px">{{ $t("GOVERNANCE.TITLE") }}</h1>
</div> </div>
<div <div
v-for="(item, index) in state.list" v-for="(item, index) in state.list"

View File

@ -28,13 +28,12 @@
</div> </div>
<div class="relative z-10"> <div class="relative z-10">
<!-- 标题区 --> <!-- 标题区 -->
<div class="company-overview w-[900PX] pb-[130PX] !mt-[50PX]"> <div class="company-overview h-[550PX] w-[900PX] pb-[130PX] !mt-[50PX]">
<div class="hero-section"> <div class="hero-section">
<!-- <transition name="fade-up" appear> --> <!-- <transition name="fade-up" appear> -->
<n-h1 class="hero-title text-[40PX] min-h-[168PX]" <n-h1 class="hero-title text-[40PX] min-h-[168PX]">{{
>FiEE, Inc. has a team of capable senior management with extensive t("MANAGEMENT.TITLE")
professional experience</n-h1 }}</n-h1>
>
<!-- </transition> --> <!-- </transition> -->
</div> </div>
</div> </div>
@ -44,22 +43,32 @@
<div class="leadership-grid"> <div class="leadership-grid">
<!-- 每个高管卡片 --> <!-- 每个高管卡片 -->
<div <div
v-for="(leader, index) in leadershipTeam" v-for="(leader, index) in data"
:key="index" :key="index"
class="leader-card mt-[20PX]" class="leader-card mt-[20PX]"
:style="{ '--delay': index * 0.2 + 's' }" :style="{ '--delay': index * 0.2 + 's' }"
> >
<div> <div>
<div class="flex items-center"> <div class="flex items-center">
<img
v-if="leader.image"
:src="leader.image"
alt=""
class="w-[58PX] h-[58PX] rounded-[50%] ml-[12PX]"
/>
<div <div
v-else
class="w-[58PX] h-[58PX] rounded-[50%] bg-[#FF7BAC] text-[#fff] flex justify-center items-center text-[20PX] font-600" class="w-[58PX] h-[58PX] rounded-[50%] bg-[#FF7BAC] text-[#fff] flex justify-center items-center text-[20PX] font-600"
> >
{{ getInitials(leader.name) }} {{ getInitials(leader.name) }}
<!-- {{ getInitials(leader.name) }} -->
</div> </div>
<div class="flex flex-col justify-between ml-[12PX]"> <div class="flex flex-col justify-between ml-[12PX]">
<h2 class="my-0">{{ leader.name }}</h2> <h2 class="my-0">{{ leader.name }}</h2>
<div class="text-[#FF7BAC] text-[16PX]"> <div class="text-[#FF7BAC] text-[16PX]">
{{ leader.position }} <!-- {{ leader.position }} -->
{{ leader.brief }}
</div> </div>
</div> </div>
</div> </div>
@ -67,6 +76,14 @@
<!-- 卡片下半部 --> <!-- 卡片下半部 -->
<div> <div>
<div class="content-section">
<p>
{{ leader.introduction }}
</p>
</div>
</div>
<!-- <div>
<div <div
class="content-section" class="content-section"
v-for="(content, cIndex) in leader.content" v-for="(content, cIndex) in leader.content"
@ -74,7 +91,7 @@
> >
<p>{{ content }}</p> <p>{{ content }}</p>
</div> </div>
</div> </div> -->
</div> </div>
</div> </div>
</main> </main>
@ -85,6 +102,15 @@
<script setup> <script setup>
import { useI18n } from "vue-i18n"; import { useI18n } from "vue-i18n";
import { computed } from "vue"; import { computed } from "vue";
import { departmentManagement } from "@/api/auth";
import { ref } from "vue";
const data = ref([]);
const getData = async () => {
const res = await departmentManagement({});
data.value = res.data.item || [];
};
getData();
const { t } = useI18n(); const { t } = useI18n();
@ -132,7 +158,7 @@ const getInitials = (name) => {
background-size: 400% 400%; background-size: 400% 400%;
/* animation: gradientBG 15s ease infinite; */ /* animation: gradientBG 15s ease infinite; */
color: #000; color: #000;
padding: 120PX 0; padding: 120px 0;
text-align: center; text-align: center;
border-radius: 8px; border-radius: 8px;
} }

View File

@ -28,13 +28,12 @@
</div> </div>
<div class="relative z-10"> <div class="relative z-10">
<!-- 标题区 --> <!-- 标题区 -->
<div class="company-overview w-[900PX] pb-[130PX] !mt-[50PX]"> <div class="company-overview h-[550PX] w-[900PX] pb-[130PX] !mt-[50PX]">
<div class="hero-section"> <div class="hero-section">
<!-- <transition name="fade-up" appear> --> <!-- <transition name="fade-up" appear> -->
<n-h1 class="hero-title text-[40PX] min-h-[168PX]" <n-h1 class="hero-title text-[40PX] min-h-[168PX]">{{
>FiEE, Inc. has a team of capable senior management with extensive t("MANAGEMENT.TITLE")
professional experience</n-h1 }}</n-h1>
>
<!-- </transition> --> <!-- </transition> -->
</div> </div>
</div> </div>
@ -44,22 +43,32 @@
<div class="leadership-grid"> <div class="leadership-grid">
<!-- 每个高管卡片 --> <!-- 每个高管卡片 -->
<div <div
v-for="(leader, index) in leadershipTeam" v-for="(leader, index) in data"
:key="index" :key="index"
class="leader-card mt-[20PX]" class="leader-card mt-[20PX]"
:style="{ '--delay': index * 0.2 + 's' }" :style="{ '--delay': index * 0.2 + 's' }"
> >
<div> <div>
<div class="flex items-center"> <div class="flex items-center">
<img
v-if="leader.image"
:src="leader.image"
alt=""
class="w-[58PX] h-[58PX] rounded-[50%] ml-[12PX]"
/>
<div <div
v-else
class="w-[58PX] h-[58PX] rounded-[50%] bg-[#FF7BAC] text-[#fff] flex justify-center items-center text-[20PX] font-600" class="w-[58PX] h-[58PX] rounded-[50%] bg-[#FF7BAC] text-[#fff] flex justify-center items-center text-[20PX] font-600"
> >
{{ getInitials(leader.name) }} {{ getInitials(leader.name) }}
<!-- {{ getInitials(leader.name) }} -->
</div> </div>
<div class="flex flex-col justify-between ml-[12PX]"> <div class="flex flex-col justify-between ml-[12PX]">
<h2 class="my-0">{{ leader.name }}</h2> <h2 class="my-0">{{ leader.name }}</h2>
<div class="text-[#FF7BAC] text-[16PX]"> <div class="text-[#FF7BAC] text-[16PX]">
{{ leader.position }} <!-- {{ leader.position }} -->
{{ leader.brief }}
</div> </div>
</div> </div>
</div> </div>
@ -67,6 +76,14 @@
<!-- 卡片下半部 --> <!-- 卡片下半部 -->
<div> <div>
<div class="content-section">
<p>
{{ leader.introduction }}
</p>
</div>
</div>
<!-- <div>
<div <div
class="content-section" class="content-section"
v-for="(content, cIndex) in leader.content" v-for="(content, cIndex) in leader.content"
@ -74,7 +91,7 @@
> >
<p>{{ content }}</p> <p>{{ content }}</p>
</div> </div>
</div> </div> -->
</div> </div>
</div> </div>
</main> </main>
@ -85,6 +102,15 @@
<script setup> <script setup>
import { useI18n } from "vue-i18n"; import { useI18n } from "vue-i18n";
import { computed } from "vue"; import { computed } from "vue";
import { departmentManagement } from "@/api/auth";
import { ref } from "vue";
const data = ref([]);
const getData = async () => {
const res = await departmentManagement({});
data.value = res.data.item || [];
};
getData();
const { t } = useI18n(); const { t } = useI18n();
@ -132,7 +158,7 @@ const getInitials = (name) => {
background-size: 400% 400%; background-size: 400% 400%;
/* animation: gradientBG 15s ease infinite; */ /* animation: gradientBG 15s ease infinite; */
color: #000; color: #000;
padding: 120PX 0; padding: 120px 0;
text-align: center; text-align: center;
border-radius: 8px; border-radius: 8px;
} }

View File

@ -4,7 +4,7 @@
class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-1" class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-1"
style="width: 320px; pointer-events: none; mix-blend-mode: multiply" style="width: 320px; pointer-events: none; mix-blend-mode: multiply"
> >
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" /> <img src="@/assets/image/content/line375.png" class="w-[100%]" alt="" />
</div> </div>
<div class="w-[100%] h-[680PX] z-[] top-0 absolute"> <div class="w-[100%] h-[680PX] z-[] top-0 absolute">
<div class="relative w-[100%] h-[100%]"> <div class="relative w-[100%] h-[100%]">
@ -28,13 +28,13 @@
</div> </div>
<div class="relative z-10"> <div class="relative z-10">
<!-- 标题区 --> <!-- 标题区 -->
<div class="company-overview w-[311PX] pb-[160PX] !mt-[150PX]"> <div class="company-overview w-[311PX] h-[500PX] !mt-[250PX]">
<div class="hero-section"> <div class="hero-section">
<!-- <transition name="fade-up" appear> --> <!-- <transition name="fade-up" appear> -->
<n-h1 class="hero-title text-[24PX] min-h-[168PX]" <n-h1 class="hero-title text-[24PX]"
>FiEE, Inc. has a team of capable senior management with extensive >{{
professional experience</n-h1 t("MANAGEMENT.TITLE")
> }}</n-h1>
<!-- </transition> --> <!-- </transition> -->
</div> </div>
</div> </div>
@ -44,22 +44,31 @@
<div class="leadership-grid"> <div class="leadership-grid">
<!-- 每个高管卡片 --> <!-- 每个高管卡片 -->
<div <div
v-for="(leader, index) in leadershipTeam" v-for="(leader, index) in data"
:key="index" :key="index"
class="leader-card mt-[20PX]" class="leader-card mt-[20PX]"
:style="{ '--delay': index * 0.2 + 's' }" :style="{ '--delay': index * 0.2 + 's' }"
> >
<div> <div>
<div class="flex items-center"> <div class="flex items-center">
<img
v-if="leader.image"
:src="leader.image"
alt=""
class="w-[58PX] h-[58PX] rounded-[50%] ml-[12PX]"
/>
<div <div
class="w-[58PX] h-[58PX] rounded-[50%] bg-[#FF7BAC] text-[#fff] flex justify-center items-center text-[20PX] font-600 flex-shrink-0" v-else
class="w-[58PX] h-[58PX] rounded-[50%] bg-[#FF7BAC] text-[#fff] flex justify-center items-center text-[20PX] font-600"
> >
{{ getInitials(leader.name) }} {{ getInitials(leader.name) }}
<!-- {{ getInitials(leader.name) }} -->
</div> </div>
<div class="flex flex-col justify-between ml-[12PX]"> <div class="flex flex-col justify-between ml-[12PX]">
<h2 class="my-0">{{ leader.name }}</h2> <h2 class="my-0">{{ leader.name }}</h2>
<div class="text-[#FF7BAC] text-[16PX]"> <div class="text-[#FF7BAC] text-[16PX]">
{{ leader.position }} <!-- {{ leader.position }} -->
{{ leader.brief }}
</div> </div>
</div> </div>
</div> </div>
@ -67,6 +76,13 @@
<!-- 卡片下半部 --> <!-- 卡片下半部 -->
<div> <div>
<div class="content-section">
<p>
{{ leader.introduction }}
</p>
</div>
</div>
<!-- <div>
<div <div
class="content-section" class="content-section"
v-for="(content, cIndex) in leader.content" v-for="(content, cIndex) in leader.content"
@ -74,7 +90,7 @@
> >
<p>{{ content }}</p> <p>{{ content }}</p>
</div> </div>
</div> </div> -->
</div> </div>
</div> </div>
</main> </main>
@ -85,6 +101,15 @@
<script setup> <script setup>
import { useI18n } from "vue-i18n"; import { useI18n } from "vue-i18n";
import { computed } from "vue"; import { computed } from "vue";
import { departmentManagement } from "@/api/auth";
import { ref } from "vue";
const data = ref([]);
const getData = async () => {
const res = await departmentManagement({});
data.value = res.data.item || [];
};
getData();
const { t } = useI18n(); const { t } = useI18n();
@ -132,7 +157,7 @@ const getInitials = (name) => {
background-size: 400% 400%; background-size: 400% 400%;
/* animation: gradientBG 15s ease infinite; */ /* animation: gradientBG 15s ease infinite; */
color: #000; color: #000;
padding: 120PX 0; /* padding: 120PX 0; */
text-align: center; text-align: center;
border-radius: 8px; border-radius: 8px;
} }

View File

@ -4,7 +4,7 @@
class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-1" class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-1"
style="width: 620px; pointer-events: none; mix-blend-mode: multiply" style="width: 620px; pointer-events: none; mix-blend-mode: multiply"
> >
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" /> <img src="@/assets/image/content/line768.png" class="w-[100%]" alt="" />
</div> </div>
<div class="w-[100%] h-[550PX] z-[] top-0 absolute"> <div class="w-[100%] h-[550PX] z-[] top-0 absolute">
<div class="relative w-[100%] h-[100%]"> <div class="relative w-[100%] h-[100%]">
@ -32,9 +32,9 @@
<div class="hero-section"> <div class="hero-section">
<!-- <transition name="fade-up" appear> --> <!-- <transition name="fade-up" appear> -->
<n-h1 class="hero-title text-[32PX] min-h-[168PX]" <n-h1 class="hero-title text-[32PX] min-h-[168PX]"
>FiEE, Inc. has a team of capable senior management with extensive >{{
professional experience</n-h1 t("MANAGEMENT.TITLE")
> }}</n-h1>
<!-- </transition> --> <!-- </transition> -->
</div> </div>
</div> </div>
@ -44,22 +44,31 @@
<div class="leadership-grid"> <div class="leadership-grid">
<!-- 每个高管卡片 --> <!-- 每个高管卡片 -->
<div <div
v-for="(leader, index) in leadershipTeam" v-for="(leader, index) in data"
:key="index" :key="index"
class="leader-card mt-[20PX]" class="leader-card mt-[20PX]"
:style="{ '--delay': index * 0.2 + 's' }" :style="{ '--delay': index * 0.2 + 's' }"
> >
<div> <div>
<div class="flex items-center"> <div class="flex items-center">
<img
v-if="leader.image"
:src="leader.image"
alt=""
class="w-[58PX] h-[58PX] rounded-[50%] ml-[12PX]"
/>
<div <div
v-else
class="w-[58PX] h-[58PX] rounded-[50%] bg-[#FF7BAC] text-[#fff] flex justify-center items-center text-[20PX] font-600" class="w-[58PX] h-[58PX] rounded-[50%] bg-[#FF7BAC] text-[#fff] flex justify-center items-center text-[20PX] font-600"
> >
{{ getInitials(leader.name) }} {{ getInitials(leader.name) }}
<!-- {{ getInitials(leader.name) }} -->
</div> </div>
<div class="flex flex-col justify-between ml-[12PX]"> <div class="flex flex-col justify-between ml-[12PX]">
<h2 class="my-0">{{ leader.name }}</h2> <h2 class="my-0">{{ leader.name }}</h2>
<div class="text-[#FF7BAC] text-[16PX]"> <div class="text-[#FF7BAC] text-[16PX]">
{{ leader.position }} <!-- {{ leader.position }} -->
{{ leader.brief }}
</div> </div>
</div> </div>
</div> </div>
@ -67,6 +76,13 @@
<!-- 卡片下半部 --> <!-- 卡片下半部 -->
<div> <div>
<div class="content-section">
<p>
{{ leader.introduction }}
</p>
</div>
</div>
<!-- <div>
<div <div
class="content-section" class="content-section"
v-for="(content, cIndex) in leader.content" v-for="(content, cIndex) in leader.content"
@ -74,7 +90,7 @@
> >
<p>{{ content }}</p> <p>{{ content }}</p>
</div> </div>
</div> </div> -->
</div> </div>
</div> </div>
</main> </main>
@ -85,6 +101,15 @@
<script setup> <script setup>
import { useI18n } from "vue-i18n"; import { useI18n } from "vue-i18n";
import { computed } from "vue"; import { computed } from "vue";
import { departmentManagement } from "@/api/auth";
import { ref } from "vue";
const data = ref([]);
const getData = async () => {
const res = await departmentManagement({});
data.value = res.data.item || [];
};
getData();
const { t } = useI18n(); const { t } = useI18n();

View File

@ -46,7 +46,7 @@
style="max-width: 900px; margin: 0 auto; padding: 0" style="max-width: 900px; margin: 0 auto; padding: 0"
> >
<h3 class="section-title">{{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }}</h3> <h3 class="section-title">{{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }}</h3>
<h1 class="section-titles">Company Profile</h1> <h1 class="section-titles">{{ $t("COMPANYOVERVIEW.Company") }}</h1>
<div class="content-block text-[#455363]"> <div class="content-block text-[#455363]">
<p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}</p> <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}</p>
<p> <p>

View File

@ -6,12 +6,12 @@
> >
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" /> <img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div> </div>
<div class="w-[100%] h-[916PX] z-[] top-0 absolute"> <div class="w-[100%] h-[900PX] z-[] top-0 absolute">
<div class="relative w-[100%] h-[100%]"> <div class="relative w-[100%] h-[100%]">
<img <img
src="@/assets/image/content/bg_1.png" src="@/assets/image/content/bg_1.png"
alt="" alt=""
class="w-[100vw] absolute top-[-90px]" class="w-[100vw] h-[900PX] absolute top-[-90px]"
/> />
<img <img
src="@/assets/image/content/bg_2.png" src="@/assets/image/content/bg_2.png"
@ -22,7 +22,7 @@
</div> </div>
<section <section
class="company-overview h-[916px]" class="company-overview h-[916px]"
style="width: 900px; margin: 0 auto; padding: 0; padding-top: 190px" style="width: 900px; margin: 0 auto; padding: 0; padding-top: 300px"
> >
<div class="hero-section"> <div class="hero-section">
<transition name="fade-up" appear> <transition name="fade-up" appear>
@ -46,7 +46,7 @@
style="width: 900px; margin: 0 auto; padding: 0" style="width: 900px; margin: 0 auto; padding: 0"
> >
<h3 class="section-title">{{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }}</h3> <h3 class="section-title">{{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }}</h3>
<h1 class="section-titles">Company Profile</h1> <h1 class="section-titles">{{ $t("COMPANYOVERVIEW.Company") }}</h1>
<div class="content-block text-[#455363]"> <div class="content-block text-[#455363]">
<p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}</p> <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}</p>
<p> <p>

View File

@ -35,7 +35,7 @@
<!-- 公司概况 --> <!-- 公司概况 -->
<section class="company-overview" style="max-width: 311px; margin: 0 auto; padding: 0;margin-top: 100px;"> <section class="company-overview" style="max-width: 311px; margin: 0 auto; padding: 0;margin-top: 100px;">
<h3 class="section-title">{{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }}</h3> <h3 class="section-title">{{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }}</h3>
<h1 class="section-titles">Company Profile</h1> <h1 class="section-titles">{{ $t("COMPANYOVERVIEW.Company") }}</h1>
<div class="content-block text-[#455363]"> <div class="content-block text-[#455363]">
<p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}</p> <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}</p>
<p> <p>

View File

@ -57,7 +57,7 @@
style="max-width: 618px; margin: 0 auto; padding: 0;margin-top: 100px;" style="max-width: 618px; margin: 0 auto; padding: 0;margin-top: 100px;"
> >
<h3 class="section-title">{{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }}</h3> <h3 class="section-title">{{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }}</h3>
<h1 class="section-titles">Company Profile</h1> <h1 class="section-titles">{{ $t("COMPANYOVERVIEW.Company") }}</h1>
<div class="content-block text-[#455363]"> <div class="content-block text-[#455363]">
<p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}</p> <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}</p>
<p> <p>