2015-05-02 18:34:16 -04:00
|
|
|
/*
|
|
|
|
* Code Pane Directive
|
|
|
|
*
|
|
|
|
* @requires codeTab Directive
|
|
|
|
*
|
2017-04-01 14:38:49 -04:00
|
|
|
* Individual panes displayed in the
|
2015-05-02 18:34:16 -04:00
|
|
|
* codeTab elements
|
|
|
|
*/
|
|
|
|
|
|
|
|
angularIO.directive('codePane', function() {
|
|
|
|
return {
|
|
|
|
require: '^codeTabs',
|
|
|
|
restrict: 'E',
|
2015-05-03 22:09:25 -04:00
|
|
|
scope: true,
|
2015-05-02 18:34:16 -04:00
|
|
|
|
2015-05-03 22:09:25 -04:00
|
|
|
compile: function(tElement, tAttrs) {
|
|
|
|
var html = (tAttrs.escape === "html") ? _.escape(tElement.html()) : tElement.html();
|
2016-01-20 07:07:00 -05:00
|
|
|
var template =
|
|
|
|
'<copy-container ng-show="selected">' +
|
|
|
|
'<pre class="prettyprint ' + tAttrs.format + ' lang-' + tAttrs.language + '">' +
|
|
|
|
'<code class="animated fadeIn" ng-non-bindable>' + html + '</code>' +
|
|
|
|
'</pre>' +
|
|
|
|
'</copy-container>';
|
2015-05-02 18:34:16 -04:00
|
|
|
|
2015-05-03 22:09:25 -04:00
|
|
|
// UPDATE ELEMENT WITH NEW TEMPLATE
|
|
|
|
tElement.html(template);
|
|
|
|
|
|
|
|
|
|
|
|
// RETURN LINK METHOD
|
|
|
|
return function(scope, element, attrs, controller) {
|
|
|
|
scope.name = attrs.name;
|
|
|
|
|
2017-04-01 14:38:49 -04:00
|
|
|
// ADD PANE TO CONTROLLER
|
2015-05-03 22:09:25 -04:00
|
|
|
controller.addPane(scope);
|
|
|
|
};
|
|
|
|
}
|
2015-05-02 18:34:16 -04:00
|
|
|
};
|
2017-04-01 14:38:49 -04:00
|
|
|
});
|