1

I can't seem to find a way to convert the repeat-linear-gradient to a base64 image format.

background-image: repeating-linear-gradient(-45deg, transparent, transparent 5px, white 5px, white 10px);

My problem is I want to print an HTML page with html2canvas and jsPDF but since html2canvas doesn't support support repeat-linear-gradient, I would like to know if there is a way to convert the value to base64.

Also, since the background image is rendered by the gantt-chart library, I can't change how it is set

Het Pandya
  • 82
  • 1
  • 6
henok
  • 864
  • 5
  • 12
  • https://stackoverflow.com/questions/56398519/how-to-make-a-repeating-canvasgradient though the biggest problem would be parsing the CSS value. Does your viz-library produce a standard format? – Kaiido Jul 24 '20 at 03:02
  • updated my answer with a dynamic solution – Temani Afif Jul 24 '20 at 13:10
  • @Kalido no, but i already have a way to parse the css but the problem is changing the format – henok Jul 28 '20 at 09:30

1 Answers1

0

Since it's a repeating gradient, you can identify the smallest portion that you can export as image and that will allow you to have the same background by repeating this image.

You are dealing with +-45deg and the last color stop is 10px so the smallest portion is 10px*sqrt(2) = 14.14px for the height and width:

.box {
  height: 14.14px;
  width: 14.14px;
  background: repeating-linear-gradient(-45deg, transparent, transparent 5px, blue 5px, blue 10px);
}
<div class="box"></div>

You save this as an image and you use any online tool that convert a png to base64:

.box {
  height: 100px;
  margin: 5px;
  background: url('');
}
<div class="box"></div>

<div class="box" style="background:repeating-linear-gradient(-45deg, transparent, transparent 5px, blue 5px, blue 10px)"></div>

For a dynamic solution I will consider the code used in this previous answer

var box = document.querySelector(".box");

domtoimage.toPng(box)
  .then(function(dataUrl) {
    console.log(dataUrl)
    var image = new Image();
    image.onload = function() {
        document.body.appendChild(image);
    };
    image.src = dataUrl;
  })
.box {
  height: 100px;
  margin:5px;
  background: repeating-linear-gradient(-45deg, transparent, transparent 5px, blue 5px, blue 10px);
}
<script type="text/javascript" src="https://css-challenges.com/wp-content/themes/ronneby_child/js/dom-to-image.js"></script>

<div class="box"></div>

Also like this:

var box = document.querySelector(".box");

domtoimage.toPng(box)
  .then(function(dataUrl) {
    console.log(dataUrl);
    document.querySelector(".alt").style.background='url('+dataUrl+')';
  })
.box {
  height: 14.14px;
  width: 14.14px;
  background: repeating-linear-gradient(-45deg, transparent, transparent 5px, blue 5px, blue 10px);
}

.alt {
  height:100px;
  margin:5px;
}
<script type="text/javascript" src="https://css-challenges.com/wp-content/themes/ronneby_child/js/dom-to-image.js"></script>

<div class="box"></div>

<div class="alt"></div>
Temani Afif
  • 245,468
  • 26
  • 309
  • 415
  • 1
    "You save this as an image and you use any online tool that convert a png to base64". I think that if they could do it, they wouldn't have their current problem to begin with. They are asking for a way to do it from the page itself, dynamically. – Kaiido Jul 24 '20 at 03:01
  • @Kaiido added a dynamic solution – Temani Afif Jul 24 '20 at 13:09
  • @Temani thanks this works. but would've loved it if there was a native way to do it without loading up another library :) – henok Jul 28 '20 at 12:22
  • 1
    @henokg you can always dig into how the library works (https://github.com/tsayen/dom-to-image#how-it-works) and try to write a minimal code that works for your case ;) (PS: don't forget to also upvote the answer if you found it useful :) ) – Temani Afif Jul 28 '20 at 12:31