Создание пользовательских визуализаций в Google Data Studio с использованием SVG - PullRequest
1 голос
/ 24 марта 2019

В настоящее время я пытаюсь перенести библиотеку радиальных показателей SVG в Google Data Studio, но я просто продолжаю получать пустые визуализации.

Вот код, который работает в html https://codepen.io/grant-kemp/pen/NJoYLB

<div class="flex-wrapper">

  <div class="single-chart">
    <svg viewBox="0 0 36 36" class="circular-chart blue">
      <path class="circle-bg"
        d="M18 2.0845
          a 15.9155 15.9155 0 0 1 0 31.831
          a 15.9155 15.9155 0 0 1 0 -31.831"
      />
      <path class="circle"
        stroke-dasharray="90, 100"
        d="M18 2.0845
          a 15.9155 15.9155 0 0 1 0 31.831
          a 15.9155 15.9155 0 0 1 0 -31.831"
      />
      <text x="18" y="20.35" class="percentage">90%</text>
      <text x="18" y="12" class="percentageLabel">Mobile</text>
    </svg>
  </div>
</div>

CSS:

.flex-wrapper {
  display: flex;
  flex-flow: row nowrap;
}

.single-chart {
  width: 33%;
  justify-content: space-around ;
}

.circular-chart {
  display: block;
  margin: 10px auto;
  max-width: 80%;
  max-height: 250px;
}

.circle-bg {
  fill: none;
  stroke: #eee;
  stroke-width: 3.8;
}

.circle {
  fill: none;
  stroke-width: 2.8;
  stroke-linecap: round;
  animation: progress 1s ease-out forwards;
}

@keyframes progress {
  0% {
    stroke-dasharray: 0 100;
  }
}

.circular-chart.orange .circle {
  stroke: #ff9f00;
}

.circular-chart.green .circle {
  stroke: #4CC790;
}

.circular-chart.blue .circle {
  stroke: #3c9ee5;
}

.percentage {
  fill: #667 ;
  font-family: sans-serif;
  font-size: 0.5em;
  text-anchor: middle;
}
.percentageLabel {
  fill: #667 ;
  font-family: sans-serif;
  font-size: 0.2em;
  text-anchor: middle;
}

Когда я пытаюсь перенести это на JS для работы в Data studio Iиспользуйте это, которое, кажется, дает мне пустой экран. (без ошибок)

Data Studio Code

function drawViz(data) {
  var height = dscc.getHeight();
  var width = dscc.getWidth();
  console.log("drawing")
  console.log("data is "+data);

  var newDiv = document.createElement('div')
newDiv.class = "flex-wrapper"
var chartDiv = document.createElement('single-chart');
chartDiv.innerText = "test"

var chartSVG = document .createElementNS("http://www.w3.org/2000/svg", "svg");
chartSVG.setAttribute("viewBox","0 0 36 36")
chartSVG.setAttributeNS(null, "class",  "circular-chart orange");
var newPath1 = document.createElementNS("http://www.w3.org/2000/svg","path");
newPath1.setAttributeNS(null, "class", "circle-bg");
newPath1.setAttributeNS(null, "d", "M18 2.0845 a 15.9155 15.9155 0 0 1 0 31.831 a 15.9155 15.9155 0 0 1 0 -31.831");
chartSVG.appendChild(newPath1);
var newPath2 = document.createElementNS("http://www.w3.org/2000/svg","path");
newPath2.setAttributeNS(null, "class", "circle");
newPath2.setAttributeNS(null, "stroke-dasharray", "30, 100");
newPath2.setAttributeNS(null, "d", "M18 2.0845 a 15.9155 15.9155 0 0 1 0 31.831 a 15.9155 15.9155 0 0 1 0 -31.831");
chartSVG.appendChild(newPath2);

var text = document.createElement("text")
text.setAttribute("x","18")
text.setAttribute("y","20.35")
text.setAttribute("class","percentage")
text.innerText = "30%"
chartSVG.appendChild(text)

chartDiv.appendChild.chartSVG
  newDiv.appendChild(chartDiv)
document.body.appendChild(newDiv)
}

// subscribe to data and style changes.
dscc.subscribeToData(drawViz, {transform: dscc.objectTransform});

Ответы [ 2 ]

1 голос
/ 28 марта 2019

В итоге я использовал альтернативную библиотеку, которая не зависит от SVG.

Я уверен, что этот метод поддерживается, но у меня не было времени копаться.

Выложу ссылку на решение, как только оно у меня появится на Github

0 голосов
/ 08 апреля 2019

Мне бы очень хотелось увидеть это на Github, когда он закончится

...