import { ExternalLink, Eye, EyeOff, FlaskConical } from 'lucide-react' import Link from 'next/link' import { ReactNode } from 'react' import { LOCAL_STORAGE_KEYS, useParams } from 'common' import { useSendEventMutation } from 'data/telemetry/send-event-mutation' import { useSelectedOrganizationQuery } from 'hooks/misc/useSelectedOrganization' import { IS_PLATFORM } from 'lib/constants' import { Badge, Button, Modal, ScrollArea, cn } from 'ui' import { AdvisorRulesPreview } from './AdvisorRulesPreview' import { APISidePanelPreview } from './APISidePanelPreview' import { Branching2Preview } from './Branching2Preview' import { CLSPreview } from './CLSPreview' import { FEATURE_PREVIEWS } from './FeaturePreview.constants' import { useFeaturePreviewContext, useFeaturePreviewModal } from './FeaturePreviewContext' import { UnifiedLogsPreview } from './UnifiedLogsPreview' const FEATURE_PREVIEW_KEY_TO_CONTENT: { [key: string]: ReactNode } = { [LOCAL_STORAGE_KEYS.UI_PREVIEW_BRANCHING_2_0]: , [LOCAL_STORAGE_KEYS.UI_PREVIEW_ADVISOR_RULES]: , [LOCAL_STORAGE_KEYS.UI_PREVIEW_API_SIDE_PANEL]: , [LOCAL_STORAGE_KEYS.UI_PREVIEW_CLS]: , [LOCAL_STORAGE_KEYS.UI_PREVIEW_UNIFIED_LOGS]: , } const FeaturePreviewModal = () => { const { ref } = useParams() const { showFeaturePreviewModal, selectedFeatureKey, selectFeaturePreview, closeFeaturePreviewModal, isFeaturePreviewReleasedToPublic, } = useFeaturePreviewModal() const { data: org } = useSelectedOrganizationQuery() const featurePreviewContext = useFeaturePreviewContext() const { mutate: sendEvent } = useSendEventMutation() const { flags, onUpdateFlag } = featurePreviewContext const selectedFeature = FEATURE_PREVIEWS.find((preview) => preview.key === selectedFeatureKey) ?? FEATURE_PREVIEWS[0] const isSelectedFeatureEnabled = flags[selectedFeatureKey] const allFeaturePreviews = IS_PLATFORM ? FEATURE_PREVIEWS : FEATURE_PREVIEWS.filter((x) => !x.isPlatformOnly) const toggleFeature = () => { onUpdateFlag(selectedFeature.key, !isSelectedFeatureEnabled) sendEvent({ action: isSelectedFeatureEnabled ? 'feature_preview_disabled' : 'feature_preview_enabled', properties: { feature: selectedFeature.key }, groups: { project: ref ?? 'Unknown', organization: org?.slug ?? 'Unknown' }, }) } return ( {FEATURE_PREVIEWS.length > 0 ? (
{allFeaturePreviews .filter((feature) => isFeaturePreviewReleasedToPublic(feature)) .map((feature) => { const isEnabled = flags[feature.key] ?? false return (
selectFeaturePreview(feature.key)} className={cn( 'flex items-center space-x-3 p-4 border-b cursor-pointer bg transition', selectedFeature.key === feature.key ? 'bg-surface-300' : 'bg-surface-100' )} > {isEnabled ? ( ) : ( )}

{feature.name}

) })}

{selectedFeature?.name}

{selectedFeature?.isNew && New}
{selectedFeature?.discussionsUrl !== undefined && ( )}
{FEATURE_PREVIEW_KEY_TO_CONTENT[selectedFeature.key]}
) : (

No feature previews available

Have an idea for the dashboard? Let us know via GitHub Discussions!

)}
) } export default FeaturePreviewModal