Caret/js/editor.js

109 lines
3.4 KiB
JavaScript
Raw Normal View History

define([
"storage/file",
"command",
"settings!ace,user",
"util/dom2"
], function(File, command, Settings) {
2013-08-20 00:53:03 +00:00
/*
Module for loading the editor, adding window resizing and other events. Returns the editor straight from Ace.
*/
var userConfig = Settings.get("user");
var aceConfig = Settings.get("ace");
2013-08-20 00:53:03 +00:00
var editor = window.editor = ace.edit("editor");
2013-08-23 23:03:46 +00:00
var themes = document.querySelector(".theme");
//one-time startup
var init = function() {
aceConfig.themes.forEach(function(theme) {
var option = document.createElement("option");
option.innerHTML = theme.label;
option.setAttribute("value", theme.name);
themes.append(option);
});
2013-09-14 21:08:25 +00:00
if (userConfig.emulateVim) {
ace.require("ace/lib/net").loadScript("js/ace/keybinding-vim.js", function() {
editor.setKeyboardHandler(ace.require("ace/keyboard/vim").handler);
});
}
reset();
//let main.js know this module is ready
return "editor";
};
//reloaded when settings change
var reset = function() {
2013-09-04 19:26:09 +00:00
userConfig = Settings.get("user");
themes.value = userConfig.defaultTheme;
editor.setTheme("ace/theme/" + themes.value);
editor.setShowPrintMargin(userConfig.showMargin || false);
editor.setPrintMarginColumn(userConfig.wrapLimit || 80);
editor.setShowInvisibles(userConfig.showWhitespace || false);
editor.setHighlightActiveLine(userConfig.highlightLine || true);
editor.container.style.fontFamily = userConfig.fontFamily || null;
defaultFontSize();
2013-10-28 16:18:43 +00:00
ace.config.loadModule("ace/ext/language_tools", function() {
editor.setOptions({
enableBasicAutocompletion: userConfig.autocomplete
});
});
};
var defaultFontSize = function(c) {
var size = Settings.get("user").fontSize;
editor.container.style.fontSize = size ? size + "px" : null;
if (c) c();
};
var adjustFontSize = function(delta, c) {
var current = editor.container.style.fontSize;
if (current) {
current = current.replace("px", "") * 1;
} else {
current = Settings.get("user").fontSize;
}
var adjusted = current + delta;
editor.container.style.fontSize = adjusted + "px";
if (c) c();
}
command.on("editor:default-zoom", defaultFontSize);
command.on("editor:adjust-zoom", adjustFontSize);
command.on("init:startup", init);
command.on("init:restart", reset);
2013-08-23 23:03:46 +00:00
command.on("editor:theme", function(theme, c) {
2013-08-23 23:03:46 +00:00
editor.setTheme("ace/theme/" + theme);
themes.value = theme;
editor.focus();
if (c) c();
2013-08-23 23:03:46 +00:00
});
2013-09-04 23:36:33 +00:00
//disable focusing on the editor except by program
document.find("textarea").setAttribute("tabindex", -1);
2013-08-23 23:03:46 +00:00
2014-01-20 17:10:24 +00:00
command.on("editor:print", function(c) {
ace.require("ace/config").loadModule("ace/ext/static_highlight", function(static) {
var session = editor.getSession();
var printable = static.renderSync(session.getValue(), session.getMode(), editor.renderer.theme);
var iframe = document.createElement("iframe");
var css = "<style>" + printable.css + "</style>";
var doc = css + printable.html;
iframe.srcdoc = doc;
iframe.width = iframe.height = 1;
iframe.style.display = "none";
document.body.append(iframe);
setTimeout(function() {
iframe.contentWindow.print();
setTimeout(function() {
iframe.remove();
})
});
});
});
2013-08-20 00:53:03 +00:00
return editor;
});