PhantomJS が HTML および PDF 出力を作成するように、HTML 内に角度ディレクティブを追加しようとしています。
スニペットは以下のとおりです。
Angular ディレクティブを追加しようとしているコードは以下のとおりです。
function drawWidget(widgets) {
for(var i = 0; i < widgets.length; i++) {
var iDiv = document.createElement('div');
var att = document.createAttribute("data-ss-colspan");
iDiv.className = "widget_box";
iDiv.id = "graphId" + i;
iDiv.innerHTML = '<div class="col-md-12 col-sm-12 head_categories">\
<span>' + widgets[i]["widgetTitle"] + '</span>\
<span class="pull-right menu_categori"></span>\
</div>\
<div style="clear:both;"></div>';
att.value = widgets[i]["widgetSize"].toString(); // Set the value of the class attribute
iDiv.setAttributeNode(att);
document.getElementById('widget_container').appendChild(iDiv);
//var chartDiv = document.createElement('editor');
document.getElementById(iDiv.id).append(angular.element('#widget_container').
scope().getChartElement(widgets, i));
}
}
私のAngularディレクティブは以下のようです:
angular.module('app',[]).directive("editor", function(){
return {
require: "?ngModel",
scope: true,
controller: 'ChartController',
template: "<input ng-model='value' ng-change='onChange()'>",
link: function(scope, element, attrs, ngModel) {
if (!ngModel) return;
scope.onChange = function(){
ngModel.$setViewValue(scope.value);
};
ngModel.$render = function(){
scope.value = ngModel.$modelValue;
};
}
};
});
get ChartElement コードは次のとおりです。
(function(){
'use strict'
angular.module('app').controller('ChartController', chartController);
chartController.$inject = ['$scope', '$compile'];
function chartController($scope, $compile) {
$scope.getChartElement = function(widgets, i) {
$scope.id = "graphId" + i;
$scope.data = widgets[i]["chart_data"]["data"];
/*var elementString ='<line-graph graph-id="id" graph-data="data" ' + ' width="' + widgets[i]["chart_data"]["divWidth"] + '" height="' + widgets[i]["chart_height"] +
'" colors="' + widgets[i]["chart_data"]["colors"] +
'" interval="' + widgets[i]["chart_data"]["interval"] + '"></line-graph>';*/
var elementString ='<editor ng-model="abc" minlength="3"></editor>';
console.log("Element String : " + elementString);
return elementString;
};
};
})();