Files
overleaf-cep/services/web/frontend/js/shared/context/user-features-context.tsx
Jimmy Domagala-Tang 72b7524094 Revert "Revert "Adding More Ai Quota Tiers"" (#32433)
* Revert "Revert "Adding More Ai Quota Tiers (#32128)" (#32431)"

This reverts commit f0ea19b418da6096c84b42024aea643807347649.

* fix: dont block workbench from users who have access via WF

* fix: simplify workbench access rules and ensure wf premium users can use workbench

GitOrigin-RevId: 7927248eadd906d7f802d55fa5c6bc7df162b141
2026-03-27 09:05:21 +00:00

78 lines
2.1 KiB
TypeScript

import {
createContext,
FC,
useCallback,
useContext,
useEffect,
useState,
} from 'react'
import { User } from '../../../../types/user'
import { useUserContext } from './user-context'
import { useReceiveUser } from '../hooks/user-channel/use-receive-user'
import { getJSON } from '@/infrastructure/fetch-json'
import { useEditorContext } from './editor-context'
import getMeta from '@/utils/meta'
export const UserFeaturesContext = createContext<User['features']>(undefined)
const hasUnlimitedAi = getMeta('ol-hasUnlimitedAi')
export const UserFeaturesProvider: FC<React.PropsWithChildren> = ({
children,
}) => {
const user = useUserContext()
const { writefullInstance } = useEditorContext()
const [features, setFeatures] = useState(user.features || {})
useReceiveUser(
useCallback(data => {
if (data?.features) {
setFeatures(data.features)
}
}, [])
)
useEffect(() => {
const listener = async ({ isPremium }: { isPremium: boolean }) => {
// todo: quota clean-up: remove once we are transitioned off aiErrorAssistant naming
const hasPremiumQuota = hasUnlimitedAi
const alreadyPremium =
features?.aiErrorAssistant === isPremium ||
hasPremiumQuota === isPremium
if (alreadyPremium) {
// the user is premium on writefull and has the AI assist, no need to refresh the features
return
}
const newFeatures = await getJSON('/user/features')
setFeatures(newFeatures)
}
writefullInstance?.addEventListener('writefull-login-complete', listener)
return () => {
writefullInstance?.removeEventListener(
'writefull-login-complete',
listener
)
}
}, [features?.aiErrorAssistant, writefullInstance])
return (
<UserFeaturesContext.Provider value={features}>
{children}
</UserFeaturesContext.Provider>
)
}
export function useUserFeaturesContext() {
const context = useContext(UserFeaturesContext)
if (!context) {
throw new Error(
'useUserFeaturesContext is only available inside UserFeaturesContext'
)
}
return context
}