You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
632 lines
18 KiB
632 lines
18 KiB
ace.define("ace/theme/textmate",["require","exports","module","ace/lib/dom"], function(require, exports, module) { |
|
"use strict"; |
|
|
|
exports.isDark = false; |
|
exports.cssClass = "ace-tm"; |
|
exports.cssText = ".ace-tm .ace_gutter {\ |
|
background: #f0f0f0;\ |
|
color: #333;\ |
|
}\ |
|
.ace-tm .ace_print-margin {\ |
|
width: 1px;\ |
|
background: #e8e8e8;\ |
|
}\ |
|
.ace-tm .ace_fold {\ |
|
background-color: #6B72E6;\ |
|
}\ |
|
.ace-tm {\ |
|
background-color: #FFFFFF;\ |
|
color: black;\ |
|
}\ |
|
.ace-tm .ace_cursor {\ |
|
color: black;\ |
|
}\ |
|
.ace-tm .ace_invisible {\ |
|
color: rgb(191, 191, 191);\ |
|
}\ |
|
.ace-tm .ace_storage,\ |
|
.ace-tm .ace_keyword {\ |
|
color: blue;\ |
|
}\ |
|
.ace-tm .ace_constant {\ |
|
color: rgb(197, 6, 11);\ |
|
}\ |
|
.ace-tm .ace_constant.ace_buildin {\ |
|
color: rgb(88, 72, 246);\ |
|
}\ |
|
.ace-tm .ace_constant.ace_language {\ |
|
color: rgb(88, 92, 246);\ |
|
}\ |
|
.ace-tm .ace_constant.ace_library {\ |
|
color: rgb(6, 150, 14);\ |
|
}\ |
|
.ace-tm .ace_invalid {\ |
|
background-color: rgba(255, 0, 0, 0.1);\ |
|
color: red;\ |
|
}\ |
|
.ace-tm .ace_support.ace_function {\ |
|
color: rgb(60, 76, 114);\ |
|
}\ |
|
.ace-tm .ace_support.ace_constant {\ |
|
color: rgb(6, 150, 14);\ |
|
}\ |
|
.ace-tm .ace_support.ace_type,\ |
|
.ace-tm .ace_support.ace_class {\ |
|
color: rgb(109, 121, 222);\ |
|
}\ |
|
.ace-tm .ace_keyword.ace_operator {\ |
|
color: rgb(104, 118, 135);\ |
|
}\ |
|
.ace-tm .ace_string {\ |
|
color: rgb(3, 106, 7);\ |
|
}\ |
|
.ace-tm .ace_comment {\ |
|
color: rgb(76, 136, 107);\ |
|
}\ |
|
.ace-tm .ace_comment.ace_doc {\ |
|
color: rgb(0, 102, 255);\ |
|
}\ |
|
.ace-tm .ace_comment.ace_doc.ace_tag {\ |
|
color: rgb(128, 159, 191);\ |
|
}\ |
|
.ace-tm .ace_constant.ace_numeric {\ |
|
color: rgb(0, 0, 205);\ |
|
}\ |
|
.ace-tm .ace_variable {\ |
|
color: rgb(49, 132, 149);\ |
|
}\ |
|
.ace-tm .ace_xml-pe {\ |
|
color: rgb(104, 104, 91);\ |
|
}\ |
|
.ace-tm .ace_entity.ace_name.ace_function {\ |
|
color: #0000A2;\ |
|
}\ |
|
.ace-tm .ace_heading {\ |
|
color: rgb(12, 7, 255);\ |
|
}\ |
|
.ace-tm .ace_list {\ |
|
color:rgb(185, 6, 144);\ |
|
}\ |
|
.ace-tm .ace_meta.ace_tag {\ |
|
color:rgb(0, 22, 142);\ |
|
}\ |
|
.ace-tm .ace_string.ace_regex {\ |
|
color: rgb(255, 0, 0)\ |
|
}\ |
|
.ace-tm .ace_marker-layer .ace_selection {\ |
|
background: rgb(181, 213, 255);\ |
|
}\ |
|
.ace-tm.ace_multiselect .ace_selection.ace_start {\ |
|
box-shadow: 0 0 3px 0px white;\ |
|
border-radius: 2px;\ |
|
}\ |
|
.ace-tm .ace_marker-layer .ace_step {\ |
|
background: rgb(252, 255, 0);\ |
|
}\ |
|
.ace-tm .ace_marker-layer .ace_stack {\ |
|
background: rgb(164, 229, 101);\ |
|
}\ |
|
.ace-tm .ace_marker-layer .ace_bracket {\ |
|
margin: -1px 0 0 -1px;\ |
|
border: 1px solid rgb(192, 192, 192);\ |
|
}\ |
|
.ace-tm .ace_marker-layer .ace_active-line {\ |
|
background: rgba(0, 0, 0, 0.07);\ |
|
}\ |
|
.ace-tm .ace_gutter-active-line {\ |
|
background-color : #dcdcdc;\ |
|
}\ |
|
.ace-tm .ace_marker-layer .ace_selected-word {\ |
|
background: rgb(250, 250, 255);\ |
|
border: 1px solid rgb(200, 200, 250);\ |
|
}\ |
|
.ace-tm .ace_indent-guide {\ |
|
background: url(\"\") right repeat-y;\ |
|
}\ |
|
"; |
|
|
|
var dom = require("../lib/dom"); |
|
dom.importCssString(exports.cssText, exports.cssClass); |
|
}); |
|
|
|
ace.define("ace/ace",["require","exports","module","ace/lib/fixoldbrowsers","ace/lib/dom","ace/lib/event","ace/editor","ace/edit_session","ace/undomanager","ace/virtual_renderer","ace/worker/worker_client","ace/keyboard/hash_handler","ace/placeholder","ace/multi_select","ace/mode/folding/fold_mode","ace/theme/textmate","ace/ext/error_marker","ace/config"], function(require, exports, module) { |
|
"use strict"; |
|
|
|
require("./lib/fixoldbrowsers"); |
|
|
|
var dom = require("./lib/dom"); |
|
var event = require("./lib/event"); |
|
|
|
var Editor = require("./editor").Editor; |
|
var EditSession = require("./edit_session").EditSession; |
|
var UndoManager = require("./undomanager").UndoManager; |
|
var Renderer = require("./virtual_renderer").VirtualRenderer; |
|
require("./worker/worker_client"); |
|
require("./keyboard/hash_handler"); |
|
require("./placeholder"); |
|
require("./multi_select"); |
|
require("./mode/folding/fold_mode"); |
|
require("./theme/textmate"); |
|
require("./ext/error_marker"); |
|
|
|
exports.config = require("./config"); |
|
exports.require = require; |
|
exports.edit = function(el) { |
|
if (typeof(el) == "string") { |
|
var _id = el; |
|
el = document.getElementById(_id); |
|
if (!el) |
|
throw new Error("ace.edit can't find div #" + _id); |
|
} |
|
|
|
if (el && el.env && el.env.editor instanceof Editor) |
|
return el.env.editor; |
|
|
|
var value = ""; |
|
if (el && /input|textarea/i.test(el.tagName)) { |
|
var oldNode = el; |
|
value = oldNode.value; |
|
el = dom.createElement("pre"); |
|
oldNode.parentNode.replaceChild(el, oldNode); |
|
} else { |
|
value = dom.getInnerText(el); |
|
el.innerHTML = ''; |
|
} |
|
|
|
var doc = exports.createEditSession(value); |
|
|
|
var editor = new Editor(new Renderer(el)); |
|
editor.setSession(doc); |
|
|
|
var env = { |
|
document: doc, |
|
editor: editor, |
|
onResize: editor.resize.bind(editor, null) |
|
}; |
|
if (oldNode) env.textarea = oldNode; |
|
event.addListener(window, "resize", env.onResize); |
|
editor.on("destroy", function() { |
|
event.removeListener(window, "resize", env.onResize); |
|
env.editor.container.env = null; // prevent memory leak on old ie |
|
}); |
|
editor.container.env = editor.env = env; |
|
return editor; |
|
}; |
|
exports.createEditSession = function(text, mode) { |
|
var doc = new EditSession(text, mode); |
|
doc.setUndoManager(new UndoManager()); |
|
return doc; |
|
} |
|
exports.EditSession = EditSession; |
|
exports.UndoManager = UndoManager; |
|
}); |
|
|
|
ace.define("ace/ext/textarea",["require","exports","module","ace/lib/event","ace/lib/useragent","ace/lib/net","ace/ace","ace/theme/textmate"], function(require, exports, module) { |
|
"use strict"; |
|
|
|
var event = require("../lib/event"); |
|
var UA = require("../lib/useragent"); |
|
var net = require("../lib/net"); |
|
var ace = require("../ace"); |
|
|
|
require("../theme/textmate"); |
|
|
|
module.exports = exports = ace; |
|
var getCSSProperty = function(element, container, property) { |
|
var ret = element.style[property]; |
|
|
|
if (!ret) { |
|
if (window.getComputedStyle) { |
|
ret = window.getComputedStyle(element, '').getPropertyValue(property); |
|
} else { |
|
ret = element.currentStyle[property]; |
|
} |
|
} |
|
|
|
if (!ret || ret == 'auto' || ret == 'intrinsic') { |
|
ret = container.style[property]; |
|
} |
|
return ret; |
|
}; |
|
|
|
function applyStyles(elm, styles) { |
|
for (var style in styles) { |
|
elm.style[style] = styles[style]; |
|
} |
|
} |
|
|
|
function setupContainer(element, getValue) { |
|
if (element.type != 'textarea') { |
|
throw new Error("Textarea required!"); |
|
} |
|
|
|
var parentNode = element.parentNode; |
|
var container = document.createElement('div'); |
|
var resizeEvent = function() { |
|
var style = 'position:relative;'; |
|
[ |
|
'margin-top', 'margin-left', 'margin-right', 'margin-bottom' |
|
].forEach(function(item) { |
|
style += item + ':' + |
|
getCSSProperty(element, container, item) + ';'; |
|
}); |
|
var width = getCSSProperty(element, container, 'width') || (element.clientWidth + "px"); |
|
var height = getCSSProperty(element, container, 'height') || (element.clientHeight + "px"); |
|
style += 'height:' + height + ';width:' + width + ';'; |
|
style += 'display:inline-block;'; |
|
container.setAttribute('style', style); |
|
}; |
|
event.addListener(window, 'resize', resizeEvent); |
|
resizeEvent(); |
|
parentNode.insertBefore(container, element.nextSibling); |
|
while (parentNode !== document) { |
|
if (parentNode.tagName.toUpperCase() === 'FORM') { |
|
var oldSumit = parentNode.onsubmit; |
|
parentNode.onsubmit = function(evt) { |
|
element.value = getValue(); |
|
if (oldSumit) { |
|
oldSumit.call(this, evt); |
|
} |
|
}; |
|
break; |
|
} |
|
parentNode = parentNode.parentNode; |
|
} |
|
return container; |
|
} |
|
|
|
exports.transformTextarea = function(element, options) { |
|
var session; |
|
var container = setupContainer(element, function() { |
|
return session.getValue(); |
|
}); |
|
element.style.display = 'none'; |
|
container.style.background = 'white'; |
|
var editorDiv = document.createElement("div"); |
|
applyStyles(editorDiv, { |
|
top: "0px", |
|
left: "0px", |
|
right: "0px", |
|
bottom: "0px", |
|
border: "1px solid gray", |
|
position: "absolute" |
|
}); |
|
container.appendChild(editorDiv); |
|
|
|
var settingOpener = document.createElement("div"); |
|
applyStyles(settingOpener, { |
|
position: "absolute", |
|
right: "0px", |
|
bottom: "0px", |
|
background: "red", |
|
cursor: "nw-resize", |
|
borderStyle: "solid", |
|
borderWidth: "9px 8px 10px 9px", |
|
width: "2px", |
|
borderColor: "lightblue gray gray lightblue", |
|
zIndex: 101 |
|
}); |
|
|
|
var settingDiv = document.createElement("div"); |
|
var settingDivStyles = { |
|
top: "0px", |
|
left: "20%", |
|
right: "0px", |
|
bottom: "0px", |
|
position: "absolute", |
|
padding: "5px", |
|
zIndex: 100, |
|
color: "white", |
|
display: "none", |
|
overflow: "auto", |
|
fontSize: "14px", |
|
boxShadow: "-5px 2px 3px gray" |
|
}; |
|
if (!UA.isOldIE) { |
|
settingDivStyles.backgroundColor = "rgba(0, 0, 0, 0.6)"; |
|
} else { |
|
settingDivStyles.backgroundColor = "#333"; |
|
} |
|
|
|
applyStyles(settingDiv, settingDivStyles); |
|
container.appendChild(settingDiv); |
|
|
|
options = options || exports.defaultOptions; |
|
var editor = ace.edit(editorDiv); |
|
session = editor.getSession(); |
|
|
|
session.setValue(element.value || element.innerHTML); |
|
editor.focus(); |
|
container.appendChild(settingOpener); |
|
setupApi(editor, editorDiv, settingDiv, ace, options, load); |
|
setupSettingPanel(settingDiv, settingOpener, editor); |
|
|
|
var state = ""; |
|
event.addListener(settingOpener, "mousemove", function(e) { |
|
var rect = this.getBoundingClientRect(); |
|
var x = e.clientX - rect.left, y = e.clientY - rect.top; |
|
if (x + y < (rect.width + rect.height)/2) { |
|
this.style.cursor = "pointer"; |
|
state = "toggle"; |
|
} else { |
|
state = "resize"; |
|
this.style.cursor = "nw-resize"; |
|
} |
|
}); |
|
|
|
event.addListener(settingOpener, "mousedown", function(e) { |
|
if (state == "toggle") { |
|
editor.setDisplaySettings(); |
|
return; |
|
} |
|
container.style.zIndex = 100000; |
|
var rect = container.getBoundingClientRect(); |
|
var startX = rect.width + rect.left - e.clientX; |
|
var startY = rect.height + rect.top - e.clientY; |
|
event.capture(settingOpener, function(e) { |
|
container.style.width = e.clientX - rect.left + startX + "px"; |
|
container.style.height = e.clientY - rect.top + startY + "px"; |
|
editor.resize(); |
|
}, function() {}); |
|
}); |
|
|
|
return editor; |
|
}; |
|
|
|
function load(url, module, callback) { |
|
net.loadScript(url, function() { |
|
require([module], callback); |
|
}); |
|
} |
|
|
|
function setupApi(editor, editorDiv, settingDiv, ace, options, loader) { |
|
var session = editor.getSession(); |
|
var renderer = editor.renderer; |
|
loader = loader || load; |
|
|
|
function toBool(value) { |
|
return value === "true" || value == true; |
|
} |
|
|
|
editor.setDisplaySettings = function(display) { |
|
if (display == null) |
|
display = settingDiv.style.display == "none"; |
|
if (display) { |
|
settingDiv.style.display = "block"; |
|
settingDiv.hideButton.focus(); |
|
editor.on("focus", function onFocus() { |
|
editor.removeListener("focus", onFocus); |
|
settingDiv.style.display = "none"; |
|
}); |
|
} else { |
|
editor.focus(); |
|
} |
|
}; |
|
|
|
editor.$setOption = editor.setOption; |
|
editor.$getOption = editor.getOption; |
|
editor.setOption = function(key, value) { |
|
switch (key) { |
|
case "mode": |
|
editor.$setOption("mode", "ace/mode/" + value) |
|
break; |
|
case "theme": |
|
editor.$setOption("theme", "ace/theme/" + value) |
|
break; |
|
case "keybindings": |
|
switch (value) { |
|
case "vim": |
|
editor.setKeyboardHandler("ace/keyboard/vim"); |
|
break; |
|
case "emacs": |
|
editor.setKeyboardHandler("ace/keyboard/emacs"); |
|
break; |
|
default: |
|
editor.setKeyboardHandler(null); |
|
} |
|
break; |
|
|
|
case "softWrap": |
|
case "fontSize": |
|
editor.$setOption(key, value); |
|
break; |
|
|
|
default: |
|
editor.$setOption(key, toBool(value)); |
|
} |
|
}; |
|
|
|
editor.getOption = function(key) { |
|
switch (key) { |
|
case "mode": |
|
return editor.$getOption("mode").substr("ace/mode/".length) |
|
break; |
|
|
|
case "theme": |
|
return editor.$getOption("theme").substr("ace/theme/".length) |
|
break; |
|
|
|
case "keybindings": |
|
var value = editor.getKeyboardHandler() |
|
switch (value && value.$id) { |
|
case "ace/keyboard/vim": |
|
return "vim"; |
|
case "ace/keyboard/emacs": |
|
return "emacs"; |
|
default: |
|
return "ace"; |
|
} |
|
break; |
|
|
|
default: |
|
return editor.$getOption(key); |
|
} |
|
}; |
|
|
|
editor.setOptions(options); |
|
return editor; |
|
} |
|
|
|
function setupSettingPanel(settingDiv, settingOpener, editor) { |
|
var BOOL = null; |
|
|
|
var desc = { |
|
mode: "Mode:", |
|
wrap: "Soft Wrap:", |
|
theme: "Theme:", |
|
fontSize: "Font Size:", |
|
showGutter: "Display Gutter:", |
|
keybindings: "Keyboard", |
|
showPrintMargin: "Show Print Margin:", |
|
useSoftTabs: "Use Soft Tabs:", |
|
showInvisibles: "Show Invisibles" |
|
}; |
|
|
|
var optionValues = { |
|
mode: { |
|
text: "Plain", |
|
javascript: "JavaScript", |
|
xml: "XML", |
|
html: "HTML", |
|
css: "CSS", |
|
scss: "SCSS", |
|
python: "Python", |
|
php: "PHP", |
|
java: "Java", |
|
ruby: "Ruby", |
|
c_cpp: "C/C++", |
|
coffee: "CoffeeScript", |
|
json: "json", |
|
perl: "Perl", |
|
clojure: "Clojure", |
|
ocaml: "OCaml", |
|
csharp: "C#", |
|
haxe: "haXe", |
|
svg: "SVG", |
|
textile: "Textile", |
|
groovy: "Groovy", |
|
liquid: "Liquid", |
|
Scala: "Scala" |
|
}, |
|
theme: { |
|
clouds: "Clouds", |
|
clouds_midnight: "Clouds Midnight", |
|
cobalt: "Cobalt", |
|
crimson_editor: "Crimson Editor", |
|
dawn: "Dawn", |
|
eclipse: "Eclipse", |
|
idle_fingers: "Idle Fingers", |
|
kr_theme: "Kr Theme", |
|
merbivore: "Merbivore", |
|
merbivore_soft: "Merbivore Soft", |
|
mono_industrial: "Mono Industrial", |
|
monokai: "Monokai", |
|
pastel_on_dark: "Pastel On Dark", |
|
solarized_dark: "Solarized Dark", |
|
solarized_light: "Solarized Light", |
|
textmate: "Textmate", |
|
twilight: "Twilight", |
|
vibrant_ink: "Vibrant Ink" |
|
}, |
|
showGutter: BOOL, |
|
fontSize: { |
|
"10px": "10px", |
|
"11px": "11px", |
|
"12px": "12px", |
|
"14px": "14px", |
|
"16px": "16px" |
|
}, |
|
wrap: { |
|
off: "Off", |
|
40: "40", |
|
80: "80", |
|
free: "Free" |
|
}, |
|
keybindings: { |
|
ace: "ace", |
|
vim: "vim", |
|
emacs: "emacs" |
|
}, |
|
showPrintMargin: BOOL, |
|
useSoftTabs: BOOL, |
|
showInvisibles: BOOL |
|
}; |
|
|
|
var table = []; |
|
table.push("<table><tr><th>Setting</th><th>Value</th></tr>"); |
|
|
|
function renderOption(builder, option, obj, cValue) { |
|
if (!obj) { |
|
builder.push( |
|
"<input type='checkbox' title='", option, "' ", |
|
cValue + "" == "true" ? "checked='true'" : "", |
|
"'></input>" |
|
); |
|
return; |
|
} |
|
builder.push("<select title='" + option + "'>"); |
|
for (var value in obj) { |
|
builder.push("<option value='" + value + "' "); |
|
|
|
if (cValue == value) { |
|
builder.push(" selected "); |
|
} |
|
|
|
builder.push(">", |
|
obj[value], |
|
"</option>"); |
|
} |
|
builder.push("</select>"); |
|
} |
|
|
|
for (var option in exports.defaultOptions) { |
|
table.push("<tr><td>", desc[option], "</td>"); |
|
table.push("<td>"); |
|
renderOption(table, option, optionValues[option], editor.getOption(option)); |
|
table.push("</td></tr>"); |
|
} |
|
table.push("</table>"); |
|
settingDiv.innerHTML = table.join(""); |
|
|
|
var onChange = function(e) { |
|
var select = e.currentTarget; |
|
editor.setOption(select.title, select.value); |
|
}; |
|
var onClick = function(e) { |
|
var cb = e.currentTarget; |
|
editor.setOption(cb.title, cb.checked); |
|
}; |
|
var selects = settingDiv.getElementsByTagName("select"); |
|
for (var i = 0; i < selects.length; i++) |
|
selects[i].onchange = onChange; |
|
var cbs = settingDiv.getElementsByTagName("input"); |
|
for (var i = 0; i < cbs.length; i++) |
|
cbs[i].onclick = onClick; |
|
|
|
|
|
var button = document.createElement("input"); |
|
button.type = "button"; |
|
button.value = "Hide"; |
|
event.addListener(button, "click", function() { |
|
editor.setDisplaySettings(false); |
|
}); |
|
settingDiv.appendChild(button); |
|
settingDiv.hideButton = button; |
|
} |
|
exports.defaultOptions = { |
|
mode: "javascript", |
|
theme: "textmate", |
|
wrap: "off", |
|
fontSize: "12px", |
|
showGutter: "false", |
|
keybindings: "ace", |
|
showPrintMargin: "false", |
|
useSoftTabs: "true", |
|
showInvisibles: "false" |
|
}; |
|
|
|
}); |
|
(function() { |
|
ace.require(["ace/ext/textarea"], function() {}); |
|
})(); |
|
|