mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-10 10:11:25 +08:00
102 lines
3.3 KiB
CoffeeScript
102 lines
3.3 KiB
CoffeeScript
React = require 'react'
|
|
_ = require 'underscore'
|
|
path = require 'path'
|
|
fs = require 'fs'
|
|
{RetinaImg, Flexbox} = require 'nylas-component-kit'
|
|
|
|
DisplayedKeybindings = [
|
|
['application:new-message', 'New Message'],
|
|
['application:reply', 'Reply'],
|
|
['application:reply-all', 'Reply All'],
|
|
['application:forward', 'Forward'],
|
|
['application:focus-search', 'Search'],
|
|
['application:change-category', 'Change Folder / Labels'],
|
|
['core:select-item', 'Select Focused Item'],
|
|
['core:star-item', 'Star Focused Item'],
|
|
]
|
|
|
|
class PreferencesKeymaps extends React.Component
|
|
@displayName: 'PreferencesKeymaps'
|
|
|
|
constructor: (@props) ->
|
|
@state =
|
|
templates: []
|
|
bindings: @_getStateFromKeymaps()
|
|
@_loadTemplates()
|
|
|
|
componentDidMount: =>
|
|
@unsubscribe = atom.keymaps.onDidReloadKeymap =>
|
|
@setState(bindings: @_getStateFromKeymaps())
|
|
|
|
componentWillUnmount: =>
|
|
@unsubscribe?()
|
|
|
|
_loadTemplates: =>
|
|
templatesDir = path.join(atom.getLoadSettings().resourcePath, 'keymaps', 'templates')
|
|
fs.readdir templatesDir, (err, files) =>
|
|
return unless files and files instanceof Array
|
|
templates = files.filter (filename) =>
|
|
path.extname(filename) is '.cson' or path.extname(filename) is '.json'
|
|
templates = templates.map (filename) =>
|
|
path.parse(filename).name
|
|
@setState(templates: templates)
|
|
|
|
_getStateFromKeymaps: =>
|
|
bindings = {}
|
|
for [command, label] in DisplayedKeybindings
|
|
bindings[command] = atom.keymaps.findKeyBindings(command: command, target: document.body) || []
|
|
bindings
|
|
|
|
render: =>
|
|
<div className="container-keymaps">
|
|
<Flexbox className="shortcut shortcut-select">
|
|
<div className="shortcut-name">Keyboard shortcut set:</div>
|
|
<div className="shortcut-value">
|
|
<select
|
|
style={margin:0}
|
|
value={@props.config.get('core.keymapTemplate')}
|
|
onChange={ (event) => @props.config.set('core.keymapTemplate', event.target.value) }>
|
|
{ @state.templates.map (template) =>
|
|
<option key={template} value={template}>{template}</option>
|
|
}
|
|
</select>
|
|
</div>
|
|
</Flexbox>
|
|
{@_renderBindings()}
|
|
|
|
<div className="shortcuts-extras">
|
|
<button className="btn" onClick={@_onShowUserKeymaps}>Edit custom shortcuts</button>
|
|
</div>
|
|
</div>
|
|
|
|
_renderBindingFor: ([command, label]) =>
|
|
descriptions = []
|
|
if @state.bindings[command]
|
|
for binding in @state.bindings[command]
|
|
descriptions.push(@_formatKeystrokes(binding.keystrokes))
|
|
|
|
if descriptions.length is 0
|
|
value = 'None'
|
|
else
|
|
value = _.uniq(descriptions).join(', ')
|
|
|
|
<Flexbox className="shortcut" key={command}>
|
|
<div className="shortcut-name">{label}</div>
|
|
<div className="shortcut-value">{value}</div>
|
|
</Flexbox>
|
|
|
|
_renderBindings: =>
|
|
DisplayedKeybindings.map(@_renderBindingFor)
|
|
|
|
_formatKeystrokes: (keystrokes) ->
|
|
if process.platform is 'win32'
|
|
# On Windows, display cmd-shift-c
|
|
return keystrokes
|
|
else
|
|
# On Mac and Linux, display ⌘⇧C
|
|
return keystrokes.replace(/-/gi,'').replace(/cmd/gi, '⌘').replace(/alt/gi, '⌥').replace(/shift/gi, '⇧').replace(/ctrl/gi, '^').toUpperCase()
|
|
|
|
_onShowUserKeymaps: =>
|
|
require('shell').openItem(atom.keymaps.getUserKeymapPath())
|
|
|
|
module.exports = PreferencesKeymaps
|