mirror of
https://github.com/QuantumNous/new-api.git
synced 2026-04-20 02:18:37 +00:00
Summary • Added new Ratio tab in Settings for managing all ratio-related configurations (group & model multipliers). • Created `RatioSetting` component to host GroupRatio, ModelRatio, Visual Editor and Unset-Models panels. • Moved ratio components to `web/src/pages/Setting/Ratio/` directory: – `GroupRatioSettings.js` – `ModelRatioSettings.js` – `ModelSettingsVisualEditor.js` – `ModelRationNotSetEditor.js` • Updated imports in `RatioSetting.js` to use the new path. • Updated main Settings router (`web/src/pages/Setting/index.js`) to include the new “Ratio Settings” tab. • Pruned `OperationSetting.js`: – Removed ratio-specific cards, tabs and unused imports. – Reduced state to only the keys required by its child components. – Deleted obsolete fields (`StreamCacheQueueLength`, `CheckSensitiveOnCompletionEnabled`, `StopOnSensitiveEnabled`). • Added boolean handling simplification in `OperationSetting.js`. • Adjusted helper import list and removed unused translation hook. Why Separating ratio-related settings improves UX clarity, reduces cognitive load in the Operation Settings panel and keeps the codebase modular and easier to maintain. BREAKING CHANGE The file paths for ratio components have changed. Any external imports referencing the old `Operation` directory must update to the new `Ratio` path.
109 lines
3.2 KiB
JavaScript
109 lines
3.2 KiB
JavaScript
import React, { useEffect, useState } from 'react';
|
||
import { Card, Spin, Tabs } from '@douyinfe/semi-ui';
|
||
import { useTranslation } from 'react-i18next';
|
||
|
||
import GroupRatioSettings from '../../pages/Setting/Ratio/GroupRatioSettings.js';
|
||
import ModelRatioSettings from '../../pages/Setting/Ratio/ModelRatioSettings.js';
|
||
import ModelSettingsVisualEditor from '../../pages/Setting/Ratio/ModelSettingsVisualEditor.js';
|
||
import ModelRatioNotSetEditor from '../../pages/Setting/Ratio/ModelRationNotSetEditor.js';
|
||
|
||
import { API, showError } from '../../helpers';
|
||
|
||
const RatioSetting = () => {
|
||
const { t } = useTranslation();
|
||
|
||
let [inputs, setInputs] = useState({
|
||
ModelPrice: '',
|
||
ModelRatio: '',
|
||
CacheRatio: '',
|
||
CompletionRatio: '',
|
||
GroupRatio: '',
|
||
GroupGroupRatio: '',
|
||
AutoGroups: '',
|
||
DefaultUseAutoGroup: false,
|
||
UserUsableGroups: '',
|
||
});
|
||
|
||
const [loading, setLoading] = useState(false);
|
||
|
||
const getOptions = async () => {
|
||
const res = await API.get('/api/option/');
|
||
const { success, message, data } = res.data;
|
||
if (success) {
|
||
let newInputs = {};
|
||
data.forEach((item) => {
|
||
if (
|
||
item.key === 'ModelRatio' ||
|
||
item.key === 'GroupRatio' ||
|
||
item.key === 'GroupGroupRatio' ||
|
||
item.key === 'AutoGroups' ||
|
||
item.key === 'UserUsableGroups' ||
|
||
item.key === 'CompletionRatio' ||
|
||
item.key === 'ModelPrice' ||
|
||
item.key === 'CacheRatio'
|
||
) {
|
||
try {
|
||
item.value = JSON.stringify(JSON.parse(item.value), null, 2);
|
||
} catch (e) {
|
||
// 如果后端返回的不是合法 JSON,直接展示
|
||
}
|
||
}
|
||
if (['DefaultUseAutoGroup'].includes(item.key)) {
|
||
newInputs[item.key] = item.value === 'true' ? true : false;
|
||
} else {
|
||
newInputs[item.key] = item.value;
|
||
}
|
||
});
|
||
setInputs(newInputs);
|
||
} else {
|
||
showError(message);
|
||
}
|
||
};
|
||
|
||
const onRefresh = async () => {
|
||
try {
|
||
setLoading(true);
|
||
await getOptions();
|
||
} catch (error) {
|
||
showError('刷新失败');
|
||
} finally {
|
||
setLoading(false);
|
||
}
|
||
};
|
||
|
||
useEffect(() => {
|
||
onRefresh();
|
||
// eslint-disable-next-line react-hooks/exhaustive-deps
|
||
}, []);
|
||
|
||
return (
|
||
<Spin spinning={loading} size='large'>
|
||
{/* 分组倍率设置 */}
|
||
<Card style={{ marginTop: '10px' }}>
|
||
<GroupRatioSettings options={inputs} refresh={onRefresh} />
|
||
</Card>
|
||
{/* 模型倍率设置以及可视化编辑器 */}
|
||
<Card style={{ marginTop: '10px' }}>
|
||
<Tabs type='line'>
|
||
<Tabs.TabPane tab={t('模型倍率设置')} itemKey='model'>
|
||
<ModelRatioSettings options={inputs} refresh={onRefresh} />
|
||
</Tabs.TabPane>
|
||
<Tabs.TabPane tab={t('可视化倍率设置')} itemKey='visual'>
|
||
<ModelSettingsVisualEditor
|
||
options={inputs}
|
||
refresh={onRefresh}
|
||
/>
|
||
</Tabs.TabPane>
|
||
<Tabs.TabPane tab={t('未设置倍率模型')} itemKey='unset_models'>
|
||
<ModelRatioNotSetEditor
|
||
options={inputs}
|
||
refresh={onRefresh}
|
||
/>
|
||
</Tabs.TabPane>
|
||
</Tabs>
|
||
</Card>
|
||
</Spin>
|
||
);
|
||
};
|
||
|
||
export default RatioSetting;
|