mirror of
https://github.com/linsa-io/linsa.git
synced 2026-01-12 12:20:23 +01:00
* wip * wip page * chore: style * wip pages * wip pages * chore: toggle * chore: link * feat: topic search * chore: page section * refactor: apply tailwind class ordering * fix: handle loggedIn user for guest route * feat: folder & image schema * chore: move utils to shared * refactor: tailwind class ordering * feat: img ext for editor * refactor: remove qa * fix: tanstack start * fix: wrong import * chore: use toast * chore: schema
68 lines
1.7 KiB
TypeScript
68 lines
1.7 KiB
TypeScript
import { isServer } from "@shared/utils"
|
|
|
|
interface ShortcutKeyResult {
|
|
symbol: string
|
|
readable: string
|
|
}
|
|
|
|
export function getShortcutKey(key: string): ShortcutKeyResult {
|
|
const lowercaseKey = key.toLowerCase()
|
|
if (lowercaseKey === "mod") {
|
|
return isMac()
|
|
? { symbol: "⌘", readable: "Command" }
|
|
: { symbol: "Ctrl", readable: "Control" }
|
|
} else if (lowercaseKey === "alt") {
|
|
return isMac()
|
|
? { symbol: "⌥", readable: "Option" }
|
|
: { symbol: "Alt", readable: "Alt" }
|
|
} else if (lowercaseKey === "shift") {
|
|
return isMac()
|
|
? { symbol: "⇧", readable: "Shift" }
|
|
: { symbol: "Shift", readable: "Shift" }
|
|
} else {
|
|
return { symbol: key.toUpperCase(), readable: key }
|
|
}
|
|
}
|
|
|
|
export function getShortcutKeys(keys: string[]): ShortcutKeyResult[] {
|
|
return keys.map((key) => getShortcutKey(key))
|
|
}
|
|
|
|
export function isModKey(
|
|
event: KeyboardEvent | MouseEvent | React.KeyboardEvent,
|
|
) {
|
|
return isMac() ? event.metaKey : event.ctrlKey
|
|
}
|
|
|
|
export function isMac(): boolean {
|
|
if (isServer()) {
|
|
return false
|
|
}
|
|
return window.navigator.platform === "MacIntel"
|
|
}
|
|
|
|
export function isWindows(): boolean {
|
|
if (isServer()) {
|
|
return false
|
|
}
|
|
return window.navigator.platform === "Win32"
|
|
}
|
|
|
|
let supportsPassive = false
|
|
|
|
try {
|
|
const opts = Object.defineProperty({}, "passive", {
|
|
get() {
|
|
supportsPassive = true
|
|
},
|
|
})
|
|
// @ts-expect-error ts-migrate(2769) testPassive is not a real event
|
|
window.addEventListener("testPassive", null, opts)
|
|
// @ts-expect-error ts-migrate(2769) testPassive is not a real event
|
|
window.removeEventListener("testPassive", null, opts)
|
|
} catch (e) {
|
|
// No-op
|
|
}
|
|
|
|
export const supportsPassiveListener = supportsPassive
|