Skip to content

Commit

Permalink
chore: persist player preferences (#23113)
Browse files Browse the repository at this point in the history
  • Loading branch information
daibhin authored Jun 20, 2024
1 parent 7f94854 commit 0dbd9f1
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 17 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import { FloatingContainerContext } from 'lib/hooks/useFloatingContainerContext'
import { HotkeysInterface, useKeyboardHotkeys } from 'lib/hooks/useKeyboardHotkeys'
import { usePageVisibility } from 'lib/hooks/usePageVisibility'
import { useResizeBreakpoints } from 'lib/hooks/useResizeObserver'
import { useMemo, useRef, useState } from 'react'
import { useMemo, useRef } from 'react'
import { useNotebookDrag } from 'scenes/notebooks/AddToNotebook/DraggableToNotebook'
import { PlayerController } from 'scenes/session-recordings/player/controller/PlayerController'
import { PlayerInspector } from 'scenes/session-recordings/player/inspector/PlayerInspector'
Expand All @@ -21,6 +21,7 @@ import { NetworkView } from '../apm/NetworkView'
import { PlayerFrameOverlay } from './PlayerFrameOverlay'
import { PlayerMeta } from './PlayerMeta'
import { PlayerPersonMeta } from './PlayerPersonMeta'
import { PlaybackViewMode, playerSettingsLogic } from './playerSettingsLogic'
import { sessionRecordingDataLogic } from './sessionRecordingDataLogic'
import {
ONE_FRAME_MS,
Expand All @@ -43,8 +44,6 @@ enum InspectorStacking {
Horizontal = 'horizontal',
}

type PlaybackViewType = 'waterfall' | 'playback' | 'inspector'

export const createPlaybackSpeedKey = (action: (val: number) => void): HotkeysInterface => {
return PLAYBACK_SPEEDS.map((x, i) => ({ key: `${i}`, value: x })).reduce(
(acc, x) => ({ ...acc, [x.key]: { action: () => action(x.value) } }),
Expand Down Expand Up @@ -96,6 +95,8 @@ export function SessionRecordingPlayer(props: SessionRecordingPlayerProps): JSX.
const { isNotFound } = useValues(sessionRecordingDataLogic(logicProps))
const { isFullScreen, explorerMode, isBuffering } = useValues(sessionRecordingPlayerLogic(logicProps))
const speedHotkeys = useMemo(() => createPlaybackSpeedKey(setSpeed), [setSpeed])
const { preferredInspectorStacking, playbackViewMode } = useValues(playerSettingsLogic)
const { setPreferredInspectorStacking, setPlaybackViewMode } = useActions(playerSettingsLogic)

const allowWaterfallView = useFeatureFlag('SESSION_REPLAY_NETWORK_VIEW')

Expand Down Expand Up @@ -161,11 +162,6 @@ export function SessionRecordingPlayer(props: SessionRecordingPlayerProps): JSX.
}
)

const isWidescreen = !isFullScreen && size === 'wide'

const [preferredInspectorStacking, setPreferredInspectorStacking] = useState(InspectorStacking.Horizontal)
const [playerView, setPlayerView] = useState<PlaybackViewType>(isWidescreen ? 'inspector' : 'playback')

const compactLayout = size === 'small'
const layoutStacking = compactLayout ? InspectorStacking.Vertical : preferredInspectorStacking
const isVerticallyStacked = layoutStacking === InspectorStacking.Vertical
Expand All @@ -180,19 +176,23 @@ export function SessionRecordingPlayer(props: SessionRecordingPlayerProps): JSX.
)
}

const viewOptions: LemonSegmentedButtonOption<PlaybackViewType>[] = [
{ value: 'playback', label: 'Playback', 'data-attr': 'session-recording-player-view-choice-playback' },
const viewOptions: LemonSegmentedButtonOption<PlaybackViewMode>[] = [
{
value: PlaybackViewMode.Playback,
label: 'Playback',
'data-attr': 'session-recording-player-view-choice-playback',
},
]
if (!noInspector) {
viewOptions.push({
value: 'inspector',
value: PlaybackViewMode.Inspector,
label: 'Inspector',
'data-attr': 'session-recording-player-view-choice-inspector',
})
}
if (allowWaterfallView) {
viewOptions.push({
value: 'waterfall',
value: PlaybackViewMode.Waterfall,
label: (
<div className="space-x-1">
<span>Waterfall</span>
Expand Down Expand Up @@ -228,12 +228,12 @@ export function SessionRecordingPlayer(props: SessionRecordingPlayerProps): JSX.

<LemonSegmentedButton
size="xsmall"
value={playerView}
onChange={setPlayerView}
value={playbackViewMode}
onChange={setPlaybackViewMode}
options={viewOptions}
/>
</div>
{playerView === 'waterfall' ? (
{playbackViewMode === PlaybackViewMode.Waterfall ? (
<NetworkView sessionRecordingId={sessionRecordingId} />
) : (
<div
Expand All @@ -256,9 +256,9 @@ export function SessionRecordingPlayer(props: SessionRecordingPlayerProps): JSX.
<PlayerController linkIconsOnly={playerMainSize === 'small'} />
</div>

{playerView === 'inspector' && (
{playbackViewMode === PlaybackViewMode.Inspector && (
<PlayerInspector
onClose={() => setPlayerView('playback')}
onClose={() => setPlaybackViewMode(PlaybackViewMode.Playback)}
isVerticallyStacked={isVerticallyStacked}
toggleLayoutStacking={
compactLayout
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,17 @@ export enum TimestampFormat {
Device = 'device',
}

export enum InspectorStacking {
Vertical = 'vertical',
Horizontal = 'horizontal',
}

export enum PlaybackViewMode {
Playback = 'playback',
Inspector = 'inspector',
Waterfall = 'waterfall',
}

const MiniFilters: SharedListMiniFilter[] = [
{
tab: SessionRecordingPlayerTab.ALL,
Expand Down Expand Up @@ -191,6 +202,8 @@ export const playerSettingsLogic = kea<playerSettingsLogicType>([
setPrefersAdvancedFilters: (prefersAdvancedFilters: boolean) => ({ prefersAdvancedFilters }),
setQuickFilterProperties: (properties: string[]) => ({ properties }),
setTimestampFormat: (format: TimestampFormat) => ({ format }),
setPreferredInspectorStacking: (stacking: InspectorStacking) => ({ stacking }),
setPlaybackViewMode: (mode: PlaybackViewMode) => ({ mode }),
}),
connect({
values: [teamLogic, ['currentTeam']],
Expand All @@ -205,6 +218,20 @@ export const playerSettingsLogic = kea<playerSettingsLogicType>([
setShowFilters: (_, { showFilters }) => showFilters,
},
],
preferredInspectorStacking: [
InspectorStacking.Horizontal as InspectorStacking,
{ persist: true },
{
setPreferredInspectorStacking: (_, { stacking }) => stacking,
},
],
playbackViewMode: [
PlaybackViewMode.Playback as PlaybackViewMode,
{ persist: true },
{
setPlaybackViewMode: (_, { mode }) => mode,
},
],
prefersAdvancedFilters: [
true,
{
Expand Down

0 comments on commit 0dbd9f1

Please sign in to comment.