summaryrefslogtreecommitdiffstats
path: root/public/javascripts
diff options
context:
space:
mode:
authorGo MAEDA <maeda@farend.jp>2021-01-26 06:50:34 +0000
committerGo MAEDA <maeda@farend.jp>2021-01-26 06:50:34 +0000
commit082570094a512c06d86fabf9df7a602e42645be4 (patch)
tree054c9f916f1f8d944415ae0abe67023586d5d072 /public/javascripts
parent876d6fd628ca99c8fb668636e1762e59955abece (diff)
downloadredmine-082570094a512c06d86fabf9df7a602e42645be4.tar.gz
redmine-082570094a512c06d86fabf9df7a602e42645be4.zip
Add keyboard shortcuts for bold, italic and underline buttons (#34549).
Patch by Marius BALTEANU. git-svn-id: http://svn.redmine.org/redmine/trunk@20729 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'public/javascripts')
-rw-r--r--public/javascripts/jstoolbar/jstoolbar.js50
-rw-r--r--public/javascripts/jstoolbar/markdown.js3
-rw-r--r--public/javascripts/jstoolbar/textile.js3
3 files changed, 49 insertions, 7 deletions
diff --git a/public/javascripts/jstoolbar/jstoolbar.js b/public/javascripts/jstoolbar/jstoolbar.js
index de4eb997a..ed6605965 100644
--- a/public/javascripts/jstoolbar/jstoolbar.js
+++ b/public/javascripts/jstoolbar/jstoolbar.js
@@ -22,6 +22,7 @@
/* Modified by JP LANG for textile formatting */
let lastJstPreviewed = null;
+const isMac = Boolean(navigator.platform.toLowerCase().match(/mac/));
function jsToolBar(textarea) {
if (!document.createElement) { return; }
@@ -208,6 +209,7 @@ jsToolBar.prototype = {
mode: 'wiki',
elements: {},
help_link: '',
+ shortcuts: {},
getMode: function() {
return this.mode;
@@ -233,10 +235,27 @@ jsToolBar.prototype = {
button: function(toolName) {
var tool = this.elements[toolName];
if (typeof tool.fn[this.mode] != 'function') return null;
- var b = new jsButton(tool.title, tool.fn[this.mode], this, 'jstb_'+toolName);
+
+ const className = 'jstb_' + toolName;
+ let title = tool.title
+
+ if (tool.hasOwnProperty('shortcut')) {
+ this.shortcuts[tool.shortcut] = className;
+ title = this.buttonTitleWithShortcut(tool.title, tool.shortcut)
+ }
+
+ var b = new jsButton(title, tool.fn[this.mode], this, className);
if (tool.icon != undefined) b.icon = tool.icon;
+
return b;
},
+ buttonTitleWithShortcut: function(title, shortcutKey) {
+ if (isMac) {
+ return title + " (⌘" + shortcutKey.toUpperCase() + ")";
+ } else {
+ return title + " (Ctrl+" + shortcutKey.toUpperCase() + ")";
+ }
+ },
space: function(toolName) {
var tool = new jsSpace(toolName)
if (this.elements[toolName].width !== undefined)
@@ -409,7 +428,7 @@ jsToolBar.prototype = {
this.toolbar.classList.add('hidden');
this.textarea.classList.add('hidden');
this.preview.classList.remove('hidden');
- this.tabsBlock.getElementsByClassName('tab-edit')[0].classList.remove('selected');
+ this.tabsBlock.querySelector('.tab-edit').classList.remove('selected');
event.target.classList.add('selected');
},
hidePreview: function(event) {
@@ -418,18 +437,26 @@ jsToolBar.prototype = {
this.textarea.classList.remove('hidden');
this.textarea.focus();
this.preview.classList.add('hidden');
- this.tabsBlock.getElementsByClassName('tab-preview')[0].classList.remove('selected');
+ this.tabsBlock.querySelector('.tab-preview').classList.remove('selected');
event.target.classList.add('selected');
},
keyboardShortcuts: function(e) {
+ let stop = false;
if (isToogleEditPreviewShortcut(e)) {
- // Switch to preview only if tab edit is selected when the event triggered.
+ // Switch to preview only if Edit tab is selected when the event triggers.
if (this.tabsBlock.querySelector('.tab-edit.selected')) {
- e.stopPropagation();
- e.preventDefault();
- this.tabsBlock.getElementsByClassName('tab-preview')[0].click();
+ stop = true
+ this.tabsBlock.querySelector('.tab-preview').click();
}
}
+ if (isModifierKey(e) && this.shortcuts.hasOwnProperty(e.key.toLowerCase())) {
+ stop = true
+ this.toolbar.querySelector("." + this.shortcuts[e.key.toLowerCase()]).click();
+ }
+ if (stop) {
+ e.stopPropagation();
+ e.preventDefault();
+ }
},
stripBaseURL: function(url) {
if (this.base_url != '') {
@@ -539,4 +566,13 @@ function isToogleEditPreviewShortcut(e) {
} else {
return false;
}
+}
+function isModifierKey(e) {
+ if (isMac && e.metaKey) {
+ return true;
+ } else if (!isMac && e.ctrlKey) {
+ return true;
+ } else {
+ return false;
+ }
} \ No newline at end of file
diff --git a/public/javascripts/jstoolbar/markdown.js b/public/javascripts/jstoolbar/markdown.js
index c30de3096..ae2725269 100644
--- a/public/javascripts/jstoolbar/markdown.js
+++ b/public/javascripts/jstoolbar/markdown.js
@@ -26,6 +26,7 @@
jsToolBar.prototype.elements.strong = {
type: 'button',
title: 'Strong',
+ shortcut: 'b',
fn: {
wiki: function() { this.singleTag('**') }
}
@@ -35,6 +36,7 @@ jsToolBar.prototype.elements.strong = {
jsToolBar.prototype.elements.em = {
type: 'button',
title: 'Italic',
+ shortcut: 'i',
fn: {
wiki: function() { this.singleTag("*") }
}
@@ -44,6 +46,7 @@ jsToolBar.prototype.elements.em = {
jsToolBar.prototype.elements.ins = {
type: 'button',
title: 'Underline',
+ shortcut: 'u',
fn: {
wiki: function() { this.singleTag('_') }
}
diff --git a/public/javascripts/jstoolbar/textile.js b/public/javascripts/jstoolbar/textile.js
index 9adc77add..76d2170cc 100644
--- a/public/javascripts/jstoolbar/textile.js
+++ b/public/javascripts/jstoolbar/textile.js
@@ -26,6 +26,7 @@
jsToolBar.prototype.elements.strong = {
type: 'button',
title: 'Strong',
+ shortcut: 'b',
fn: {
wiki: function() { this.singleTag('*') }
}
@@ -35,6 +36,7 @@ jsToolBar.prototype.elements.strong = {
jsToolBar.prototype.elements.em = {
type: 'button',
title: 'Italic',
+ shortcut: 'i',
fn: {
wiki: function() { this.singleTag("_") }
}
@@ -44,6 +46,7 @@ jsToolBar.prototype.elements.em = {
jsToolBar.prototype.elements.ins = {
type: 'button',
title: 'Underline',
+ shortcut: 'u',
fn: {
wiki: function() { this.singleTag('+') }
}