Merge branch 'alpha' into refactor/model-pricing

This commit is contained in:
t0ng7u
2025-07-27 00:03:18 +08:00
5 changed files with 18 additions and 14 deletions

View File

@@ -33,7 +33,7 @@ import {
Settings, Settings,
} from 'lucide-react'; } from 'lucide-react';
import { useTranslation } from 'react-i18next'; import { useTranslation } from 'react-i18next';
import { renderGroupOption, modelSelectFilter } from '../../helpers'; import { renderGroupOption, selectFilter } from '../../helpers';
import ParameterControl from './ParameterControl'; import ParameterControl from './ParameterControl';
import ImageUrlInput from './ImageUrlInput'; import ImageUrlInput from './ImageUrlInput';
import ConfigManager from './ConfigManager'; import ConfigManager from './ConfigManager';
@@ -173,7 +173,7 @@ const SettingsPanel = ({
name='model' name='model'
required required
selection selection
filter={modelSelectFilter} filter={selectFilter}
autoClearSearchValue={false} autoClearSearchValue={false}
onChange={(value) => onInputChange('model', value)} onChange={(value) => onInputChange('model', value)}
value={inputs.model} value={inputs.model}

View File

@@ -46,7 +46,7 @@ import {
Col, Col,
Highlight, Highlight,
} from '@douyinfe/semi-ui'; } from '@douyinfe/semi-ui';
import { getChannelModels, copy, getChannelIcon, getModelCategories, modelSelectFilter } from '../../../../helpers'; import { getChannelModels, copy, getChannelIcon, getModelCategories, selectFilter } from '../../../../helpers';
import { import {
IconSave, IconSave,
IconClose, IconClose,
@@ -979,7 +979,7 @@ const EditChannelModal = (props) => {
rules={[{ required: true, message: t('请选择渠道类型') }]} rules={[{ required: true, message: t('请选择渠道类型') }]}
optionList={channelOptionList} optionList={channelOptionList}
style={{ width: '100%' }} style={{ width: '100%' }}
filter={modelSelectFilter} filter={selectFilter}
autoClearSearchValue={false} autoClearSearchValue={false}
searchPosition='dropdown' searchPosition='dropdown'
onSearch={(value) => setChannelSearchValue(value)} onSearch={(value) => setChannelSearchValue(value)}
@@ -1380,7 +1380,7 @@ const EditChannelModal = (props) => {
placeholder={t('请选择该渠道所支持的模型')} placeholder={t('请选择该渠道所支持的模型')}
rules={[{ required: true, message: t('请选择模型') }]} rules={[{ required: true, message: t('请选择模型') }]}
multiple multiple
filter={modelSelectFilter} filter={selectFilter}
autoClearSearchValue={false} autoClearSearchValue={false}
searchPosition='dropdown' searchPosition='dropdown'
optionList={modelOptions} optionList={modelOptions}

View File

@@ -25,7 +25,7 @@ import {
showSuccess, showSuccess,
showWarning, showWarning,
verifyJSON, verifyJSON,
modelSelectFilter, selectFilter,
} from '../../../../helpers'; } from '../../../../helpers';
import { import {
SideSheet, SideSheet,
@@ -395,7 +395,7 @@ const EditTagModal = (props) => {
label={t('模型')} label={t('模型')}
placeholder={t('请选择该渠道所支持的模型,留空则不更改')} placeholder={t('请选择该渠道所支持的模型,留空则不更改')}
multiple multiple
filter={modelSelectFilter} filter={selectFilter}
autoClearSearchValue={false} autoClearSearchValue={false}
searchPosition='dropdown' searchPosition='dropdown'
optionList={modelOptions} optionList={modelOptions}

View File

@@ -26,7 +26,7 @@ import {
renderGroupOption, renderGroupOption,
renderQuotaWithPrompt, renderQuotaWithPrompt,
getModelCategories, getModelCategories,
modelSelectFilter, selectFilter,
} from '../../../../helpers'; } from '../../../../helpers';
import { useIsMobile } from '../../../../hooks/common/useIsMobile.js'; import { useIsMobile } from '../../../../hooks/common/useIsMobile.js';
import { import {
@@ -514,7 +514,7 @@ const EditTokenModal = (props) => {
multiple multiple
optionList={models} optionList={models}
extraText={t('非必要,不建议启用模型限制')} extraText={t('非必要,不建议启用模型限制')}
filter={modelSelectFilter} filter={selectFilter}
autoClearSearchValue={false} autoClearSearchValue={false}
searchPosition='dropdown' searchPosition='dropdown'
showClear showClear

View File

@@ -560,12 +560,16 @@ export function setTableCompactMode(compact, tableKey = 'global') {
// ------------------------------- // -------------------------------
// Select 组件统一过滤逻辑 // Select 组件统一过滤逻辑
// 解决 label 为 ReactNode带图标等时无法用内置 filter 搜索的问题。 // 使用方式: <Select filter={selectFilter} ... />
// 使用方式: <Select filter={modelSelectFilter} ... /> // 统一的 Select 搜索过滤逻辑 -- 支持同时匹配 option.value 与 option.label
export const modelSelectFilter = (input, option) => { export const selectFilter = (input, option) => {
if (!input) return true; if (!input) return true;
const val = (option?.value || '').toString().toLowerCase();
return val.includes(input.trim().toLowerCase()); const keyword = input.trim().toLowerCase();
const valueText = (option?.value ?? '').toString().toLowerCase();
const labelText = (option?.label ?? '').toString().toLowerCase();
return valueText.includes(keyword) || labelText.includes(keyword);
}; };
// ------------------------------- // -------------------------------