feat: keyboard shortcuts for primary actions (#2030)

This commit is contained in:
Mo
2022-11-18 09:01:48 -06:00
committed by GitHub
parent 0309912f98
commit f49ba6bd4d
67 changed files with 1296 additions and 555 deletions

View File

@@ -0,0 +1,38 @@
import { PlatformedKeyboardShortcut, keyboardCharacterForModifier, isMacPlatform } from '@standardnotes/ui-services'
type Props = {
shortcut: PlatformedKeyboardShortcut
className?: string
}
export const KeyboardShortcutIndicator = ({ shortcut, className }: Props) => {
const modifiers = shortcut.modifiers || []
const primaryKey = (shortcut.key || '').toUpperCase()
const addPluses = !isMacPlatform(shortcut.platform)
const spacingClass = addPluses ? '' : 'ml-0.5'
const keys: string[] = []
modifiers.forEach((modifier, index) => {
keys.push(keyboardCharacterForModifier(modifier, shortcut.platform))
if (addPluses && (primaryKey || index !== modifiers.length - 1)) {
keys.push('+')
}
})
if (primaryKey) {
keys.push(primaryKey)
}
return (
<div className={`keyboard-shortcut-indicator flex opacity-[0.35] ${className}`}>
{keys.map((key, index) => {
return (
<div className={index !== 0 ? spacingClass : ''} key={index}>
{key}
</div>
)
})}
</div>
)
}