| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137 | 
							- 'use client'
 
- import { createRef, useCallback, useEffect, useMemo, useRef, useState } from 'react'
 
- import useSWR from 'swr'
 
- import { createContext, useContext, useContextSelector } from 'use-context-selector'
 
- import type { FC, ReactNode } from 'react'
 
- import { fetchAppList } from '@/service/apps'
 
- import Loading from '@/app/components/base/loading'
 
- import { fetchCurrentWorkspace, fetchLanggeniusVersion, fetchUserProfile } from '@/service/common'
 
- import type { App } from '@/types/app'
 
- import type { ICurrentWorkspace, LangGeniusVersionResponse, UserProfileResponse } from '@/models/common'
 
- import MaintenanceNotice from '@/app/components/header/maintenance-notice'
 
- export type AppContextValue = {
 
-   apps: App[]
 
-   mutateApps: VoidFunction
 
-   userProfile: UserProfileResponse
 
-   mutateUserProfile: VoidFunction
 
-   currentWorkspace: ICurrentWorkspace
 
-   isCurrentWorkspaceManager: boolean
 
-   isCurrentWorkspaceOwner: boolean
 
-   mutateCurrentWorkspace: VoidFunction
 
-   pageContainerRef: React.RefObject<HTMLDivElement>
 
-   langeniusVersionInfo: LangGeniusVersionResponse
 
-   useSelector: typeof useSelector
 
- }
 
- const initialLangeniusVersionInfo = {
 
-   current_env: '',
 
-   current_version: '',
 
-   latest_version: '',
 
-   release_date: '',
 
-   release_notes: '',
 
-   version: '',
 
-   can_auto_update: false,
 
- }
 
- const initialWorkspaceInfo: ICurrentWorkspace = {
 
-   id: '',
 
-   name: '',
 
-   plan: '',
 
-   status: '',
 
-   created_at: 0,
 
-   role: 'normal',
 
-   providers: [],
 
-   in_trail: true,
 
- }
 
- const AppContext = createContext<AppContextValue>({
 
-   apps: [],
 
-   mutateApps: () => { },
 
-   userProfile: {
 
-     id: '',
 
-     name: '',
 
-     email: '',
 
-     avatar: '',
 
-     is_password_set: false,
 
-   },
 
-   currentWorkspace: initialWorkspaceInfo,
 
-   isCurrentWorkspaceManager: false,
 
-   mutateUserProfile: () => { },
 
-   mutateCurrentWorkspace: () => { },
 
-   pageContainerRef: createRef(),
 
-   langeniusVersionInfo: initialLangeniusVersionInfo,
 
-   useSelector,
 
- })
 
- export function useSelector<T>(selector: (value: AppContextValue) => T): T {
 
-   return useContextSelector(AppContext, selector)
 
- }
 
- export type AppContextProviderProps = {
 
-   children: ReactNode
 
- }
 
- export const AppContextProvider: FC<AppContextProviderProps> = ({ children }) => {
 
-   const pageContainerRef = useRef<HTMLDivElement>(null)
 
-   const { data: appList, mutate: mutateApps } = useSWR({ url: '/apps', params: { page: 1 } }, fetchAppList)
 
-   const { data: userProfileResponse, mutate: mutateUserProfile } = useSWR({ url: '/account/profile', params: {} }, fetchUserProfile)
 
-   const { data: currentWorkspaceResponse, mutate: mutateCurrentWorkspace } = useSWR({ url: '/workspaces/current', params: {} }, fetchCurrentWorkspace)
 
-   const [userProfile, setUserProfile] = useState<UserProfileResponse>()
 
-   const [langeniusVersionInfo, setLangeniusVersionInfo] = useState<LangGeniusVersionResponse>(initialLangeniusVersionInfo)
 
-   const [currentWorkspace, setCurrentWorkspace] = useState<ICurrentWorkspace>(initialWorkspaceInfo)
 
-   const isCurrentWorkspaceManager = useMemo(() => ['owner', 'admin'].includes(currentWorkspace.role), [currentWorkspace.role])
 
-   const isCurrentWorkspaceOwner = useMemo(() => currentWorkspace.role === 'owner', [currentWorkspace.role])
 
-   const updateUserProfileAndVersion = useCallback(async () => {
 
-     if (userProfileResponse && !userProfileResponse.bodyUsed) {
 
-       const result = await userProfileResponse.json()
 
-       setUserProfile(result)
 
-       const current_version = userProfileResponse.headers.get('x-version')
 
-       const current_env = process.env.NODE_ENV === 'development' ? 'DEVELOPMENT' : userProfileResponse.headers.get('x-env')
 
-       const versionData = await fetchLanggeniusVersion({ url: '/version', params: { current_version } })
 
-       setLangeniusVersionInfo({ ...versionData, current_version, latest_version: versionData.version, current_env })
 
-     }
 
-   }, [userProfileResponse])
 
-   useEffect(() => {
 
-     updateUserProfileAndVersion()
 
-   }, [updateUserProfileAndVersion, userProfileResponse])
 
-   useEffect(() => {
 
-     if (currentWorkspaceResponse)
 
-       setCurrentWorkspace(currentWorkspaceResponse)
 
-   }, [currentWorkspaceResponse])
 
-   if (!appList || !userProfile)
 
-     return <Loading type='app' />
 
-   return (
 
-     <AppContext.Provider value={{
 
-       apps: appList.data,
 
-       mutateApps,
 
-       userProfile,
 
-       mutateUserProfile,
 
-       pageContainerRef,
 
-       langeniusVersionInfo,
 
-       useSelector,
 
-       currentWorkspace,
 
-       isCurrentWorkspaceManager,
 
-       isCurrentWorkspaceOwner,
 
-       mutateCurrentWorkspace,
 
-     }}>
 
-       <div className='flex flex-col h-full overflow-y-auto'>
 
-         {globalThis.document?.body?.getAttribute('data-public-maintenance-notice') && <MaintenanceNotice />}
 
-         <div ref={pageContainerRef} className='grow relative flex flex-col overflow-y-auto overflow-x-hidden bg-gray-100'>
 
-           {children}
 
-         </div>
 
-       </div>
 
-     </AppContext.Provider>
 
-   )
 
- }
 
- export const useAppContext = () => useContext(AppContext)
 
- export default AppContext
 
 
  |