summaryrefslogtreecommitdiff
path: root/public/js/index.js
diff options
context:
space:
mode:
Diffstat (limited to 'public/js/index.js')
-rw-r--r--public/js/index.js53
1 files changed, 53 insertions, 0 deletions
diff --git a/public/js/index.js b/public/js/index.js
index c70f013b..361772d3 100644
--- a/public/js/index.js
+++ b/public/js/index.js
@@ -472,6 +472,7 @@ var statusKeymap = null;
var statusIndent = null;
var statusTheme = null;
var statusSpellcheck = null;
+var statusPreferences = null;
function getStatusBarTemplate(callback) {
$.get(serverurl + '/views/statusbar.html', function (template) {
@@ -495,6 +496,7 @@ function addStatusBar() {
statusLength = statusBar.find('.status-length');
statusTheme = statusBar.find('.status-theme');
statusSpellcheck = statusBar.find('.status-spellcheck');
+ statusPreferences = statusBar.find('.status-preferences');
statusPanel = editor.addPanel(statusBar[0], {
position: "bottom"
});
@@ -503,6 +505,7 @@ function addStatusBar() {
setKeymap();
setTheme();
setSpellcheck();
+ setPreferences();
}
function setIndent() {
@@ -619,6 +622,8 @@ function setKeymap() {
expires: 365
});
label.text(keymap);
+ restoreOverrideEditorKeymap();
+ setOverrideBrowserKeymap();
}
setKeymapLabel();
@@ -719,6 +724,50 @@ function setSpellcheck() {
}
}
+var jumpToAddressBarKeymapName = mac ? "Cmd-L" : "Ctrl-L";
+var jumpToAddressBarKeymapValue = null;
+function resetEditorKeymapToBrowserKeymap() {
+ var keymap = editor.getOption('keyMap');
+ if (!jumpToAddressBarKeymapValue) {
+ jumpToAddressBarKeymapValue = CodeMirror.keyMap[keymap][jumpToAddressBarKeymapName];
+ delete CodeMirror.keyMap[keymap][jumpToAddressBarKeymapName];
+ }
+}
+function restoreOverrideEditorKeymap() {
+ var keymap = editor.getOption('keyMap');
+ if (jumpToAddressBarKeymapValue) {
+ CodeMirror.keyMap[keymap][jumpToAddressBarKeymapName] = jumpToAddressBarKeymapValue;
+ jumpToAddressBarKeymapValue = null;
+ }
+}
+function setOverrideBrowserKeymap() {
+ var overrideBrowserKeymap = $('.ui-preferences-override-browser-keymap label > input[type="checkbox"]');
+ if(overrideBrowserKeymap.is(":checked")) {
+ Cookies.set('preferences-override-browser-keymap', true, {
+ expires: 365
+ });
+ restoreOverrideEditorKeymap();
+ } else {
+ Cookies.remove('preferences-override-browser-keymap');
+ resetEditorKeymapToBrowserKeymap();
+ }
+}
+
+function setPreferences() {
+ var overrideBrowserKeymap = $('.ui-preferences-override-browser-keymap label > input[type="checkbox"]');
+ var cookieOverrideBrowserKeymap = Cookies.get('preferences-override-browser-keymap');
+ if (cookieOverrideBrowserKeymap && cookieOverrideBrowserKeymap === "true") {
+ overrideBrowserKeymap.prop('checked', true);
+ } else {
+ overrideBrowserKeymap.prop('checked', false);
+ }
+ setOverrideBrowserKeymap();
+
+ overrideBrowserKeymap.change(function() {
+ setOverrideBrowserKeymap();
+ });
+}
+
var selection = null;
function updateStatusBar() {
@@ -989,6 +1038,10 @@ $(document).ready(function () {
key('ctrl+alt+b', function (e) {
changeMode(modeType.both);
});
+ // toggle-dropdown
+ $(document).on('click', '.toggle-dropdown .dropdown-menu', function (e) {
+ e.stopPropagation();
+ });
});
//when page resize
$(window).resize(function () {