π File detail
keybindings/template.ts
π§© .tsπ 53 linesπΎ 1,721 bytesπ text
β Back to All Filesπ― Use case
This file lives under βkeybindings/β, which covers keyboard shortcuts and binding tables. On the API surface it exposes generateKeybindingsTemplate β mainly functions, hooks, or classes. It composes internal code from utils, defaultBindings, reservedShortcuts, and types (relative imports). What the file header says: Keybindings template generator. Generates a well-documented template file for ~/.claude/keybindings.json.
Generated from folder role, exports, dependency roots, and inline comments β not hand-reviewed for every path.
π§ Inline summary
Keybindings template generator. Generates a well-documented template file for ~/.claude/keybindings.json
π€ Exports (heuristic)
generateKeybindingsTemplate
π₯οΈ Source preview
/**
* Keybindings template generator.
* Generates a well-documented template file for ~/.claude/keybindings.json
*/
import { jsonStringify } from '../utils/slowOperations.js'
import { DEFAULT_BINDINGS } from './defaultBindings.js'
import {
NON_REBINDABLE,
normalizeKeyForComparison,
} from './reservedShortcuts.js'
import type { KeybindingBlock } from './types.js'
/**
* Filter out reserved shortcuts that cannot be rebound.
* These would cause /doctor to warn, so we exclude them from the template.
*/
function filterReservedShortcuts(blocks: KeybindingBlock[]): KeybindingBlock[] {
const reservedKeys = new Set(
NON_REBINDABLE.map(r => normalizeKeyForComparison(r.key)),
)
return blocks
.map(block => {
const filteredBindings: Record<string, string | null> = {}
for (const [key, action] of Object.entries(block.bindings)) {
if (!reservedKeys.has(normalizeKeyForComparison(key))) {
filteredBindings[key] = action
}
}
return { context: block.context, bindings: filteredBindings }
})
.filter(block => Object.keys(block.bindings).length > 0)
}
/**
* Generate a template keybindings.json file content.
* Creates a fully valid JSON file with all default bindings that users can customize.
*/
export function generateKeybindingsTemplate(): string {
// Filter out reserved shortcuts that cannot be rebound
const bindings = filterReservedShortcuts(DEFAULT_BINDINGS)
// Format as object wrapper with bindings array
const config = {
$schema: 'https://www.schemastore.org/claude-code-keybindings.json',
$docs: 'https://code.claude.com/docs/en/keybindings',
bindings,
}
return jsonStringify(config, null, 2) + '\n'
}