0

我有一个 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 无效。不符合类型约束”

  • “过滤器无效”

文档来看,虽然我认为我的过滤器结构正确......有什么想法吗?我觉得它的一些小东西我错过了..

4

1 回答 1

1

我最终能够弄清楚这一点。在这里发布答案,以防它帮助其他人。来自 powerbi 嵌入式库的过滤器对象中的日期必须像这样格式化:

“2016-12-01T18:52:11.148Z”

使用 javascript 日期对象 .toISOString() 或 .toJSON() 就可以了。

于 2016-12-01T19:02:17.230 回答