2016-12-08 5 views
3

Я изо всех сил пытаюсь построить линию sigle в визуальном представлении Power BI. Отчеты в Power BI записываются с использованием TypeScript и d3.js v.3.0. Я могу построить график с осями, но строка не появляется. Использование чистого d3.js в HTML-файле очень просто, но его сложно интегрировать с TypeScript из-за сохранения титров.Постройте линию, используя библиотеку d3.js в Power BI custom visual

При разработке этого кода у меня было несколько проблем с типом. Код ниже почти работает. Взгляните на этот фрагмент. Проблема с типизацией возникает, когда внизу я удаляю «any».

Here is link to sandbox at CodePen: https://codepen.io/SuszonyDzik/pen/aBaJJQ

module powerbi.extensibility.visual { 
    export class Visual implements IVisual { 
     private target: HTMLElement; 
     private updateCount: number; 

     private svg: d3.Selection<SVGAElement>; 
     private host: IVisualHost; 
     private selectionManager: ISelectionManager; 

     //private xAxis: d3.Selection<SVGAElement>; 
     //private yAxis: d3.Selection<SVGAElement>; 


     private data = [ 
      {date: "2011-10-01", close: 582.13}, 
      {date: "2011-10-10", close: 303.00}, 
      {date: "2011-10-20", close: 103.00}, 
      {date: "2011-10-25", close: 143.00}, 
     ] 

     static Config = { 
      xScalePadding: 0.1, 
      solidOpacity: 1, 
      transparentOpacity: 0.5, 
      xAxisFontMultiplier: 0.04, 
     }; 

     private margin = {top: 20, right: 30, bottom: 30, left: 80}; 



     constructor(options: VisualConstructorOptions) { 
      this.host = options.host; 

      let svg = this.svg = d3.select(options.element) 
       .append('svg') 
       .classed('worksheet', true); 
     } 

     public update(options: VisualUpdateOptions) { 
      let width = options.viewport.width - this.margin.left - this.margin.right; 
      let height = options.viewport.height - this.margin.top - this.margin.bottom; 

      this.svg.attr({ 
       width: width + this.margin.left + this.margin.right, 
       height: height + this.margin.top + this.margin.bottom 
      }); 



      let parseDate = d3.time.format("%Y-%m-%d").parse;      

      let xScale = d3.time.scale() 
       .domain(this.data.map(function(d) { return parseDate(d.date); })) 
       .range([0, width]) 

      let yScale = d3.scale.linear() 
       .domain([0, d3.max(this.data, function(d) { return d.close; })]) 
       .range([height, 0]);   

      let xAxis = d3.svg.axis() 
       .scale(xScale) 
       .orient("bottom") 
       .ticks(10) 

      let yAxis = d3.svg.axis() 
       .scale(yScale) 
       .orient("left") 
       .ticks(10) 
       .innerTickSize(-width) 
       .outerTickSize(10) 
       .tickPadding(10) 



      let worksheet = d3.select(".worksheet") 
       .attr("width", width + this.margin.left + this.margin.right) 
       .attr("height", height + this.margin.top + this.margin.bottom); 


      // remove exsisting axis and bar 
      this.svg.selectAll('.axis').remove(); 
      this.svg.selectAll('.bar').remove(); 
      this.svg.selectAll('.chart').remove(); 


      let chart = d3.select(".worksheet") 
       .append("g") 
       .attr("transform", "translate(" + this.margin.left + "," + this.margin.top + ")") 
       .attr("class", "chart") 

      chart.append("g") 
       .attr("class", "x axis") 
       .attr("transform", "translate(0," + height + ")") 
       .call(xAxis); 


      chart.append("g") 
       .attr("class", "y axis") 
       .call(yAxis) 


      let line = d3.svg.line() 
      .x(function(d) { console.log(parseDate(this.data.date)); return xScale(parseDate(this.data.date)); }) 
      .y(function(d) { return yScale(this.data.close); }) 
      .interpolate("linear") 

      chart.append("path") 
       .datum(this.data) 
       .attr("class", "line")   
       .attr("d", <any> line) 

     } 

     public destroy(): void { 
      //TODO: Perform any cleanup tasks here 
     } 
    } 
} 

Power BI chart with axes but without line

+0

Можете добавить его в CodePen. Кто-то ответит на него гораздо быстрее, если есть работающий код. CodePen позволяет использовать файлы TypeScript, и он переводит его в JS при запуске. – Ryan

+0

. Вот ссылка на песочницу в CodePen: https://codepen.io/SuszonyDzik/pen/aBaJJQ –

+0

Ничего не показывает, когда я открываю это. Вы запустили d3 в кодефене с чем-то базовым, чтобы исключить простые ошибки настройки? – Ryan

ответ

1

Пожалуйста, измените код с

chart.append("path") 
.datum(this.data) 
.attr("class", "line")   
.attr("d", <any> line) 

Для

chart.append("path") 
.datum(this.data) 
.attr("class", "line") 
.attr("d", "M" + this.data.map((d)=> { 
return xScale(parseDate(d.date)) + ',' + yScale(d.close); 
}).join('L')) 

А также из ниже

let xScale = d3.time.scale() 
.domain(this.data.map(function(d) { return parseDate(d.date); })) 
.range([0, width]) 

в

let xScale = d3.time.scale() 
.domain(d3.extent(this.data,function(d) { return parseDate(d.date); })) 
.range([0, width]) 

Я изменил код и работал. Пожалуйста, найдите результат. Output