From d8a29ecc8c0b32c47d9ab403a74052aa74e71c97 Mon Sep 17 00:00:00 2001 From: Arvin Xu Date: Mon, 6 Jan 2025 09:55:19 +0800 Subject: [PATCH 1/3] =?UTF-8?q?=F0=9F=90=9B=20fix:=20fix=20format=20short?= =?UTF-8?q?=20number=20(#5294)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * pin pdfjs dist * refactor * fix number format * Revert "pin pdfjs dist" This reverts commit 1a2eae1494d2355c0354dd44b1af767a77c8a548. * fix * fix * fix --- next.config.ts | 10 ++-------- src/features/User/DataStatistics.tsx | 24 ++++-------------------- src/utils/format.test.ts | 8 +++++--- src/utils/format.ts | 2 +- 4 files changed, 12 insertions(+), 32 deletions(-) diff --git a/next.config.ts b/next.config.ts index 35095f78efe4..4aa829ffaf03 100644 --- a/next.config.ts +++ b/next.config.ts @@ -10,7 +10,6 @@ const enableReactScan = !!process.env.REACT_SCAN_MONITOR_API_KEY; const isUsePglite = process.env.NEXT_PUBLIC_CLIENT_DB === 'pglite'; // if you need to proxy the api endpoint to remote server -const API_PROXY_ENDPOINT = process.env.API_PROXY_ENDPOINT || ''; const basePath = process.env.NEXT_PUBLIC_BASE_PATH; @@ -28,7 +27,6 @@ const nextConfig: NextConfig = { ], webVitalsAttribution: ['CLS', 'LCP'], }, - async headers() { return [ { @@ -166,14 +164,10 @@ const nextConfig: NextConfig = { source: '/welcome', }, ], - rewrites: async () => [ - // due to google api not work correct in some countries - // we need a proxy to bypass the restriction - { destination: `${API_PROXY_ENDPOINT}/api/chat/google`, source: '/api/chat/google' }, - ], - serverExternalPackages: ['@electric-sql/pglite'], + transpilePackages: ['pdfjs-dist', 'mermaid'], + webpack(config) { config.experiments = { asyncWebAssembly: true, diff --git a/src/features/User/DataStatistics.tsx b/src/features/User/DataStatistics.tsx index c5589bd53c7b..dc337093ab71 100644 --- a/src/features/User/DataStatistics.tsx +++ b/src/features/User/DataStatistics.tsx @@ -3,7 +3,7 @@ import { Icon, Tooltip } from '@lobehub/ui'; import { Badge } from 'antd'; import { createStyles } from 'antd-style'; -import { isNumber, isUndefined } from 'lodash-es'; +import { isUndefined } from 'lodash-es'; import { LoaderCircle } from 'lucide-react'; import { memo, useMemo } from 'react'; import { useTranslation } from 'react-i18next'; @@ -14,6 +14,7 @@ import { messageService } from '@/services/message'; import { sessionService } from '@/services/session'; import { topicService } from '@/services/topic'; import { useServerConfigStore } from '@/store/serverConfig'; +import { formatShortenNumber } from '@/utils/format'; import { today } from '@/utils/time'; const useStyles = createStyles(({ css, token }) => ({ @@ -42,23 +43,6 @@ const useStyles = createStyles(({ css, token }) => ({ `, })); -const formatNumber = (num: any) => { - if (!isNumber(num)) return num; - // 使用Intl.NumberFormat来添加千分号 - const formattedWithComma = new Intl.NumberFormat('en-US').format(num); - - // 格式化为 K 或 M - if (num >= 10_000_000) { - return (num / 1_000_000).toFixed(1) + 'M'; - } else if (num >= 10_000) { - return (num / 1000).toFixed(1) + 'K'; - } else if (num === 0) { - return 0; - } else { - return formattedWithComma; - } -}; - const DataStatistics = memo>(({ style, ...rest }) => { const mobile = useServerConfigStore((s) => s.isMobile); // sessions @@ -128,7 +112,7 @@ const DataStatistics = memo>(({ style, ...rest }) key={item.key} > -
{formatNumber(item.count)}
+
{formatShortenNumber(item.count)}
{item.title}
{showBadge && ( @@ -150,7 +134,7 @@ const DataStatistics = memo>(({ style, ...rest }) return ( -
{formatNumber(item.count)}
+
{formatShortenNumber(item.count)}
{item.title}
diff --git a/src/utils/format.test.ts b/src/utils/format.test.ts index 537e45049345..470d9c4e256e 100644 --- a/src/utils/format.test.ts +++ b/src/utils/format.test.ts @@ -16,7 +16,6 @@ import { formatTokenNumber, } from './format'; -// 保留你已经编写的测试用例 describe('format', () => { describe('formatSize', () => { it('should format bytes to KB correctly', () => { @@ -128,10 +127,13 @@ describe('format', () => { expect(formatShortenNumber(9999)).toBe('9,999'); }); - it('should format numbers between 10,000 and 9,999,999 correctly', () => { + it('should format numbers between 10,000 and 999,999 correctly', () => { expect(formatShortenNumber(10000)).toBe('10.0K'); expect(formatShortenNumber(123456)).toBe('123.5K'); - expect(formatShortenNumber(9999999)).toBe('10000.0K'); + expect(formatShortenNumber(998000)).toBe('998.0K'); + expect(formatShortenNumber(999999)).toBe('1000.0K'); + expect(formatShortenNumber(1000000)).toBe('1.0M'); + expect(formatShortenNumber(9999999)).toBe('10.0M'); }); it('should format numbers 10,000,000 and above correctly', () => { diff --git a/src/utils/format.ts b/src/utils/format.ts index b13aea94ba5f..46a0c1af0882 100644 --- a/src/utils/format.ts +++ b/src/utils/format.ts @@ -69,7 +69,7 @@ export const formatShortenNumber = (num: any) => { const formattedWithComma = new Intl.NumberFormat('en-US').format(num); // 格式化为 K 或 M - if (num >= 10_000_000) { + if (num >= 1_000_000) { return (num / 1_000_000).toFixed(1) + 'M'; } else if (num >= 10_000) { return (num / 1000).toFixed(1) + 'K'; From adc64b9ec398baf50f693104b7282cbfbbef6984 Mon Sep 17 00:00:00 2001 From: semantic-release-bot Date: Mon, 6 Jan 2025 02:03:29 +0000 Subject: [PATCH 2/3] :bookmark: chore(release): v1.43.4 [skip ci] MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ### [Version 1.43.4](https://github.com/lobehub/lobe-chat/compare/v1.43.3...v1.43.4) Released on **2025-01-06** #### 🐛 Bug Fixes - **misc**: Fix format short number.
Improvements and Fixes #### What's fixed * **misc**: Fix format short number, closes [#5294](https://github.com/lobehub/lobe-chat/issues/5294) ([d8a29ec](https://github.com/lobehub/lobe-chat/commit/d8a29ec))
[![](https://img.shields.io/badge/-BACK_TO_TOP-151515?style=flat-square)](#readme-top)
--- CHANGELOG.md | 25 +++++++++++++++++++++++++ package.json | 2 +- 2 files changed, 26 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 748850639cd1..4a51ab64ad4c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,31 @@ # Changelog +### [Version 1.43.4](https://github.com/lobehub/lobe-chat/compare/v1.43.3...v1.43.4) + +Released on **2025-01-06** + +#### 🐛 Bug Fixes + +- **misc**: Fix format short number. + +
+ +
+Improvements and Fixes + +#### What's fixed + +- **misc**: Fix format short number, closes [#5294](https://github.com/lobehub/lobe-chat/issues/5294) ([d8a29ec](https://github.com/lobehub/lobe-chat/commit/d8a29ec)) + +
+ +
+ +[![](https://img.shields.io/badge/-BACK_TO_TOP-151515?style=flat-square)](#readme-top) + +
+ ### [Version 1.43.3](https://github.com/lobehub/lobe-chat/compare/v1.43.2...v1.43.3) Released on **2025-01-04** diff --git a/package.json b/package.json index 8c66144dd079..6e488864b5e4 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@lobehub/chat", - "version": "1.43.3", + "version": "1.43.4", "description": "Lobe Chat - an open-source, high-performance chatbot framework that supports speech synthesis, multimodal, and extensible Function Call plugin system. Supports one-click free deployment of your private ChatGPT/LLM web application.", "keywords": [ "framework", From 20f28092c63aa29c69203a89a965e7beac6b4006 Mon Sep 17 00:00:00 2001 From: lobehubbot Date: Mon, 6 Jan 2025 02:04:25 +0000 Subject: [PATCH 3/3] =?UTF-8?q?=F0=9F=93=9D=20docs(bot):=20Auto=20sync=20a?= =?UTF-8?q?gents=20&=20plugin=20to=20readme?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- changelog/v1.json | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/changelog/v1.json b/changelog/v1.json index 19a918cb9c71..63eb6d90fd8d 100644 --- a/changelog/v1.json +++ b/changelog/v1.json @@ -1,4 +1,11 @@ [ + { + "children": { + "fixes": ["Fix format short number."] + }, + "date": "2025-01-06", + "version": "1.43.4" + }, { "children": { "improvements": ["Upgrade @clerk/nextjs to v6."]