如何应用使用日期的Powerbi Embedded高级过滤器

时间:2016-11-30 19:41:29

标签: javascript angularjs powerbi powerbi-embedded

我有一个1.5角应用程序正在使用power bi嵌入式js库来实例化高级过滤器,然后通过setFilters()函数将其应用于嵌入式报告:

reportsCtrl.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);
    });
}

reports.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个错误。

  • &#34; .operator无效。不符合要求的约束&#34;

  • &#34; .conditions.0.value无效。不符合类型约束&#34;

  • &#34;过滤器无效&#34;

documentation判断,虽然我认为我的过滤器结构正确......任何想法?我觉得我想念的东西很小......

1 个答案:

答案 0 :(得分:1)

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

&#34; 2016-12-01T18:52:11.148Z&#34;

使用javascript日期对象.toISOString()或.toJSON()可以解决问题。