123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 |
- 'use client'
- import React, { FC, useEffect, useState } from 'react'
- import ExploreContext from '@/context/explore-context'
- import Sidebar from '@/app/components/explore/sidebar'
- import { useAppContext } from '@/context/app-context'
- import { fetchMembers } from '@/service/common'
- import { InstalledApp } from '@/models/explore'
- import { useTranslation } from 'react-i18next'
- export interface IExploreProps {
- children: React.ReactNode
- }
- const Explore: FC<IExploreProps> = ({
- children
- }) => {
- const { t } = useTranslation()
- const [controlUpdateInstalledApps, setControlUpdateInstalledApps] = useState(0)
- const { userProfile } = useAppContext()
- const [hasEditPermission, setHasEditPermission] = useState(false)
- const [installedApps, setInstalledApps] = useState<InstalledApp[]>([])
- useEffect(() => {
- document.title = `${t('explore.title')} - Dify`;
- (async () => {
- const { accounts } = await fetchMembers({ url: '/workspaces/current/members', params: {}})
- if(!accounts) return
- const currUser = accounts.find(account => account.id === userProfile.id)
- setHasEditPermission(currUser?.role !== 'normal')
- })()
- }, [])
- return (
- <div className='flex h-full bg-gray-100 border-t border-gray-200'>
- <ExploreContext.Provider
- value={
- {
- controlUpdateInstalledApps,
- setControlUpdateInstalledApps,
- hasEditPermission,
- installedApps,
- setInstalledApps
- }
- }
- >
- <Sidebar controlUpdateInstalledApps={controlUpdateInstalledApps} />
- <div className='grow'>
- {children}
- </div>
- </ExploreContext.Provider>
- </div>
- )
- }
- export default React.memo(Explore)
|