summaryrefslogtreecommitdiff
path: root/public/vendor/codemirror/mode/handlebars
diff options
context:
space:
mode:
Diffstat (limited to 'public/vendor/codemirror/mode/handlebars')
-rwxr-xr-xpublic/vendor/codemirror/mode/handlebars/handlebars.js53
-rwxr-xr-xpublic/vendor/codemirror/mode/handlebars/index.html83
2 files changed, 136 insertions, 0 deletions
diff --git a/public/vendor/codemirror/mode/handlebars/handlebars.js b/public/vendor/codemirror/mode/handlebars/handlebars.js
new file mode 100755
index 00000000..40dfea42
--- /dev/null
+++ b/public/vendor/codemirror/mode/handlebars/handlebars.js
@@ -0,0 +1,53 @@
+// CodeMirror, copyright (c) by Marijn Haverbeke and others
+// Distributed under an MIT license: http://codemirror.net/LICENSE
+
+(function(mod) {
+ if (typeof exports == "object" && typeof module == "object") // CommonJS
+ mod(require("../../lib/codemirror"), require("../../addon/mode/simple"));
+ else if (typeof define == "function" && define.amd) // AMD
+ define(["../../lib/codemirror", "../../addon/mode/simple"], mod);
+ else // Plain browser env
+ mod(CodeMirror);
+})(function(CodeMirror) {
+ "use strict";
+
+ CodeMirror.defineSimpleMode("handlebars", {
+ start: [
+ { regex: /\{\{!--/, push: "dash_comment", token: "comment" },
+ { regex: /\{\{!/, push: "comment", token: "comment" },
+ { regex: /\{\{/, push: "handlebars", token: "tag" }
+ ],
+ handlebars: [
+ { regex: /\}\}/, pop: true, token: "tag" },
+
+ // Double and single quotes
+ { regex: /"(?:[^\\]|\\.)*?"/, token: "string" },
+ { regex: /'(?:[^\\]|\\.)*?'/, token: "string" },
+
+ // Handlebars keywords
+ { regex: />|[#\/]([A-Za-z_]\w*)/, token: "keyword" },
+ { regex: /(?:else|this)\b/, token: "keyword" },
+
+ // Numeral
+ { regex: /\d+/i, token: "number" },
+
+ // Atoms like = and .
+ { regex: /=|~|@|true|false/, token: "atom" },
+
+ // Paths
+ { regex: /(?:\.\.\/)*(?:[A-Za-z_][\w\.]*)+/, token: "variable-2" }
+ ],
+ dash_comment: [
+ { regex: /--\}\}/, pop: true, token: "comment" },
+
+ // Commented code
+ { regex: /./, token: "comment"}
+ ],
+ comment: [
+ { regex: /\}\}/, pop: true, token: "comment" },
+ { regex: /./, token: "comment" }
+ ]
+ });
+
+ CodeMirror.defineMIME("text/x-handlebars-template", "handlebars");
+});
diff --git a/public/vendor/codemirror/mode/handlebars/index.html b/public/vendor/codemirror/mode/handlebars/index.html
new file mode 100755
index 00000000..beaef87a
--- /dev/null
+++ b/public/vendor/codemirror/mode/handlebars/index.html
@@ -0,0 +1,83 @@
+<!doctype html>
+
+<title>CodeMirror: Handlebars 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="../../addon/mode/simple.js"></script>
+<script src="../../addon/mode/multiplex.js"></script>
+<script src="../xml/xml.js"></script>
+<script src="handlebars.js"></script>
+<style>.CodeMirror {border-top: 1px solid black; border-bottom: 1px solid black;}</style>
+<div id=nav>
+ <a href="http://codemirror.net"><h1>CodeMirror</h1><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/codemirror/codemirror">Code</a>
+ </ul>
+ <ul>
+ <li><a href="../index.html">Language modes</a>
+ <li><a class=active href="#">HTML mixed</a>
+ </ul>
+</div>
+
+<article>
+<h2>Handlebars</h2>
+<form><textarea id="code" name="code">
+{{> breadcrumbs}}
+
+{{!--
+ You can use the t function to get
+ content translated to the current locale, es:
+ {{t 'article_list'}}
+--}}
+
+<h1>{{t 'article_list'}}</h1>
+
+{{! one line comment }}
+
+{{#each articles}}
+ {{~title}}
+ <p>{{excerpt body size=120 ellipsis=true}}</p>
+
+ {{#with author}}
+ written by {{first_name}} {{last_name}}
+ from category: {{../category.title}}
+ {{#if @../last}}foobar!{{/if}}
+ {{/with~}}
+
+ {{#if promoted.latest}}Read this one! {{else}} This is ok! {{/if}}
+
+ {{#if @last}}<hr>{{/if}}
+{{/each}}
+
+{{#form new_comment}}
+ <input type="text" name="body">
+{{/form}}
+
+</textarea></form>
+ <script>
+ CodeMirror.defineMode("htmlhandlebars", function(config) {
+ return CodeMirror.multiplexingMode(
+ CodeMirror.getMode(config, "text/html"),
+ {open: "{{", close: "}}",
+ mode: CodeMirror.getMode(config, "handlebars"),
+ parseDelimiters: true});
+ });
+
+ var editor = CodeMirror.fromTextArea(document.getElementById("code"), {
+ lineNumbers: true,
+ matchBrackets: true,
+ mode: "htmlhandlebars"
+ });
+ </script>
+ </script>
+
+ <p>Handlebars syntax highlighting for CodeMirror.</p>
+
+ <p><strong>MIME types defined:</strong> <code>text/x-handlebars-template</code></p>
+</article>