Merge pull request #4174 from omnivore-app/fix/web-beta-features
Remove beta features page as all are enabled
This commit is contained in:
@ -19,34 +19,6 @@ const StyledLabel = styled('label', {
|
||||
})
|
||||
|
||||
export default function BetaFeatures(): JSX.Element {
|
||||
const { viewerData, isLoading, mutate } = useGetViewerQuery()
|
||||
const [pageLoading, setPageLoading] = useState(false)
|
||||
|
||||
const showSpinner = useMemo(() => {
|
||||
return isLoading || pageLoading
|
||||
}, [isLoading, pageLoading])
|
||||
|
||||
const requestFeatureAccess = useCallback(
|
||||
async (featureName: string) => {
|
||||
setPageLoading(true)
|
||||
const result = await optInFeature({ name: featureName })
|
||||
if (!result) {
|
||||
showErrorToast('Error opting into feature.')
|
||||
} else {
|
||||
showSuccessToast('Feature added')
|
||||
}
|
||||
mutate()
|
||||
setPageLoading(false)
|
||||
},
|
||||
[setPageLoading, mutate]
|
||||
)
|
||||
|
||||
const hasYouTube = useMemo(() => {
|
||||
return viewerData?.me?.featureList?.some(
|
||||
(f) => f.name === 'youtube-transcripts'
|
||||
)
|
||||
}, [viewerData])
|
||||
|
||||
applyStoredTheme()
|
||||
|
||||
return (
|
||||
@ -58,162 +30,11 @@ export default function BetaFeatures(): JSX.Element {
|
||||
/>
|
||||
|
||||
<VStack
|
||||
css={{ width: '100%', height: '100%' }}
|
||||
css={{ width: '100%', height: '100%', mt: '80px' }}
|
||||
distribution="start"
|
||||
alignment="center"
|
||||
>
|
||||
<VStack
|
||||
css={{
|
||||
padding: '24px',
|
||||
width: '100%',
|
||||
height: '100%',
|
||||
minWidth: '300px',
|
||||
maxWidth: '865px',
|
||||
}}
|
||||
>
|
||||
<VStack
|
||||
css={{
|
||||
padding: '24px',
|
||||
width: '100%',
|
||||
height: '100%',
|
||||
bg: '$grayBg',
|
||||
gap: '10px',
|
||||
borderRadius: '5px',
|
||||
}}
|
||||
>
|
||||
<StyledLabel>Enabled beta features</StyledLabel>
|
||||
{!showSpinner ? (
|
||||
<>
|
||||
{viewerData?.me?.featureList.map((feature) => {
|
||||
return (
|
||||
<StyledText
|
||||
key={`feature-${feature}`}
|
||||
style="footnote"
|
||||
css={{
|
||||
display: 'flex',
|
||||
gap: '5px',
|
||||
marginBlockStart: '0px',
|
||||
marginBlockEnd: '0px',
|
||||
}}
|
||||
>
|
||||
<input
|
||||
type="checkbox"
|
||||
checked={userHasFeature(viewerData?.me, feature.name)}
|
||||
disabled={true}
|
||||
></input>
|
||||
{`${feature.name}${
|
||||
userHasFeature(viewerData?.me, feature.name)
|
||||
? ''
|
||||
: ' - Requested'
|
||||
}`}
|
||||
</StyledText>
|
||||
)
|
||||
})}
|
||||
|
||||
{!hasYouTube /* || !hasAISummaries || !hasDigest */ && (
|
||||
<StyledLabel css={{ mt: '25px' }}>
|
||||
Available beta features
|
||||
</StyledLabel>
|
||||
)}
|
||||
|
||||
<VStack css={{ gap: '15px' }}>
|
||||
{!hasYouTube && (
|
||||
<VStack
|
||||
alignment="start"
|
||||
distribution="start"
|
||||
css={{ width: '100%' }}
|
||||
>
|
||||
<StyledText
|
||||
style="footnote"
|
||||
css={{ display: 'flex', gap: '5px' }}
|
||||
>
|
||||
- YouTube transcripts: nicely formatted documents
|
||||
generated from YouTube transcript data. Currently
|
||||
limited to videos under 30 minutes.
|
||||
</StyledText>
|
||||
<Button
|
||||
style="ctaDarkYellow"
|
||||
onClick={(event) => {
|
||||
requestFeatureAccess('youtube-transcripts')
|
||||
event.preventDefault()
|
||||
}}
|
||||
>
|
||||
Request feature
|
||||
</Button>
|
||||
</VStack>
|
||||
)}
|
||||
|
||||
{/* <VStack
|
||||
alignment="start"
|
||||
distribution="start"
|
||||
css={{ width: '100%' }}
|
||||
>
|
||||
<StyledText
|
||||
style="footnote"
|
||||
css={{ display: 'flex', gap: '5px' }}
|
||||
>
|
||||
- AI Summaries: Short summaries of your newly saved
|
||||
articles
|
||||
</StyledText>
|
||||
<Button
|
||||
style="ctaDarkYellow"
|
||||
onClick={(event) => {
|
||||
requestFeatureAccess('ai-summaries')
|
||||
event.preventDefault()
|
||||
}}
|
||||
>
|
||||
Request feature
|
||||
</Button>
|
||||
</VStack>
|
||||
|
||||
<VStack
|
||||
alignment="start"
|
||||
distribution="start"
|
||||
css={{ width: '100%' }}
|
||||
>
|
||||
<StyledText
|
||||
style="footnote"
|
||||
css={{ display: 'flex', gap: '5px' }}
|
||||
>
|
||||
- Daily digest: Every day we pick some of the items we
|
||||
think You will enjoy reading the most and create a daily
|
||||
digest of them.
|
||||
</StyledText>
|
||||
<Button
|
||||
style="ctaDarkYellow"
|
||||
onClick={(event) => {
|
||||
requestFeatureAccess('daily-digest')
|
||||
event.preventDefault()
|
||||
}}
|
||||
>
|
||||
Request feature
|
||||
</Button>
|
||||
</VStack> */}
|
||||
</VStack>
|
||||
</>
|
||||
) : (
|
||||
<HStack
|
||||
distribution="center"
|
||||
css={{
|
||||
width: '100%',
|
||||
svg: {
|
||||
animation: 'spin 1s infinite linear',
|
||||
'@keyframes spin': {
|
||||
from: {
|
||||
transform: 'scale(1) rotate(0deg)',
|
||||
},
|
||||
to: {
|
||||
transform: 'scale(1) rotate(360deg)',
|
||||
},
|
||||
},
|
||||
},
|
||||
}}
|
||||
>
|
||||
<Spinner size={16} />
|
||||
</HStack>
|
||||
)}
|
||||
</VStack>
|
||||
</VStack>
|
||||
All beta features are enabled.
|
||||
</VStack>
|
||||
</SettingsLayout>
|
||||
)
|
||||
|
||||
Reference in New Issue
Block a user