Compare commits
	
		
			No commits in common. "86799ccf1d136e9b6c1e1160b0da8809821884eb" and "1a2f9417fbde831721d8789ee259f1c7b1f1f761" have entirely different histories.
		
	
	
		
			86799ccf1d
			...
			1a2f9417fb
		
	
		
							
								
								
									
										3
									
								
								env/.env.prod
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								env/.env.prod
									
									
									
									
										vendored
									
									
								
							| @ -5,6 +5,3 @@ VITE_DELETE_CONSOLE = true | |||||||
| # 是否开启sourcemap | # 是否开启sourcemap | ||||||
| VITE_SHOW_SOURCEMAP = false | VITE_SHOW_SOURCEMAP = false | ||||||
| VITE_BASEURL = '//appointteam.szjixun.cn' | VITE_BASEURL = '//appointteam.szjixun.cn' | ||||||
| 
 |  | ||||||
| # 文档查看 |  | ||||||
| VITE_PAGE_URL="http://172.16.100.22:8045" |  | ||||||
|  | |||||||
							
								
								
									
										4
									
								
								env/.env.test
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								env/.env.test
									
									
									
									
										vendored
									
									
								
							| @ -3,7 +3,3 @@ NODE_ENV = 'test' | |||||||
| # 是否去除console 和 debugger | # 是否去除console 和 debugger | ||||||
| VITE_DELETE_CONSOLE = false | VITE_DELETE_CONSOLE = false | ||||||
| VITE_BASEURL = '//kid-art-test.szjixun.cn' | VITE_BASEURL = '//kid-art-test.szjixun.cn' | ||||||
| 
 |  | ||||||
| # 文档查看 |  | ||||||
| VITE_PAGE_URL="http://172.16.100.22:8045" |  | ||||||
| # VITE_PAGE_URL="http://192.168.88.50:5878" |  | ||||||
|  | |||||||
| @ -12,7 +12,6 @@ | |||||||
|   }, |   }, | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@fingerprintjs/fingerprintjs": "^4.4.3", |     "@fingerprintjs/fingerprintjs": "^4.4.3", | ||||||
|     "@onlyoffice/document-editor-vue": "^1.5.0", |  | ||||||
|     "@unocss/reset": "^0.61.9", |     "@unocss/reset": "^0.61.9", | ||||||
|     "@vicons/ionicons5": "^0.13.0", |     "@vicons/ionicons5": "^0.13.0", | ||||||
|     "@vicons/utils": "^0.1.4", |     "@vicons/utils": "^0.1.4", | ||||||
|  | |||||||
| @ -11,9 +11,6 @@ importers: | |||||||
|       '@fingerprintjs/fingerprintjs': |       '@fingerprintjs/fingerprintjs': | ||||||
|         specifier: ^4.4.3 |         specifier: ^4.4.3 | ||||||
|         version: 4.4.3 |         version: 4.4.3 | ||||||
|       '@onlyoffice/document-editor-vue': |  | ||||||
|         specifier: ^1.5.0 |  | ||||||
|         version: 1.5.0(vue@3.4.35) |  | ||||||
|       '@unocss/reset': |       '@unocss/reset': | ||||||
|         specifier: ^0.61.9 |         specifier: ^0.61.9 | ||||||
|         version: 0.61.9 |         version: 0.61.9 | ||||||
| @ -1282,11 +1279,6 @@ packages: | |||||||
|     resolution: {integrity: sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==} |     resolution: {integrity: sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==} | ||||||
|     engines: {node: '>= 8'} |     engines: {node: '>= 8'} | ||||||
| 
 | 
 | ||||||
|   '@onlyoffice/document-editor-vue@1.5.0': |  | ||||||
|     resolution: {integrity: sha512-HZEebUhBloP4LomspI5BddgoQdhtPq91h57yA9K/Lk70MMc1vgOTQ4Wq+N5TZYXNxdDTv+TSsEVFLnBCl1Y71A==} |  | ||||||
|     peerDependencies: |  | ||||||
|       vue: ^3.0.0 |  | ||||||
| 
 |  | ||||||
|   '@polka/url@1.0.0-next.25': |   '@polka/url@1.0.0-next.25': | ||||||
|     resolution: {integrity: sha512-j7P6Rgr3mmtdkeDGTe0E/aYyWEWVtc5yFXtHCRHs28/jptDEWfaVOc5T7cblqy1XKPPfCxJc/8DwQ5YgLOZOVQ==} |     resolution: {integrity: sha512-j7P6Rgr3mmtdkeDGTe0E/aYyWEWVtc5yFXtHCRHs28/jptDEWfaVOc5T7cblqy1XKPPfCxJc/8DwQ5YgLOZOVQ==} | ||||||
| 
 | 
 | ||||||
| @ -5544,11 +5536,6 @@ snapshots: | |||||||
|       '@nodelib/fs.scandir': 2.1.5 |       '@nodelib/fs.scandir': 2.1.5 | ||||||
|       fastq: 1.17.1 |       fastq: 1.17.1 | ||||||
| 
 | 
 | ||||||
|   '@onlyoffice/document-editor-vue@1.5.0(vue@3.4.35)': |  | ||||||
|     dependencies: |  | ||||||
|       lodash: 4.17.21 |  | ||||||
|       vue: 3.4.35 |  | ||||||
| 
 |  | ||||||
|   '@polka/url@1.0.0-next.25': {} |   '@polka/url@1.0.0-next.25': {} | ||||||
| 
 | 
 | ||||||
|   '@rollup/plugin-babel@6.0.4(@babel/core@7.25.2)(rollup@4.20.0)': |   '@rollup/plugin-babel@6.0.4(@babel/core@7.25.2)(rollup@4.20.0)': | ||||||
|  | |||||||
| @ -143,11 +143,6 @@ const routes = [ | |||||||
|       }, |       }, | ||||||
|     ], |     ], | ||||||
|   }, |   }, | ||||||
|   { |  | ||||||
|     path: '/office', |  | ||||||
|     name: 'office', |  | ||||||
|     component: () => import('@/views/office/index.vue'), |  | ||||||
|   }, |  | ||||||
|    |    | ||||||
|   // {
 |   // {
 | ||||||
|   //     path: '/companyprofil',
 |   //     path: '/companyprofil',
 | ||||||
|  | |||||||
| @ -16,7 +16,7 @@ | |||||||
|         class="absolute inset-0 bg-gradient-to-r from-[#f5f0ff] to-white opacity-80" |         class="absolute inset-0 bg-gradient-to-r from-[#f5f0ff] to-white opacity-80" | ||||||
|       ></div> |       ></div> | ||||||
|       <div class="relative p-8 flex flex-col h-full"> |       <div class="relative p-8 flex flex-col h-full"> | ||||||
|         <div class="flex items-center mb-6 max-h-[3.5rem]"> |         <div class="flex items-start mb-6"> | ||||||
|           <div |           <div | ||||||
|             class="bg-[#895bff] p-3 rounded-lg shadow-md mr-6 transform hover:rotate-6 transition-transform duration-300 governance-icon" |             class="bg-[#895bff] p-3 rounded-lg shadow-md mr-6 transform hover:rotate-6 transition-transform duration-300 governance-icon" | ||||||
|           > |           > | ||||||
| @ -36,37 +36,18 @@ | |||||||
|             </svg> |             </svg> | ||||||
|           </div> |           </div> | ||||||
|           <div> |           <div> | ||||||
|             <n-tooltip trigger="hover" :disabled="!item.showTooltip" width="trigger"> |             <h1 style="font-size: 18px" class=""> | ||||||
|               <template #trigger> |  | ||||||
|                 <h1 |  | ||||||
|                   :ref="el => setTitleRef(el, index)" |  | ||||||
|                   style=" |  | ||||||
|                     font-size: 18px; |  | ||||||
|                     word-break: break-word; |  | ||||||
|                     display: -webkit-box; |  | ||||||
|                     -webkit-line-clamp: 2; |  | ||||||
|                     -webkit-box-orient: vertical; |  | ||||||
|                     overflow: hidden; |  | ||||||
|                     text-overflow: ellipsis; |  | ||||||
|                   " |  | ||||||
|                   class="" |  | ||||||
|                 > |  | ||||||
|               {{ item.title }} |               {{ item.title }} | ||||||
|             </h1> |             </h1> | ||||||
|             <!-- <text> {{ item.date }}</text> --> |             <!-- <text> {{ item.date }}</text> --> | ||||||
|               </template> |  | ||||||
|               <div slot="content"> |  | ||||||
|                 {{ item.title }} |  | ||||||
|               </div> |  | ||||||
|             </n-tooltip> |  | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <div class="mt-auto"> |         <div class="mt-auto"> | ||||||
|           <a |           <a | ||||||
|  |             :href="item.url" | ||||||
|             class="inline-flex items-center px-5 py-3 border border-transparent text-base font-medium rounded-md text-white bg-[#895bff] hover:bg-[#7a4de6] transition-all duration-300 transform hover:scale-105 shadow-md" |             class="inline-flex items-center px-5 py-3 border border-transparent text-base font-medium rounded-md text-white bg-[#895bff] hover:bg-[#7a4de6] transition-all duration-300 transform hover:scale-105 shadow-md" | ||||||
|             target="_blank" |             target="_blank" | ||||||
|             style="font-size: 16px; cursor: pointer;" |             style="font-size: 16px" | ||||||
|             @click="handleViewDocument(item)" |  | ||||||
|           > |           > | ||||||
|             View Document |             View Document | ||||||
|             <svg |             <svg | ||||||
| @ -91,110 +72,46 @@ | |||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import { reactive, onMounted, ref, nextTick, watch } from 'vue' | import { reactive } from "vue"; | ||||||
| import axios from 'axios' | import quarterlyPdfone from "@/assets/file/FiEE, Inc._Audit Committee Charter.pdf"; | ||||||
| import { NTooltip } from 'naive-ui' | import quarterlyPdftwo from "@/assets/file/FiEE, Inc. _Code of Business Conduct and Ethics.pdf"; | ||||||
| 
 | 
 | ||||||
| import quarterlyPdfone from '@/assets/file/FiEE, Inc._Audit Committee Charter.pdf' | import quarterlyPdfthree from "@/assets/file/FiEE, Inc._Compensation Committee Charter.pdf"; | ||||||
| import quarterlyPdftwo from '@/assets/file/FiEE, Inc. _Code of Business Conduct and Ethics.pdf' |  | ||||||
| 
 | 
 | ||||||
| import quarterlyPdfthree from '@/assets/file/FiEE, Inc._Compensation Committee Charter.pdf' | import quarterlyPdffour from "@/assets/file/FiEE, Inc. _Nominating and Corporate Governance Committee Charter.pdf"; | ||||||
| 
 |  | ||||||
| import quarterlyPdffour from '@/assets/file/FiEE, Inc. _Nominating and Corporate Governance Committee Charter.pdf' |  | ||||||
| 
 | 
 | ||||||
| const state = reactive({ | const state = reactive({ | ||||||
|   list: [ |   list: [ | ||||||
|     // { |     { | ||||||
|     //   title: 'AUDIT COMMITTEE CHARTER', |       title: "AUDIT COMMITTEE CHARTER", | ||||||
|     //   description: |       description: | ||||||
|     //     'Defines the purpose, composition, and responsibilities of the Audit Committee in overseeing financial reporting and disclosure.', |         "Defines the purpose, composition, and responsibilities of the Audit Committee in overseeing financial reporting and disclosure.", | ||||||
|     //   url: quarterlyPdfone, |       url: quarterlyPdfone, | ||||||
|     //   date: 'May 30, 2025', |       date: "May 30, 2025", | ||||||
|     // }, |     }, | ||||||
|     // { |     { | ||||||
|     //   title: 'CODE OF BUSINESS CONDUCT AND ETHICS', |       title: "CODE OF BUSINESS CONDUCT AND ETHICS", | ||||||
|     //   description: |       description: | ||||||
|     //     'Establishes the ethical standards and legal compliance expectations for all directors, officers and employees.', |         "Establishes the ethical standards and legal compliance expectations for all directors, officers and employees.", | ||||||
|     //   url: quarterlyPdftwo, |       url: quarterlyPdftwo, | ||||||
|     //   date: 'May 30, 2025', |       date: "May 30, 2025", | ||||||
|     // }, |     }, | ||||||
|     // { |     { | ||||||
|     //   title: 'COMPENSATION COMMITTEE CHARTER', |       title: "COMPENSATION COMMITTEE CHARTER", | ||||||
|     //   description: |       description: | ||||||
|     //     'Outlines the duties and responsibilities for overseeing executive compensation and benefit plans.', |         "Outlines the duties and responsibilities for overseeing executive compensation and benefit plans.", | ||||||
|     //   url: quarterlyPdfthree, |       url: quarterlyPdfthree, | ||||||
|     //   date: 'May 30, 2025', |       date: "May 30, 2025", | ||||||
|     // }, |     }, | ||||||
|     // { |     { | ||||||
|     //   title: 'NOMINATING AND CORPORATE GOVERNANCE COMMITTEE CHARTER', |       title: "NOMINATING AND CORPORATE GOVERNANCE COMMITTEE CHARTER", | ||||||
|     //   description: |       description: | ||||||
|     //     'Provides the framework for director nominations and corporate governance matters.', |         "Provides the framework for director nominations and corporate governance matters.", | ||||||
|     //   url: quarterlyPdffour, |       url: quarterlyPdffour, | ||||||
|     //   date: 'May 30, 2025', |       date: "May 30, 2025", | ||||||
|     // }, |     }, | ||||||
|   ], |   ], | ||||||
| }) | }); | ||||||
| 
 |  | ||||||
| const titleRefs = ref([]) |  | ||||||
| 
 |  | ||||||
