2015-08-15 06:40:11 +08:00
|
|
|
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'],
|
2015-11-07 03:47:06 +08:00
|
|
|
['application:star-item', 'Star Focused Item'],
|
2015-08-15 06:40:11 +08:00
|
|
|
]
|
|
|
|
|
|
|
|
class PreferencesKeymaps extends React.Component
|
|
|
|
@displayName: 'PreferencesKeymaps'
|
|
|
|
|
|
|
|
constructor: (@props) ->
|
|
|
|
@state =
|
|
|
|
templates: []
|
|
|
|
bindings: @_getStateFromKeymaps()
|
|
|
|
@_loadTemplates()
|
|
|
|
|
|
|
|
componentDidMount: =>
|
2015-11-12 02:25:11 +08:00
|
|
|
@_disposable = NylasEnv.keymaps.onDidReloadKeymap =>
|
2015-08-15 06:40:11 +08:00
|
|
|
@setState(bindings: @_getStateFromKeymaps())
|
|
|
|
|
|
|
|
componentWillUnmount: =>
|
2015-11-12 02:20:48 +08:00
|
|
|
@_disposable.dispose()
|
2015-08-15 06:40:11 +08:00
|
|
|
|
|
|
|
_loadTemplates: =>
|
2015-11-12 02:25:11 +08:00
|
|
|
templatesDir = path.join(NylasEnv.getLoadSettings().resourcePath, 'keymaps', 'templates')
|
2015-08-15 06:40:11 +08:00
|
|
|
fs.readdir templatesDir, (err, files) =>
|
|
|
|
return unless files and files instanceof Array
|
|
|
|
templates = files.filter (filename) =>
|
2015-08-19 05:50:53 +08:00
|
|
|
path.extname(filename) is '.cson' or path.extname(filename) is '.json'
|
|
|
|
templates = templates.map (filename) =>
|
|
|
|
path.parse(filename).name
|
2015-08-15 06:40:11 +08:00
|
|
|
@setState(templates: templates)
|
|
|
|
|
|
|
|
_getStateFromKeymaps: =>
|
|
|
|
bindings = {}
|
|
|
|
for [command, label] in DisplayedKeybindings
|
2015-11-12 02:25:11 +08:00
|
|
|
bindings[command] = NylasEnv.keymaps.findKeyBindings(command: command, target: document.body) || []
|
2015-08-15 06:40:11 +08:00
|
|
|
bindings
|
|
|
|
|
|
|
|
render: =>
|
|
|
|
<div className="container-keymaps">
|
2015-11-24 04:20:51 +08:00
|
|
|
<section>
|
|
|
|
<h2>Shortcuts</h2>
|
|
|
|
<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()}
|
|
|
|
</section>
|
|
|
|
<section>
|
|
|
|
<h2>Customization</h2>
|
|
|
|
<p>Define additional shortcuts by adding them to your shortcuts file.</p>
|
2015-08-15 06:40:11 +08:00
|
|
|
<button className="btn" onClick={@_onShowUserKeymaps}>Edit custom shortcuts</button>
|
2015-11-24 04:20:51 +08:00
|
|
|
</section>
|
2015-08-15 06:40:11 +08:00
|
|
|
</div>
|
|
|
|
|
|
|
|
_renderBindingFor: ([command, label]) =>
|
2015-08-15 07:41:52 +08:00
|
|
|
descriptions = []
|
2015-08-15 06:40:11 +08:00
|
|
|
if @state.bindings[command]
|
2015-08-15 07:41:52 +08:00
|
|
|
for binding in @state.bindings[command]
|
|
|
|
descriptions.push(@_formatKeystrokes(binding.keystrokes))
|
|
|
|
|
|
|
|
if descriptions.length is 0
|
|
|
|
value = 'None'
|
|
|
|
else
|
|
|
|
value = _.uniq(descriptions).join(', ')
|
2015-08-15 06:40:11 +08:00
|
|
|
|
|
|
|
<Flexbox className="shortcut" key={command}>
|
|
|
|
<div className="shortcut-name">{label}</div>
|
2015-08-15 07:41:52 +08:00
|
|
|
<div className="shortcut-value">{value}</div>
|
2015-08-15 06:40:11 +08:00
|
|
|
</Flexbox>
|
|
|
|
|
|
|
|
_renderBindings: =>
|
|
|
|
DisplayedKeybindings.map(@_renderBindingFor)
|
|
|
|
|
2015-08-15 07:41:52 +08:00
|
|
|
_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()
|
|
|
|
|
2015-08-15 06:40:11 +08:00
|
|
|
_onShowUserKeymaps: =>
|
2015-11-12 02:25:11 +08:00
|
|
|
keymapsFile = NylasEnv.keymaps.getUserKeymapPath()
|
2015-11-07 10:55:33 +08:00
|
|
|
if !fs.existsSync(keymapsFile)
|
|
|
|
fs.writeSync(fs.openSync(keymapsFile, 'w'), '')
|
|
|
|
require('shell').showItemInFolder(keymapsFile)
|
2015-08-15 06:40:11 +08:00
|
|
|
|
|
|
|
module.exports = PreferencesKeymaps
|