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 && ( }> Give feedback )} toggleFeature()}> {isSelectedFeatureEnabled ? 'Disable' : 'Enable'} feature {FEATURE_PREVIEW_KEY_TO_CONTENT[selectedFeature.key]} ) : ( No feature previews available Have an idea for the dashboard? Let us know via GitHub Discussions! }> GitHub Discussions )} ) } export default FeaturePreviewModal
{feature.name}
{selectedFeature?.name}
No feature previews available
Have an idea for the dashboard? Let us know via GitHub Discussions!