balibabu
feat: generate select options for SystemModelSettingModal grouped by type and add llm icon and add upgrade button to UserSettingTeam and replace the icon in the sidebar of the user settings page (#128)
d80b399
import { ITenantInfo } from '@/interfaces/database/knowledge'; | |
import { IUserInfo } from '@/interfaces/database/userSetting'; | |
import authorizationUtil from '@/utils/authorizationUtil'; | |
import { useCallback, useEffect, useMemo } from 'react'; | |
import { history, useDispatch, useSelector } from 'umi'; | |
export const useFetchUserInfo = () => { | |
const dispatch = useDispatch(); | |
const fetchUserInfo = useCallback(() => { | |
dispatch({ type: 'settingModel/getUserInfo' }); | |
}, [dispatch]); | |
useEffect(() => { | |
fetchUserInfo(); | |
}, [fetchUserInfo]); | |
}; | |
export const useSelectUserInfo = () => { | |
const userInfo: IUserInfo = useSelector( | |
(state: any) => state.settingModel.userInfo, | |
); | |
return userInfo; | |
}; | |
export const useSelectTenantInfo = () => { | |
const tenantInfo: ITenantInfo = useSelector( | |
(state: any) => state.settingModel.tenantIfo, | |
); | |
return tenantInfo; | |
}; | |
export const useFetchTenantInfo = (isOnMountFetching: boolean = true) => { | |
const dispatch = useDispatch(); | |
const fetchTenantInfo = useCallback(() => { | |
dispatch({ | |
type: 'settingModel/getTenantInfo', | |
}); | |
}, [dispatch]); | |
useEffect(() => { | |
if (isOnMountFetching) { | |
fetchTenantInfo(); | |
} | |
}, [fetchTenantInfo, isOnMountFetching]); | |
return fetchTenantInfo; | |
}; | |
export const useSelectParserList = (): Array<{ | |
value: string; | |
label: string; | |
}> => { | |
const tenantInfo: ITenantInfo = useSelectTenantInfo(); | |
const parserList = useMemo(() => { | |
const parserArray: Array<string> = tenantInfo?.parser_ids.split(',') ?? []; | |
return parserArray.map((x) => { | |
const arr = x.split(':'); | |
return { value: arr[0], label: arr[1] }; | |
}); | |
}, [tenantInfo]); | |
return parserList; | |
}; | |
export const useLogout = () => { | |
const dispatch = useDispatch(); // TODO: clear redux state | |
const logout = useCallback(async () => { | |
const retcode = await dispatch<any>({ type: 'loginModel/logout' }); | |
if (retcode === 0) { | |
authorizationUtil.removeAll(); | |
history.push('/login'); | |
} | |
}, [dispatch]); | |
return logout; | |
}; | |
export const useSaveSetting = () => { | |
const dispatch = useDispatch(); | |
const saveSetting = useCallback( | |
(userInfo: { new_password: string } | IUserInfo): number => { | |
return dispatch<any>({ type: 'settingModel/setting', payload: userInfo }); | |
}, | |
[dispatch], | |
); | |
return saveSetting; | |
}; | |