| const setTitleRef = (el, idx) => { |  | ||||||
|   if (el) titleRefs.value[idx] = el |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const checkAllTitleOverflow = () => { |  | ||||||
|   state.list.forEach((item, idx) => { |  | ||||||
|     const el = titleRefs.value[idx] |  | ||||||
|     if (!el) { |  | ||||||
|       item.showTooltip = false |  | ||||||
|       return |  | ||||||
|     } |  | ||||||
|     item.showTooltip = el.scrollHeight > el.clientHeight || el.scrollWidth > el.clientWidth |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| onMounted(() => { |  | ||||||
|   getGovernanceDisplay() |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }) |  | ||||||
| 
 |  | ||||||
| watch(() => state.list, () => { |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }, { deep: true }) |  | ||||||
| 
 |  | ||||||
| //获取官网展示文档 |  | ||||||
| const getGovernanceDisplay = () => { |  | ||||||
|   // let url = 'https://common.szjixun.cn/api/fiee/governance/display' |  | ||||||
|   let url = 'http://172.16.100.93:9020/api/fiee/governance/display' |  | ||||||
|   let params = {} |  | ||||||
|   axios |  | ||||||
|     .get(url, { params }) |  | ||||||
|     .then((res) => { |  | ||||||
|       // console.log(res) |  | ||||||
|       if (res.status === 200) { |  | ||||||
|         if (res.data.status === 0) { |  | ||||||
|           state.list = res.data.data.data || [] |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     }) |  | ||||||
|     .catch((err) => { |  | ||||||
|       // console.log(err) |  | ||||||
|     }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // 查看文档 |  | ||||||
| const handleViewDocument = (item) => { |  | ||||||
|   // console.log(item) |  | ||||||
|   window.open( |  | ||||||
|     `${import.meta.env.VITE_PAGE_URL}/office?url=${ |  | ||||||
|       item.attachment |  | ||||||
|     }&attachmentName=${item.attachmentName}`, |  | ||||||
|     '_blank', |  | ||||||
|   ) |  | ||||||
| } |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
|  | |||||||
| @ -16,7 +16,7 @@ | |||||||
|         class="absolute inset-0 bg-gradient-to-r from-[#f5f0ff] to-white opacity-80" |         class="absolute inset-0 bg-gradient-to-r from-[#f5f0ff] to-white opacity-80" | ||||||
|       ></div> |       ></div> | ||||||
|       <div class="relative p-8 flex flex-col h-full"> |       <div class="relative p-8 flex flex-col h-full"> | ||||||
|         <div class="flex items-center mb-6 max-h-[3.5rem]"> |         <div class="flex items-start mb-6"> | ||||||
|           <div |           <div | ||||||
|             class="bg-[#895bff] p-3 rounded-lg shadow-md mr-6 transform hover:rotate-6 transition-transform duration-300 governance-icon" |             class="bg-[#895bff] p-3 rounded-lg shadow-md mr-6 transform hover:rotate-6 transition-transform duration-300 governance-icon" | ||||||
|           > |           > | ||||||
| @ -36,37 +36,18 @@ | |||||||
|             </svg> |             </svg> | ||||||
|           </div> |           </div> | ||||||
|           <div> |           <div> | ||||||
|             <n-tooltip trigger="hover" :disabled="!item.showTooltip" width="trigger"> |             <h1 style="font-size: 18px" class=""> | ||||||
|               <template #trigger> |  | ||||||
|                 <h1 |  | ||||||
|                   :ref="el => setTitleRef(el, index)" |  | ||||||
|                   style=" |  | ||||||
|                     font-size: 18px; |  | ||||||
|                     word-break: break-word; |  | ||||||
|                     display: -webkit-box; |  | ||||||
|                     -webkit-line-clamp: 2; |  | ||||||
|                     -webkit-box-orient: vertical; |  | ||||||
|                     overflow: hidden; |  | ||||||
|                     text-overflow: ellipsis; |  | ||||||
|                   " |  | ||||||
|                   class="" |  | ||||||
|                 > |  | ||||||
|               {{ item.title }} |               {{ item.title }} | ||||||
|             </h1> |             </h1> | ||||||
|             <!-- <text> {{ item.date }}</text> --> |             <!-- <text> {{ item.date }}</text> --> | ||||||
|               </template> |  | ||||||
|               <div slot="content"> |  | ||||||
|                 {{ item.title }} |  | ||||||
|               </div> |  | ||||||
|             </n-tooltip> |  | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <div class="mt-auto"> |         <div class="mt-auto"> | ||||||
|           <a |           <a | ||||||
|  |             :href="item.url" | ||||||
|             class="inline-flex items-center px-5 py-3 border border-transparent text-base font-medium rounded-md text-white bg-[#895bff] hover:bg-[#7a4de6] transition-all duration-300 transform hover:scale-105 shadow-md" |             class="inline-flex items-center px-5 py-3 border border-transparent text-base font-medium rounded-md text-white bg-[#895bff] hover:bg-[#7a4de6] transition-all duration-300 transform hover:scale-105 shadow-md" | ||||||
|             target="_blank" |             target="_blank" | ||||||
|             style="font-size: 16px; cursor: pointer;" |             style="font-size: 16px" | ||||||
|             @click="handleViewDocument(item)" |  | ||||||
|           > |           > | ||||||
|             View Document |             View Document | ||||||
|             <svg |             <svg | ||||||
| @ -91,110 +72,46 @@ | |||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import { reactive, onMounted, ref, nextTick, watch } from 'vue' | import { reactive } from "vue"; | ||||||
| import axios from 'axios' | import quarterlyPdfone from "@/assets/file/FiEE, Inc._Audit Committee Charter.pdf"; | ||||||
| import { NTooltip } from 'naive-ui' | import quarterlyPdftwo from "@/assets/file/FiEE, Inc. _Code of Business Conduct and Ethics.pdf"; | ||||||
| 
 | 
 | ||||||
| import quarterlyPdfone from '@/assets/file/FiEE, Inc._Audit Committee Charter.pdf' | import quarterlyPdfthree from "@/assets/file/FiEE, Inc._Compensation Committee Charter.pdf"; | ||||||
| import quarterlyPdftwo from '@/assets/file/FiEE, Inc. _Code of Business Conduct and Ethics.pdf' |  | ||||||
| 
 | 
 | ||||||
| import quarterlyPdfthree from '@/assets/file/FiEE, Inc._Compensation Committee Charter.pdf' | import quarterlyPdffour from "@/assets/file/FiEE, Inc. _Nominating and Corporate Governance Committee Charter.pdf"; | ||||||
| 
 |  | ||||||
| import quarterlyPdffour from '@/assets/file/FiEE, Inc. _Nominating and Corporate Governance Committee Charter.pdf' |  | ||||||
| 
 | 
 | ||||||
| const state = reactive({ | const state = reactive({ | ||||||
|   list: [ |   list: [ | ||||||
|     // { |     { | ||||||
|     //   title: 'AUDIT COMMITTEE CHARTER', |       title: "AUDIT COMMITTEE CHARTER", | ||||||
|     //   description: |       description: | ||||||
|     //     'Defines the purpose, composition, and responsibilities of the Audit Committee in overseeing financial reporting and disclosure.', |         "Defines the purpose, composition, and responsibilities of the Audit Committee in overseeing financial reporting and disclosure.", | ||||||
|     //   url: quarterlyPdfone, |       url: quarterlyPdfone, | ||||||
|     //   date: 'May 30, 2025', |       date: "May 30, 2025", | ||||||
|     // }, |     }, | ||||||
|     // { |     { | ||||||
|     //   title: 'CODE OF BUSINESS CONDUCT AND ETHICS', |       title: "CODE OF BUSINESS CONDUCT AND ETHICS", | ||||||
|     //   description: |       description: | ||||||
|     //     'Establishes the ethical standards and legal compliance expectations for all directors, officers and employees.', |         "Establishes the ethical standards and legal compliance expectations for all directors, officers and employees.", | ||||||
|     //   url: quarterlyPdftwo, |       url: quarterlyPdftwo, | ||||||
|     //   date: 'May 30, 2025', |       date: "May 30, 2025", | ||||||
|     // }, |     }, | ||||||
|     // { |     { | ||||||
|     //   title: 'COMPENSATION COMMITTEE CHARTER', |       title: "COMPENSATION COMMITTEE CHARTER", | ||||||
|     //   description: |       description: | ||||||
|     //     'Outlines the duties and responsibilities for overseeing executive compensation and benefit plans.', |         "Outlines the duties and responsibilities for overseeing executive compensation and benefit plans.", | ||||||
|     //   url: quarterlyPdfthree, |       url: quarterlyPdfthree, | ||||||
|     //   date: 'May 30, 2025', |       date: "May 30, 2025", | ||||||
|     // }, |     }, | ||||||
|     // { |     { | ||||||
|     //   title: 'NOMINATING AND CORPORATE GOVERNANCE COMMITTEE CHARTER', |       title: "NOMINATING AND CORPORATE GOVERNANCE COMMITTEE CHARTER", | ||||||
|     //   description: |       description: | ||||||
|     //     'Provides the framework for director nominations and corporate governance matters.', |         "Provides the framework for director nominations and corporate governance matters.", | ||||||
|     //   url: quarterlyPdffour, |       url: quarterlyPdffour, | ||||||
|     //   date: 'May 30, 2025', |       date: "May 30, 2025", | ||||||
|     // }, |     }, | ||||||
|   ], |   ], | ||||||
| }) | }); | ||||||
| 
 |  | ||||||
| const titleRefs = ref([]) |  | ||||||
| 
 |  | ||||||
| const setTitleRef = (el, idx) => { |  | ||||||
|   if (el) titleRefs.value[idx] = el |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const checkAllTitleOverflow = () => { |  | ||||||
|   state.list.forEach((item, idx) => { |  | ||||||
|     const el = titleRefs.value[idx] |  | ||||||
|     if (!el) { |  | ||||||
|       item.showTooltip = false |  | ||||||
|       return |  | ||||||
|     } |  | ||||||
|     item.showTooltip = el.scrollHeight > el.clientHeight || el.scrollWidth > el.clientWidth |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| onMounted(() => { |  | ||||||
|   getGovernanceDisplay() |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }) |  | ||||||
| 
 |  | ||||||
| watch(() => state.list, () => { |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }, { deep: true }) |  | ||||||
| 
 |  | ||||||
| //获取官网展示文档 |  | ||||||
| const getGovernanceDisplay = () => { |  | ||||||
|   // let url = 'https://common.szjixun.cn/api/fiee/governance/display' |  | ||||||
|   let url = 'http://172.16.100.93:9020/api/fiee/governance/display' |  | ||||||
|   let params = {} |  | ||||||
|   axios |  | ||||||
|     .get(url, { params }) |  | ||||||
|     .then((res) => { |  | ||||||
|       // console.log(res) |  | ||||||
|       if (res.status === 200) { |  | ||||||
|         if (res.data.status === 0) { |  | ||||||
|           state.list = res.data.data.data || [] |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     }) |  | ||||||
|     .catch((err) => { |  | ||||||
|       // console.log(err) |  | ||||||
|     }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // 查看文档 |  | ||||||
| const handleViewDocument = (item) => { |  | ||||||
|   // console.log(item) |  | ||||||
|   window.open( |  | ||||||
|     `${import.meta.env.VITE_PAGE_URL}/office?url=${ |  | ||||||
|       item.attachment |  | ||||||
|     }&attachmentName=${item.attachmentName}`, |  | ||||||
|     '_blank', |  | ||||||
|   ) |  | ||||||
| } |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
|  | |||||||
| @ -13,7 +13,7 @@ | |||||||
|         class="absolute inset-0 bg-gradient-to-r from-[#f5f0ff] to-white opacity-80" |         class="absolute inset-0 bg-gradient-to-r from-[#f5f0ff] to-white opacity-80" | ||||||
|       ></div> |       ></div> | ||||||
|       <div class="relative p-8 flex flex-col h-full"> |       <div class="relative p-8 flex flex-col h-full"> | ||||||
|         <div class="flex items-center mb-6 max-h-[3.5rem]"> |         <div class="flex items-start mb-6"> | ||||||
|           <div |           <div | ||||||
|             class="bg-[#895bff] p-3 rounded-lg shadow-md mr-6 transform hover:rotate-6 transition-transform duration-300 governance-icon" |             class="bg-[#895bff] p-3 rounded-lg shadow-md mr-6 transform hover:rotate-6 transition-transform duration-300 governance-icon" | ||||||
|           > |           > | ||||||
| @ -33,36 +33,17 @@ | |||||||
|             </svg> |             </svg> | ||||||
|           </div> |           </div> | ||||||
|           <div> |           <div> | ||||||
|             <n-tooltip trigger="click" :disabled="!item.showTooltip" width="trigger"> |             <h1 class="text-2xl font-medium text-gray-800 mb-2"> | ||||||
|               <template #trigger> |  | ||||||
|                 <h1 |  | ||||||
|                   :ref="(el) => setTitleRef(el, index)" |  | ||||||
|                   class="text-2xl font-medium text-gray-800" |  | ||||||
|                   style=" |  | ||||||
|                     word-break: break-word; |  | ||||||
|                     display: -webkit-box; |  | ||||||
|                     -webkit-line-clamp: 2; |  | ||||||
|                     -webkit-box-orient: vertical; |  | ||||||
|                     overflow: hidden; |  | ||||||
|                     text-overflow: ellipsis; |  | ||||||
|                   " |  | ||||||
|                 > |  | ||||||
|               {{ item.title }} |               {{ item.title }} | ||||||
|             </h1> |             </h1> | ||||||
|             <!-- <text> {{ item.date }}</text> --> |             <!-- <text> {{ item.date }}</text> --> | ||||||
|               </template> |  | ||||||
|               <div slot="content"> |  | ||||||
|                 {{ item.title }} |  | ||||||
|               </div> |  | ||||||
|             </n-tooltip> |  | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <div class="mt-auto"> |         <div class="mt-auto"> | ||||||
|           <a |           <a | ||||||
|  |             :href="item.url" | ||||||
|             class="inline-flex items-center px-5 py-3 border border-transparent text-base font-medium rounded-md text-white bg-[#895bff] hover:bg-[#7a4de6] transition-all duration-300 transform hover:scale-105 shadow-md" |             class="inline-flex items-center px-5 py-3 border border-transparent text-base font-medium rounded-md text-white bg-[#895bff] hover:bg-[#7a4de6] transition-all duration-300 transform hover:scale-105 shadow-md" | ||||||
|             target="_blank" |             target="_blank" | ||||||
|             style="cursor: pointer;" |  | ||||||
|             @click="handleViewDocument(item)" |  | ||||||
|           > |           > | ||||||
|             View Document |             View Document | ||||||
|             <svg |             <svg | ||||||
| @ -87,110 +68,46 @@ | |||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import { reactive, onMounted, ref, nextTick, watch } from 'vue' | import { reactive } from "vue"; | ||||||
| import axios from 'axios' | import quarterlyPdfone from "@/assets/file/FiEE, Inc._Audit Committee Charter.pdf"; | ||||||
| import { NTooltip } from 'naive-ui' | import quarterlyPdftwo from "@/assets/file/FiEE, Inc. _Code of Business Conduct and Ethics.pdf"; | ||||||
| 
 | 
 | ||||||
| import quarterlyPdfone from '@/assets/file/FiEE, Inc._Audit Committee Charter.pdf' | import quarterlyPdfthree from "@/assets/file/FiEE, Inc._Compensation Committee Charter.pdf"; | ||||||
| import quarterlyPdftwo from '@/assets/file/FiEE, Inc. _Code of Business Conduct and Ethics.pdf' |  | ||||||
| 
 | 
 | ||||||
| import quarterlyPdfthree from '@/assets/file/FiEE, Inc._Compensation Committee Charter.pdf' | import quarterlyPdffour from "@/assets/file/FiEE, Inc. _Nominating and Corporate Governance Committee Charter.pdf"; | ||||||
| 
 |  | ||||||
| import quarterlyPdffour from '@/assets/file/FiEE, Inc. _Nominating and Corporate Governance Committee Charter.pdf' |  | ||||||
| 
 | 
 | ||||||
| const state = reactive({ | const state = reactive({ | ||||||
|   list: [ |   list: [ | ||||||
|     // { |     { | ||||||
|     //   title: 'AUDIT COMMITTEE CHARTER', |       title: "AUDIT COMMITTEE CHARTER", | ||||||
|     //   description: |       description: | ||||||
|     //     'Defines the purpose, composition, and responsibilities of the Audit Committee in overseeing financial reporting and disclosure.', |         "Defines the purpose, composition, and responsibilities of the Audit Committee in overseeing financial reporting and disclosure.", | ||||||
|     //   url: quarterlyPdfone, |       url: quarterlyPdfone, | ||||||
|     //   date: 'May 30, 2025', |       date: "May 30, 2025", | ||||||
|     // }, |     }, | ||||||
|     // { |     { | ||||||
|     //   title: 'CODE OF BUSINESS CONDUCT AND ETHICS', |       title: "CODE OF BUSINESS CONDUCT AND ETHICS", | ||||||
|     //   description: |       description: | ||||||
|     //     'Establishes the ethical standards and legal compliance expectations for all directors, officers and employees.', |         "Establishes the ethical standards and legal compliance expectations for all directors, officers and employees.", | ||||||
|     //   url: quarterlyPdftwo, |       url: quarterlyPdftwo, | ||||||
|     //   date: 'May 30, 2025', |       date: "May 30, 2025", | ||||||
|     // }, |     }, | ||||||
|     // { |     { | ||||||
|     //   title: 'COMPENSATION COMMITTEE CHARTER', |       title: "COMPENSATION COMMITTEE CHARTER", | ||||||
|     //   description: |       description: | ||||||
|     //     'Outlines the duties and responsibilities for overseeing executive compensation and benefit plans.', |         "Outlines the duties and responsibilities for overseeing executive compensation and benefit plans.", | ||||||
|     //   url: quarterlyPdfthree, |       url: quarterlyPdfthree, | ||||||
|     //   date: 'May 30, 2025', |       date: "May 30, 2025", | ||||||
|     // }, |     }, | ||||||
|     // { |     { | ||||||
|     //   title: 'NOMINATING AND CORPORATE GOVERNANCE COMMITTEE CHARTER', |       title: "NOMINATING AND CORPORATE GOVERNANCE COMMITTEE CHARTER", | ||||||
|     //   description: |       description: | ||||||
|     //     'Provides the framework for director nominations and corporate governance matters.', |         "Provides the framework for director nominations and corporate governance matters.", | ||||||
|     //   url: quarterlyPdffour, |       url: quarterlyPdffour, | ||||||
|     //   date: 'May 30, 2025', |       date: "May 30, 2025", | ||||||
|     // }, |     }, | ||||||
|   ], |   ], | ||||||
| }) | }); | ||||||
| 
 |  | ||||||
| const titleRefs = ref([]) |  | ||||||
| 
 |  | ||||||
| const setTitleRef = (el, idx) => { |  | ||||||
|   if (el) titleRefs.value[idx] = el |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const checkAllTitleOverflow = () => { |  | ||||||
|   state.list.forEach((item, idx) => { |  | ||||||
|     const el = titleRefs.value[idx] |  | ||||||
|     if (!el) { |  | ||||||
|       item.showTooltip = false |  | ||||||
|       return |  | ||||||
|     } |  | ||||||
|     item.showTooltip = el.scrollHeight > el.clientHeight || el.scrollWidth > el.clientWidth |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| onMounted(() => { |  | ||||||
|   getGovernanceDisplay() |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }) |  | ||||||
| 
 |  | ||||||
| watch(() => state.list, () => { |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }, { deep: true }) |  | ||||||
| 
 |  | ||||||
| //获取官网展示文档 |  | ||||||
| const getGovernanceDisplay = () => { |  | ||||||
|   // let url = 'https://common.szjixun.cn/api/fiee/governance/display' |  | ||||||
|   let url = 'http://172.16.100.93:9020/api/fiee/governance/display' |  | ||||||
|   let params = {} |  | ||||||
|   axios |  | ||||||
|     .get(url, { params }) |  | ||||||
|     .then((res) => { |  | ||||||
|       // console.log(res) |  | ||||||
|       if (res.status === 200) { |  | ||||||
|         if (res.data.status === 0) { |  | ||||||
|           state.list = res.data.data.data || [] |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     }) |  | ||||||
|     .catch((err) => { |  | ||||||
|       // console.log(err) |  | ||||||
|     }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // 查看文档 |  | ||||||
| const handleViewDocument = (item) => { |  | ||||||
|   // console.log(item) |  | ||||||
|   window.open( |  | ||||||
|     `${import.meta.env.VITE_PAGE_URL}/office?url=${ |  | ||||||
|       item.attachment |  | ||||||
|     }&attachmentName=${item.attachmentName}`, |  | ||||||
|     '_blank', |  | ||||||
|   ) |  | ||||||
| } |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
|  | |||||||
| @ -13,7 +13,7 @@ | |||||||
|         class="absolute inset-0 bg-gradient-to-r from-[#f5f0ff] to-white opacity-80" |         class="absolute inset-0 bg-gradient-to-r from-[#f5f0ff] to-white opacity-80" | ||||||
|       ></div> |       ></div> | ||||||
|       <div class="relative p-8 flex flex-col h-full"> |       <div class="relative p-8 flex flex-col h-full"> | ||||||
|         <div class="flex items-center mb-6 max-h-[3.5rem]"> |         <div class="flex items-start mb-6"> | ||||||
|           <div |           <div | ||||||
|             class="bg-[#895bff] p-3 rounded-lg shadow-md mr-6 transform hover:rotate-6 transition-transform duration-300 governance-icon" |             class="bg-[#895bff] p-3 rounded-lg shadow-md mr-6 transform hover:rotate-6 transition-transform duration-300 governance-icon" | ||||||
|           > |           > | ||||||
| @ -33,36 +33,17 @@ | |||||||
|             </svg> |             </svg> | ||||||
|           </div> |           </div> | ||||||
|           <div> |           <div> | ||||||
|             <n-tooltip trigger="click" :disabled="!item.showTooltip" width="trigger"> |             <h1 class="text-2xl font-medium text-gray-800 mb-2"> | ||||||
|               <template #trigger> |  | ||||||
|                 <h1 |  | ||||||
|                   :ref="(el) => setTitleRef(el, index)" |  | ||||||
|                   class="text-2xl font-medium text-gray-800" |  | ||||||
|                   style=" |  | ||||||
|                     word-break: break-word; |  | ||||||
|                     display: -webkit-box; |  | ||||||
|                     -webkit-line-clamp: 2; |  | ||||||
|                     -webkit-box-orient: vertical; |  | ||||||
|                     overflow: hidden; |  | ||||||
|                     text-overflow: ellipsis; |  | ||||||
|                   " |  | ||||||
|                 > |  | ||||||
|               {{ item.title }} |               {{ item.title }} | ||||||
|             </h1> |             </h1> | ||||||
|             <!-- <text> {{ item.date }}</text> --> |             <!-- <text> {{ item.date }}</text> --> | ||||||
|               </template> |  | ||||||
|               <div slot="content"> |  | ||||||
|                 {{ item.title }} |  | ||||||
|               </div> |  | ||||||
|             </n-tooltip> |  | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <div class="mt-auto"> |         <div class="mt-auto"> | ||||||
|           <a |           <a | ||||||
|  |             :href="item.url" | ||||||
|             class="inline-flex items-center px-5 py-3 border border-transparent text-base font-medium rounded-md text-white bg-[#895bff] hover:bg-[#7a4de6] transition-all duration-300 transform hover:scale-105 shadow-md" |             class="inline-flex items-center px-5 py-3 border border-transparent text-base font-medium rounded-md text-white bg-[#895bff] hover:bg-[#7a4de6] transition-all duration-300 transform hover:scale-105 shadow-md" | ||||||
|             target="_blank" |             target="_blank" | ||||||
|             style="cursor: pointer;" |  | ||||||
|             @click="handleViewDocument(item)" |  | ||||||
|           > |           > | ||||||
|             View Document |             View Document | ||||||
|             <svg |             <svg | ||||||
| @ -87,110 +68,46 @@ | |||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import { reactive, onMounted, ref, nextTick, watch } from 'vue' | import { reactive } from "vue"; | ||||||
| import axios from 'axios' | import quarterlyPdfone from "@/assets/file/FiEE, Inc._Audit Committee Charter.pdf"; | ||||||
| import { NTooltip } from 'naive-ui' | import quarterlyPdftwo from "@/assets/file/FiEE, Inc. _Code of Business Conduct and Ethics.pdf"; | ||||||
| 
 | 
 | ||||||
| import quarterlyPdfone from '@/assets/file/FiEE, Inc._Audit Committee Charter.pdf' | import quarterlyPdfthree from "@/assets/file/FiEE, Inc._Compensation Committee Charter.pdf"; | ||||||
| import quarterlyPdftwo from '@/assets/file/FiEE, Inc. _Code of Business Conduct and Ethics.pdf' |  | ||||||
| 
 | 
 | ||||||
| import quarterlyPdfthree from '@/assets/file/FiEE, Inc._Compensation Committee Charter.pdf' | import quarterlyPdffour from "@/assets/file/FiEE, Inc. _Nominating and Corporate Governance Committee Charter.pdf"; | ||||||
| 
 |  | ||||||
| import quarterlyPdffour from '@/assets/file/FiEE, Inc. _Nominating and Corporate Governance Committee Charter.pdf' |  | ||||||
| 
 | 
 | ||||||
| const state = reactive({ | const state = reactive({ | ||||||
|   list: [ |   list: [ | ||||||
|     // { |     { | ||||||
|     //   title: 'AUDIT COMMITTEE CHARTER', |       title: "AUDIT COMMITTEE CHARTER", | ||||||
|     //   description: |       description: | ||||||
|     //     'Defines the purpose, composition, and responsibilities of the Audit Committee in overseeing financial reporting and disclosure.', |         "Defines the purpose, composition, and responsibilities of the Audit Committee in overseeing financial reporting and disclosure.", | ||||||
|     //   url: quarterlyPdfone, |       url: quarterlyPdfone, | ||||||
|     //   date: 'May 30, 2025', |       date: "May 30, 2025", | ||||||
|     // }, |     }, | ||||||
|     // { |     { | ||||||
|     //   title: 'CODE OF BUSINESS CONDUCT AND ETHICS', |       title: "CODE OF BUSINESS CONDUCT AND ETHICS", | ||||||
|     //   description: |       description: | ||||||
|     //     'Establishes the ethical standards and legal compliance expectations for all directors, officers and employees.', |         "Establishes the ethical standards and legal compliance expectations for all directors, officers and employees.", | ||||||
|     //   url: quarterlyPdftwo, |       url: quarterlyPdftwo, | ||||||
|     //   date: 'May 30, 2025', |       date: "May 30, 2025", | ||||||
|     // }, |     }, | ||||||
|     // { |     { | ||||||
|     //   title: 'COMPENSATION COMMITTEE CHARTER', |       title: "COMPENSATION COMMITTEE CHARTER", | ||||||
|     //   description: |       description: | ||||||
|     //     'Outlines the duties and responsibilities for overseeing executive compensation and benefit plans.', |         "Outlines the duties and responsibilities for overseeing executive compensation and benefit plans.", | ||||||
|     //   url: quarterlyPdfthree, |       url: quarterlyPdfthree, | ||||||
|     //   date: 'May 30, 2025', |       date: "May 30, 2025", | ||||||
|     // }, |     }, | ||||||
|     // { |     { | ||||||
|     //   title: 'NOMINATING AND CORPORATE GOVERNANCE COMMITTEE CHARTER', |       title: "NOMINATING AND CORPORATE GOVERNANCE COMMITTEE CHARTER", | ||||||
|     //   description: |       description: | ||||||
|     //     'Provides the framework for director nominations and corporate governance matters.', |         "Provides the framework for director nominations and corporate governance matters.", | ||||||
|     //   url: quarterlyPdffour, |       url: quarterlyPdffour, | ||||||
|     //   date: 'May 30, 2025', |       date: "May 30, 2025", | ||||||
|     // }, |     }, | ||||||
|   ], |   ], | ||||||
| }) | }); | ||||||
| 
 |  | ||||||
| const titleRefs = ref([]) |  | ||||||
| 
 |  | ||||||
| const setTitleRef = (el, idx) => { |  | ||||||
|   if (el) titleRefs.value[idx] = el |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const checkAllTitleOverflow = () => { |  | ||||||
|   state.list.forEach((item, idx) => { |  | ||||||
|     const el = titleRefs.value[idx] |  | ||||||
|     if (!el) { |  | ||||||
|       item.showTooltip = false |  | ||||||
|       return |  | ||||||
|     } |  | ||||||
|     item.showTooltip = el.scrollHeight > el.clientHeight || el.scrollWidth > el.clientWidth |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| onMounted(() => { |  | ||||||
|   getGovernanceDisplay() |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }) |  | ||||||
| 
 |  | ||||||
| watch(() => state.list, () => { |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }, { deep: true }) |  | ||||||
| 
 |  | ||||||
| //获取官网展示文档 |  | ||||||
| const getGovernanceDisplay = () => { |  | ||||||
|   // let url = 'https://common.szjixun.cn/api/fiee/governance/display' |  | ||||||
|   let url = 'http://172.16.100.93:9020/api/fiee/governance/display' |  | ||||||
|   let params = {} |  | ||||||
|   axios |  | ||||||
|     .get(url, { params }) |  | ||||||
|     .then((res) => { |  | ||||||
|       // console.log(res) |  | ||||||
|       if (res.status === 200) { |  | ||||||
|         if (res.data.status === 0) { |  | ||||||
|           state.list = res.data.data.data || [] |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     }) |  | ||||||
|     .catch((err) => { |  | ||||||
|       // console.log(err) |  | ||||||
|     }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // 查看文档 |  | ||||||
| const handleViewDocument = (item) => { |  | ||||||
|   // console.log(item) |  | ||||||
|   window.open( |  | ||||||
|     `${import.meta.env.VITE_PAGE_URL}/office?url=${ |  | ||||||
|       item.attachment |  | ||||||
|     }&attachmentName=${item.attachmentName}`, |  | ||||||
|     '_blank', |  | ||||||
|   ) |  | ||||||
| } |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
|  | |||||||
| @ -1,17 +1,16 @@ | |||||||
| <script setup> | <script setup> | ||||||
| import customHeader from '@/components/customHeader/index.vue' | import customHeader from '@/components/customHeader/index.vue' | ||||||
| import customFooter from '@/components/customFooter/index.vue' | import customFooter from '@/components/customFooter/index.vue' | ||||||
| import { NScrollbar } from 'naive-ui' |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
|   <div class="flex flex-col h-screen"> |   <div class="flex flex-col h-screen"> | ||||||
|     <customHeader></customHeader> |     <customHeader></customHeader> | ||||||
|     <n-scrollbar class="bg-[url('@/assets/image/bg-pc.png')] bg-cover bg-center flex-1"> |     <div | ||||||
|       <div> |       class="bg-[url('@/assets/image/bg-pc.png')] bg-cover bg-center flex-1 overflow-auto" | ||||||
|  |     > | ||||||
|       <router-view /> |       <router-view /> | ||||||
|     </div> |     </div> | ||||||
|     </n-scrollbar> |  | ||||||
|     <customFooter></customFooter> |     <customFooter></customFooter> | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
|  | |||||||
| @ -1,19 +1,16 @@ | |||||||
| <script setup> | <script setup> | ||||||
| import customHeader from '@/components/customHeader/index.vue' | import customHeader from '@/components/customHeader/index.vue' | ||||||
| import customFooter from '@/components/customFooter/index.vue' | import customFooter from '@/components/customFooter/index.vue' | ||||||
| import { NScrollbar } from 'naive-ui' |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
|   <div class="flex flex-col h-100svh"> |   <div class="flex flex-col h-100svh"> | ||||||
|     <customHeader /> |     <customHeader /> | ||||||
|     <n-scrollbar |     <div | ||||||
|       class="bg-[url('@/assets/image/bg-mobile.png')] bg-cover bg-center flex-1" |       class="bg-[url('@/assets/image/bg-mobile.png')] bg-cover bg-center flex-1 overflow-auto" | ||||||
|     > |     > | ||||||
|       <div> |  | ||||||
|       <router-view /> |       <router-view /> | ||||||
|     </div> |     </div> | ||||||
|     </n-scrollbar> |  | ||||||
|     <customFooter /> |     <customFooter /> | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
|  | |||||||
| @ -74,37 +74,16 @@ | |||||||
|           > |           > | ||||||
|             <div> |             <div> | ||||||
|               <div style="font-size: 18px">{{ item.time }}</div> |               <div style="font-size: 18px">{{ item.time }}</div> | ||||||
|               <n-tooltip | 
 | ||||||
|                 trigger="hover" |               <div style="font-size: 18px"> | ||||||
|                 :disabled="!item.showTooltip" |  | ||||||
|                 width="trigger" |  | ||||||
|               > |  | ||||||
|                 <template #trigger> |  | ||||||
|                   <div |  | ||||||
|                     :ref="(el) => setTitleRef(el, index)" |  | ||||||
|                     style=" |  | ||||||
|                       font-size: 18px; |  | ||||||
|                       word-break: break-word; |  | ||||||
|                       display: -webkit-box; |  | ||||||
|                       -webkit-line-clamp: 2; |  | ||||||
|                       -webkit-box-orient: vertical; |  | ||||||
|                       overflow: hidden; |  | ||||||
|                       text-overflow: ellipsis; |  | ||||||
|                     " |  | ||||||
|                   > |  | ||||||
|                 {{ item.title }} |                 {{ item.title }} | ||||||
|               </div> |               </div> | ||||||
|                 </template> |  | ||||||
|                 <div slot="content"> |  | ||||||
|                   {{ item.title }} |  | ||||||
|                 </div> |  | ||||||
|               </n-tooltip> |  | ||||||
|             </div> |             </div> | ||||||
| 
 | 
 | ||||||
|             <div |             <div | ||||||
|               style="font-size: 18px;flex-shrink: 0; margin: 0 0 0 0.6rem;" |               style="font-size: 18px" | ||||||
|               class="cursor-pointer" |               class="cursor-pointer" | ||||||
|               @click="handleLink(item)" |               @click="handleLink(item.router, item.time)" | ||||||
|             > |             > | ||||||
|               View Press Release<img |               View Press Release<img | ||||||
|                 class="ml-[10px]" |                 class="ml-[10px]" | ||||||
| @ -115,13 +94,6 @@ | |||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <div v-if="newList.length === 0" class="flex justify-center items-center"> |  | ||||||
|           <img |  | ||||||
|             src="@/assets/image/icon/default-empty.png" |  | ||||||
|             alt="empty" |  | ||||||
|             style="width: 109px; height: 60px;" |  | ||||||
|           /> |  | ||||||
|         </div> |  | ||||||
|       </div> |       </div> | ||||||
|     </section> |     </section> | ||||||
|     <!-- 新增:股票信息与活动预告双栏模块 --> |     <!-- 新增:股票信息与活动预告双栏模块 --> | ||||||
| @ -230,11 +202,9 @@ | |||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import { onMounted, ref, onUnmounted, computed, nextTick, watch } from "vue"; | import { onMounted, ref, onUnmounted, computed } from "vue"; | ||||||
| import { NTooltip } from 'naive-ui' |  | ||||||
| import { useI18n } from "vue-i18n"; | import { useI18n } from "vue-i18n"; | ||||||
| import { useStockQuote } from "@/store/stock-quote/index.js"; | import { useStockQuote } from "@/store/stock-quote/index.js"; | ||||||
| import axios from 'axios' |  | ||||||
| const { getStockQuate, stockQuote, formatted } = useStockQuote(); | const { getStockQuate, stockQuote, formatted } = useStockQuote(); | ||||||
| 
 | 
 | ||||||
| getStockQuate(); | getStockQuate(); | ||||||
| @ -244,44 +214,17 @@ const contentRef = ref(null); | |||||||
| const isInView = ref(false); | const isInView = ref(false); | ||||||
| let observer = null; | let observer = null; | ||||||
| const newList = ref([ | const newList = ref([ | ||||||
|   // { |   { | ||||||
|   //   time: "June 3, 2025", |     time: "June 3, 2025", | ||||||
|   //   title: "FiEE, Inc. seized market opportunities through 2025 Osaka Expo", |     title: "FiEE, Inc. seized market opportunities through 2025 Osaka Expo", | ||||||
|   //   router: "/news", |     router: "/news", | ||||||
|   // }, |   }, | ||||||
|   // { |   { | ||||||
|   //   time: "June 2, 2025", |     time: "June 2, 2025", | ||||||
|   //   title: "FiEE, Inc. Closes Its First Day of Trading on NASDAQ", |     title: "FiEE, Inc. Closes Its First Day of Trading on NASDAQ", | ||||||
|   //   router: "/news", |     router: "/news", | ||||||
|   // }, |   }, | ||||||
| ]); | ]); | ||||||
| 
 |  | ||||||
| // 获取新闻发布(展示在首页的) |  | ||||||
| const getPressReleasesDisplay = () => { |  | ||||||
|   let url = 'http://172.16.100.93:9020/api/fiee/pressreleases/display' |  | ||||||
|   let params = { |  | ||||||
|     page: 1, |  | ||||||
|     pageSize: 10, |  | ||||||
|     display: 2, // 1: 不展示在首页 2: 展示在首页 |  | ||||||
|   } |  | ||||||
|   // console.log(params) |  | ||||||
|   axios.post(url, params).then((res) => { |  | ||||||
|     // console.log(res) |  | ||||||
|     if (res.status === 200) { |  | ||||||
|       if (res.data.status === 0) { |  | ||||||
|         res.data.data?.data?.forEach((item) => { |  | ||||||
|           item.time = new Date(item.createdAt).toLocaleDateString('en-US', { |  | ||||||
|             month: 'long', |  | ||||||
|             day: 'numeric', |  | ||||||
|             year: 'numeric', |  | ||||||
|           }) |  | ||||||
|         }) |  | ||||||
|         newList.value = res.data.data?.data || [] |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   if (contentRef.value && "IntersectionObserver" in window) { |   if (contentRef.value && "IntersectionObserver" in window) { | ||||||
|     observer = new IntersectionObserver( |     observer = new IntersectionObserver( | ||||||
| @ -306,36 +249,8 @@ onMounted(() => { | |||||||
|     // 回退方案:如果不支持IntersectionObserver则直接显示 |     // 回退方案:如果不支持IntersectionObserver则直接显示 | ||||||
|     isInView.value = true; |     isInView.value = true; | ||||||
|   } |   } | ||||||
|   getPressReleasesDisplay() |  | ||||||
| 
 |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| const titleRefs = ref([]) |  | ||||||
| 
 |  | ||||||
| const setTitleRef = (el, idx) => { |  | ||||||
|   if (el) titleRefs.value[idx] = el |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const checkAllTitleOverflow = () => { |  | ||||||
|   newList.value.forEach((item, idx) => { |  | ||||||
|     const el = titleRefs.value[idx] |  | ||||||
|     if (!el) { |  | ||||||
|       item.showTooltip = false |  | ||||||
|       return |  | ||||||
|     } |  | ||||||
|     item.showTooltip = el.scrollHeight > el.clientHeight || el.scrollWidth > el.clientWidth |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| watch(() => newList.value, () => { |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }, { deep: true }) |  | ||||||
| 
 |  | ||||||
| onUnmounted(() => { | onUnmounted(() => { | ||||||
|   if (observer) { |   if (observer) { | ||||||
|     observer.disconnect(); |     observer.disconnect(); | ||||||
| @ -343,11 +258,11 @@ onUnmounted(() => { | |||||||
| }); | }); | ||||||
| import { useRouter } from "vue-router"; | import { useRouter } from "vue-router"; | ||||||
| const router = useRouter(); | const router = useRouter(); | ||||||
| const handleLink = (item) => { | const handleLink = (routers, index) => { | ||||||
|   router.push({ |   router.push({ | ||||||
|     path: "/news", |     path: routers, | ||||||
|     query: { |     query: { | ||||||
|       id: item.id, |       date: index, | ||||||
|     }, |     }, | ||||||
|   }); |   }); | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -74,37 +74,15 @@ | |||||||
|             <div> |             <div> | ||||||
|               <div style="font-size: 18px">{{ item.time }}</div> |               <div style="font-size: 18px">{{ item.time }}</div> | ||||||
| 
 | 
 | ||||||
|               <n-tooltip |               <div style="font-size: 18px"> | ||||||
|                 trigger="hover" |  | ||||||
|                 :disabled="!item.showTooltip" |  | ||||||
|                 width="trigger" |  | ||||||
|               > |  | ||||||
|                 <template #trigger> |  | ||||||
|                   <div |  | ||||||
|                     :ref="(el) => setTitleRef(el, index)" |  | ||||||
|                     style=" |  | ||||||
|                       font-size: 18px; |  | ||||||
|                       word-break: break-word; |  | ||||||
|                       display: -webkit-box; |  | ||||||
|                       -webkit-line-clamp: 2; |  | ||||||
|                       -webkit-box-orient: vertical; |  | ||||||
|                       overflow: hidden; |  | ||||||
|                       text-overflow: ellipsis; |  | ||||||
|                     " |  | ||||||
|                   > |  | ||||||
|                 {{ item.title }} |                 {{ item.title }} | ||||||
|               </div> |               </div> | ||||||
|                 </template> |  | ||||||
|                 <div slot="content"> |  | ||||||
|                   {{ item.title }} |  | ||||||
|                 </div> |  | ||||||
|               </n-tooltip> |  | ||||||
|             </div> |             </div> | ||||||
| 
 | 
 | ||||||
|             <div |             <div | ||||||
|               style="font-size: 18px;flex-shrink: 0; margin: 0 0 0 0.6rem;" |               style="font-size: 18px" | ||||||
|               class="cursor-pointer" |               class="cursor-pointer" | ||||||
|               @click="handleLink(item)" |               @click="handleLink(item.router, item.time)" | ||||||
|             > |             > | ||||||
|               View Press Release<img |               View Press Release<img | ||||||
|                 class="ml-[10px]" |                 class="ml-[10px]" | ||||||
| @ -115,13 +93,6 @@ | |||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <div v-if="newList.length === 0" class="flex justify-center items-center"> |  | ||||||
|           <img |  | ||||||
|             src="@/assets/image/icon/default-empty.png" |  | ||||||
|             alt="empty" |  | ||||||
|             style="width: 109px; height: 60px;" |  | ||||||
|           /> |  | ||||||
|         </div> |  | ||||||
|       </div> |       </div> | ||||||
|     </section> |     </section> | ||||||
|     <!-- 新增:股票信息与活动预告双栏模块 --> |     <!-- 新增:股票信息与活动预告双栏模块 --> | ||||||
| @ -220,55 +191,27 @@ | |||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import { onMounted, ref, onUnmounted, computed, nextTick, watch } from "vue"; | import { onMounted, ref, onUnmounted, computed } from "vue"; | ||||||
| import { NTooltip } from 'naive-ui' |  | ||||||
| import { useI18n } from "vue-i18n"; | import { useI18n } from "vue-i18n"; | ||||||
| import { useStockQuote } from "@/store/stock-quote/index.js"; | import { useStockQuote } from "@/store/stock-quote/index.js"; | ||||||
| import axios from 'axios' |  | ||||||
| const { getStockQuate, stockQuote, formatted } = useStockQuote(); | const { getStockQuate, stockQuote, formatted } = useStockQuote(); | ||||||
| getStockQuate(); | getStockQuate(); | ||||||
| // 示例数据 | // 示例数据 | ||||||
| const sampleDate = ref(formatted); | const sampleDate = ref(formatted); | ||||||
| 
 | 
 | ||||||
| const newList = ref([ | const newList = ref([ | ||||||
|   // { |   { | ||||||
|   //   time: "June 3, 2025", |     time: "June 3, 2025", | ||||||
|   //   title: "FiEE, Inc. seized market opportunities through 2025 Osaka Expo", |     title: "FiEE, Inc. seized market opportunities through 2025 Osaka Expo", | ||||||
|   //   router: "/news", |     router: "/news", | ||||||
|   // }, |   }, | ||||||
|   // { |   { | ||||||
|   //   time: "June 2, 2025", |     time: "June 2, 2025", | ||||||
|   //   title: "FiEE, Inc. Closes Its First Day of Trading on NASDAQ", |     title: "FiEE, Inc. Closes Its First Day of Trading on NASDAQ", | ||||||
|   //   router: "/news", |     router: "/news", | ||||||
|   // }, |   }, | ||||||
| ]); | ]); | ||||||
| 
 | 
 | ||||||
| // 获取新闻发布(展示在首页的) |  | ||||||
| const getPressReleasesDisplay = () => { |  | ||||||
|   let url = 'http://172.16.100.93:9020/api/fiee/pressreleases/display' |  | ||||||
|   let params = { |  | ||||||
|     page: 1, |  | ||||||
|     pageSize: 10, |  | ||||||
|     display: 2, // 1: 不展示在首页 2: 展示在首页 |  | ||||||
|   } |  | ||||||
|   // console.log(params) |  | ||||||
|   axios.post(url, params).then((res) => { |  | ||||||
|     // console.log(res) |  | ||||||
|     if (res.status === 200) { |  | ||||||
|       if (res.data.status === 0) { |  | ||||||
|         res.data.data?.data?.forEach((item) => { |  | ||||||
|           item.time = new Date(item.createdAt).toLocaleDateString('en-US', { |  | ||||||
|             month: 'long', |  | ||||||
|             day: 'numeric', |  | ||||||
|             year: 'numeric', |  | ||||||
|           }) |  | ||||||
|         }) |  | ||||||
|         newList.value = res.data.data?.data || [] |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const { t: $t } = useI18n(); | const { t: $t } = useI18n(); | ||||||
| const contentRef = ref(null); | const contentRef = ref(null); | ||||||
| const isInView = ref(false); | const isInView = ref(false); | ||||||
| @ -297,36 +240,8 @@ onMounted(() => { | |||||||
|     // 回退方案:如果不支持IntersectionObserver则直接显示 |     // 回退方案:如果不支持IntersectionObserver则直接显示 | ||||||
|     isInView.value = true; |     isInView.value = true; | ||||||
|   } |   } | ||||||
|   getPressReleasesDisplay() |  | ||||||
|    |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| const titleRefs = ref([]) |  | ||||||
| 
 |  | ||||||
| const setTitleRef = (el, idx) => { |  | ||||||
|   if (el) titleRefs.value[idx] = el |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const checkAllTitleOverflow = () => { |  | ||||||
|   newList.value.forEach((item, idx) => { |  | ||||||
|     const el = titleRefs.value[idx] |  | ||||||
|     if (!el) { |  | ||||||
|       item.showTooltip = false |  | ||||||
|       return |  | ||||||
|     } |  | ||||||
|     item.showTooltip = el.scrollHeight > el.clientHeight || el.scrollWidth > el.clientWidth |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| watch(() => newList.value, () => { |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }, { deep: true }) |  | ||||||
| 
 |  | ||||||
| onUnmounted(() => { | onUnmounted(() => { | ||||||
|   if (observer) { |   if (observer) { | ||||||
|     observer.disconnect(); |     observer.disconnect(); | ||||||
| @ -334,11 +249,11 @@ onUnmounted(() => { | |||||||
| }); | }); | ||||||
| import { useRouter } from "vue-router"; | import { useRouter } from "vue-router"; | ||||||
| const router = useRouter(); | const router = useRouter(); | ||||||
| const handleLink = (item) => { | const handleLink = (routers, index) => { | ||||||
|   router.push({ |   router.push({ | ||||||
|     path: "/news", |     path: routers, | ||||||
|     query: { |     query: { | ||||||
|       id: item.id, |       date: index, | ||||||
|     }, |     }, | ||||||
|   }); |   }); | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -74,37 +74,16 @@ | |||||||
|           > |           > | ||||||
|             <div> |             <div> | ||||||
|               <div style="font-size: 18px">{{ item.time }}</div> |               <div style="font-size: 18px">{{ item.time }}</div> | ||||||
|               <n-tooltip | 
 | ||||||
|                 trigger="click" |               <div style="font-size: 18px"> | ||||||
|                 :disabled="!item.showTooltip" |  | ||||||
|                 width="trigger" |  | ||||||
|               > |  | ||||||
|                 <template #trigger> |  | ||||||
|                   <div |  | ||||||
|                     :ref="(el) => setTitleRef(el, index)" |  | ||||||
|                     style=" |  | ||||||
|                       font-size: 18px; |  | ||||||
|                       word-break: break-word; |  | ||||||
|                       display: -webkit-box; |  | ||||||
|                       -webkit-line-clamp: 2; |  | ||||||
|                       -webkit-box-orient: vertical; |  | ||||||
|                       overflow: hidden; |  | ||||||
|                       text-overflow: ellipsis; |  | ||||||
|                     " |  | ||||||
|                   > |  | ||||||
|                 {{ item.title }} |                 {{ item.title }} | ||||||
|               </div> |               </div> | ||||||
|                 </template> |  | ||||||
|                 <div slot="content"> |  | ||||||
|                   {{ item.title }} |  | ||||||
|                 </div> |  | ||||||
|               </n-tooltip> |  | ||||||
|             </div> |             </div> | ||||||
| 
 | 
 | ||||||
|             <div |             <div | ||||||
|               style="font-size: 18px;flex-shrink: 0;margin: 0 0 0 0.6rem;" |               style="font-size: 18px" | ||||||
|               class="cursor-pointer" |               class="cursor-pointer" | ||||||
|               @click="handleLink(item)" |               @click="handleLink(item.router, item.time)" | ||||||
|             > |             > | ||||||
|               View Press Release<img |               View Press Release<img | ||||||
|                 class="ml-[10px]" |                 class="ml-[10px]" | ||||||
| @ -115,13 +94,6 @@ | |||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <div v-if="newList.length === 0" class="flex justify-center items-center"> |  | ||||||
|           <img |  | ||||||
|             src="@/assets/image/icon/default-empty.png" |  | ||||||
|             alt="empty" |  | ||||||
|             style="width: 109px; height: 60px;" |  | ||||||
|           /> |  | ||||||
|         </div> |  | ||||||
|       </div> |       </div> | ||||||
|     </section> |     </section> | ||||||
|     <!-- 新增:股票信息与活动预告双栏模块 --> |     <!-- 新增:股票信息与活动预告双栏模块 --> | ||||||
| @ -230,11 +202,9 @@ | |||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import { onMounted, ref, onUnmounted, computed, nextTick, watch } from "vue"; | import { onMounted, ref, onUnmounted, computed } from "vue"; | ||||||
| import { NTooltip } from 'naive-ui' |  | ||||||
| import { useI18n } from "vue-i18n"; | import { useI18n } from "vue-i18n"; | ||||||
| import { useStockQuote } from "@/store/stock-quote/index.js"; | import { useStockQuote } from "@/store/stock-quote/index.js"; | ||||||
| import axios from 'axios' |  | ||||||
| const { getStockQuate, stockQuote, formatted } = useStockQuote(); | const { getStockQuate, stockQuote, formatted } = useStockQuote(); | ||||||
| getStockQuate(); | getStockQuate(); | ||||||
| const { t: $t } = useI18n(); | const { t: $t } = useI18n(); | ||||||
| @ -242,44 +212,17 @@ const contentRef = ref(null); | |||||||
| const isInView = ref(false); | const isInView = ref(false); | ||||||
| let observer = null; | let observer = null; | ||||||
| const newList = ref([ | const newList = ref([ | ||||||
|   // { |   { | ||||||
|   //   time: "June 3, 2025", |     time: "June 3, 2025", | ||||||
|   //   title: "FiEE, Inc. seized market opportunities through 2025 Osaka Expo", |     title: "FiEE, Inc. seized market opportunities through 2025 Osaka Expo", | ||||||
|   //   router: "/news", |     router: "/news", | ||||||
|   // }, |   }, | ||||||
|   // { |   { | ||||||
|   //   time: "June 2, 2025", |     time: "June 2, 2025", | ||||||
|   //   title: "FiEE, Inc. Closes Its First Day of Trading on NASDAQ", |     title: "FiEE, Inc. Closes Its First Day of Trading on NASDAQ", | ||||||
|   //   router: "/news", |     router: "/news", | ||||||
|   // }, |   }, | ||||||
| ]); | ]); | ||||||
| 
 |  | ||||||
| // 获取新闻发布(展示在首页的) |  | ||||||
| const getPressReleasesDisplay = () => { |  | ||||||
|   let url = 'http://172.16.100.93:9020/api/fiee/pressreleases/display' |  | ||||||
|   let params = { |  | ||||||
|     page: 1, |  | ||||||
|     pageSize: 10, |  | ||||||
|     display: 2, // 1: 不展示在首页 2: 展示在首页 |  | ||||||
|   } |  | ||||||
|   // console.log(params) |  | ||||||
|   axios.post(url, params).then((res) => { |  | ||||||
|     // console.log(res) |  | ||||||
|     if (res.status === 200) { |  | ||||||
|       if (res.data.status === 0) { |  | ||||||
|         res.data.data?.data?.forEach((item) => { |  | ||||||
|           item.time = new Date(item.createdAt).toLocaleDateString('en-US', { |  | ||||||
|             month: 'long', |  | ||||||
|             day: 'numeric', |  | ||||||
|             year: 'numeric', |  | ||||||
|           }) |  | ||||||
|         }) |  | ||||||
|         newList.value = res.data.data?.data || [] |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   if (contentRef.value && "IntersectionObserver" in window) { |   if (contentRef.value && "IntersectionObserver" in window) { | ||||||
|     observer = new IntersectionObserver( |     observer = new IntersectionObserver( | ||||||
| @ -304,36 +247,8 @@ onMounted(() => { | |||||||
|     // 回退方案:如果不支持IntersectionObserver则直接显示 |     // 回退方案:如果不支持IntersectionObserver则直接显示 | ||||||
|     isInView.value = true; |     isInView.value = true; | ||||||
|   } |   } | ||||||
|   getPressReleasesDisplay() |  | ||||||
| 
 |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| const titleRefs = ref([]) |  | ||||||
| 
 |  | ||||||
| const setTitleRef = (el, idx) => { |  | ||||||
|   if (el) titleRefs.value[idx] = el |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const checkAllTitleOverflow = () => { |  | ||||||
|   newList.value.forEach((item, idx) => { |  | ||||||
|     const el = titleRefs.value[idx] |  | ||||||
|     if (!el) { |  | ||||||
|       item.showTooltip = false |  | ||||||
|       return |  | ||||||
|     } |  | ||||||
|     item.showTooltip = el.scrollHeight > el.clientHeight || el.scrollWidth > el.clientWidth |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| watch(() => newList.value, () => { |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }, { deep: true }) |  | ||||||
| 
 |  | ||||||
| onUnmounted(() => { | onUnmounted(() => { | ||||||
|   if (observer) { |   if (observer) { | ||||||
|     observer.disconnect(); |     observer.disconnect(); | ||||||
| @ -341,11 +256,11 @@ onUnmounted(() => { | |||||||
| }); | }); | ||||||
| import { useRouter } from "vue-router"; | import { useRouter } from "vue-router"; | ||||||
| const router = useRouter(); | const router = useRouter(); | ||||||
| const handleLink = (item) => { | const handleLink = (routers, index) => { | ||||||
|   router.push({ |   router.push({ | ||||||
|     path: "/news", |     path: routers, | ||||||
|     query: { |     query: { | ||||||
|       id: item.id, |       date: index, | ||||||
|     }, |     }, | ||||||
|   }); |   }); | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -74,37 +74,16 @@ | |||||||
|           > |           > | ||||||
|             <div> |             <div> | ||||||
|               <div style="font-size: 18px">{{ item.time }}</div> |               <div style="font-size: 18px">{{ item.time }}</div> | ||||||
|               <n-tooltip | 
 | ||||||
|                 trigger="click" |               <div style="font-size: 18px"> | ||||||
|                 :disabled="!item.showTooltip" |  | ||||||
|                 width="trigger" |  | ||||||
|               > |  | ||||||
|                 <template #trigger> |  | ||||||
|                   <div |  | ||||||
|                     :ref="(el) => setTitleRef(el, index)" |  | ||||||
|                     style=" |  | ||||||
|                       font-size: 18px; |  | ||||||
|                       word-break: break-word; |  | ||||||
|                       display: -webkit-box; |  | ||||||
|                       -webkit-line-clamp: 2; |  | ||||||
|                       -webkit-box-orient: vertical; |  | ||||||
|                       overflow: hidden; |  | ||||||
|                       text-overflow: ellipsis; |  | ||||||
|                     " |  | ||||||
|                   > |  | ||||||
|                 {{ item.title }} |                 {{ item.title }} | ||||||
|               </div> |               </div> | ||||||
|                 </template> |  | ||||||
|                 <div slot="content"> |  | ||||||
|                   {{ item.title }} |  | ||||||
|                 </div> |  | ||||||
|               </n-tooltip> |  | ||||||
|             </div> |             </div> | ||||||
| 
 | 
 | ||||||
|             <div |             <div | ||||||
|               style="font-size: 18px;flex-shrink: 0; margin: 0 0 0 0.9rem;" |               style="font-size: 18px" | ||||||
|               class="cursor-pointer" |               class="cursor-pointer" | ||||||
|               @click="handleLink(item)" |               @click="handleLink(item.router, item.time)" | ||||||
|             > |             > | ||||||
|               View Press Release<img |               View Press Release<img | ||||||
|                 class="ml-[10px]" |                 class="ml-[10px]" | ||||||
| @ -115,13 +94,6 @@ | |||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <div v-if="newList.length === 0" class="flex justify-center items-center"> |  | ||||||
|           <img |  | ||||||
|             src="@/assets/image/icon/default-empty.png" |  | ||||||
|             alt="empty" |  | ||||||
|             style="width: 109px; height: 60px;" |  | ||||||
|           /> |  | ||||||
|         </div> |  | ||||||
|       </div> |       </div> | ||||||
|     </section> |     </section> | ||||||
|     <!-- 新增:股票信息与活动预告双栏模块 --> |     <!-- 新增:股票信息与活动预告双栏模块 --> | ||||||
| @ -230,11 +202,9 @@ | |||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import { onMounted, ref, onUnmounted, computed, nextTick, watch } from "vue"; | import { onMounted, ref, onUnmounted, computed } from "vue"; | ||||||
| import { NTooltip } from 'naive-ui' |  | ||||||
| import { useI18n } from "vue-i18n"; | import { useI18n } from "vue-i18n"; | ||||||
| import { useStockQuote } from "@/store/stock-quote/index.js"; | import { useStockQuote } from "@/store/stock-quote/index.js"; | ||||||
| import axios from 'axios' |  | ||||||
| const { getStockQuate, stockQuote, formatted } = useStockQuote(); | const { getStockQuate, stockQuote, formatted } = useStockQuote(); | ||||||
| 
 | 
 | ||||||
| getStockQuate(); | getStockQuate(); | ||||||
| @ -244,19 +214,6 @@ const contentRef = ref(null); | |||||||
| const isInView = ref(false); | const isInView = ref(false); | ||||||
| let observer = null; | let observer = null; | ||||||
| 
 | 
 | ||||||
| const newList = ref([ |  | ||||||
|   // { |  | ||||||
|   //   time: "June 3, 2025", |  | ||||||
|   //   title: "FiEE, Inc. seized market opportunities through 2025 Osaka Expo", |  | ||||||
|   //   router: "/news", |  | ||||||
|   // }, |  | ||||||
|   // { |  | ||||||
|   //   time: "June 2, 2025", |  | ||||||
|   //   title: "FiEE, Inc. Closes Its First Day of Trading on NASDAQ", |  | ||||||
|   //   router: "/news", |  | ||||||
|   // }, |  | ||||||
| ]); |  | ||||||
| 
 |  | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   if (contentRef.value && "IntersectionObserver" in window) { |   if (contentRef.value && "IntersectionObserver" in window) { | ||||||
|     observer = new IntersectionObserver( |     observer = new IntersectionObserver( | ||||||
| @ -281,61 +238,19 @@ onMounted(() => { | |||||||
|     // 回退方案:如果不支持IntersectionObserver则直接显示 |     // 回退方案:如果不支持IntersectionObserver则直接显示 | ||||||
|     isInView.value = true; |     isInView.value = true; | ||||||
|   } |   } | ||||||
|   getPressReleasesDisplay() |  | ||||||
| 
 |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }); | }); | ||||||
| 
 | const newList = ref([ | ||||||
| const titleRefs = ref([]) |   { | ||||||
| 
 |     time: "June 3, 2025", | ||||||
| const setTitleRef = (el, idx) => { |     title: "FiEE, Inc. seized market opportunities through 2025 Osaka Expo", | ||||||
|   if (el) titleRefs.value[idx] = el |     router: "/news", | ||||||
| } |   }, | ||||||
| 
 |   { | ||||||
| const checkAllTitleOverflow = () => { |     time: "June 2, 2025", | ||||||
|   newList.value.forEach((item, idx) => { |     title: "FiEE, Inc. Closes Its First Day of Trading on NASDAQ", | ||||||
|     const el = titleRefs.value[idx] |     router: "/news", | ||||||
|     if (!el) { |   }, | ||||||
|       item.showTooltip = false | ]); | ||||||
|       return |  | ||||||
|     } |  | ||||||
|     item.showTooltip = el.scrollHeight > el.clientHeight || el.scrollWidth > el.clientWidth |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| watch(() => newList.value, () => { |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }, { deep: true }) |  | ||||||
| 
 |  | ||||||
| // 获取新闻发布(展示在首页的) |  | ||||||
| const getPressReleasesDisplay = () => { |  | ||||||
|   let url = 'http://172.16.100.93:9020/api/fiee/pressreleases/display' |  | ||||||
|   let params = { |  | ||||||
|     page: 1, |  | ||||||
|     pageSize: 10, |  | ||||||
|     display: 2, // 1: 不展示在首页 2: 展示在首页 |  | ||||||
|   } |  | ||||||
|   // console.log(params) |  | ||||||
|   axios.post(url, params).then((res) => { |  | ||||||
|     // console.log(res) |  | ||||||
|     if (res.status === 200) { |  | ||||||
|       if (res.data.status === 0) { |  | ||||||
|         res.data.data?.data?.forEach((item) => { |  | ||||||
|           item.time = new Date(item.createdAt).toLocaleDateString('en-US', { |  | ||||||
|             month: 'long', |  | ||||||
|             day: 'numeric', |  | ||||||
|             year: 'numeric', |  | ||||||
|           }) |  | ||||||
|         }) |  | ||||||
|         newList.value = res.data.data?.data || [] |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| onUnmounted(() => { | onUnmounted(() => { | ||||||
|   if (observer) { |   if (observer) { | ||||||
| @ -344,11 +259,11 @@ onUnmounted(() => { | |||||||
| }); | }); | ||||||
| import { useRouter } from "vue-router"; | import { useRouter } from "vue-router"; | ||||||
| const router = useRouter(); | const router = useRouter(); | ||||||
| const handleLink = (item) => { | const handleLink = (routers, index) => { | ||||||
|   router.push({ |   router.push({ | ||||||
|     path: "/news", |     path: routers, | ||||||
|     query: { |     query: { | ||||||
|       id: item.id, |       date: index, | ||||||
|     }, |     }, | ||||||
|   }); |   }); | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -1,6 +1,339 @@ | |||||||
| <template> | <template> | ||||||
|   <div class="page-container"> |   <div class="page-container"> | ||||||
|     <div id="my-richText"></div> |     <template v-if="state.date === 'May 30, 2025'"> | ||||||
|  |       <h2> | ||||||
|  |         <strong>FiEE, Inc. Announces Reinitiation of Trading on Nasdaq</strong> | ||||||
|  |       </h2> | ||||||
|  |       <p>May 30, 2025</p> | ||||||
|  |       <p> | ||||||
|  |         <em>Company will resume trading under its existing symbol "MINM"</em> | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Hong Kong, May 30, 2025 </strong>— FiEE, Inc. (“FiEE, Inc.” or | ||||||
|  |         the “Company”), a technology company integrating IoT, connectivity and | ||||||
|  |         AI to redefine brand management solutions in the digital era, is pleased | ||||||
|  |         to announce that following a hearing before the Nasdaq Hearings Panel | ||||||
|  |         (the “Panel”) on May 13, 2025, the Panel issued a decision on May 29, | ||||||
|  |         2025, stating that Nasdaq will reinstate trading of the Company's common | ||||||
|  |         stock on the Nasdaq Capital Market at the open of business on Monday, | ||||||
|  |         June 2, 2025 under the ticker symbol "MINM". | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Rafael Li, Chief Executive Officer of FiEE, </strong>commented, | ||||||
|  |         "We are honored to announce the reinitiation of trading of our common | ||||||
|  |         stock on Nasdaq, a significant milestone that reflects our unwavering | ||||||
|  |         commitment to operational excellence and strategic growth. We extend our | ||||||
|  |         sincere gratitude to the Nasdaq team for their prompt review and | ||||||
|  |         approval of our request, affirming our compliance with all applicable | ||||||
|  |         criteria for continued listing on the Nasdaq Capital Market. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. is currently undergoing a strategic transformation aimed at | ||||||
|  |         capitalizing on broader market opportunities. Central to this evolution | ||||||
|  |         is our integrated approach, where cyber-hardened IoT connectivity | ||||||
|  |         converges with AI-driven content creation and audience targeting. This | ||||||
|  |         synergy is designed to empower Key Opinion Leaders (KOLs) and brands to | ||||||
|  |         achieve accelerated growth and deeper audience engagement. Leveraging | ||||||
|  |         IoT-connectivity solutions, AI and big data analytics, we are capable of | ||||||
|  |         delivering intelligent, multimedia and multilingual content tailored to | ||||||
|  |         diverse audiences. Coupling with AI targeting analysis, we enhance | ||||||
|  |         audience targeting capabilities, ensuring effective content placement | ||||||
|  |         and personalized promotions. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         As we advance, our focus remains on continuous innovation and strategic | ||||||
|  |         initiatives that drive long- term growth and shareholder value." | ||||||
|  |       </p> | ||||||
|  |       <h3>About FiEE, Inc.</h3> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. (NASDAQ: MINM), formerly Minim, Inc., was founded in 1977. It | ||||||
|  |         has a historical track record of delivering comprehensive WiFi/Software | ||||||
|  |         as a Service platform in the market. After years of development, it made | ||||||
|  |         the strategic decision to transition to a Software First Model in 2023 | ||||||
|  |         to expand our technology portfolio and revenue streams. In 2025, FiEE, | ||||||
|  |         Inc. rebranded itself as a technology company leveraging the expertise | ||||||
|  |         in IoT, connectivity, and artificial intelligence ("AI") to explore new | ||||||
|  |         business prospects and extend our global footprint. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         Our services are structured 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. | ||||||
|  |       </p> | ||||||
|  |       <h3>Forward-Looking Statements</h3> | ||||||
|  |       <p> | ||||||
|  |         This communication contains forward-looking statements which include, | ||||||
|  |         but are not limited to, statements regarding the Company's listing of | ||||||
|  |         its common stock on Nasdaq; the impact of the listing; the Company's | ||||||
|  |         business strategy, including its strategic transformation; and the | ||||||
|  |         Company's ability to drive long-term growth and shareholder value. These | ||||||
|  |         forward-looking statements are subject to the safe harbor provisions | ||||||
|  |         under the Private Securities Litigation Reform Act of 1995. The | ||||||
|  |         Company's expectations and beliefs regarding these matters may not | ||||||
|  |         materialize. Actual outcomes and results may differ materially from | ||||||
|  |         those contemplated by these forward-looking statements as a result of | ||||||
|  |         uncertainties, risks, and changes in circumstances, including but not | ||||||
|  |         limited to risks and uncertainties related to: the ability of the | ||||||
|  |         Company to maintain compliance with the Nasdaq continued listing | ||||||
|  |         standards; the impact of fluctuations in global financial markets on the | ||||||
|  |         Company's business and the actions it may take in response thereto; the | ||||||
|  |         Company's ability to execute its plans and strategies; and the impact of | ||||||
|  |         government laws and regulations. Additional risks and uncertainties that | ||||||
|  |         could cause actual outcomes and results to differ materially from those | ||||||
|  |         contemplated by the forward- looking statements are included under the | ||||||
|  |         caption "Risk Factors" in the Company's Quarterly Report on Form 10-Q | ||||||
|  |         for the quarter ended March 31, 2025 and elsewhere in the Company's | ||||||
|  |         subsequent reports on Form 10-K, Form 10-Q or Form 8-K filed with the | ||||||
|  |         U.S. Securities and Exchange Commission from time to time and available | ||||||
|  |         at | ||||||
|  |         <a href="http://www.sec.gov/">www.sec.gov.</a> | ||||||
|  |       </p> | ||||||
|  |       <div><strong>Media </strong></div> | ||||||
|  |       <a href="mailto:fiee@dlkadvisory.com">fiee@dlkadvisory.com</a> | ||||||
|  |       <div>Source: FiEE, Inc.</div> | ||||||
|  |     </template> | ||||||
|  |     <template v-if="state.date === 'June 2, 2025'"> | ||||||
|  |       <h2> | ||||||
|  |         <strong>FiEE, Inc. Closes Its First Day of Trading on NASDAQ </strong> | ||||||
|  |       </h2> | ||||||
|  |       <p>June 2, 2025</p> | ||||||
|  |       <p><em>Company resumed trading under its existing symbol "MINM" </em></p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Hong Kong, 2 June 2025 </strong>— FiEE, Inc. (NASDAQ:MINM) | ||||||
|  |         (“FiEE, Inc.” or the “Company”), a technology company integrating IoT, | ||||||
|  |         connectivity and AI to redefine brand management solutions in the | ||||||
|  |         digital era, commenced the trading of its common stock on Monday, June | ||||||
|  |         2, 2025 on the Nasdaq Capital Market under the ticker symbol "MINM". | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         With the vision of growing Key Opinion Leaders (“KOLs”) in the market, | ||||||
|  |         FiEE, Inc. is currently strategically transforming to seize market | ||||||
|  |         opportunities with its innovative brand management solutions for the | ||||||
|  |         underrecognized talents. Since 2023, FiEE, Inc. has been pivoting to a | ||||||
|  |         Software First business model through enhancing its MinimOS cloud | ||||||
|  |         platform and API suite for ISPs/OEMs, as well merging with e2Companies | ||||||
|  |         to broaden its technology and revenue base. Currently, it is offering | ||||||
|  |         multi-faceted IoT-enabled Connectivity Solutions for the talented | ||||||
|  |         individuals in the market, including Cloud-Managed Connectivity (WiFi) | ||||||
|  |         Platform, IoT Hardware Sales & Licensing, SAAS Solutions, and | ||||||
|  |         Professional To-C and To-B Services & Support. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         With its innovative positioning, FiEE, Inc. is addressing significant | ||||||
|  |         challenges faced by talented individuals in the market, such as | ||||||
|  |         insufficient promotion channels, overdependence on offline events, and | ||||||
|  |         high costs of conventional advertising. It is establishing a | ||||||
|  |         comprehensive value ecosystem that offers a secure, diverse and enduring | ||||||
|  |         platform for these talents, aiming to elevate their personal brand and | ||||||
|  |         influence. Leveraging robust technological foundation on cybersecurity, | ||||||
|  |         market analysis, AI and big data analysis, the Company is also | ||||||
|  |         positioned to safeguard original creations, digital arts, NFTs and | ||||||
|  |         exclusive content for these talented individuals. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Rafael Li, Chief Executive Officer of FiEE, Inc.</strong> added, | ||||||
|  |         "We are glad to witness our common stock resumed trading on Nasdaq. In | ||||||
|  |         the foreseeable future, I plan to lead the team to continuously enhance | ||||||
|  |         our technological capabilities, utilizing AI, big data analysis, and our | ||||||
|  |         long-standing IoT-enabled Connectivity Solutions to match potential | ||||||
|  |         users in the market and provide them with comprehensive solutions. Our | ||||||
|  |         long-term goal is to build a unique KOL community with billions of fans, | ||||||
|  |         empowering them to achieve sustained success in the digital landscape. | ||||||
|  |         We are confident that with our new positioning, FiEE, Inc. will reach | ||||||
|  |         new heights and create long-lasting value for our shareholders.” | ||||||
|  |       </p> | ||||||
|  |       <p><strong>About FiEE, Inc.</strong></p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. (NASDAQ:MINM), formerly Minim, Inc., was founded in 1977. It | ||||||
|  |         has a historical track record of delivering comprehensive WiFi/Software | ||||||
|  |         as a Service platform in the market. After years of development, it made | ||||||
|  |         the strategic decision to transition to a Software First Model in 2023 | ||||||
|  |         to expand its technology portfolio and revenue streams. In 2025, FiEE, | ||||||
|  |         Inc. rebranded itself as a technology company leveraging the expertise | ||||||
|  |         in IoT, connectivity, and AI to explore new business prospects and | ||||||
|  |         extend its global footprint. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc.'s services are structured 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, FiEE, Inc. has introduced its innovative Software as a | ||||||
|  |         Service solutions, which integrate its AI and data analytics | ||||||
|  |         capabilities into content creation and brand management. This initiative | ||||||
|  |         has led to the nurturing of a robust pool of KOLs on major social media | ||||||
|  |         platforms worldwide, assisting them in developing, managing, and | ||||||
|  |         optimizing their digital presence across global platforms. FiEE Inc.'s | ||||||
|  |         services include customized graphics and posts, short videos, and | ||||||
|  |         editorial calendars tailored to align with brand objectives. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Forward-Looking Statements</strong><br />This communication | ||||||
|  |         contains forward-looking statements which include, but are not limited | ||||||
|  |         to, statements regarding the Company's listing of its common stock on | ||||||
|  |         Nasdaq; the impact of the listing; the Company's business strategy, | ||||||
|  |         including its strategic transformation; and the Company's ability to | ||||||
|  |         drive long-term growth and shareholder value. These forward-looking | ||||||
|  |         statements are subject to the safe harbor provisions under the Private | ||||||
|  |         Securities Litigation Reform Act of 1995. The Company's expectations and | ||||||
|  |         beliefs regarding these matters may not materialize. Actual outcomes and | ||||||
|  |         results may differ materially from those contemplated by these | ||||||
|  |         forward-looking statements as a result of uncertainties, risks, and | ||||||
|  |         changes in circumstances, including but not limited to risks and | ||||||
|  |         uncertainties related to: the ability of the Company to maintain | ||||||
|  |         compliance with the Nasdaq continued listing standards; the impact of | ||||||
|  |         fluctuations in global financial markets on the Company's business and | ||||||
|  |         the actions it may take in response thereto; the Company's ability to | ||||||
|  |         execute its plans and strategies; and the impact of government laws and | ||||||
|  |         regulations. Additional risks and uncertainties that could cause actual | ||||||
|  |         outcomes and results to differ materially from those contemplated by the | ||||||
|  |         forward-looking statements are included under the caption "Risk Factors" | ||||||
|  |         in the Company's Quarterly Report on Form 10-Q for the quarter ended | ||||||
|  |         March 31, 2025 and elsewhere in the Company's subsequent reports on Form | ||||||
|  |         10-K, Form 10-Q or Form 8-K filed with the U.S. Securities and Exchange | ||||||
|  |         Commission from time to time and available at www.sec.gov. | ||||||
|  |       </p> | ||||||
|  | 
 | ||||||
|  |       <div><strong>Media </strong></div> | ||||||
|  |       <a href="mailto:fiee@dlkadvisory.com">fiee@dlkadvisory.com</a> | ||||||
|  |       <div>Source: FiEE, Inc.</div> | ||||||
|  |     </template> | ||||||
|  |     <template v-if="state.date === 'June 3, 2025'"> | ||||||
|  |       <h2> | ||||||
|  |         <strong | ||||||
|  |           >FiEE, Inc. seized market opportunities through 2025 Osaka | ||||||
|  |           Expo</strong | ||||||
|  |         > | ||||||
|  |       </h2> | ||||||
|  |       <p>3 June, 2025</p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Hong Kong, 3 June 2025 </strong>— FiEE, Inc. (NASDAQ:MINM) | ||||||
|  |         (“FiEE, Inc.” or the “Company”), a technology company integrating IoT, | ||||||
|  |         connectivity and AI to redefine brand management solutions in the | ||||||
|  |         digital era, is pleased to announce significant business updates. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         Recently, FiEE, Inc. has entered into a strategic agency and cooperation | ||||||
|  |         agreement with Beijing Yilian World Expo Business Management Group Co., | ||||||
|  |         Ltd. (“Beijing Yilian”). The Company is appointed as the agent to | ||||||
|  |         introduce businesses to participate in the international trade fair held | ||||||
|  |         at INTEX Osaka. The trade fair will be held from mid-June to August | ||||||
|  |         2025, featuring a diverse range of categories, including International | ||||||
|  |         Wine, Food and Equipment; International Leather and Footwear; | ||||||
|  |         International Tea, Ceramics, Jewelry, Watches, Crafts and Art; | ||||||
|  |         International Hardware, Building Materials and Interior Decoration; | ||||||
|  |         International New Energy and Emerging Industries Technology. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Rafael Li, Chief Executive Officer of FiEE, Inc.</strong>, | ||||||
|  |         commented, “INTEX Osaka is a famous International Trade Fair and | ||||||
|  |         Exhibition in Collaboration with the 2025 Osaka Expo. It is expected to | ||||||
|  |         draw numerous visitors, presenting a valuable opportunity for marketing | ||||||
|  |         and exposure. This strategic cooperation highlights the Company's | ||||||
|  |         extensive network resources, facilitating the identification of suitable | ||||||
|  |         businesses or Key Opinion Leaders (“KOLs”) to participate in | ||||||
|  |         international trade fairs, bolstering their reputation and influence.” | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         In addition, the Company launched its new SaaS products for the talented | ||||||
|  |         individuals in March 2025, which is anticipated to generate recurring | ||||||
|  |         revenue streams while also scaling rapidly to capture a large customer | ||||||
|  |         base over time. The talented individuals subscribing for our SaaS | ||||||
|  |         products would gain access to abundant resources, such as brand / | ||||||
|  |         product partnership and sponsorship, affiliate marketing and product | ||||||
|  |         placement, IP protection services, among others. FiEE Inc. has signed | ||||||
|  |         sales contracts with 40 new customers, securing over US$200,000 in | ||||||
|  |         expected revenue in less than two months. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. is currently undergoing a strategic transformation to seize | ||||||
|  |         market opportunities with its innovative brand management solutions for | ||||||
|  |         underrecognized talents. It is offering multi-faceted IoT-enabled | ||||||
|  |         Connectivity Solutions for the talented individuals in the market, | ||||||
|  |         including Cloud-Managed Connectivity (WiFi) Platform, IoT Hardware Sales | ||||||
|  |         & Licensing, SAAS Solutions, and Professional To-C and To-B Services | ||||||
|  |         & Support. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         With its innovative positioning, FiEE, Inc. is establishing a | ||||||
|  |         comprehensive value ecosystem that offers a secure, diverse and enduring | ||||||
|  |         platform for the talented individuals, aiming to elevate their personal | ||||||
|  |         brand and influence. Leveraging a robust technological foundation on | ||||||
|  |         cybersecurity, market analysis, AI and big data analysis, the Company is | ||||||
|  |         also positioned to safeguard original creations, digital arts, NFTs and | ||||||
|  |         exclusive content for these talented individuals. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc.’s long-term goal is to build a unique KOL community with | ||||||
|  |         billions of fans, empowering them to achieve sustained success in the | ||||||
|  |         digital landscape. With its new positioning, the Company believes it | ||||||
|  |         will reach new heights and create long-lasting value for its | ||||||
|  |         shareholders. | ||||||
|  |       </p> | ||||||
|  |       <p><strong>About FiEE, Inc.</strong></p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. (NASDAQ:MINM), formerly Minim, Inc., was founded in 1977. It | ||||||
|  |         has a historical track record of delivering comprehensive WiFi/Software | ||||||
|  |         as a Service platform in the market. After years of development, it made | ||||||
|  |         the strategic decision to transition to a Software First Model in 2023 | ||||||
|  |         to expand its technology portfolio and revenue streams. In 2025, FiEE, | ||||||
|  |         Inc. rebranded itself as a technology company leveraging its expertise | ||||||
|  |         in IoT, connectivity, and AI to explore new business prospects and | ||||||
|  |         extend its global footprint. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc.’s services are structured 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, FiEE, Inc. has introduced its innovative Software as a | ||||||
|  |         Service solutions, which integrate its AI and data analytics | ||||||
|  |         capabilities into content creation and brand management. This initiative | ||||||
|  |         has led to the nurturing of a robust pool of KOLs on major social media | ||||||
|  |         platforms worldwide, assisting them in developing, managing, and | ||||||
|  |         optimizing their digital presence across global platforms. FiEE Inc.’s | ||||||
|  |         services include customized graphics and posts, short videos, and | ||||||
|  |         editorial calendars tailored to align with brand objectives. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Forward-Looking Statements</strong><br />This communication | ||||||
|  |         contains forward-looking statements which include, but are not limited | ||||||
|  |         to, statements regarding the benefits of the strategic agency and | ||||||
|  |         cooperation agreement entered into with Beijing Yilian; the expected | ||||||
|  |         success of the Company’s new SaaS products; the Company’s business | ||||||
|  |         strategy, including its strategic transformation; and the Company’s | ||||||
|  |         ability to drive long-term growth and shareholder value. These | ||||||
|  |         forward-looking statements are subject to the safe harbor provisions | ||||||
|  |         under the Private Securities Litigation Reform Act of 1995. The | ||||||
|  |         Company’s expectations and beliefs regarding these matters may not | ||||||
|  |         materialize. Actual outcomes and results may differ materially from | ||||||
|  |         those contemplated by these forward-looking statements as a result of | ||||||
|  |         uncertainties, risks, and changes in circumstances, including but not | ||||||
|  |         limited to risks and uncertainties related to: the ability of the | ||||||
|  |         Company to maintain compliance with the Nasdaq continued listing | ||||||
|  |         standards; the impact of fluctuations in global financial markets on the | ||||||
|  |         Company’s business and the actions it may take in response thereto; the | ||||||
|  |         Company’s ability to execute its plans and strategies; and the impact of | ||||||
|  |         government laws and regulations. Additional risks and uncertainties that | ||||||
|  |         could cause actual outcomes and results to differ materially from those | ||||||
|  |         contemplated by the forward-looking statements are included under the | ||||||
|  |         caption “Risk Factors” in the Company’s Quarterly Report on Form 10-Q | ||||||
|  |         for the quarter ended March 31, 2025 and elsewhere in the Company’s | ||||||
|  |         subsequent reports on Form 10-K, Form 10-Q or Form 8-K filed with the | ||||||
|  |         U.S. Securities and Exchange Commission from time to time and available | ||||||
|  |         at www.sec.gov. | ||||||
|  |       </p> | ||||||
|  | 
 | ||||||
|  |       <div><strong>Media </strong></div> | ||||||
|  |       <a href="mailto:fiee@dlkadvisory.com">fiee@dlkadvisory.com</a> | ||||||
|  |       <div>Source: FiEE, Inc.</div> | ||||||
|  |     </template> | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| @ -12,31 +345,15 @@ import { useI18n } from "vue-i18n"; | |||||||
| const { t } = useI18n(); | const { t } = useI18n(); | ||||||
| import { useRoute } from "vue-router"; | import { useRoute } from "vue-router"; | ||||||
| const route = useRoute(); | const route = useRoute(); | ||||||
| import axios from 'axios' |  | ||||||
| 
 | 
 | ||||||
| const state = reactive({ | const state = reactive({ | ||||||
|   id: "", // 新闻id |   date: "", | ||||||
| }); | }); | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   if (route.query.id) { |   if (route.query.date) { | ||||||
|     state.id = route.query.id; |     state.date = route.query.date; | ||||||
|   } |   } | ||||||
|   getPressReleasesInfo(); |  | ||||||
| }); | }); | ||||||
| 
 |  | ||||||
| //获取新闻信息 |  | ||||||
| const getPressReleasesInfo = () => { |  | ||||||
|   let url = 'http://172.16.100.93:9020/api/fiee/pressreleases?id=' + state.id |  | ||||||
|   axios.get(url).then((res) => { |  | ||||||
|     // console.log(res) |  | ||||||
|     if (res.status === 200) { |  | ||||||
|       if (res.data.status === 0) { |  | ||||||
|        const myRichText = document.getElementById('my-richText') |  | ||||||
|        myRichText.innerHTML = res.data.data.content |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
|  | |||||||
| @ -1,6 +1,339 @@ | |||||||
| <template> | <template> | ||||||
|   <div class="page-container"> |   <div class="page-container"> | ||||||
|     <div id="my-richText"></div> |     <template v-if="state.date === 'May 30, 2025'"> | ||||||
|  |       <h2> | ||||||
|  |         <strong>FiEE, Inc. Announces Reinitiation of Trading on Nasdaq</strong> | ||||||
|  |       </h2> | ||||||
|  |       <p>May 30, 2025</p> | ||||||
|  |       <p> | ||||||
|  |         <em>Company will resume trading under its existing symbol "MINM"</em> | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Hong Kong, May 30, 2025 </strong>— FiEE, Inc. (“FiEE, Inc.” or | ||||||
|  |         the “Company”), a technology company integrating IoT, connectivity and | ||||||
|  |         AI to redefine brand management solutions in the digital era, is pleased | ||||||
|  |         to announce that following a hearing before the Nasdaq Hearings Panel | ||||||
|  |         (the “Panel”) on May 13, 2025, the Panel issued a decision on May 29, | ||||||
|  |         2025, stating that Nasdaq will reinstate trading of the Company's common | ||||||
|  |         stock on the Nasdaq Capital Market at the open of business on Monday, | ||||||
|  |         June 2, 2025 under the ticker symbol "MINM". | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Rafael Li, Chief Executive Officer of FiEE, </strong>commented, | ||||||
|  |         "We are honored to announce the reinitiation of trading of our common | ||||||
|  |         stock on Nasdaq, a significant milestone that reflects our unwavering | ||||||
|  |         commitment to operational excellence and strategic growth. We extend our | ||||||
|  |         sincere gratitude to the Nasdaq team for their prompt review and | ||||||
|  |         approval of our request, affirming our compliance with all applicable | ||||||
|  |         criteria for continued listing on the Nasdaq Capital Market. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. is currently undergoing a strategic transformation aimed at | ||||||
|  |         capitalizing on broader market opportunities. Central to this evolution | ||||||
|  |         is our integrated approach, where cyber-hardened IoT connectivity | ||||||
|  |         converges with AI-driven content creation and audience targeting. This | ||||||
|  |         synergy is designed to empower Key Opinion Leaders (KOLs) and brands to | ||||||
|  |         achieve accelerated growth and deeper audience engagement. Leveraging | ||||||
|  |         IoT-connectivity solutions, AI and big data analytics, we are capable of | ||||||
|  |         delivering intelligent, multimedia and multilingual content tailored to | ||||||
|  |         diverse audiences. Coupling with AI targeting analysis, we enhance | ||||||
|  |         audience targeting capabilities, ensuring effective content placement | ||||||
|  |         and personalized promotions. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         As we advance, our focus remains on continuous innovation and strategic | ||||||
|  |         initiatives that drive long- term growth and shareholder value." | ||||||
|  |       </p> | ||||||
|  |       <h3>About FiEE, Inc.</h3> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. (NASDAQ: MINM), formerly Minim, Inc., was founded in 1977. It | ||||||
|  |         has a historical track record of delivering comprehensive WiFi/Software | ||||||
|  |         as a Service platform in the market. After years of development, it made | ||||||
|  |         the strategic decision to transition to a Software First Model in 2023 | ||||||
|  |         to expand our technology portfolio and revenue streams. In 2025, FiEE, | ||||||
|  |         Inc. rebranded itself as a technology company leveraging the expertise | ||||||
|  |         in IoT, connectivity, and artificial intelligence ("AI") to explore new | ||||||
|  |         business prospects and extend our global footprint. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         Our services are structured 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. | ||||||
|  |       </p> | ||||||
|  |       <h3>Forward-Looking Statements</h3> | ||||||
|  |       <p> | ||||||
|  |         This communication contains forward-looking statements which include, | ||||||
|  |         but are not limited to, statements regarding the Company's listing of | ||||||
|  |         its common stock on Nasdaq; the impact of the listing; the Company's | ||||||
|  |         business strategy, including its strategic transformation; and the | ||||||
|  |         Company's ability to drive long-term growth and shareholder value. These | ||||||
|  |         forward-looking statements are subject to the safe harbor provisions | ||||||
|  |         under the Private Securities Litigation Reform Act of 1995. The | ||||||
|  |         Company's expectations and beliefs regarding these matters may not | ||||||
|  |         materialize. Actual outcomes and results may differ materially from | ||||||
|  |         those contemplated by these forward-looking statements as a result of | ||||||
|  |         uncertainties, risks, and changes in circumstances, including but not | ||||||
|  |         limited to risks and uncertainties related to: the ability of the | ||||||
|  |         Company to maintain compliance with the Nasdaq continued listing | ||||||
|  |         standards; the impact of fluctuations in global financial markets on the | ||||||
|  |         Company's business and the actions it may take in response thereto; the | ||||||
|  |         Company's ability to execute its plans and strategies; and the impact of | ||||||
|  |         government laws and regulations. Additional risks and uncertainties that | ||||||
|  |         could cause actual outcomes and results to differ materially from those | ||||||
|  |         contemplated by the forward- looking statements are included under the | ||||||
|  |         caption "Risk Factors" in the Company's Quarterly Report on Form 10-Q | ||||||
|  |         for the quarter ended March 31, 2025 and elsewhere in the Company's | ||||||
|  |         subsequent reports on Form 10-K, Form 10-Q or Form 8-K filed with the | ||||||
|  |         U.S. Securities and Exchange Commission from time to time and available | ||||||
|  |         at | ||||||
|  |         <a href="http://www.sec.gov/">www.sec.gov.</a> | ||||||
|  |       </p> | ||||||
|  |       <div><strong>Media </strong></div> | ||||||
|  |       <a href="mailto:fiee@dlkadvisory.com">fiee@dlkadvisory.com</a> | ||||||
|  |       <div>Source: FiEE, Inc.</div> | ||||||
|  |     </template> | ||||||
|  |     <template v-if="state.date === 'June 2, 2025'"> | ||||||
|  |       <h2> | ||||||
|  |         <strong>FiEE, Inc. Closes Its First Day of Trading on NASDAQ </strong> | ||||||
|  |       </h2> | ||||||
|  |       <p>June 2, 2025</p> | ||||||
|  |       <p><em>Company resumed trading under its existing symbol "MINM" </em></p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Hong Kong, 2 June 2025 </strong>— FiEE, Inc. (NASDAQ:MINM) | ||||||
|  |         (“FiEE, Inc.” or the “Company”), a technology company integrating IoT, | ||||||
|  |         connectivity and AI to redefine brand management solutions in the | ||||||
|  |         digital era, commenced the trading of its common stock on Monday, June | ||||||
|  |         2, 2025 on the Nasdaq Capital Market under the ticker symbol "MINM". | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         With the vision of growing Key Opinion Leaders (“KOLs”) in the market, | ||||||
|  |         FiEE, Inc. is currently strategically transforming to seize market | ||||||
|  |         opportunities with its innovative brand management solutions for the | ||||||
|  |         underrecognized talents. Since 2023, FiEE, Inc. has been pivoting to a | ||||||
|  |         Software First business model through enhancing its MinimOS cloud | ||||||
|  |         platform and API suite for ISPs/OEMs, as well merging with e2Companies | ||||||
|  |         to broaden its technology and revenue base. Currently, it is offering | ||||||
|  |         multi-faceted IoT-enabled Connectivity Solutions for the talented | ||||||
|  |         individuals in the market, including Cloud-Managed Connectivity (WiFi) | ||||||
|  |         Platform, IoT Hardware Sales & Licensing, SAAS Solutions, and | ||||||
|  |         Professional To-C and To-B Services & Support. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         With its innovative positioning, FiEE, Inc. is addressing significant | ||||||
|  |         challenges faced by talented individuals in the market, such as | ||||||
|  |         insufficient promotion channels, overdependence on offline events, and | ||||||
|  |         high costs of conventional advertising. It is establishing a | ||||||
|  |         comprehensive value ecosystem that offers a secure, diverse and enduring | ||||||
|  |         platform for these talents, aiming to elevate their personal brand and | ||||||
|  |         influence. Leveraging robust technological foundation on cybersecurity, | ||||||
|  |         market analysis, AI and big data analysis, the Company is also | ||||||
|  |         positioned to safeguard original creations, digital arts, NFTs and | ||||||
|  |         exclusive content for these talented individuals. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Rafael Li, Chief Executive Officer of FiEE, Inc.</strong> added, | ||||||
|  |         "We are glad to witness our common stock resumed trading on Nasdaq. In | ||||||
|  |         the foreseeable future, I plan to lead the team to continuously enhance | ||||||
|  |         our technological capabilities, utilizing AI, big data analysis, and our | ||||||
|  |         long-standing IoT-enabled Connectivity Solutions to match potential | ||||||
|  |         users in the market and provide them with comprehensive solutions. Our | ||||||
|  |         long-term goal is to build a unique KOL community with billions of fans, | ||||||
|  |         empowering them to achieve sustained success in the digital landscape. | ||||||
|  |         We are confident that with our new positioning, FiEE, Inc. will reach | ||||||
|  |         new heights and create long-lasting value for our shareholders.” | ||||||
|  |       </p> | ||||||
|  |       <p><strong>About FiEE, Inc.</strong></p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. (NASDAQ:MINM), formerly Minim, Inc., was founded in 1977. It | ||||||
|  |         has a historical track record of delivering comprehensive WiFi/Software | ||||||
|  |         as a Service platform in the market. After years of development, it made | ||||||
|  |         the strategic decision to transition to a Software First Model in 2023 | ||||||
|  |         to expand its technology portfolio and revenue streams. In 2025, FiEE, | ||||||
|  |         Inc. rebranded itself as a technology company leveraging the expertise | ||||||
|  |         in IoT, connectivity, and AI to explore new business prospects and | ||||||
|  |         extend its global footprint. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc.'s services are structured 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, FiEE, Inc. has introduced its innovative Software as a | ||||||
|  |         Service solutions, which integrate its AI and data analytics | ||||||
|  |         capabilities into content creation and brand management. This initiative | ||||||
|  |         has led to the nurturing of a robust pool of KOLs on major social media | ||||||
|  |         platforms worldwide, assisting them in developing, managing, and | ||||||
|  |         optimizing their digital presence across global platforms. FiEE Inc.'s | ||||||
|  |         services include customized graphics and posts, short videos, and | ||||||
|  |         editorial calendars tailored to align with brand objectives. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Forward-Looking Statements</strong><br />This communication | ||||||
|  |         contains forward-looking statements which include, but are not limited | ||||||
|  |         to, statements regarding the Company's listing of its common stock on | ||||||
|  |         Nasdaq; the impact of the listing; the Company's business strategy, | ||||||
|  |         including its strategic transformation; and the Company's ability to | ||||||
|  |         drive long-term growth and shareholder value. These forward-looking | ||||||
|  |         statements are subject to the safe harbor provisions under the Private | ||||||
|  |         Securities Litigation Reform Act of 1995. The Company's expectations and | ||||||
|  |         beliefs regarding these matters may not materialize. Actual outcomes and | ||||||
|  |         results may differ materially from those contemplated by these | ||||||
|  |         forward-looking statements as a result of uncertainties, risks, and | ||||||
|  |         changes in circumstances, including but not limited to risks and | ||||||
|  |         uncertainties related to: the ability of the Company to maintain | ||||||
|  |         compliance with the Nasdaq continued listing standards; the impact of | ||||||
|  |         fluctuations in global financial markets on the Company's business and | ||||||
|  |         the actions it may take in response thereto; the Company's ability to | ||||||
|  |         execute its plans and strategies; and the impact of government laws and | ||||||
|  |         regulations. Additional risks and uncertainties that could cause actual | ||||||
|  |         outcomes and results to differ materially from those contemplated by the | ||||||
|  |         forward-looking statements are included under the caption "Risk Factors" | ||||||
|  |         in the Company's Quarterly Report on Form 10-Q for the quarter ended | ||||||
|  |         March 31, 2025 and elsewhere in the Company's subsequent reports on Form | ||||||
|  |         10-K, Form 10-Q or Form 8-K filed with the U.S. Securities and Exchange | ||||||
|  |         Commission from time to time and available at www.sec.gov. | ||||||
|  |       </p> | ||||||
|  | 
 | ||||||
|  |       <div><strong>Media </strong></div> | ||||||
|  |       <a href="mailto:fiee@dlkadvisory.com">fiee@dlkadvisory.com</a> | ||||||
|  |       <div>Source: FiEE, Inc.</div> | ||||||
|  |     </template> | ||||||
|  |     <template v-if="state.date === 'June 3, 2025'"> | ||||||
|  |       <h2> | ||||||
|  |         <strong | ||||||
|  |           >FiEE, Inc. seized market opportunities through 2025 Osaka | ||||||
|  |           Expo</strong | ||||||
|  |         > | ||||||
|  |       </h2> | ||||||
|  |       <p>3 June, 2025</p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Hong Kong, 3 June 2025 </strong>— FiEE, Inc. (NASDAQ:MINM) | ||||||
|  |         (“FiEE, Inc.” or the “Company”), a technology company integrating IoT, | ||||||
|  |         connectivity and AI to redefine brand management solutions in the | ||||||
|  |         digital era, is pleased to announce significant business updates. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         Recently, FiEE, Inc. has entered into a strategic agency and cooperation | ||||||
|  |         agreement with Beijing Yilian World Expo Business Management Group Co., | ||||||
|  |         Ltd. (“Beijing Yilian”). The Company is appointed as the agent to | ||||||
|  |         introduce businesses to participate in the international trade fair held | ||||||
|  |         at INTEX Osaka. The trade fair will be held from mid-June to August | ||||||
|  |         2025, featuring a diverse range of categories, including International | ||||||
|  |         Wine, Food and Equipment; International Leather and Footwear; | ||||||
|  |         International Tea, Ceramics, Jewelry, Watches, Crafts and Art; | ||||||
|  |         International Hardware, Building Materials and Interior Decoration; | ||||||
|  |         International New Energy and Emerging Industries Technology. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Rafael Li, Chief Executive Officer of FiEE, Inc.</strong>, | ||||||
|  |         commented, “INTEX Osaka is a famous International Trade Fair and | ||||||
|  |         Exhibition in Collaboration with the 2025 Osaka Expo. It is expected to | ||||||
|  |         draw numerous visitors, presenting a valuable opportunity for marketing | ||||||
|  |         and exposure. This strategic cooperation highlights the Company's | ||||||
|  |         extensive network resources, facilitating the identification of suitable | ||||||
|  |         businesses or Key Opinion Leaders (“KOLs”) to participate in | ||||||
|  |         international trade fairs, bolstering their reputation and influence.” | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         In addition, the Company launched its new SaaS products for the talented | ||||||
|  |         individuals in March 2025, which is anticipated to generate recurring | ||||||
|  |         revenue streams while also scaling rapidly to capture a large customer | ||||||
|  |         base over time. The talented individuals subscribing for our SaaS | ||||||
|  |         products would gain access to abundant resources, such as brand / | ||||||
|  |         product partnership and sponsorship, affiliate marketing and product | ||||||
|  |         placement, IP protection services, among others. FiEE Inc. has signed | ||||||
|  |         sales contracts with 40 new customers, securing over US$200,000 in | ||||||
|  |         expected revenue in less than two months. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. is currently undergoing a strategic transformation to seize | ||||||
|  |         market opportunities with its innovative brand management solutions for | ||||||
|  |         underrecognized talents. It is offering multi-faceted IoT-enabled | ||||||
|  |         Connectivity Solutions for the talented individuals in the market, | ||||||
|  |         including Cloud-Managed Connectivity (WiFi) Platform, IoT Hardware Sales | ||||||
|  |         & Licensing, SAAS Solutions, and Professional To-C and To-B Services | ||||||
|  |         & Support. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         With its innovative positioning, FiEE, Inc. is establishing a | ||||||
|  |         comprehensive value ecosystem that offers a secure, diverse and enduring | ||||||
|  |         platform for the talented individuals, aiming to elevate their personal | ||||||
|  |         brand and influence. Leveraging a robust technological foundation on | ||||||
|  |         cybersecurity, market analysis, AI and big data analysis, the Company is | ||||||
|  |         also positioned to safeguard original creations, digital arts, NFTs and | ||||||
|  |         exclusive content for these talented individuals. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc.’s long-term goal is to build a unique KOL community with | ||||||
|  |         billions of fans, empowering them to achieve sustained success in the | ||||||
|  |         digital landscape. With its new positioning, the Company believes it | ||||||
|  |         will reach new heights and create long-lasting value for its | ||||||
|  |         shareholders. | ||||||
|  |       </p> | ||||||
|  |       <p><strong>About FiEE, Inc.</strong></p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. (NASDAQ:MINM), formerly Minim, Inc., was founded in 1977. It | ||||||
|  |         has a historical track record of delivering comprehensive WiFi/Software | ||||||
|  |         as a Service platform in the market. After years of development, it made | ||||||
|  |         the strategic decision to transition to a Software First Model in 2023 | ||||||
|  |         to expand its technology portfolio and revenue streams. In 2025, FiEE, | ||||||
|  |         Inc. rebranded itself as a technology company leveraging its expertise | ||||||
|  |         in IoT, connectivity, and AI to explore new business prospects and | ||||||
|  |         extend its global footprint. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc.’s services are structured 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, FiEE, Inc. has introduced its innovative Software as a | ||||||
|  |         Service solutions, which integrate its AI and data analytics | ||||||
|  |         capabilities into content creation and brand management. This initiative | ||||||
|  |         has led to the nurturing of a robust pool of KOLs on major social media | ||||||
|  |         platforms worldwide, assisting them in developing, managing, and | ||||||
|  |         optimizing their digital presence across global platforms. FiEE Inc.’s | ||||||
|  |         services include customized graphics and posts, short videos, and | ||||||
|  |         editorial calendars tailored to align with brand objectives. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Forward-Looking Statements</strong><br />This communication | ||||||
|  |         contains forward-looking statements which include, but are not limited | ||||||
|  |         to, statements regarding the benefits of the strategic agency and | ||||||
|  |         cooperation agreement entered into with Beijing Yilian; the expected | ||||||
|  |         success of the Company’s new SaaS products; the Company’s business | ||||||
|  |         strategy, including its strategic transformation; and the Company’s | ||||||
|  |         ability to drive long-term growth and shareholder value. These | ||||||
|  |         forward-looking statements are subject to the safe harbor provisions | ||||||
|  |         under the Private Securities Litigation Reform Act of 1995. The | ||||||
|  |         Company’s expectations and beliefs regarding these matters may not | ||||||
|  |         materialize. Actual outcomes and results may differ materially from | ||||||
|  |         those contemplated by these forward-looking statements as a result of | ||||||
|  |         uncertainties, risks, and changes in circumstances, including but not | ||||||
|  |         limited to risks and uncertainties related to: the ability of the | ||||||
|  |         Company to maintain compliance with the Nasdaq continued listing | ||||||
|  |         standards; the impact of fluctuations in global financial markets on the | ||||||
|  |         Company’s business and the actions it may take in response thereto; the | ||||||
|  |         Company’s ability to execute its plans and strategies; and the impact of | ||||||
|  |         government laws and regulations. Additional risks and uncertainties that | ||||||
|  |         could cause actual outcomes and results to differ materially from those | ||||||
|  |         contemplated by the forward-looking statements are included under the | ||||||
|  |         caption “Risk Factors” in the Company’s Quarterly Report on Form 10-Q | ||||||
|  |         for the quarter ended March 31, 2025 and elsewhere in the Company’s | ||||||
|  |         subsequent reports on Form 10-K, Form 10-Q or Form 8-K filed with the | ||||||
|  |         U.S. Securities and Exchange Commission from time to time and available | ||||||
|  |         at www.sec.gov. | ||||||
|  |       </p> | ||||||
|  | 
 | ||||||
|  |       <div><strong>Media </strong></div> | ||||||
|  |       <a href="mailto:fiee@dlkadvisory.com">fiee@dlkadvisory.com</a> | ||||||
|  |       <div>Source: FiEE, Inc.</div> | ||||||
|  |     </template> | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| @ -12,31 +345,15 @@ import { useI18n } from "vue-i18n"; | |||||||
| const { t } = useI18n(); | const { t } = useI18n(); | ||||||
| import { useRoute } from "vue-router"; | import { useRoute } from "vue-router"; | ||||||
| const route = useRoute(); | const route = useRoute(); | ||||||
| import axios from 'axios' |  | ||||||
| 
 | 
 | ||||||
| const state = reactive({ | const state = reactive({ | ||||||
|   id: "", // 新闻id |   date: "", | ||||||
| }); | }); | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   if (route.query.id) { |   if (route.query.date) { | ||||||
|     state.id = route.query.id; |     state.date = route.query.date; | ||||||
|   } |   } | ||||||
|   getPressReleasesInfo(); |  | ||||||
| }); | }); | ||||||
| 
 |  | ||||||
| //获取新闻信息 |  | ||||||
| const getPressReleasesInfo = () => { |  | ||||||
|   let url = 'http://172.16.100.93:9020/api/fiee/pressreleases?id=' + state.id |  | ||||||
|   axios.get(url).then((res) => { |  | ||||||
|     // console.log(res) |  | ||||||
|     if (res.status === 200) { |  | ||||||
|       if (res.data.status === 0) { |  | ||||||
|        const myRichText = document.getElementById('my-richText') |  | ||||||
|        myRichText.innerHTML = res.data.data.content |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| </script> | </script> | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
| .page-container { | .page-container { | ||||||
|  | |||||||
| @ -1,6 +1,340 @@ | |||||||
| <template> | <template> | ||||||
|   <div class="page-container"> |   <div class="page-container"> | ||||||
|     <div id="my-richText"></div> |     <template v-if="state.date === 'May 30, 2025'"> | ||||||
|  |       <h2> | ||||||
|  |         <strong>FiEE, Inc. Announces Reinitiation of Trading on Nasdaq</strong> | ||||||
|  |       </h2> | ||||||
|  |       <p>May 30, 2025</p> | ||||||
|  |       <p> | ||||||
|  |         <em>Company will resume trading under its existing symbol "MINM"</em> | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Hong Kong, May 30, 2025 </strong>— FiEE, Inc. (“FiEE, Inc.” or | ||||||
|  |         the “Company”), a technology company integrating IoT, connectivity and | ||||||
|  |         AI to redefine brand management solutions in the digital era, is pleased | ||||||
|  |         to announce that following a hearing before the Nasdaq Hearings Panel | ||||||
|  |         (the “Panel”) on May 13, 2025, the Panel issued a decision on May 29, | ||||||
|  |         2025, stating that Nasdaq will reinstate trading of the Company's common | ||||||
|  |         stock on the Nasdaq Capital Market at the open of business on Monday, | ||||||
|  |         June 2, 2025 under the ticker symbol "MINM". | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Rafael Li, Chief Executive Officer of FiEE, </strong>commented, | ||||||
|  |         "We are honored to announce the reinitiation of trading of our common | ||||||
|  |         stock on Nasdaq, a significant milestone that reflects our unwavering | ||||||
|  |         commitment to operational excellence and strategic growth. We extend our | ||||||
|  |         sincere gratitude to the Nasdaq team for their prompt review and | ||||||
|  |         approval of our request, affirming our compliance with all applicable | ||||||
|  |         criteria for continued listing on the Nasdaq Capital Market. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. is currently undergoing a strategic transformation aimed at | ||||||
|  |         capitalizing on broader market opportunities. Central to this evolution | ||||||
|  |         is our integrated approach, where cyber-hardened IoT connectivity | ||||||
|  |         converges with AI-driven content creation and audience targeting. This | ||||||
|  |         synergy is designed to empower Key Opinion Leaders (KOLs) and brands to | ||||||
|  |         achieve accelerated growth and deeper audience engagement. Leveraging | ||||||
|  |         IoT-connectivity solutions, AI and big data analytics, we are capable of | ||||||
|  |         delivering intelligent, multimedia and multilingual content tailored to | ||||||
|  |         diverse audiences. Coupling with AI targeting analysis, we enhance | ||||||
|  |         audience targeting capabilities, ensuring effective content placement | ||||||
|  |         and personalized promotions. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         As we advance, our focus remains on continuous innovation and strategic | ||||||
|  |         initiatives that drive long- term growth and shareholder value." | ||||||
|  |       </p> | ||||||
|  |       <h3>About FiEE, Inc.</h3> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. (NASDAQ: MINM), formerly Minim, Inc., was founded in 1977. It | ||||||
|  |         has a historical track record of delivering comprehensive WiFi/Software | ||||||
|  |         as a Service platform in the market. After years of development, it made | ||||||
|  |         the strategic decision to transition to a Software First Model in 2023 | ||||||
|  |         to expand our technology portfolio and revenue streams. In 2025, FiEE, | ||||||
|  |         Inc. rebranded itself as a technology company leveraging the expertise | ||||||
|  |         in IoT, connectivity, and artificial intelligence ("AI") to explore new | ||||||
|  |         business prospects and extend our global footprint. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         Our services are structured 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. | ||||||
|  |       </p> | ||||||
|  |       <h3>Forward-Looking Statements</h3> | ||||||
|  |       <p> | ||||||
|  |         This communication contains forward-looking statements which include, | ||||||
|  |         but are not limited to, statements regarding the Company's listing of | ||||||
|  |         its common stock on Nasdaq; the impact of the listing; the Company's | ||||||
|  |         business strategy, including its strategic transformation; and the | ||||||
|  |         Company's ability to drive long-term growth and shareholder value. These | ||||||
|  |         forward-looking statements are subject to the safe harbor provisions | ||||||
|  |         under the Private Securities Litigation Reform Act of 1995. The | ||||||
|  |         Company's expectations and beliefs regarding these matters may not | ||||||
|  |         materialize. Actual outcomes and results may differ materially from | ||||||
|  |         those contemplated by these forward-looking statements as a result of | ||||||
|  |         uncertainties, risks, and changes in circumstances, including but not | ||||||
|  |         limited to risks and uncertainties related to: the ability of the | ||||||
|  |         Company to maintain compliance with the Nasdaq continued listing | ||||||
|  |         standards; the impact of fluctuations in global financial markets on the | ||||||
|  |         Company's business and the actions it may take in response thereto; the | ||||||
|  |         Company's ability to execute its plans and strategies; and the impact of | ||||||
|  |         government laws and regulations. Additional risks and uncertainties that | ||||||
|  |         could cause actual outcomes and results to differ materially from those | ||||||
|  |         contemplated by the forward- looking statements are included under the | ||||||
|  |         caption "Risk Factors" in the Company's Quarterly Report on Form 10-Q | ||||||
|  |         for the quarter ended March 31, 2025 and elsewhere in the Company's | ||||||
|  |         subsequent reports on Form 10-K, Form 10-Q or Form 8-K filed with the | ||||||
|  |         U.S. Securities and Exchange Commission from time to time and available | ||||||
|  |         at | ||||||
|  |         <a href="http://www.sec.gov/">www.sec.gov.</a> | ||||||
|  |       </p> | ||||||
|  |       <div><strong>Media </strong></div> | ||||||
|  |       <a href="mailto:fiee@dlkadvisory.com">fiee@dlkadvisory.com</a> | ||||||
|  |       <div>Source: FiEE, Inc.</div> | ||||||
|  |     </template> | ||||||
|  |     <template v-if="state.date === 'June 2, 2025'"> | ||||||
|  |       <h2> | ||||||
|  |         <strong>FiEE, Inc. Closes Its First Day of Trading on NASDAQ </strong> | ||||||
|  |       </h2> | ||||||
|  |       <p>June 2, 2025</p> | ||||||
|  |       <p><em>Company resumed trading under its existing symbol "MINM" </em></p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Hong Kong, 2 June 2025 </strong>— FiEE, Inc. (NASDAQ:MINM) | ||||||
|  |         (“FiEE, Inc.” or the “Company”), a technology company integrating IoT, | ||||||
|  |         connectivity and AI to redefine brand management solutions in the | ||||||
|  |         digital era, commenced the trading of its common stock on Monday, June | ||||||
|  |         2, 2025 on the Nasdaq Capital Market under the ticker symbol "MINM". | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         With the vision of growing Key Opinion Leaders (“KOLs”) in the market, | ||||||
|  |         FiEE, Inc. is currently strategically transforming to seize market | ||||||
|  |         opportunities with its innovative brand management solutions for the | ||||||
|  |         underrecognized talents. Since 2023, FiEE, Inc. has been pivoting to a | ||||||
|  |         Software First business model through enhancing its MinimOS cloud | ||||||
|  |         platform and API suite for ISPs/OEMs, as well merging with e2Companies | ||||||
|  |         to broaden its technology and revenue base. Currently, it is offering | ||||||
|  |         multi-faceted IoT-enabled Connectivity Solutions for the talented | ||||||
|  |         individuals in the market, including Cloud-Managed Connectivity (WiFi) | ||||||
|  |         Platform, IoT Hardware Sales & Licensing, SAAS Solutions, and | ||||||
|  |         Professional To-C and To-B Services & Support. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         With its innovative positioning, FiEE, Inc. is addressing significant | ||||||
|  |         challenges faced by talented individuals in the market, such as | ||||||
|  |         insufficient promotion channels, overdependence on offline events, and | ||||||
|  |         high costs of conventional advertising. It is establishing a | ||||||
|  |         comprehensive value ecosystem that offers a secure, diverse and enduring | ||||||
|  |         platform for these talents, aiming to elevate their personal brand and | ||||||
|  |         influence. Leveraging robust technological foundation on cybersecurity, | ||||||
|  |         market analysis, AI and big data analysis, the Company is also | ||||||
|  |         positioned to safeguard original creations, digital arts, NFTs and | ||||||
|  |         exclusive content for these talented individuals. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Rafael Li, Chief Executive Officer of FiEE, Inc.</strong> added, | ||||||
|  |         "We are glad to witness our common stock resumed trading on Nasdaq. In | ||||||
|  |         the foreseeable future, I plan to lead the team to continuously enhance | ||||||
|  |         our technological capabilities, utilizing AI, big data analysis, and our | ||||||
|  |         long-standing IoT-enabled Connectivity Solutions to match potential | ||||||
|  |         users in the market and provide them with comprehensive solutions. Our | ||||||
|  |         long-term goal is to build a unique KOL community with billions of fans, | ||||||
|  |         empowering them to achieve sustained success in the digital landscape. | ||||||
|  |         We are confident that with our new positioning, FiEE, Inc. will reach | ||||||
|  |         new heights and create long-lasting value for our shareholders.” | ||||||
|  |       </p> | ||||||
|  |       <p><strong>About FiEE, Inc.</strong></p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. (NASDAQ:MINM), formerly Minim, Inc., was founded in 1977. It | ||||||
|  |         has a historical track record of delivering comprehensive WiFi/Software | ||||||
|  |         as a Service platform in the market. After years of development, it made | ||||||
|  |         the strategic decision to transition to a Software First Model in 2023 | ||||||
|  |         to expand its technology portfolio and revenue streams. In 2025, FiEE, | ||||||
|  |         Inc. rebranded itself as a technology company leveraging the expertise | ||||||
|  |         in IoT, connectivity, and AI to explore new business prospects and | ||||||
|  |         extend its global footprint. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc.'s services are structured 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, FiEE, Inc. has introduced its innovative Software as a | ||||||
|  |         Service solutions, which integrate its AI and data analytics | ||||||
|  |         capabilities into content creation and brand management. This initiative | ||||||
|  |         has led to the nurturing of a robust pool of KOLs on major social media | ||||||
|  |         platforms worldwide, assisting them in developing, managing, and | ||||||
|  |         optimizing their digital presence across global platforms. FiEE Inc.'s | ||||||
|  |         services include customized graphics and posts, short videos, and | ||||||
|  |         editorial calendars tailored to align with brand objectives. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Forward-Looking Statements</strong><br />This communication | ||||||
|  |         contains forward-looking statements which include, but are not limited | ||||||
|  |         to, statements regarding the Company's listing of its common stock on | ||||||
|  |         Nasdaq; the impact of the listing; the Company's business strategy, | ||||||
|  |         including its strategic transformation; and the Company's ability to | ||||||
|  |         drive long-term growth and shareholder value. These forward-looking | ||||||
|  |         statements are subject to the safe harbor provisions under the Private | ||||||
|  |         Securities Litigation Reform Act of 1995. The Company's expectations and | ||||||
|  |         beliefs regarding these matters may not materialize. Actual outcomes and | ||||||
|  |         results may differ materially from those contemplated by these | ||||||
|  |         forward-looking statements as a result of uncertainties, risks, and | ||||||
|  |         changes in circumstances, including but not limited to risks and | ||||||
|  |         uncertainties related to: the ability of the Company to maintain | ||||||
|  |         compliance with the Nasdaq continued listing standards; the impact of | ||||||
|  |         fluctuations in global financial markets on the Company's business and | ||||||
|  |         the actions it may take in response thereto; the Company's ability to | ||||||
|  |         execute its plans and strategies; and the impact of government laws and | ||||||
|  |         regulations. Additional risks and uncertainties that could cause actual | ||||||
|  |         outcomes and results to differ materially from those contemplated by the | ||||||
|  |         forward-looking statements are included under the caption "Risk Factors" | ||||||
|  |         in the Company's Quarterly Report on Form 10-Q for the quarter ended | ||||||
|  |         March 31, 2025 and elsewhere in the Company's subsequent reports on Form | ||||||
|  |         10-K, Form 10-Q or Form 8-K filed with the U.S. Securities and Exchange | ||||||
|  |         Commission from time to time and available at www.sec.gov. | ||||||
|  |       </p> | ||||||
|  | 
 | ||||||
|  |       <div><strong>Media </strong></div> | ||||||
|  |       <a href="mailto:fiee@dlkadvisory.com">fiee@dlkadvisory.com</a> | ||||||
|  |       <div>Source: FiEE, Inc.</div> | ||||||
|  |     </template> | ||||||
|  | 
 | ||||||
|  |     <template v-if="state.date === 'June 3, 2025'"> | ||||||
|  |       <h2> | ||||||
|  |         <strong | ||||||
|  |           >FiEE, Inc. seized market opportunities through 2025 Osaka | ||||||
|  |           Expo</strong | ||||||
|  |         > | ||||||
|  |       </h2> | ||||||
|  |       <p>3 June, 2025</p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Hong Kong, 3 June 2025 </strong>— FiEE, Inc. (NASDAQ:MINM) | ||||||
|  |         (“FiEE, Inc.” or the “Company”), a technology company integrating IoT, | ||||||
|  |         connectivity and AI to redefine brand management solutions in the | ||||||
|  |         digital era, is pleased to announce significant business updates. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         Recently, FiEE, Inc. has entered into a strategic agency and cooperation | ||||||
|  |         agreement with Beijing Yilian World Expo Business Management Group Co., | ||||||
|  |         Ltd. (“Beijing Yilian”). The Company is appointed as the agent to | ||||||
|  |         introduce businesses to participate in the international trade fair held | ||||||
|  |         at INTEX Osaka. The trade fair will be held from mid-June to August | ||||||
|  |         2025, featuring a diverse range of categories, including International | ||||||
|  |         Wine, Food and Equipment; International Leather and Footwear; | ||||||
|  |         International Tea, Ceramics, Jewelry, Watches, Crafts and Art; | ||||||
|  |         International Hardware, Building Materials and Interior Decoration; | ||||||
|  |         International New Energy and Emerging Industries Technology. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Rafael Li, Chief Executive Officer of FiEE, Inc.</strong>, | ||||||
|  |         commented, “INTEX Osaka is a famous International Trade Fair and | ||||||
|  |         Exhibition in Collaboration with the 2025 Osaka Expo. It is expected to | ||||||
|  |         draw numerous visitors, presenting a valuable opportunity for marketing | ||||||
|  |         and exposure. This strategic cooperation highlights the Company's | ||||||
|  |         extensive network resources, facilitating the identification of suitable | ||||||
|  |         businesses or Key Opinion Leaders (“KOLs”) to participate in | ||||||
|  |         international trade fairs, bolstering their reputation and influence.” | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         In addition, the Company launched its new SaaS products for the talented | ||||||
|  |         individuals in March 2025, which is anticipated to generate recurring | ||||||
|  |         revenue streams while also scaling rapidly to capture a large customer | ||||||
|  |         base over time. The talented individuals subscribing for our SaaS | ||||||
|  |         products would gain access to abundant resources, such as brand / | ||||||
|  |         product partnership and sponsorship, affiliate marketing and product | ||||||
|  |         placement, IP protection services, among others. FiEE Inc. has signed | ||||||
|  |         sales contracts with 40 new customers, securing over US$200,000 in | ||||||
|  |         expected revenue in less than two months. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. is currently undergoing a strategic transformation to seize | ||||||
|  |         market opportunities with its innovative brand management solutions for | ||||||
|  |         underrecognized talents. It is offering multi-faceted IoT-enabled | ||||||
|  |         Connectivity Solutions for the talented individuals in the market, | ||||||
|  |         including Cloud-Managed Connectivity (WiFi) Platform, IoT Hardware Sales | ||||||
|  |         & Licensing, SAAS Solutions, and Professional To-C and To-B Services | ||||||
|  |         & Support. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         With its innovative positioning, FiEE, Inc. is establishing a | ||||||
|  |         comprehensive value ecosystem that offers a secure, diverse and enduring | ||||||
|  |         platform for the talented individuals, aiming to elevate their personal | ||||||
|  |         brand and influence. Leveraging a robust technological foundation on | ||||||
|  |         cybersecurity, market analysis, AI and big data analysis, the Company is | ||||||
|  |         also positioned to safeguard original creations, digital arts, NFTs and | ||||||
|  |         exclusive content for these talented individuals. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc.’s long-term goal is to build a unique KOL community with | ||||||
|  |         billions of fans, empowering them to achieve sustained success in the | ||||||
|  |         digital landscape. With its new positioning, the Company believes it | ||||||
|  |         will reach new heights and create long-lasting value for its | ||||||
|  |         shareholders. | ||||||
|  |       </p> | ||||||
|  |       <p><strong>About FiEE, Inc.</strong></p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. (NASDAQ:MINM), formerly Minim, Inc., was founded in 1977. It | ||||||
|  |         has a historical track record of delivering comprehensive WiFi/Software | ||||||
|  |         as a Service platform in the market. After years of development, it made | ||||||
|  |         the strategic decision to transition to a Software First Model in 2023 | ||||||
|  |         to expand its technology portfolio and revenue streams. In 2025, FiEE, | ||||||
|  |         Inc. rebranded itself as a technology company leveraging its expertise | ||||||
|  |         in IoT, connectivity, and AI to explore new business prospects and | ||||||
|  |         extend its global footprint. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc.’s services are structured 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, FiEE, Inc. has introduced its innovative Software as a | ||||||
|  |         Service solutions, which integrate its AI and data analytics | ||||||
|  |         capabilities into content creation and brand management. This initiative | ||||||
|  |         has led to the nurturing of a robust pool of KOLs on major social media | ||||||
|  |         platforms worldwide, assisting them in developing, managing, and | ||||||
|  |         optimizing their digital presence across global platforms. FiEE Inc.’s | ||||||
|  |         services include customized graphics and posts, short videos, and | ||||||
|  |         editorial calendars tailored to align with brand objectives. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Forward-Looking Statements</strong><br />This communication | ||||||
|  |         contains forward-looking statements which include, but are not limited | ||||||
|  |         to, statements regarding the benefits of the strategic agency and | ||||||
|  |         cooperation agreement entered into with Beijing Yilian; the expected | ||||||
|  |         success of the Company’s new SaaS products; the Company’s business | ||||||
|  |         strategy, including its strategic transformation; and the Company’s | ||||||
|  |         ability to drive long-term growth and shareholder value. These | ||||||
|  |         forward-looking statements are subject to the safe harbor provisions | ||||||
|  |         under the Private Securities Litigation Reform Act of 1995. The | ||||||
|  |         Company’s expectations and beliefs regarding these matters may not | ||||||
|  |         materialize. Actual outcomes and results may differ materially from | ||||||
|  |         those contemplated by these forward-looking statements as a result of | ||||||
|  |         uncertainties, risks, and changes in circumstances, including but not | ||||||
|  |         limited to risks and uncertainties related to: the ability of the | ||||||
|  |         Company to maintain compliance with the Nasdaq continued listing | ||||||
|  |         standards; the impact of fluctuations in global financial markets on the | ||||||
|  |         Company’s business and the actions it may take in response thereto; the | ||||||
|  |         Company’s ability to execute its plans and strategies; and the impact of | ||||||
|  |         government laws and regulations. Additional risks and uncertainties that | ||||||
|  |         could cause actual outcomes and results to differ materially from those | ||||||
|  |         contemplated by the forward-looking statements are included under the | ||||||
|  |         caption “Risk Factors” in the Company’s Quarterly Report on Form 10-Q | ||||||
|  |         for the quarter ended March 31, 2025 and elsewhere in the Company’s | ||||||
|  |         subsequent reports on Form 10-K, Form 10-Q or Form 8-K filed with the | ||||||
|  |         U.S. Securities and Exchange Commission from time to time and available | ||||||
|  |         at www.sec.gov. | ||||||
|  |       </p> | ||||||
|  | 
 | ||||||
|  |       <div><strong>Media </strong></div> | ||||||
|  |       <a href="mailto:fiee@dlkadvisory.com">fiee@dlkadvisory.com</a> | ||||||
|  |       <div>Source: FiEE, Inc.</div> | ||||||
|  |     </template> | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| @ -12,31 +346,15 @@ import { useI18n } from "vue-i18n"; | |||||||
| const { t } = useI18n(); | const { t } = useI18n(); | ||||||
| import { useRoute } from "vue-router"; | import { useRoute } from "vue-router"; | ||||||
| const route = useRoute(); | const route = useRoute(); | ||||||
| import axios from 'axios' |  | ||||||
| 
 | 
 | ||||||
| const state = reactive({ | const state = reactive({ | ||||||
|   id: "", // 新闻id |   date: "", | ||||||
| }); | }); | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   if (route.query.id) { |   if (route.query.date) { | ||||||
|     state.id = route.query.id; |     state.date = route.query.date; | ||||||
|   } |   } | ||||||
|   getPressReleasesInfo(); |  | ||||||
| }); | }); | ||||||
| 
 |  | ||||||
| //获取新闻信息 |  | ||||||
| const getPressReleasesInfo = () => { |  | ||||||
|   let url = 'http://172.16.100.93:9020/api/fiee/pressreleases?id=' + state.id |  | ||||||
|   axios.get(url).then((res) => { |  | ||||||
|     // console.log(res) |  | ||||||
|     if (res.status === 200) { |  | ||||||
|       if (res.data.status === 0) { |  | ||||||
|        const myRichText = document.getElementById('my-richText') |  | ||||||
|        myRichText.innerHTML = res.data.data.content |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
|  | |||||||
| @ -1,6 +1,340 @@ | |||||||
| <template> | <template> | ||||||
|   <div class="page-container"> |   <div class="page-container"> | ||||||
|     <div id="my-richText"></div> |     <template v-if="state.date === 'May 30, 2025'"> | ||||||
|  |       <h2> | ||||||
|  |         <strong>FiEE, Inc. Announces Reinitiation of Trading on Nasdaq</strong> | ||||||
|  |       </h2> | ||||||
|  |       <p>May 30, 2025</p> | ||||||
|  |       <p> | ||||||
|  |         <em>Company will resume trading under its existing symbol "MINM"</em> | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Hong Kong, May 30, 2025 </strong>— FiEE, Inc. (“FiEE, Inc.” or | ||||||
|  |         the “Company”), a technology company integrating IoT, connectivity and | ||||||
|  |         AI to redefine brand management solutions in the digital era, is pleased | ||||||
|  |         to announce that following a hearing before the Nasdaq Hearings Panel | ||||||
|  |         (the “Panel”) on May 13, 2025, the Panel issued a decision on May 29, | ||||||
|  |         2025, stating that Nasdaq will reinstate trading of the Company's common | ||||||
|  |         stock on the Nasdaq Capital Market at the open of business on Monday, | ||||||
|  |         June 2, 2025 under the ticker symbol "MINM". | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Rafael Li, Chief Executive Officer of FiEE, </strong>commented, | ||||||
|  |         "We are honored to announce the reinitiation of trading of our common | ||||||
|  |         stock on Nasdaq, a significant milestone that reflects our unwavering | ||||||
|  |         commitment to operational excellence and strategic growth. We extend our | ||||||
|  |         sincere gratitude to the Nasdaq team for their prompt review and | ||||||
|  |         approval of our request, affirming our compliance with all applicable | ||||||
|  |         criteria for continued listing on the Nasdaq Capital Market. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. is currently undergoing a strategic transformation aimed at | ||||||
|  |         capitalizing on broader market opportunities. Central to this evolution | ||||||
|  |         is our integrated approach, where cyber-hardened IoT connectivity | ||||||
|  |         converges with AI-driven content creation and audience targeting. This | ||||||
|  |         synergy is designed to empower Key Opinion Leaders (KOLs) and brands to | ||||||
|  |         achieve accelerated growth and deeper audience engagement. Leveraging | ||||||
|  |         IoT-connectivity solutions, AI and big data analytics, we are capable of | ||||||
|  |         delivering intelligent, multimedia and multilingual content tailored to | ||||||
|  |         diverse audiences. Coupling with AI targeting analysis, we enhance | ||||||
|  |         audience targeting capabilities, ensuring effective content placement | ||||||
|  |         and personalized promotions. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         As we advance, our focus remains on continuous innovation and strategic | ||||||
|  |         initiatives that drive long- term growth and shareholder value." | ||||||
|  |       </p> | ||||||
|  |       <h3>About FiEE, Inc.</h3> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. (NASDAQ: MINM), formerly Minim, Inc., was founded in 1977. It | ||||||
|  |         has a historical track record of delivering comprehensive WiFi/Software | ||||||
|  |         as a Service platform in the market. After years of development, it made | ||||||
|  |         the strategic decision to transition to a Software First Model in 2023 | ||||||
|  |         to expand our technology portfolio and revenue streams. In 2025, FiEE, | ||||||
|  |         Inc. rebranded itself as a technology company leveraging the expertise | ||||||
|  |         in IoT, connectivity, and artificial intelligence ("AI") to explore new | ||||||
|  |         business prospects and extend our global footprint. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         Our services are structured 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. | ||||||
|  |       </p> | ||||||
|  |       <h3>Forward-Looking Statements</h3> | ||||||
|  |       <p> | ||||||
|  |         This communication contains forward-looking statements which include, | ||||||
|  |         but are not limited to, statements regarding the Company's listing of | ||||||
|  |         its common stock on Nasdaq; the impact of the listing; the Company's | ||||||
|  |         business strategy, including its strategic transformation; and the | ||||||
|  |         Company's ability to drive long-term growth and shareholder value. These | ||||||
|  |         forward-looking statements are subject to the safe harbor provisions | ||||||
|  |         under the Private Securities Litigation Reform Act of 1995. The | ||||||
|  |         Company's expectations and beliefs regarding these matters may not | ||||||
|  |         materialize. Actual outcomes and results may differ materially from | ||||||
|  |         those contemplated by these forward-looking statements as a result of | ||||||
|  |         uncertainties, risks, and changes in circumstances, including but not | ||||||
|  |         limited to risks and uncertainties related to: the ability of the | ||||||
|  |         Company to maintain compliance with the Nasdaq continued listing | ||||||
|  |         standards; the impact of fluctuations in global financial markets on the | ||||||
|  |         Company's business and the actions it may take in response thereto; the | ||||||
|  |         Company's ability to execute its plans and strategies; and the impact of | ||||||
|  |         government laws and regulations. Additional risks and uncertainties that | ||||||
|  |         could cause actual outcomes and results to differ materially from those | ||||||
|  |         contemplated by the forward- looking statements are included under the | ||||||
|  |         caption "Risk Factors" in the Company's Quarterly Report on Form 10-Q | ||||||
|  |         for the quarter ended March 31, 2025 and elsewhere in the Company's | ||||||
|  |         subsequent reports on Form 10-K, Form 10-Q or Form 8-K filed with the | ||||||
|  |         U.S. Securities and Exchange Commission from time to time and available | ||||||
|  |         at | ||||||
|  |         <a href="http://www.sec.gov/">www.sec.gov.</a> | ||||||
|  |       </p> | ||||||
|  |       <div><strong>Media </strong></div> | ||||||
|  |       <a href="mailto:fiee@dlkadvisory.com">fiee@dlkadvisory.com</a> | ||||||
|  |       <div>Source: FiEE, Inc.</div> | ||||||
|  |     </template> | ||||||
|  |     <template v-if="state.date === 'June 2, 2025'"> | ||||||
|  |       <h2> | ||||||
|  |         <strong>FiEE, Inc. Closes Its First Day of Trading on NASDAQ </strong> | ||||||
|  |       </h2> | ||||||
|  |       <p>June 2, 2025</p> | ||||||
|  |       <p><em>Company resumed trading under its existing symbol "MINM" </em></p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Hong Kong, 2 June 2025 </strong>— FiEE, Inc. (NASDAQ:MINM) | ||||||
|  |         (“FiEE, Inc.” or the “Company”), a technology company integrating IoT, | ||||||
|  |         connectivity and AI to redefine brand management solutions in the | ||||||
|  |         digital era, commenced the trading of its common stock on Monday, June | ||||||
|  |         2, 2025 on the Nasdaq Capital Market under the ticker symbol "MINM". | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         With the vision of growing Key Opinion Leaders (“KOLs”) in the market, | ||||||
|  |         FiEE, Inc. is currently strategically transforming to seize market | ||||||
|  |         opportunities with its innovative brand management solutions for the | ||||||
|  |         underrecognized talents. Since 2023, FiEE, Inc. has been pivoting to a | ||||||
|  |         Software First business model through enhancing its MinimOS cloud | ||||||
|  |         platform and API suite for ISPs/OEMs, as well merging with e2Companies | ||||||
|  |         to broaden its technology and revenue base. Currently, it is offering | ||||||
|  |         multi-faceted IoT-enabled Connectivity Solutions for the talented | ||||||
|  |         individuals in the market, including Cloud-Managed Connectivity (WiFi) | ||||||
|  |         Platform, IoT Hardware Sales & Licensing, SAAS Solutions, and | ||||||
|  |         Professional To-C and To-B Services & Support. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         With its innovative positioning, FiEE, Inc. is addressing significant | ||||||
|  |         challenges faced by talented individuals in the market, such as | ||||||
|  |         insufficient promotion channels, overdependence on offline events, and | ||||||
|  |         high costs of conventional advertising. It is establishing a | ||||||
|  |         comprehensive value ecosystem that offers a secure, diverse and enduring | ||||||
|  |         platform for these talents, aiming to elevate their personal brand and | ||||||
|  |         influence. Leveraging robust technological foundation on cybersecurity, | ||||||
|  |         market analysis, AI and big data analysis, the Company is also | ||||||
|  |         positioned to safeguard original creations, digital arts, NFTs and | ||||||
|  |         exclusive content for these talented individuals. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Rafael Li, Chief Executive Officer of FiEE, Inc.</strong> added, | ||||||
|  |         "We are glad to witness our common stock resumed trading on Nasdaq. In | ||||||
|  |         the foreseeable future, I plan to lead the team to continuously enhance | ||||||
|  |         our technological capabilities, utilizing AI, big data analysis, and our | ||||||
|  |         long-standing IoT-enabled Connectivity Solutions to match potential | ||||||
|  |         users in the market and provide them with comprehensive solutions. Our | ||||||
|  |         long-term goal is to build a unique KOL community with billions of fans, | ||||||
|  |         empowering them to achieve sustained success in the digital landscape. | ||||||
|  |         We are confident that with our new positioning, FiEE, Inc. will reach | ||||||
|  |         new heights and create long-lasting value for our shareholders.” | ||||||
|  |       </p> | ||||||
|  |       <p><strong>About FiEE, Inc.</strong></p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. (NASDAQ:MINM), formerly Minim, Inc., was founded in 1977. It | ||||||
|  |         has a historical track record of delivering comprehensive WiFi/Software | ||||||
|  |         as a Service platform in the market. After years of development, it made | ||||||
|  |         the strategic decision to transition to a Software First Model in 2023 | ||||||
|  |         to expand its technology portfolio and revenue streams. In 2025, FiEE, | ||||||
|  |         Inc. rebranded itself as a technology company leveraging the expertise | ||||||
|  |         in IoT, connectivity, and AI to explore new business prospects and | ||||||
|  |         extend its global footprint. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc.'s services are structured 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, FiEE, Inc. has introduced its innovative Software as a | ||||||
|  |         Service solutions, which integrate its AI and data analytics | ||||||
|  |         capabilities into content creation and brand management. This initiative | ||||||
|  |         has led to the nurturing of a robust pool of KOLs on major social media | ||||||
|  |         platforms worldwide, assisting them in developing, managing, and | ||||||
|  |         optimizing their digital presence across global platforms. FiEE Inc.'s | ||||||
|  |         services include customized graphics and posts, short videos, and | ||||||
|  |         editorial calendars tailored to align with brand objectives. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Forward-Looking Statements</strong><br />This communication | ||||||
|  |         contains forward-looking statements which include, but are not limited | ||||||
|  |         to, statements regarding the Company's listing of its common stock on | ||||||
|  |         Nasdaq; the impact of the listing; the Company's business strategy, | ||||||
|  |         including its strategic transformation; and the Company's ability to | ||||||
|  |         drive long-term growth and shareholder value. These forward-looking | ||||||
|  |         statements are subject to the safe harbor provisions under the Private | ||||||
|  |         Securities Litigation Reform Act of 1995. The Company's expectations and | ||||||
|  |         beliefs regarding these matters may not materialize. Actual outcomes and | ||||||
|  |         results may differ materially from those contemplated by these | ||||||
|  |         forward-looking statements as a result of uncertainties, risks, and | ||||||
|  |         changes in circumstances, including but not limited to risks and | ||||||
|  |         uncertainties related to: the ability of the Company to maintain | ||||||
|  |         compliance with the Nasdaq continued listing standards; the impact of | ||||||
|  |         fluctuations in global financial markets on the Company's business and | ||||||
|  |         the actions it may take in response thereto; the Company's ability to | ||||||
|  |         execute its plans and strategies; and the impact of government laws and | ||||||
|  |         regulations. Additional risks and uncertainties that could cause actual | ||||||
|  |         outcomes and results to differ materially from those contemplated by the | ||||||
|  |         forward-looking statements are included under the caption "Risk Factors" | ||||||
|  |         in the Company's Quarterly Report on Form 10-Q for the quarter ended | ||||||
|  |         March 31, 2025 and elsewhere in the Company's subsequent reports on Form | ||||||
|  |         10-K, Form 10-Q or Form 8-K filed with the U.S. Securities and Exchange | ||||||
|  |         Commission from time to time and available at www.sec.gov. | ||||||
|  |       </p> | ||||||
|  | 
 | ||||||
|  |       <div><strong>Media </strong></div> | ||||||
|  |       <a href="mailto:fiee@dlkadvisory.com">fiee@dlkadvisory.com</a> | ||||||
|  |       <div>Source: FiEE, Inc.</div> | ||||||
|  |     </template> | ||||||
|  | 
 | ||||||
|  |     <template v-if="state.date === 'June 3, 2025'"> | ||||||
|  |       <h2> | ||||||
|  |         <strong | ||||||
|  |           >FiEE, Inc. seized market opportunities through 2025 Osaka | ||||||
|  |           Expo</strong | ||||||
|  |         > | ||||||
|  |       </h2> | ||||||
|  |       <p>3 June, 2025</p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Hong Kong, 3 June 2025 </strong>— FiEE, Inc. (NASDAQ:MINM) | ||||||
|  |         (“FiEE, Inc.” or the “Company”), a technology company integrating IoT, | ||||||
|  |         connectivity and AI to redefine brand management solutions in the | ||||||
|  |         digital era, is pleased to announce significant business updates. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         Recently, FiEE, Inc. has entered into a strategic agency and cooperation | ||||||
|  |         agreement with Beijing Yilian World Expo Business Management Group Co., | ||||||
|  |         Ltd. (“Beijing Yilian”). The Company is appointed as the agent to | ||||||
|  |         introduce businesses to participate in the international trade fair held | ||||||
|  |         at INTEX Osaka. The trade fair will be held from mid-June to August | ||||||
|  |         2025, featuring a diverse range of categories, including International | ||||||
|  |         Wine, Food and Equipment; International Leather and Footwear; | ||||||
|  |         International Tea, Ceramics, Jewelry, Watches, Crafts and Art; | ||||||
|  |         International Hardware, Building Materials and Interior Decoration; | ||||||
|  |         International New Energy and Emerging Industries Technology. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Rafael Li, Chief Executive Officer of FiEE, Inc.</strong>, | ||||||
|  |         commented, “INTEX Osaka is a famous International Trade Fair and | ||||||
|  |         Exhibition in Collaboration with the 2025 Osaka Expo. It is expected to | ||||||
|  |         draw numerous visitors, presenting a valuable opportunity for marketing | ||||||
|  |         and exposure. This strategic cooperation highlights the Company's | ||||||
|  |         extensive network resources, facilitating the identification of suitable | ||||||
|  |         businesses or Key Opinion Leaders (“KOLs”) to participate in | ||||||
|  |         international trade fairs, bolstering their reputation and influence.” | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         In addition, the Company launched its new SaaS products for the talented | ||||||
|  |         individuals in March 2025, which is anticipated to generate recurring | ||||||
|  |         revenue streams while also scaling rapidly to capture a large customer | ||||||
|  |         base over time. The talented individuals subscribing for our SaaS | ||||||
|  |         products would gain access to abundant resources, such as brand / | ||||||
|  |         product partnership and sponsorship, affiliate marketing and product | ||||||
|  |         placement, IP protection services, among others. FiEE Inc. has signed | ||||||
|  |         sales contracts with 40 new customers, securing over US$200,000 in | ||||||
|  |         expected revenue in less than two months. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. is currently undergoing a strategic transformation to seize | ||||||
|  |         market opportunities with its innovative brand management solutions for | ||||||
|  |         underrecognized talents. It is offering multi-faceted IoT-enabled | ||||||
|  |         Connectivity Solutions for the talented individuals in the market, | ||||||
|  |         including Cloud-Managed Connectivity (WiFi) Platform, IoT Hardware Sales | ||||||
|  |         & Licensing, SAAS Solutions, and Professional To-C and To-B Services | ||||||
|  |         & Support. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         With its innovative positioning, FiEE, Inc. is establishing a | ||||||
|  |         comprehensive value ecosystem that offers a secure, diverse and enduring | ||||||
|  |         platform for the talented individuals, aiming to elevate their personal | ||||||
|  |         brand and influence. Leveraging a robust technological foundation on | ||||||
|  |         cybersecurity, market analysis, AI and big data analysis, the Company is | ||||||
|  |         also positioned to safeguard original creations, digital arts, NFTs and | ||||||
|  |         exclusive content for these talented individuals. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc.’s long-term goal is to build a unique KOL community with | ||||||
|  |         billions of fans, empowering them to achieve sustained success in the | ||||||
|  |         digital landscape. With its new positioning, the Company believes it | ||||||
|  |         will reach new heights and create long-lasting value for its | ||||||
|  |         shareholders. | ||||||
|  |       </p> | ||||||
|  |       <p><strong>About FiEE, Inc.</strong></p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc. (NASDAQ:MINM), formerly Minim, Inc., was founded in 1977. It | ||||||
|  |         has a historical track record of delivering comprehensive WiFi/Software | ||||||
|  |         as a Service platform in the market. After years of development, it made | ||||||
|  |         the strategic decision to transition to a Software First Model in 2023 | ||||||
|  |         to expand its technology portfolio and revenue streams. In 2025, FiEE, | ||||||
|  |         Inc. rebranded itself as a technology company leveraging its expertise | ||||||
|  |         in IoT, connectivity, and AI to explore new business prospects and | ||||||
|  |         extend its global footprint. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         FiEE, Inc.’s services are structured 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, FiEE, Inc. has introduced its innovative Software as a | ||||||
|  |         Service solutions, which integrate its AI and data analytics | ||||||
|  |         capabilities into content creation and brand management. This initiative | ||||||
|  |         has led to the nurturing of a robust pool of KOLs on major social media | ||||||
|  |         platforms worldwide, assisting them in developing, managing, and | ||||||
|  |         optimizing their digital presence across global platforms. FiEE Inc.’s | ||||||
|  |         services include customized graphics and posts, short videos, and | ||||||
|  |         editorial calendars tailored to align with brand objectives. | ||||||
|  |       </p> | ||||||
|  |       <p> | ||||||
|  |         <strong>Forward-Looking Statements</strong><br />This communication | ||||||
|  |         contains forward-looking statements which include, but are not limited | ||||||
|  |         to, statements regarding the benefits of the strategic agency and | ||||||
|  |         cooperation agreement entered into with Beijing Yilian; the expected | ||||||
|  |         success of the Company’s new SaaS products; the Company’s business | ||||||
|  |         strategy, including its strategic transformation; and the Company’s | ||||||
|  |         ability to drive long-term growth and shareholder value. These | ||||||
|  |         forward-looking statements are subject to the safe harbor provisions | ||||||
|  |         under the Private Securities Litigation Reform Act of 1995. The | ||||||
|  |         Company’s expectations and beliefs regarding these matters may not | ||||||
|  |         materialize. Actual outcomes and results may differ materially from | ||||||
|  |         those contemplated by these forward-looking statements as a result of | ||||||
|  |         uncertainties, risks, and changes in circumstances, including but not | ||||||
|  |         limited to risks and uncertainties related to: the ability of the | ||||||
|  |         Company to maintain compliance with the Nasdaq continued listing | ||||||
|  |         standards; the impact of fluctuations in global financial markets on the | ||||||
|  |         Company’s business and the actions it may take in response thereto; the | ||||||
|  |         Company’s ability to execute its plans and strategies; and the impact of | ||||||
|  |         government laws and regulations. Additional risks and uncertainties that | ||||||
|  |         could cause actual outcomes and results to differ materially from those | ||||||
|  |         contemplated by the forward-looking statements are included under the | ||||||
|  |         caption “Risk Factors” in the Company’s Quarterly Report on Form 10-Q | ||||||
|  |         for the quarter ended March 31, 2025 and elsewhere in the Company’s | ||||||
|  |         subsequent reports on Form 10-K, Form 10-Q or Form 8-K filed with the | ||||||
|  |         U.S. Securities and Exchange Commission from time to time and available | ||||||
|  |         at www.sec.gov. | ||||||
|  |       </p> | ||||||
|  | 
 | ||||||
|  |       <div><strong>Media </strong></div> | ||||||
|  |       <a href="mailto:fiee@dlkadvisory.com">fiee@dlkadvisory.com</a> | ||||||
|  |       <div>Source: FiEE, Inc.</div> | ||||||
|  |     </template> | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| @ -12,31 +346,15 @@ import { useI18n } from "vue-i18n"; | |||||||
| const { t } = useI18n(); | const { t } = useI18n(); | ||||||
| import { useRoute } from "vue-router"; | import { useRoute } from "vue-router"; | ||||||
| const route = useRoute(); | const route = useRoute(); | ||||||
| import axios from 'axios' |  | ||||||
| 
 | 
 | ||||||
| const state = reactive({ | const state = reactive({ | ||||||
|   id: "", // 新闻id |   date: "", | ||||||
| }); | }); | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   if (route.query.id) { |   if (route.query.date) { | ||||||
|     state.id = route.query.id; |     state.date = route.query.date; | ||||||
|   } |   } | ||||||
|   getPressReleasesInfo(); |  | ||||||
| }); | }); | ||||||
| 
 |  | ||||||
| //获取新闻信息 |  | ||||||
| const getPressReleasesInfo = () => { |  | ||||||
|   let url = 'http://172.16.100.93:9020/api/fiee/pressreleases?id=' + state.id |  | ||||||
|   axios.get(url).then((res) => { |  | ||||||
|     // console.log(res) |  | ||||||
|     if (res.status === 200) { |  | ||||||
|       if (res.data.status === 0) { |  | ||||||
|        const myRichText = document.getElementById('my-richText') |  | ||||||
|        myRichText.innerHTML = res.data.data.content |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
|  | |||||||
| @ -1,119 +0,0 @@ | |||||||
| <!-- 从chat-PC接入的文档查看 --> |  | ||||||
| <template> |  | ||||||
|   <DocumentEditor |  | ||||||
|     id="docEditor" |  | ||||||
|     :documentServerUrl="documentServerUrl" |  | ||||||
|     :config="config" |  | ||||||
|     :events_onDocumentReady="onDocumentReady" |  | ||||||
|     :onLoadComponentError="onLoadComponentError" |  | ||||||
|   /> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script setup> |  | ||||||
| import { ref, onMounted } from 'vue' |  | ||||||
| import { useRoute } from 'vue-router' |  | ||||||
| import { DocumentEditor } from "@onlyoffice/document-editor-vue" |  | ||||||
| import { useI18n } from 'vue-i18n' |  | ||||||
| const { t } = useI18n() |  | ||||||
| 
 |  | ||||||
| const documentServerUrl = 'https://onlyoffice.fontree.cn' |  | ||||||
| const route = useRoute() |  | ||||||
| 
 |  | ||||||
| onMounted(() => { |  | ||||||
|   // 动态插入 Content-Security-Policy meta 标签,只在本页面生效 |  | ||||||
|   if (!document.querySelector('meta[http-equiv="Content-Security-Policy"]')) { |  | ||||||
|     const meta = document.createElement('meta') |  | ||||||
|     meta.httpEquiv = 'Content-Security-Policy' |  | ||||||
|     meta.content = 'upgrade-insecure-requests' |  | ||||||
|     document.head.appendChild(meta) |  | ||||||
|   } |  | ||||||
| }) |  | ||||||
| 
 |  | ||||||
| // 判断文件类型 |  | ||||||
| function getDocumentTypes(url) { |  | ||||||
|   const extension = url.split('.').pop().toLowerCase() |  | ||||||
|   const types = { |  | ||||||
|     'docx': { fileType: 'docx', documentType: 'word' }, |  | ||||||
|     'doc': { fileType: 'doc', documentType: 'word' }, |  | ||||||
|     'xlsx': { fileType: 'xlsx', documentType: 'cell' }, |  | ||||||
|     'xls': { fileType: 'xls', documentType: 'cell' }, |  | ||||||
|     'pptx': { fileType: 'pptx', documentType: 'slide' }, |  | ||||||
|     'ppt': { fileType: 'ppt', documentType: 'slide' }, |  | ||||||
|     'pdf': { fileType: 'pdf', documentType: 'word' } |  | ||||||
|   } |  | ||||||
|   return types[extension] || { fileType: 'docx', documentType: 'word' } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const url = route.query.url |  | ||||||
| if (!url) { |  | ||||||
|   alert(t('PAGES.FiEEInfoManage.document.readFailed')) |  | ||||||
| } |  | ||||||
| let attachmentName = route.query.attachmentName |  | ||||||
| const fileName = attachmentName ? attachmentName : url ? url.split('/').pop() : '' |  | ||||||
| const { fileType, documentType } = getDocumentTypes(url || '') |  | ||||||
| 
 |  | ||||||
| const config = { |  | ||||||
|   document: { |  | ||||||
|     fileType, |  | ||||||
|     key: 'doc_' + Math.random().toString(36).substring(2, 15) + Math.random().toString(36).substring(2, 15), |  | ||||||
|     title: fileName, |  | ||||||
|     url |  | ||||||
|   }, |  | ||||||
|   documentType, |  | ||||||
|   editorConfig: { |  | ||||||
|      |  | ||||||
|     mode: 'view', |  | ||||||
|     lang: 'en-US', |  | ||||||
|     user: { |  | ||||||
|       id: 'user_' + new Date().getTime(), |  | ||||||
|       name: 'Guest User' |  | ||||||
|     }, |  | ||||||
|     customization: { |  | ||||||
|       about: false,        // 不显示“关于”页面 |  | ||||||
|       help: false,         // 不显示帮助菜单 |  | ||||||
|       chat: false, |  | ||||||
|       commentAuthorOnly: false, |  | ||||||
|       compactToolbar: true, |  | ||||||
|       hideRightMenu: false, // 隐藏右侧菜单 |  | ||||||
|       compatibility: true, |  | ||||||
|       showReviewChanges: false, |  | ||||||
|       loaderLogo: '',  // 设置为空字符串来隐藏加载 logo |  | ||||||
|       logo: { |  | ||||||
|         image: '',     // 设置为空字符串 |  | ||||||
|         imageDark: '', // 设置为空字符串 |  | ||||||
|         url: '',       // 设置为空字符串 |  | ||||||
|         visible: false // 设置为 false 来隐藏 logo |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const onDocumentReady = () => { |  | ||||||
|   // console.log("文档加载完成") |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const onLoadComponentError = (errorCode, errorDescription) => { |  | ||||||
|   switch(errorCode) { |  | ||||||
|     case -1: // 加载组件时发生未知错误 |  | ||||||
|       // console.log(errorDescription) |  | ||||||
|       break |  | ||||||
|     case -2: // 从文档服务器加载 DocsAPI 时发生错误 |  | ||||||
|       // console.log(errorDescription) |  | ||||||
|       break |  | ||||||
|     case -3: // DocsAPI 未定义 |  | ||||||
|       // console.log(errorDescription) |  | ||||||
|       break |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <style> |  | ||||||
| iframe[name="frameEditor"] { |  | ||||||
|   width: 100% !important; |  | ||||||
|   height: 100vh !important; |  | ||||||
|   min-height: 100vh !important; |  | ||||||
|   border: none !important; |  | ||||||
|   display: block; |  | ||||||
| } |  | ||||||
| </style> |  | ||||||
| 
 |  | ||||||
| @ -1,9 +1,8 @@ | |||||||
| <template> | <template> | ||||||
|   <div class="press-releases-page"> |   <div class="press-releases-page"> | ||||||
|     <n-infinite-scroll :distance="0" @load="doLoadMore"> |  | ||||||
|     <main class="p-[35px] max-w-[1200px] mx-auto"> |     <main class="p-[35px] max-w-[1200px] mx-auto"> | ||||||
|       <div class="title mb-[20px]"> |       <div class="title mb-[20px]"> | ||||||
|           {{ t('press_releases.title') }} |         {{ t("press_releases.title") }} | ||||||
|       </div> |       </div> | ||||||
|       <div class="search-container"> |       <div class="search-container"> | ||||||
|         <n-select |         <n-select | ||||||
| @ -22,57 +21,36 @@ | |||||||
|           @click="handleSearch" |           @click="handleSearch" | ||||||
|           class="search-button w-[80px]" |           class="search-button w-[80px]" | ||||||
|         > |         > | ||||||
|             {{ t('press_releases.search.button') }} |           {{ t("press_releases.search.button") }} | ||||||
|         </n-button> |         </n-button> | ||||||
|       </div> |       </div> | ||||||
|       <div v-for="(item, idx) in state.filterNewsData" :key="idx"> |       <div v-for="(item, idx) in state.filterNewsData" :key="idx"> | ||||||
|         <div class="news-item mt-[10px]"> |         <div class="news-item mt-[10px]"> | ||||||
|           <div class="news-item-date">{{ item.date }}</div> |           <div class="news-item-date">{{ item.date }}</div> | ||||||
|           <div |           <div | ||||||
|               class="news-item-title text-[#0078d7] cursor-pointer" |             class="news-item-title text-[#0078d7] overflow-hidden whitespace-nowrap text-ellipsis cursor-pointer" | ||||||
|               style="word-break: break-word; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis;" |  | ||||||
|             @click="handleNewClick(item)" |             @click="handleNewClick(item)" | ||||||
|           > |           > | ||||||
|             {{ item.title }} |             {{ item.title }} | ||||||
|           </div> |           </div> | ||||||
|             <n-tooltip |           <div class="news-item-content"> | ||||||
|               trigger="hover" |             {{ | ||||||
|               :disabled="!item.showTooltip" |               item.content.length > 230 | ||||||
|               width="trigger" |                 ? item.content.substring(0, 230) + "..." | ||||||
|             > |                 : item.content | ||||||
|               <template #trigger> |             }} | ||||||
|                 <div |  | ||||||
|                   :ref="(el) => setTitleRef(el, idx)" |  | ||||||
|                   class="news-item-content" |  | ||||||
|                   style=" |  | ||||||
|                     word-break: break-word; |  | ||||||
|                     display: -webkit-box; |  | ||||||
|                     -webkit-line-clamp: 2; |  | ||||||
|                     -webkit-box-orient: vertical; |  | ||||||
|                     overflow: hidden; |  | ||||||
|                     text-overflow: ellipsis; |  | ||||||
|                   " |  | ||||||
|                 > |  | ||||||
|                 {{item.summary}} |  | ||||||
|           </div> |           </div> | ||||||
|               </template> |  | ||||||
|               <div slot="content"> |  | ||||||
|                 {{item.summary}} |  | ||||||
|               </div> |  | ||||||
|             </n-tooltip> |  | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|     </main> |     </main> | ||||||
|     </n-infinite-scroll> |  | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import customDefaultPage from "@/components/customDefaultPage/index.vue"; | import customDefaultPage from "@/components/customDefaultPage/index.vue"; | ||||||
| import { reactive, onMounted, watch, nextTick, ref } from "vue"; | import { reactive, onMounted, watch } from "vue"; | ||||||
| import { NSelect, NInput, NButton, NInfiniteScroll, NTooltip } from "naive-ui"; | import { NSelect, NInput, NButton } from "naive-ui"; | ||||||
| import { useI18n } from "vue-i18n"; | import { useI18n } from "vue-i18n"; | ||||||
| import axios from 'axios' |  | ||||||
| 
 | 
 | ||||||
| import { useRouter } from "vue-router"; | import { useRouter } from "vue-router"; | ||||||
| const router = useRouter(); | const router = useRouter(); | ||||||
| @ -112,85 +90,11 @@ const state = reactive({ | |||||||
|     }, |     }, | ||||||
|   ], |   ], | ||||||
|   filterNewsData: [], |   filterNewsData: [], | ||||||
|   loading: false, //是否正在加载数据 |  | ||||||
|   hasMore: true, //是否还有更多数据 |  | ||||||
|   currentPage: 1, //当前页码 |  | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| const titleRefs = ref([]) |  | ||||||
| 
 |  | ||||||
| const setTitleRef = (el, idx) => { |  | ||||||
|   if (el) titleRefs.value[idx] = el |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const checkAllTitleOverflow = () => { |  | ||||||
|   state.filterNewsData.forEach((item, idx) => { |  | ||||||
|     const el = titleRefs.value[idx] |  | ||||||
|     if (!el) { |  | ||||||
|       item.showTooltip = false |  | ||||||
|       return |  | ||||||
|     } |  | ||||||
|     item.showTooltip = el.scrollHeight > el.clientHeight || el.scrollWidth > el.clientWidth |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   // state.filterNewsData = state.newsData; |   state.filterNewsData = state.newsData; | ||||||
|   getPressReleasesDisplay() | }); | ||||||
| 
 |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }) |  | ||||||
| 
 |  | ||||||
| watch(() => state.filterNewsData, () => { |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }, { deep: true }) |  | ||||||
| 
 |  | ||||||
| // 获取新闻列表 |  | ||||||
| const getPressReleasesDisplay = () => { |  | ||||||
|   let url = 'http://172.16.100.93:9020/api/fiee/pressreleases/display' |  | ||||||
|   let params = { |  | ||||||
|     query: state.inputValue, |  | ||||||
|     page: state.currentPage, |  | ||||||
|     pageSize: 10, |  | ||||||
|     timeStart: state.selectedValue |  | ||||||
|       ? state.selectedValue === 'all_years' |  | ||||||
|         ? null |  | ||||||
|         : new Date(state.selectedValue).getTime() |  | ||||||
|       : null, |  | ||||||
|   } |  | ||||||
|   // console.log(params) |  | ||||||
|   axios.post(url, params).then((res) => { |  | ||||||
|     // console.log(res) |  | ||||||
|     if (res.status === 200) { |  | ||||||
|       if (res.data.status === 0) { |  | ||||||
|         res.data.data?.data?.forEach((item) => { |  | ||||||
|           item.date = new Date(item.createdAt).toLocaleDateString('en-US', { |  | ||||||
|             month: 'short', |  | ||||||
|             day: 'numeric', |  | ||||||
|             year: 'numeric', |  | ||||||
|           }) |  | ||||||
|         }) |  | ||||||
|         if (state.currentPage === 1) { |  | ||||||
|           state.filterNewsData = res.data.data?.data || [] |  | ||||||
|         } else { |  | ||||||
|           state.filterNewsData = [ |  | ||||||
|             ...state.filterNewsData, |  | ||||||
|             ...(res.data.data?.data || []), |  | ||||||
|           ] |  | ||||||
|         } |  | ||||||
|         if (state.filterNewsData.length < (res.data.data?.total || 0)) { |  | ||||||
|           state.hasMore = true |  | ||||||
|         } else { |  | ||||||
|           state.hasMore = false |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| const handleFilter = () => { | const handleFilter = () => { | ||||||
|   // 筛选逻辑 |   // 筛选逻辑 | ||||||
| @ -226,17 +130,14 @@ const handleFilter = () => { | |||||||
| watch( | watch( | ||||||
|   () => [state.selectedValue, state.inputValue], |   () => [state.selectedValue, state.inputValue], | ||||||
|   () => { |   () => { | ||||||
|     // handleFilter(); |     handleFilter(); | ||||||
|     state.currentPage = 1 |   }, | ||||||
|     getPressReleasesDisplay() |   { immediate: true } | ||||||
|   } |  | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| const handleSearch = () => { | const handleSearch = () => { | ||||||
|   // 手动触发筛选(保留这个函数以保持兼容性) |   // 手动触发筛选(保留这个函数以保持兼容性) | ||||||
|   // handleFilter(); |   handleFilter(); | ||||||
|   state.currentPage = 1 |  | ||||||
|   getPressReleasesDisplay() |  | ||||||
|   // console.log("筛选结果:", state.filterNewsData); |   // console.log("筛选结果:", state.filterNewsData); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| @ -244,23 +145,10 @@ const handleNewClick = (item) => { | |||||||
|   router.push({ |   router.push({ | ||||||
|     path: "/news", |     path: "/news", | ||||||
|     query: { |     query: { | ||||||
|       id: item.id, |       date: item.date, | ||||||
|     }, |     }, | ||||||
|   }); |   }); | ||||||
| }; | }; | ||||||
| 
 |  | ||||||
| //加载更多数据 |  | ||||||
| const doLoadMore = () => { |  | ||||||
|   if (!state.hasMore || state.loading) { |  | ||||||
|     return |  | ||||||
|   } |  | ||||||
|   // console.log('触底了') |  | ||||||
|   state.loading = true |  | ||||||
|   state.currentPage++ |  | ||||||
|   getPressReleasesDisplay().finally(() => { |  | ||||||
|     state.loading = false |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
|  | |||||||
| @ -1,9 +1,8 @@ | |||||||
| <template> | <template> | ||||||
|   <div class="press-releases-page"> |   <div class="press-releases-page"> | ||||||
|     <n-infinite-scroll :distance="0" @load="doLoadMore"> |  | ||||||
|     <main class="p-[35px] max-w-[1200px] mx-auto"> |     <main class="p-[35px] max-w-[1200px] mx-auto"> | ||||||
|       <div class="title mb-[20px]"> |       <div class="title mb-[20px]"> | ||||||
|           {{ t('press_releases.title') }} |         {{ t("press_releases.title") }} | ||||||
|       </div> |       </div> | ||||||
|       <div class="search-container"> |       <div class="search-container"> | ||||||
|         <n-select |         <n-select | ||||||
| @ -22,57 +21,36 @@ | |||||||
|           @click="handleSearch" |           @click="handleSearch" | ||||||
|           class="search-button w-[60px]" |           class="search-button w-[60px]" | ||||||
|         > |         > | ||||||
|             {{ t('press_releases.search.button') }} |           {{ t("press_releases.search.button") }} | ||||||
|         </n-button> |         </n-button> | ||||||
|       </div> |       </div> | ||||||
|       <div v-for="(item, idx) in state.filterNewsData" :key="idx"> |       <div v-for="(item, idx) in state.filterNewsData" :key="idx"> | ||||||
|         <div class="news-item mt-[10px]"> |         <div class="news-item mt-[10px]"> | ||||||
|           <div class="news-item-date">{{ item.date }}</div> |           <div class="news-item-date">{{ item.date }}</div> | ||||||
|           <div |           <div | ||||||
|               class="news-item-title text-[#0078d7] cursor-pointer" |             class="news-item-title text-[#0078d7] overflow-hidden whitespace-nowrap text-ellipsis cursor-pointer" | ||||||
|               style="word-break: break-word; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis;" |  | ||||||
|             @click="handleNewClick(item)" |             @click="handleNewClick(item)" | ||||||
|           > |           > | ||||||
|             {{ item.title }} |             {{ item.title }} | ||||||
|           </div> |           </div> | ||||||
|             <n-tooltip |           <div class="news-item-content"> | ||||||
|               trigger="hover" |             {{ | ||||||
|               :disabled="!item.showTooltip" |               item.content.length > 230 | ||||||
|               width="trigger" |                 ? item.content.substring(0, 230) + "..." | ||||||
|             > |                 : item.content | ||||||
|               <template #trigger> |             }} | ||||||
|                 <div |  | ||||||
|                   :ref="(el) => setTitleRef(el, idx)" |  | ||||||
|                   class="news-item-content" |  | ||||||
|                   style=" |  | ||||||
|                     word-break: break-word; |  | ||||||
|                     display: -webkit-box; |  | ||||||
|                     -webkit-line-clamp: 2; |  | ||||||
|                     -webkit-box-orient: vertical; |  | ||||||
|                     overflow: hidden; |  | ||||||
|                     text-overflow: ellipsis; |  | ||||||
|                   " |  | ||||||
|                 > |  | ||||||
|                   {{item.summary}} |  | ||||||
|           </div> |           </div> | ||||||
|               </template> |  | ||||||
|               <div slot="content"> |  | ||||||
|                 {{item.summary}} |  | ||||||
|               </div> |  | ||||||
|             </n-tooltip> |  | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|     </main> |     </main> | ||||||
|     </n-infinite-scroll> |  | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import customDefaultPage from "@/components/customDefaultPage/index.vue"; | import customDefaultPage from "@/components/customDefaultPage/index.vue"; | ||||||
| import { reactive, onMounted, watch, nextTick, ref } from "vue"; | import { reactive, onMounted, watch } from "vue"; | ||||||
| import { NSelect, NInput, NButton, NInfiniteScroll, NTooltip } from "naive-ui"; | import { NSelect, NInput, NButton } from "naive-ui"; | ||||||
| import { useI18n } from "vue-i18n"; | import { useI18n } from "vue-i18n"; | ||||||
| import axios from 'axios' |  | ||||||
| 
 | 
 | ||||||
| import { useRouter } from "vue-router"; | import { useRouter } from "vue-router"; | ||||||
| const router = useRouter(); | const router = useRouter(); | ||||||
| @ -112,85 +90,11 @@ const state = reactive({ | |||||||
|     }, |     }, | ||||||
|   ], |   ], | ||||||
|   filterNewsData: [], |   filterNewsData: [], | ||||||
|   loading: false, //是否正在加载数据 |  | ||||||
|   hasMore: true, //是否还有更多数据 |  | ||||||
|   currentPage: 1, //当前页码 |  | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| const titleRefs = ref([]) |  | ||||||
| 
 |  | ||||||
| const setTitleRef = (el, idx) => { |  | ||||||
|   if (el) titleRefs.value[idx] = el |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const checkAllTitleOverflow = () => { |  | ||||||
|   state.filterNewsData.forEach((item, idx) => { |  | ||||||
|     const el = titleRefs.value[idx] |  | ||||||
|     if (!el) { |  | ||||||
|       item.showTooltip = false |  | ||||||
|       return |  | ||||||
|     } |  | ||||||
|     item.showTooltip = el.scrollHeight > el.clientHeight || el.scrollWidth > el.clientWidth |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   // state.filterNewsData = state.newsData; |   state.filterNewsData = state.newsData; | ||||||
|   getPressReleasesDisplay() | }); | ||||||
| 
 |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }) |  | ||||||
| 
 |  | ||||||
| watch(() => state.filterNewsData, () => { |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }, { deep: true }) |  | ||||||
| 
 |  | ||||||
| // 获取新闻列表 |  | ||||||
| const getPressReleasesDisplay = () => { |  | ||||||
|   let url = 'http://172.16.100.93:9020/api/fiee/pressreleases/display' |  | ||||||
|   let params = { |  | ||||||
|     query: state.inputValue, |  | ||||||
|     page: state.currentPage, |  | ||||||
|     pageSize: 10, |  | ||||||
|     timeStart: state.selectedValue |  | ||||||
|       ? state.selectedValue === 'all_years' |  | ||||||
|         ? null |  | ||||||
|         : new Date(state.selectedValue).getTime() |  | ||||||
|       : null, |  | ||||||
|   } |  | ||||||
|   // console.log(params) |  | ||||||
|   axios.post(url, params).then((res) => { |  | ||||||
|     // console.log(res) |  | ||||||
|     if (res.status === 200) { |  | ||||||
|       if (res.data.status === 0) { |  | ||||||
|         res.data.data?.data?.forEach((item) => { |  | ||||||
|           item.date = new Date(item.createdAt).toLocaleDateString('en-US', { |  | ||||||
|             month: 'short', |  | ||||||
|             day: 'numeric', |  | ||||||
|             year: 'numeric', |  | ||||||
|           }) |  | ||||||
|         }) |  | ||||||
|         if (state.currentPage === 1) { |  | ||||||
|           state.filterNewsData = res.data.data?.data || [] |  | ||||||
|         } else { |  | ||||||
|           state.filterNewsData = [ |  | ||||||
|             ...state.filterNewsData, |  | ||||||
|             ...(res.data.data?.data || []), |  | ||||||
|           ] |  | ||||||
|         } |  | ||||||
|         if (state.filterNewsData.length < (res.data.data?.total || 0)) { |  | ||||||
|           state.hasMore = true |  | ||||||
|         } else { |  | ||||||
|           state.hasMore = false |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| const handleFilter = () => { | const handleFilter = () => { | ||||||
|   // 筛选逻辑 |   // 筛选逻辑 | ||||||
| @ -226,17 +130,14 @@ const handleFilter = () => { | |||||||
| watch( | watch( | ||||||
|   () => [state.selectedValue, state.inputValue], |   () => [state.selectedValue, state.inputValue], | ||||||
|   () => { |   () => { | ||||||
|     // handleFilter(); |     handleFilter(); | ||||||
|     state.currentPage = 1 |   }, | ||||||
|     getPressReleasesDisplay() |   { immediate: true } | ||||||
|   } |  | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| const handleSearch = () => { | const handleSearch = () => { | ||||||
|   // 手动触发筛选(保留这个函数以保持兼容性) |   // 手动触发筛选(保留这个函数以保持兼容性) | ||||||
|   // handleFilter(); |   handleFilter(); | ||||||
|   state.currentPage = 1 |  | ||||||
|   getPressReleasesDisplay() |  | ||||||
|   // console.log("筛选结果:", state.filterNewsData); |   // console.log("筛选结果:", state.filterNewsData); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| @ -244,23 +145,10 @@ const handleNewClick = (item) => { | |||||||
|   router.push({ |   router.push({ | ||||||
|     path: "/news", |     path: "/news", | ||||||
|     query: { |     query: { | ||||||
|       id: item.id, |       date: item.date, | ||||||
|     }, |     }, | ||||||
|   }); |   }); | ||||||
| }; | }; | ||||||
| 
 |  | ||||||
| //加载更多数据 |  | ||||||
| const doLoadMore = () => { |  | ||||||
|   if (!state.hasMore || state.loading) { |  | ||||||
|     return |  | ||||||
|   } |  | ||||||
|   // console.log('触底了') |  | ||||||
|   state.loading = true |  | ||||||
|   state.currentPage++ |  | ||||||
|   getPressReleasesDisplay().finally(() => { |  | ||||||
|     state.loading = false |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
|  | |||||||
| @ -1,12 +1,8 @@ | |||||||
| <template> | <template> | ||||||
|   <div class="press-releases-page"> |   <div class="press-releases-page"> | ||||||
|     <n-infinite-scroll :distance="0" @load="doLoadMore"> |     <main class="p-[80px] mx-auto" style="max-width: 100vw; min-width: 285px"> | ||||||
|       <main |  | ||||||
|         class="p-[80px] mx-auto" |  | ||||||
|         style="max-width: 100vw; min-width: 285px;" |  | ||||||
|       > |  | ||||||
|       <div class="title mb-[24px]"> |       <div class="title mb-[24px]"> | ||||||
|           {{ t('press_releases.title') }} |         {{ t("press_releases.title") }} | ||||||
|       </div> |       </div> | ||||||
|       <div class="search-container"> |       <div class="search-container"> | ||||||
|         <n-select |         <n-select | ||||||
| @ -29,59 +25,38 @@ | |||||||
|           class="search-button" |           class="search-button" | ||||||
|           :font-size="72" |           :font-size="72" | ||||||
|         > |         > | ||||||
|             {{ t('press_releases.search.button') }} |           {{ t("press_releases.search.button") }} | ||||||
|         </n-button> |         </n-button> | ||||||
|       </div> |       </div> | ||||||
|       <div v-for="(item, idx) in state.filterNewsData" :key="idx"> |       <div v-for="(item, idx) in state.filterNewsData" :key="idx"> | ||||||
|         <div class="news-item mt-[10px]"> |         <div class="news-item mt-[10px]"> | ||||||
|           <div class="news-item-date">{{ item.date }}</div> |           <div class="news-item-date">{{ item.date }}</div> | ||||||
|           <div |           <div | ||||||
|               class="news-item-title text-[#0078d7] cursor-pointer" |             class="news-item-title text-[#0078d7] overflow-hidden whitespace-nowrap text-ellipsis cursor-pointer" | ||||||
|               style="word-break: break-word; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis;" |  | ||||||
|             @click="handleNewClick(item)" |             @click="handleNewClick(item)" | ||||||
|           > |           > | ||||||
|             {{ item.title }} |             {{ item.title }} | ||||||
|           </div> |           </div> | ||||||
|             <n-tooltip |           <div class="news-item-content"> | ||||||
|               trigger="click" |             {{ | ||||||
|               :disabled="!item.showTooltip" |               item.content.length > 230 | ||||||
|               width="trigger" |                 ? item.content.substring(0, 230) + "..." | ||||||
|             > |                 : item.content | ||||||
|               <template #trigger> |             }} | ||||||
|                 <div |  | ||||||
|                   :ref="(el) => setTitleRef(el, idx)" |  | ||||||
|                   class="news-item-content" |  | ||||||
|                   style=" |  | ||||||
|                     word-break: break-word; |  | ||||||
|                     display: -webkit-box; |  | ||||||
|                     -webkit-line-clamp: 2; |  | ||||||
|                     -webkit-box-orient: vertical; |  | ||||||
|                     overflow: hidden; |  | ||||||
|                     text-overflow: ellipsis; |  | ||||||
|                   " |  | ||||||
|                 > |  | ||||||
|                   {{item.summary}} |  | ||||||
|           </div> |           </div> | ||||||
|               </template> |  | ||||||
|               <div slot="content"> |  | ||||||
|               {{item.summary}} |  | ||||||
|               </div> |  | ||||||
|             </n-tooltip> |  | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|     </main> |     </main> | ||||||
|     </n-infinite-scroll> |  | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import customDefaultPage from "@/components/customDefaultPage/index.vue"; | import customDefaultPage from "@/components/customDefaultPage/index.vue"; | ||||||
| import { reactive, onMounted, watch, nextTick, ref } from "vue"; | import { reactive, onMounted, watch } from "vue"; | ||||||
| import { NSelect, NInput, NButton, NInfiniteScroll, NTooltip } from "naive-ui"; | import { NSelect, NInput, NButton } from "naive-ui"; | ||||||
| import { useI18n } from "vue-i18n"; | import { useI18n } from "vue-i18n"; | ||||||
| import axios from 'axios' |  | ||||||
| 
 |  | ||||||
| import { useRouter } from "vue-router"; | import { useRouter } from "vue-router"; | ||||||
|  | 
 | ||||||
| const router = useRouter(); | const router = useRouter(); | ||||||
| const { t } = useI18n(); | const { t } = useI18n(); | ||||||
| 
 | 
 | ||||||
| @ -119,85 +94,11 @@ const state = reactive({ | |||||||
|     }, |     }, | ||||||
|   ], |   ], | ||||||
|   filterNewsData: [], |   filterNewsData: [], | ||||||
|   loading: false, //是否正在加载数据 |  | ||||||
|   hasMore: true, //是否还有更多数据 |  | ||||||
|   currentPage: 1, //当前页码 |  | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| const titleRefs = ref([]) |  | ||||||
| 
 |  | ||||||
| const setTitleRef = (el, idx) => { |  | ||||||
|   if (el) titleRefs.value[idx] = el |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const checkAllTitleOverflow = () => { |  | ||||||
|   state.filterNewsData.forEach((item, idx) => { |  | ||||||
|     const el = titleRefs.value[idx] |  | ||||||
|     if (!el) { |  | ||||||
|       item.showTooltip = false |  | ||||||
|       return |  | ||||||
|     } |  | ||||||
|     item.showTooltip = el.scrollHeight > el.clientHeight || el.scrollWidth > el.clientWidth |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   // state.filterNewsData = state.newsData; |   state.filterNewsData = state.newsData; | ||||||
|   getPressReleasesDisplay() | }); | ||||||
| 
 |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }) |  | ||||||
| 
 |  | ||||||
| watch(() => state.filterNewsData, () => { |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }, { deep: true }) |  | ||||||
| 
 |  | ||||||
| // 获取新闻列表 |  | ||||||
| const getPressReleasesDisplay = () => { |  | ||||||
|   let url = 'http://172.16.100.93:9020/api/fiee/pressreleases/display' |  | ||||||
|   let params = { |  | ||||||
|     query: state.inputValue, |  | ||||||
|     page: state.currentPage, |  | ||||||
|     pageSize: 10, |  | ||||||
|     timeStart: state.selectedValue |  | ||||||
|       ? state.selectedValue === 'all_years' |  | ||||||
|         ? null |  | ||||||
|         : new Date(state.selectedValue).getTime() |  | ||||||
|       : null, |  | ||||||
|   } |  | ||||||
|   // console.log(params) |  | ||||||
|   axios.post(url, params).then((res) => { |  | ||||||
|     // console.log(res) |  | ||||||
|     if (res.status === 200) { |  | ||||||
|       if (res.data.status === 0) { |  | ||||||
|         res.data.data?.data?.forEach((item) => { |  | ||||||
|           item.date = new Date(item.createdAt).toLocaleDateString('en-US', { |  | ||||||
|             month: 'short', |  | ||||||
|             day: 'numeric', |  | ||||||
|             year: 'numeric', |  | ||||||
|           }) |  | ||||||
|         }) |  | ||||||
|         if (state.currentPage === 1) { |  | ||||||
|           state.filterNewsData = res.data.data?.data || [] |  | ||||||
|         } else { |  | ||||||
|           state.filterNewsData = [ |  | ||||||
|             ...state.filterNewsData, |  | ||||||
|             ...(res.data.data?.data || []), |  | ||||||
|           ] |  | ||||||
|         } |  | ||||||
|         if (state.filterNewsData.length < (res.data.data?.total || 0)) { |  | ||||||
|           state.hasMore = true |  | ||||||
|         } else { |  | ||||||
|           state.hasMore = false |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| const handleFilter = () => { | const handleFilter = () => { | ||||||
|   // 筛选逻辑 |   // 筛选逻辑 | ||||||
| @ -233,17 +134,14 @@ const handleFilter = () => { | |||||||
| watch( | watch( | ||||||
|   () => [state.selectedValue, state.inputValue], |   () => [state.selectedValue, state.inputValue], | ||||||
|   () => { |   () => { | ||||||
|     // handleFilter(); |     handleFilter(); | ||||||
|     state.currentPage = 1 |   }, | ||||||
|     getPressReleasesDisplay() |   { immediate: true } | ||||||
|   } |  | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| const handleSearch = () => { | const handleSearch = () => { | ||||||
|   // 手动触发筛选(保留这个函数以保持兼容性) |   // 手动触发筛选(保留这个函数以保持兼容性) | ||||||
|   // handleFilter(); |   handleFilter(); | ||||||
|   state.currentPage = 1 |  | ||||||
|   getPressReleasesDisplay() |  | ||||||
|   // console.log("筛选结果:", state.filterNewsData); |   // console.log("筛选结果:", state.filterNewsData); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| @ -251,23 +149,10 @@ const handleNewClick = (item) => { | |||||||
|   router.push({ |   router.push({ | ||||||
|     path: "/news", |     path: "/news", | ||||||
|     query: { |     query: { | ||||||
|       id: item.id, |       date: item.date, | ||||||
|     }, |     }, | ||||||
|   }); |   }); | ||||||
| }; | }; | ||||||
| 
 |  | ||||||
| //加载更多数据 |  | ||||||
| const doLoadMore = () => { |  | ||||||
|   if (!state.hasMore || state.loading) { |  | ||||||
|     return |  | ||||||
|   } |  | ||||||
|   // console.log('触底了') |  | ||||||
|   state.loading = true |  | ||||||
|   state.currentPage++ |  | ||||||
|   getPressReleasesDisplay().finally(() => { |  | ||||||
|     state.loading = false |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
|  | |||||||
| @ -1,9 +1,8 @@ | |||||||
| <template> | <template> | ||||||
|   <div class="press-releases-page"> |   <div class="press-releases-page"> | ||||||
|     <n-infinite-scroll :distance="0" @load="doLoadMore"> |     <main class="p-[35px] mx-auto" style="max-width: calc(100% - 100px)"> | ||||||
|       <main class="p-[35px] mx-auto" style="max-width: calc(100% - 100px);"> |  | ||||||
|       <div class="title mb-[20px]"> |       <div class="title mb-[20px]"> | ||||||
|           {{ t('press_releases.title') }} |         {{ t("press_releases.title") }} | ||||||
|       </div> |       </div> | ||||||
|       <div class="search-container"> |       <div class="search-container"> | ||||||
|         <n-select |         <n-select | ||||||
| @ -22,57 +21,36 @@ | |||||||
|           @click="handleSearch" |           @click="handleSearch" | ||||||
|           class="search-button w-[120px]" |           class="search-button w-[120px]" | ||||||
|         > |         > | ||||||
|             {{ t('press_releases.search.button') }} |           {{ t("press_releases.search.button") }} | ||||||
|         </n-button> |         </n-button> | ||||||
|       </div> |       </div> | ||||||
|       <div v-for="(item, idx) in state.filterNewsData" :key="idx"> |       <div v-for="(item, idx) in state.filterNewsData" :key="idx"> | ||||||
|         <div class="news-item mt-[10px]"> |         <div class="news-item mt-[10px]"> | ||||||
|           <div class="news-item-date">{{ item.date }}</div> |           <div class="news-item-date">{{ item.date }}</div> | ||||||
|           <div |           <div | ||||||
|               class="news-item-title text-[#0078d7] cursor-pointer" |             class="news-item-title text-[#0078d7] overflow-hidden whitespace-nowrap text-ellipsis cursor-pointer" | ||||||
|               style="word-break: break-word; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis;" |  | ||||||
|             @click="handleNewClick(item)" |             @click="handleNewClick(item)" | ||||||
|           > |           > | ||||||
|             {{ item.title }} |             {{ item.title }} | ||||||
|           </div> |           </div> | ||||||
|             <n-tooltip |           <div class="news-item-content"> | ||||||
|               trigger="click" |             {{ | ||||||
|               :disabled="!item.showTooltip" |               item.content.length > 230 | ||||||
|               width="trigger" |                 ? item.content.substring(0, 230) + "..." | ||||||
|             > |                 : item.content | ||||||
|               <template #trigger> |             }} | ||||||
|                 <div |  | ||||||
|                   :ref="(el) => setTitleRef(el, idx)" |  | ||||||
|                   class="news-item-content" |  | ||||||
|                   style=" |  | ||||||
|                     word-break: break-word; |  | ||||||
|                     display: -webkit-box; |  | ||||||
|                     -webkit-line-clamp: 2; |  | ||||||
|                     -webkit-box-orient: vertical; |  | ||||||
|                     overflow: hidden; |  | ||||||
|                     text-overflow: ellipsis; |  | ||||||
|                   " |  | ||||||
|                 > |  | ||||||
|                 {{item.summary}} |  | ||||||
|           </div> |           </div> | ||||||
|               </template> |  | ||||||
|               <div slot="content"> |  | ||||||
|                 {{item.summary}} |  | ||||||
|               </div> |  | ||||||
|             </n-tooltip> |  | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|     </main> |     </main> | ||||||
|     </n-infinite-scroll> |  | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| import customDefaultPage from "@/components/customDefaultPage/index.vue"; | import customDefaultPage from "@/components/customDefaultPage/index.vue"; | ||||||
| import { reactive, onMounted, watch, nextTick, ref } from "vue"; | import { reactive, onMounted, watch } from "vue"; | ||||||
| import { NSelect, NInput, NButton, NInfiniteScroll, NTooltip } from "naive-ui"; | import { NSelect, NInput, NButton } from "naive-ui"; | ||||||
| import { useI18n } from "vue-i18n"; | import { useI18n } from "vue-i18n"; | ||||||
| import axios from 'axios' |  | ||||||
| 
 | 
 | ||||||
| import { useRouter } from "vue-router"; | import { useRouter } from "vue-router"; | ||||||
| const router = useRouter(); | const router = useRouter(); | ||||||
| @ -112,85 +90,11 @@ const state = reactive({ | |||||||
|     }, |     }, | ||||||
|   ], |   ], | ||||||
|   filterNewsData: [], |   filterNewsData: [], | ||||||
|   loading: false, //是否正在加载数据 |  | ||||||
|   hasMore: true, //是否还有更多数据 |  | ||||||
|   currentPage: 1, //当前页码 |  | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| const titleRefs = ref([]) |  | ||||||
| 
 |  | ||||||
| const setTitleRef = (el, idx) => { |  | ||||||
|   if (el) titleRefs.value[idx] = el |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const checkAllTitleOverflow = () => { |  | ||||||
|   state.filterNewsData.forEach((item, idx) => { |  | ||||||
|     const el = titleRefs.value[idx] |  | ||||||
|     if (!el) { |  | ||||||
|       item.showTooltip = false |  | ||||||
|       return |  | ||||||
|     } |  | ||||||
|     item.showTooltip = el.scrollHeight > el.clientHeight || el.scrollWidth > el.clientWidth |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   // state.filterNewsData = state.newsData; |   state.filterNewsData = state.newsData; | ||||||
|   getPressReleasesDisplay() | }); | ||||||
| 
 |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }) |  | ||||||
| 
 |  | ||||||
| watch(() => state.filterNewsData, () => { |  | ||||||
|   nextTick(() => { |  | ||||||
|     checkAllTitleOverflow() |  | ||||||
|   }) |  | ||||||
| }, { deep: true }) |  | ||||||
| 
 |  | ||||||
| // 获取新闻列表 |  | ||||||
| const getPressReleasesDisplay = () => { |  | ||||||
|   let url = 'http://172.16.100.93:9020/api/fiee/pressreleases/display' |  | ||||||
|   let params = { |  | ||||||
|     query: state.inputValue, |  | ||||||
|     page: state.currentPage, |  | ||||||
|     pageSize: 10, |  | ||||||
|     timeStart: state.selectedValue |  | ||||||
|       ? state.selectedValue === 'all_years' |  | ||||||
|         ? null |  | ||||||
|         : new Date(state.selectedValue).getTime() |  | ||||||
|       : null, |  | ||||||
|   } |  | ||||||
|   // console.log(params) |  | ||||||
|   axios.post(url, params).then((res) => { |  | ||||||
|     // console.log(res) |  | ||||||
|     if (res.status === 200) { |  | ||||||
|       if (res.data.status === 0) { |  | ||||||
|         res.data.data?.data?.forEach((item) => { |  | ||||||
|           item.date = new Date(item.createdAt).toLocaleDateString('en-US', { |  | ||||||
|             month: 'short', |  | ||||||
|             day: 'numeric', |  | ||||||
|             year: 'numeric', |  | ||||||
|           }) |  | ||||||
|         }) |  | ||||||
|         if (state.currentPage === 1) { |  | ||||||
|           state.filterNewsData = res.data.data?.data || [] |  | ||||||
|         } else { |  | ||||||
|           state.filterNewsData = [ |  | ||||||
|             ...state.filterNewsData, |  | ||||||
|             ...(res.data.data?.data || []), |  | ||||||
|           ] |  | ||||||
|         } |  | ||||||
|         if (state.filterNewsData.length < (res.data.data?.total || 0)) { |  | ||||||
|           state.hasMore = true |  | ||||||
|         } else { |  | ||||||
|           state.hasMore = false |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| const handleFilter = () => { | const handleFilter = () => { | ||||||
|   // 筛选逻辑 |   // 筛选逻辑 | ||||||
| @ -226,17 +130,14 @@ const handleFilter = () => { | |||||||
| watch( | watch( | ||||||
|   () => [state.selectedValue, state.inputValue], |   () => [state.selectedValue, state.inputValue], | ||||||
|   () => { |   () => { | ||||||
|     // handleFilter(); |     handleFilter(); | ||||||
|     state.currentPage = 1 |   }, | ||||||
|     getPressReleasesDisplay() |   { immediate: true } | ||||||
|   } |  | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| const handleSearch = () => { | const handleSearch = () => { | ||||||
|   // 手动触发筛选(保留这个函数以保持兼容性) |   // 手动触发筛选(保留这个函数以保持兼容性) | ||||||
|   // handleFilter(); |   handleFilter(); | ||||||
|   state.currentPage = 1 |  | ||||||
|   getPressReleasesDisplay() |  | ||||||
|   // console.log("筛选结果:", state.filterNewsData); |   // console.log("筛选结果:", state.filterNewsData); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| @ -244,28 +145,15 @@ const handleNewClick = (item) => { | |||||||
|   router.push({ |   router.push({ | ||||||
|     path: "/news", |     path: "/news", | ||||||
|     query: { |     query: { | ||||||
|       id: item.id, |       date: item.date, | ||||||
|     }, |     }, | ||||||
|   }); |   }); | ||||||
| }; | }; | ||||||
| 
 |  | ||||||
| //加载更多数据 |  | ||||||
| const doLoadMore = () => { |  | ||||||
|   if (!state.hasMore || state.loading) { |  | ||||||
|     return |  | ||||||
|   } |  | ||||||
|   // console.log('触底了') |  | ||||||
|   state.loading = true |  | ||||||
|   state.currentPage++ |  | ||||||
|   getPressReleasesDisplay().finally(() => { |  | ||||||
|     state.loading = false |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
| .title { | .title { | ||||||
|   font-size: 63px; |   font-size: 40px; | ||||||
|   color: #333; |   color: #333; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user