init
This commit is contained in:
66
public/tinymce/plugins/codemirror/CodeMirror/mode/jade/index.html
vendored
Normal file
66
public/tinymce/plugins/codemirror/CodeMirror/mode/jade/index.html
vendored
Normal file
@ -0,0 +1,66 @@
|
||||
<!doctype html>
|
||||
|
||||
<title>CodeMirror: Jade Templating Mode</title>
|
||||
<meta charset="utf-8"/>
|
||||
<link rel=stylesheet href="../../doc/docs.css">
|
||||
|
||||
<link rel="stylesheet" href="../../lib/codemirror.css">
|
||||
<script src="../../lib/codemirror.js"></script>
|
||||
<script src="jade.js"></script>
|
||||
<style type="text/css">.CodeMirror {border-top: 1px solid black; border-bottom: 1px solid black;}</style>
|
||||
<div id=nav>
|
||||
<a href="http://codemirror.net"><img id=logo src="../../doc/logo.png"></a>
|
||||
|
||||
<ul>
|
||||
<li><a href="../../index.html">Home</a>
|
||||
<li><a href="../../doc/manual.html">Manual</a>
|
||||
<li><a href="https://github.com/marijnh/codemirror">Code</a>
|
||||
</ul>
|
||||
<ul>
|
||||
<li><a href="../index.html">Language modes</a>
|
||||
<li><a class=active href="#">Jade Templating Mode</a>
|
||||
</ul>
|
||||
</div>
|
||||
|
||||
<article>
|
||||
<h2>Jade Templating Mode</h2>
|
||||
<form><textarea id="code" name="code">
|
||||
doctype 5
|
||||
html
|
||||
head
|
||||
title= "Jade Templating CodeMirror Mode Example"
|
||||
link(rel='stylesheet', href='/css/bootstrap.min.css')
|
||||
link(rel='stylesheet', href='/css/index.css')
|
||||
script(type='text/javascript', src='/js/jquery-1.9.1.min.js')
|
||||
script(type='text/javascript', src='/js/bootstrap.min.js')
|
||||
body
|
||||
div.header
|
||||
h1 Welcome to this Example
|
||||
div.spots
|
||||
if locals.spots
|
||||
each spot in spots
|
||||
div.spot.well
|
||||
div
|
||||
if spot.logo
|
||||
img.img-rounded.logo(src=spot.logo)
|
||||
else
|
||||
img.img-rounded.logo(src="img/placeholder.png")
|
||||
h3
|
||||
a(href=spot.hash) ##{spot.hash}
|
||||
if spot.title
|
||||
span.title #{spot.title}
|
||||
if spot.desc
|
||||
div #{spot.desc}
|
||||
else
|
||||
h3 There are no spots currently available.
|
||||
</textarea></form>
|
||||
<script>
|
||||
var editor = CodeMirror.fromTextArea(document.getElementById("code"), {
|
||||
mode: {name: "jade", alignCDATA: true},
|
||||
lineNumbers: true
|
||||
});
|
||||
</script>
|
||||
<h3>The Jade Templating Mode</h3>
|
||||
<p> Created by Drew Bratcher. Managed as part of an Adobe Brackets extension at <a href="https://github.com/dbratcher/brackets-jade">https://github.com/dbratcher/brackets-jade</a>.</p>
|
||||
<p><strong>MIME type defined:</strong> <code>text/x-jade</code>.</p>
|
||||
</article>
|
90
public/tinymce/plugins/codemirror/CodeMirror/mode/jade/jade.js
vendored
Normal file
90
public/tinymce/plugins/codemirror/CodeMirror/mode/jade/jade.js
vendored
Normal file
@ -0,0 +1,90 @@
|
||||
CodeMirror.defineMode("jade", function () {
|
||||
var symbol_regex1 = /^(?:~|!|%|\^|\*|\+|=|\\|:|;|,|\/|\?|&|<|>|\|)/;
|
||||
var open_paren_regex = /^(\(|\[)/;
|
||||
var close_paren_regex = /^(\)|\])/;
|
||||
var keyword_regex1 = /^(if|else|return|var|function|include|doctype|each)/;
|
||||
var keyword_regex2 = /^(#|{|}|\.)/;
|
||||
var keyword_regex3 = /^(in)/;
|
||||
var html_regex1 = /^(html|head|title|meta|link|script|body|br|div|input|span|a|img)/;
|
||||
var html_regex2 = /^(h1|h2|h3|h4|h5|p|strong|em)/;
|
||||
return {
|
||||
startState: function () {
|
||||
return {
|
||||
inString: false,
|
||||
stringType: "",
|
||||
beforeTag: true,
|
||||
justMatchedKeyword: false,
|
||||
afterParen: false
|
||||
};
|
||||
},
|
||||
token: function (stream, state) {
|
||||
//check for state changes
|
||||
if (!state.inString && ((stream.peek() == '"') || (stream.peek() == "'"))) {
|
||||
state.stringType = stream.peek();
|
||||
stream.next(); // Skip quote
|
||||
state.inString = true; // Update state
|
||||
}
|
||||
|
||||
//return state
|
||||
if (state.inString) {
|
||||
if (stream.skipTo(state.stringType)) { // Quote found on this line
|
||||
stream.next(); // Skip quote
|
||||
state.inString = false; // Clear flag
|
||||
} else {
|
||||
stream.skipToEnd(); // Rest of line is string
|
||||
}
|
||||
state.justMatchedKeyword = false;
|
||||
return "string"; // Token style
|
||||
} else if (stream.sol() && stream.eatSpace()) {
|
||||
if (stream.match(keyword_regex1)) {
|
||||
state.justMatchedKeyword = true;
|
||||
stream.eatSpace();
|
||||
return "keyword";
|
||||
}
|
||||
if (stream.match(html_regex1) || stream.match(html_regex2)) {
|
||||
state.justMatchedKeyword = true;
|
||||
return "variable";
|
||||
}
|
||||
} else if (stream.sol() && stream.match(keyword_regex1)) {
|
||||
state.justMatchedKeyword = true;
|
||||
stream.eatSpace();
|
||||
return "keyword";
|
||||
} else if (stream.sol() && (stream.match(html_regex1) || stream.match(html_regex2))) {
|
||||
state.justMatchedKeyword = true;
|
||||
return "variable";
|
||||
} else if (stream.eatSpace()) {
|
||||
state.justMatchedKeyword = false;
|
||||
if (stream.match(keyword_regex3) && stream.eatSpace()) {
|
||||
state.justMatchedKeyword = true;
|
||||
return "keyword";
|
||||
}
|
||||
} else if (stream.match(symbol_regex1)) {
|
||||
state.justMatchedKeyword = false;
|
||||
return "atom";
|
||||
} else if (stream.match(open_paren_regex)) {
|
||||
state.afterParen = true;
|
||||
state.justMatchedKeyword = true;
|
||||
return "def";
|
||||
} else if (stream.match(close_paren_regex)) {
|
||||
state.afterParen = false;
|
||||
state.justMatchedKeyword = true;
|
||||
return "def";
|
||||
} else if (stream.match(keyword_regex2)) {
|
||||
state.justMatchedKeyword = true;
|
||||
return "keyword";
|
||||
} else if (stream.eatSpace()) {
|
||||
state.justMatchedKeyword = false;
|
||||
} else {
|
||||
stream.next();
|
||||
if (state.justMatchedKeyword) {
|
||||
return "property";
|
||||
} else if (state.afterParen) {
|
||||
return "property";
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
};
|
||||
});
|
||||
|
||||
CodeMirror.defineMIME('text/x-jade', 'jade');
|
Reference in New Issue
Block a user