diff --git a/angular-highlightjs.js b/angular-highlightjs.js index 3b3f27e..081821c 100644 --- a/angular-highlightjs.js +++ b/angular-highlightjs.js @@ -108,20 +108,21 @@ function HljsCtrl (hljsCache, hljsService) { }; }]) -.directive('hljs', [function () { +.directive('hljs', ['$interpolate', function ($interpolate) { return { restrict: 'EA', controller: 'HljsCtrl', compile: function(tElm, tAttrs, transclude) { // get static code // strip the starting "new line" character - var staticCode = tElm[0].innerHTML.replace(/^(\r\n|\r|\n)/m, ''); - + var staticCode = tElm[0].innerHTML.replace(/^(\r\n|\r|\n)/m, '') + .replace(/&/gm, '&').replace(/</gm, '<').replace(/>/gm, '>'); // put template - tElm.html('
');
+ tElm.addClass('hljs');
+ tElm.html('');
return function postLink(scope, iElm, iAttrs, ctrl) {
- ctrl.init(iElm.find('code'));
+ ctrl.init(iElm);
if (iAttrs.onhighlight) {
ctrl.highlightCallback(function () {
@@ -130,7 +131,7 @@ function HljsCtrl (hljsCache, hljsService) {
}
if (staticCode) {
- ctrl.highlight(staticCode);
+ ctrl.highlight($interpolate(staticCode)(scope));
}
scope.$on('$destroy', function () {
diff --git a/angular-highlightjs.min.js b/angular-highlightjs.min.js
index 3eaaf14..e05575c 100644
--- a/angular-highlightjs.min.js
+++ b/angular-highlightjs.min.js
@@ -1,6 +1,6 @@
/*! angular-highlightjs
-version: 0.2.7
-build date: 2014-04-09
+version: 0.2.8
+build date: 2014-04-24
author: Robin Fan
https://github.com/pc035860/angular-highlightjs.git */
-angular.module("hljs",[]).provider("hljsService",function(){var a={};return{setOptions:function(b){angular.extend(a,b)},getOptions:function(){return angular.copy(a)},$get:["$window",function(b){return(b.hljs.configure||angular.noop)(a),b.hljs}]}}).factory("hljsCache",["$cacheFactory",function(a){return a("hljsCache")}]).controller("HljsCtrl",["hljsCache","hljsService",function(a,b){var c=this,d=null,e=null,f=null,g=null;c.init=function(a){d=a},c.setLanguage=function(a){e=a,f&&c.highlight(f)},c.highlightCallback=function(a){g=a},c.highlight=function(h){if(d){var i,j;f=h,e?(j=c._cacheKey(e,f),i=a.get(j),i||(i=b.highlight(e,b.fixMarkup(f),!0),a.put(j,i))):(j=c._cacheKey(f),i=a.get(j),i||(i=b.highlightAuto(b.fixMarkup(f)),a.put(j,i))),d.html(i.value),d.addClass(i.language),null!==g&&angular.isFunction(g)&&g()}},c.clear=function(){d&&(f=null,d.text(""))},c.release=function(){d=null},c._cacheKey=function(){var a=Array.prototype.slice.call(arguments),b="!angular-highlightjs!";return a.join(b)}}]).directive("hljs",[function(){return{restrict:"EA",controller:"HljsCtrl",compile:function(a){var b=a[0].innerHTML.replace(/^(\r\n|\r|\n)/m,"");return a.html(''),function(a,c,d,e){e.init(c.find("code")),d.onhighlight&&e.highlightCallback(function(){a.$eval(d.onhighlight)}),b&&e.highlight(b),a.$on("$destroy",function(){e.release()})}}}}]).directive("language",[function(){return{require:"hljs",restrict:"A",link:function(a,b,c,d){c.$observe("language",function(a){angular.isDefined(a)&&d.setLanguage(a)})}}}]).directive("source",[function(){return{require:"hljs",restrict:"A",link:function(a,b,c,d){a.$watch(c.source,function(a){a?d.highlight(a):d.clear()})}}}]).directive("include",["$http","$templateCache","$q",function(a,b,c){return{require:"hljs",restrict:"A",compile:function(d,e){var f=e.include;return function(d,e,g,h){var i=0;d.$watch(f,function(d){var e=++i;if(d&&angular.isString(d)){var f,g;f=b.get(d),f||(g=c.defer(),a.get(d,{cache:b,transformResponse:function(a){return a}}).success(function(a){e===i&&g.resolve(a)}).error(function(){e===i&&h.clear(),g.resolve()}),f=g.promise),c.when(f).then(function(a){a&&(angular.isArray(a)?a=a[1]:angular.isObject(a)&&(a=a.data),a=a.replace(/^(\r\n|\r|\n)/m,""),h.highlight(a))})}else h.clear()})}}}}]);
\ No newline at end of file
+angular.module("hljs",[]).provider("hljsService",function(){var a={};return{setOptions:function(b){angular.extend(a,b)},getOptions:function(){return angular.copy(a)},$get:["$window",function(b){return(b.hljs.configure||angular.noop)(a),b.hljs}]}}).factory("hljsCache",["$cacheFactory",function(a){return a("hljsCache")}]).controller("HljsCtrl",["hljsCache","hljsService",function(a,b){var c=this,d=null,e=null,f=null,g=null;c.init=function(a){d=a},c.setLanguage=function(a){e=a,f&&c.highlight(f)},c.highlightCallback=function(a){g=a},c.highlight=function(h){if(d){var i,j;f=h,e?(j=c._cacheKey(e,f),i=a.get(j),i||(i=b.highlight(e,b.fixMarkup(f),!0),a.put(j,i))):(j=c._cacheKey(f),i=a.get(j),i||(i=b.highlightAuto(b.fixMarkup(f)),a.put(j,i))),d.html(i.value),d.addClass(i.language),null!==g&&angular.isFunction(g)&&g()}},c.clear=function(){d&&(f=null,d.text(""))},c.release=function(){d=null},c._cacheKey=function(){var a=Array.prototype.slice.call(arguments),b="!angular-highlightjs!";return a.join(b)}}]).directive("hljs",["$interpolate",function(a){return{restrict:"EA",controller:"HljsCtrl",compile:function(b){var c=b[0].innerHTML.replace(/^(\r\n|\r|\n)/m,"").replace(/&/gm,"&").replace(/</gm,"<").replace(/>/gm,">");return b.addClass("hljs"),b.html(""),function(b,d,e,f){f.init(d),e.onhighlight&&f.highlightCallback(function(){b.$eval(e.onhighlight)}),c&&f.highlight(a(c)(b)),b.$on("$destroy",function(){f.release()})}}}}]).directive("language",[function(){return{require:"hljs",restrict:"A",link:function(a,b,c,d){c.$observe("language",function(a){angular.isDefined(a)&&d.setLanguage(a)})}}}]).directive("source",[function(){return{require:"hljs",restrict:"A",link:function(a,b,c,d){a.$watch(c.source,function(a){a?d.highlight(a):d.clear()})}}}]).directive("include",["$http","$templateCache","$q",function(a,b,c){return{require:"hljs",restrict:"A",compile:function(d,e){var f=e.include;return function(d,e,g,h){var i=0;d.$watch(f,function(d){var e=++i;if(d&&angular.isString(d)){var f,g;f=b.get(d),f||(g=c.defer(),a.get(d,{cache:b,transformResponse:function(a){return a}}).success(function(a){e===i&&g.resolve(a)}).error(function(){e===i&&h.clear(),g.resolve()}),f=g.promise),c.when(f).then(function(a){a&&(angular.isArray(a)?a=a[1]:angular.isObject(a)&&(a=a.data),a=a.replace(/^(\r\n|\r|\n)/m,""),h.highlight(a))})}else h.clear()})}}}}]);
\ No newline at end of file
diff --git a/bower.json b/bower.json
index d82aa51..fa7a766 100644
--- a/bower.json
+++ b/bower.json
@@ -1,6 +1,6 @@
{
"name": "angular-highlightjs",
- "version": "0.2.7",
+ "version": "0.2.8",
"description": "AngularJS directive for syntax highlighting with highlight.js.",
"main": "angular-highlightjs.js",
"ignore": [
diff --git a/package.json b/package.json
index f645102..acbcec9 100644
--- a/package.json
+++ b/package.json
@@ -1,6 +1,6 @@
{
"name": "angular-highlightjs",
- "version": "0.2.7",
+ "version": "0.2.8",
"description": "AngularJS directive for syntax highlighting with highlight.js",
"main": "index.js",
"directories": {},