我有一个 Angular 1.5 应用程序,它使用 power bi 嵌入式 js 库来实例化高级过滤器,然后通过 setFilters() 函数将其应用于嵌入式报告:
报告Ctrl.js
function onEmbedded(report) {
vm.embededReport = report;
if (vm.activeFilter) {
vm.embededReport.setFilters([vm.activeFilter]);
}
}
function buildFilter() {
var date1 = new Date(vm.selectedDate.toDateString());
var date2 = new Date(date1);
//add one day via mutator setDate function
date2.setDate(date1.getDate() + 1);
vm.activeFilter = new pbi.models.AdvancedFilter(
{
table: 'tblMessage',
column: 'event_timestamp'
},
'And',
[{
operator: 'GreaterThanOrEqual',
value: date1
},
{
operator: 'LessThan',
value: date2
}]
);
if (vm.embededReport) {
vm.embededReport.setFilters([vm.activeFilter]);
}
}
function loadReport(reportId) {
vm.reportConfig = null;
reportService.getReport(reportId, facilityId).then(function (response) {
//merge report with default configurations
vm.reportConfig = angular.merge({}, defaultReportConfig, response);
});
}
报告.tpl.html
<h1>{{vm.message}}</h1>
<div ng-repeat="report in vm.reports">
<pre>{{report | json}}</pre>
<button ng-click="vm.loadReport(report.id)">embed</button>
</div>
<button ng-click="vm.buildFilter()">
Add Filter
</button>
<h2>Acitve Filter!</h2>
<pre>{{vm.activeFilter | json}}</pre>
<div>
<powerbi-component ng-if="vm.reportConfig" options="vm.reportConfig" on-embedded="vm.onEmbedded($embed)" ></powerbi-component>
</div>
应用过滤器时出现以下 3 个错误。
“.operator 无效。不符合要求的约束”
“.conditions.0.value 无效。不符合类型约束”
“过滤器无效”
从文档来看,虽然我认为我的过滤器结构正确......有什么想法吗?我觉得它的一些小东西我错过了..