fix(web): 系统设置 CRUD 修复 — version 乐观锁 + 语言字段映射 + JSON 显示
- API 层所有 Info/Request 接口添加 version 字段,update 函数传递 version
- delete 函数改为 client.delete(url, { data: { version } }) 发送 JSON body
- LanguageInfo.enabled → is_active,匹配后端 LanguageResp 字段名
- LanguageManager 编辑弹窗简化为只读详情(后端仅支持 is_active 切换)
- SystemSettings 设置值显示改用 JSON.stringify 而非 String()
- SystemSettings updateSetting 发送解析后的 JSON 对象而非字符串
This commit is contained in:
@@ -8,6 +8,7 @@ export interface DictionaryItemInfo {
|
||||
value: string;
|
||||
sort_order: number;
|
||||
color?: string;
|
||||
version: number;
|
||||
}
|
||||
|
||||
export interface DictionaryInfo {
|
||||
@@ -16,6 +17,7 @@ export interface DictionaryInfo {
|
||||
code: string;
|
||||
description?: string;
|
||||
items: DictionaryItemInfo[];
|
||||
version: number;
|
||||
}
|
||||
|
||||
export interface CreateDictionaryRequest {
|
||||
@@ -27,6 +29,7 @@ export interface CreateDictionaryRequest {
|
||||
export interface UpdateDictionaryRequest {
|
||||
name?: string;
|
||||
description?: string;
|
||||
version: number;
|
||||
}
|
||||
|
||||
export async function listDictionaries(page = 1, pageSize = 20) {
|
||||
@@ -53,8 +56,8 @@ export async function updateDictionary(id: string, req: UpdateDictionaryRequest)
|
||||
return data.data;
|
||||
}
|
||||
|
||||
export async function deleteDictionary(id: string) {
|
||||
await client.delete(`/config/dictionaries/${id}`);
|
||||
export async function deleteDictionary(id: string, version: number) {
|
||||
await client.delete(`/config/dictionaries/${id}`, { data: { version } });
|
||||
}
|
||||
|
||||
export async function listItemsByCode(code: string) {
|
||||
@@ -77,6 +80,7 @@ export interface UpdateDictionaryItemRequest {
|
||||
value?: string;
|
||||
sort_order?: number;
|
||||
color?: string;
|
||||
version: number;
|
||||
}
|
||||
|
||||
export async function createDictionaryItem(
|
||||
@@ -102,6 +106,6 @@ export async function updateDictionaryItem(
|
||||
return data.data;
|
||||
}
|
||||
|
||||
export async function deleteDictionaryItem(dictionaryId: string, itemId: string) {
|
||||
await client.delete(`/config/dictionaries/${dictionaryId}/items/${itemId}`);
|
||||
export async function deleteDictionaryItem(dictionaryId: string, itemId: string, version: number) {
|
||||
await client.delete(`/config/dictionaries/${dictionaryId}/items/${itemId}`, { data: { version } });
|
||||
}
|
||||
|
||||
@@ -5,14 +5,11 @@ import client from './client';
|
||||
export interface LanguageInfo {
|
||||
code: string;
|
||||
name: string;
|
||||
enabled: boolean;
|
||||
translations?: Record<string, string>;
|
||||
is_active: boolean;
|
||||
}
|
||||
|
||||
export interface UpdateLanguageRequest {
|
||||
name?: string;
|
||||
enabled?: boolean;
|
||||
translations?: Record<string, string>;
|
||||
is_active: boolean;
|
||||
}
|
||||
|
||||
// --- API Functions ---
|
||||
|
||||
@@ -11,6 +11,7 @@ export interface MenuInfo {
|
||||
menu_type: string;
|
||||
permission?: string;
|
||||
children: MenuInfo[];
|
||||
version: number;
|
||||
}
|
||||
|
||||
export interface MenuItemReq {
|
||||
@@ -24,6 +25,7 @@ export interface MenuItemReq {
|
||||
menu_type?: string;
|
||||
permission?: string;
|
||||
role_ids?: string[];
|
||||
version?: number;
|
||||
}
|
||||
|
||||
export async function getMenus() {
|
||||
@@ -51,6 +53,6 @@ export async function updateMenu(id: string, req: MenuItemReq) {
|
||||
return data.data;
|
||||
}
|
||||
|
||||
export async function deleteMenu(id: string) {
|
||||
await client.delete(`/config/menus/${id}`);
|
||||
export async function deleteMenu(id: string, version: number) {
|
||||
await client.delete(`/config/menus/${id}`, { data: { version } });
|
||||
}
|
||||
|
||||
@@ -13,6 +13,7 @@ export interface NumberingRuleInfo {
|
||||
separator: string;
|
||||
reset_cycle: string;
|
||||
last_reset_date?: string;
|
||||
version: number;
|
||||
}
|
||||
|
||||
export interface CreateNumberingRuleRequest {
|
||||
@@ -33,6 +34,7 @@ export interface UpdateNumberingRuleRequest {
|
||||
seq_length?: number;
|
||||
separator?: string;
|
||||
reset_cycle?: string;
|
||||
version: number;
|
||||
}
|
||||
|
||||
export async function listNumberingRules(page = 1, pageSize = 20) {
|
||||
@@ -66,6 +68,6 @@ export async function generateNumber(id: string) {
|
||||
return data.data;
|
||||
}
|
||||
|
||||
export async function deleteNumberingRule(id: string) {
|
||||
await client.delete(`/config/numbering-rules/${id}`);
|
||||
export async function deleteNumberingRule(id: string, version: number) {
|
||||
await client.delete(`/config/numbering-rules/${id}`, { data: { version } });
|
||||
}
|
||||
|
||||
@@ -6,6 +6,7 @@ export interface SettingInfo {
|
||||
scope_id?: string;
|
||||
setting_key: string;
|
||||
setting_value: unknown;
|
||||
version: number;
|
||||
}
|
||||
|
||||
export async function getSetting(key: string, scope?: string, scopeId?: string) {
|
||||
@@ -16,14 +17,14 @@ export async function getSetting(key: string, scope?: string, scopeId?: string)
|
||||
return data.data;
|
||||
}
|
||||
|
||||
export async function updateSetting(key: string, settingValue: unknown) {
|
||||
export async function updateSetting(key: string, settingValue: unknown, version?: number) {
|
||||
const { data } = await client.put<{ success: boolean; data: SettingInfo }>(
|
||||
`/config/settings/${key}`,
|
||||
{ setting_value: settingValue },
|
||||
{ setting_value: settingValue, version },
|
||||
);
|
||||
return data.data;
|
||||
}
|
||||
|
||||
export async function deleteSetting(key: string) {
|
||||
await client.delete(`/config/settings/${encodeURIComponent(key)}`);
|
||||
export async function deleteSetting(key: string, version: number) {
|
||||
await client.delete(`/config/settings/${encodeURIComponent(key)}`, { data: { version } });
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user