Skip to content

Commit

Permalink
feat(command-bar): add shortcut help (#18810)
Browse files Browse the repository at this point in the history
  • Loading branch information
thmsobrmlr authored Nov 22, 2023
1 parent 1e67eb3 commit 573487e
Show file tree
Hide file tree
Showing 7 changed files with 75 additions and 3 deletions.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
10 changes: 10 additions & 0 deletions frontend/src/lib/components/CommandBar/CommandBar.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -277,3 +277,13 @@ export function Actions(): JSX.Element {

return <CommandBar />
}

export function Shortcuts(): JSX.Element {
const { setCommandBar } = useActions(commandBarLogic)

useEffect(() => {
setCommandBar(BarStatus.SHOW_SHORTCUTS)
}, [])

return <CommandBar />
}
5 changes: 4 additions & 1 deletion frontend/src/lib/components/CommandBar/CommandBar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import { BarStatus } from './types'
import './index.scss'
import { SearchBar } from './SearchBar'
import { ActionBar } from './ActionBar'
import { Shortcuts } from './Shortcuts'

interface CommandBarOverlayProps {
barStatus: BarStatus
Expand Down Expand Up @@ -56,7 +57,9 @@ export function CommandBar(): JSX.Element | null {

return (
<CommandBarOverlay barStatus={barStatus}>
{barStatus === BarStatus.SHOW_SEARCH ? <SearchBar /> : <ActionBar />}
{barStatus === BarStatus.SHOW_SEARCH && <SearchBar />}
{barStatus === BarStatus.SHOW_ACTIONS && <ActionBar />}
{barStatus === BarStatus.SHOW_SHORTCUTS && <Shortcuts />}
</CommandBarOverlay>
)
}
23 changes: 23 additions & 0 deletions frontend/src/lib/components/CommandBar/Shortcuts.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
import { useMountedLogic } from 'kea'

import { KeyboardShortcut } from '~/layout/navigation-3000/components/KeyboardShortcut'
import { shortcutsLogic } from './shortcutsLogic'

export const Shortcuts = (): JSX.Element => {
useMountedLogic(shortcutsLogic)

return (
<div className="flex flex-col h-full p-5">
<h3>Keyboard shortcuts</h3>
<h4>Site-wide shortcuts</h4>
<div className="space-y-1">
<div>
<KeyboardShortcut command k /> Open search
</div>
<div>
<KeyboardShortcut command shift k /> Open command palette
</div>
</div>
</div>
)
}
13 changes: 11 additions & 2 deletions frontend/src/lib/components/CommandBar/commandBarLogic.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ export const commandBarLogic = kea<commandBarLogicType>([
hideCommandBar: true,
toggleSearchBar: true,
toggleActionsBar: true,
toggleShortcutOverview: true,
}),
reducers({
barStatus: [
Expand All @@ -18,9 +19,15 @@ export const commandBarLogic = kea<commandBarLogicType>([
setCommandBar: (_, { status }) => status,
hideCommandBar: () => BarStatus.HIDDEN,
toggleSearchBar: (previousState) =>
previousState === BarStatus.HIDDEN ? BarStatus.SHOW_SEARCH : BarStatus.HIDDEN,
[BarStatus.HIDDEN, BarStatus.SHOW_SHORTCUTS].includes(previousState)
? BarStatus.SHOW_SEARCH
: BarStatus.HIDDEN,
toggleActionsBar: (previousState) =>
previousState === BarStatus.HIDDEN ? BarStatus.SHOW_ACTIONS : BarStatus.HIDDEN,
[BarStatus.HIDDEN, BarStatus.SHOW_SHORTCUTS].includes(previousState)
? BarStatus.SHOW_ACTIONS
: BarStatus.HIDDEN,
toggleShortcutOverview: (previousState) =>
previousState === BarStatus.HIDDEN ? BarStatus.SHOW_SHORTCUTS : previousState,
},
],
}),
Expand All @@ -36,6 +43,8 @@ export const commandBarLogic = kea<commandBarLogicType>([
// cmd+k opens search
actions.toggleSearchBar()
}
} else if (event.shiftKey && event.key === '?') {
actions.toggleShortcutOverview()
}
}
window.addEventListener('keydown', cache.onKeyDown)
Expand Down
26 changes: 26 additions & 0 deletions frontend/src/lib/components/CommandBar/shortcutsLogic.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
import { kea, path, connect, afterMount, beforeUnmount } from 'kea'

import { commandBarLogic } from './commandBarLogic'

import type { shortcutsLogicType } from './shortcutsLogicType'

export const shortcutsLogic = kea<shortcutsLogicType>([
path(['lib', 'components', 'CommandBar', 'shortcutsLogic']),
connect({
actions: [commandBarLogic, ['hideCommandBar']],
}),
afterMount(({ actions, cache }) => {
// register keyboard shortcuts
cache.onKeyDown = (event: KeyboardEvent) => {
if (event.key === 'Escape') {
// hide command bar
actions.hideCommandBar()
}
}
window.addEventListener('keydown', cache.onKeyDown)
}),
beforeUnmount(({ cache }) => {
// unregister keyboard shortcuts
window.removeEventListener('keydown', cache.onKeyDown)
}),
])
1 change: 1 addition & 0 deletions frontend/src/lib/components/CommandBar/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ export enum BarStatus {
HIDDEN = 'hidden',
SHOW_SEARCH = 'show_search',
SHOW_ACTIONS = 'show_actions',
SHOW_SHORTCUTS = 'show_shortcuts',
}

export type ResultType = 'action' | 'cohort' | 'insight' | 'dashboard' | 'experiment' | 'feature_flag' | 'notebook'
Expand Down

0 comments on commit 573487e

Please sign in to comment.