Skip to content

Commit

Permalink
Work on table padding issue #95 (#104)
Browse files Browse the repository at this point in the history
* Work on table padding issue #95

Changed `getDefaultStyle` to create the element in the sandbox so it is pure (not tainted by CSS / ShadowDOM in the main document).
Never clone SCRIPT elements (that's just asking for trouble).
Removed `imagediff` package as it's not useful anymore.

* Add ability to insert the cloned node into the test

The allows inspecting the properties of the clone.

* Simplified the SVG

Removed the setting of the `top` and `left`
Set the `width` and `height` on the `foreignObject` element to the target size.
Removed setting of `width` and `height` on the `svg` element.

* Copy the size from the original object when possible

Falls back to the old `scrollWidth`/`scrollHeight` logic if the `width` and `height` aren't set in `px`.

* Revert to have `width` and `height` dimensions on SVG object.
  • Loading branch information
IDisposable committed Jan 15, 2023
2 parents a29ba3d + 8d73384 commit eeed471
Show file tree
Hide file tree
Showing 9 changed files with 175 additions and 90 deletions.
1 change: 0 additions & 1 deletion karma.conf.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@ module.exports = function(config) {
},

'test-lib/jquery/dist/jquery.js',
'node_modules/imagediff/imagediff.js',
'test-lib/tesseract-1.0.19.js',

'src/dom-to-image-more.js',
Expand Down
55 changes: 9 additions & 46 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 0 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@
"grunt-contrib-uglify": "^5.2.2",
"grunt-contrib-watch": "^1.1.0",
"grunt-karma": "^4.0.2",
"imagediff": "^1.0.8",
"js-yaml": "^4.1.0",
"karma": "^6.4.1",
"karma-chai": "^0.1.0",
Expand Down
57 changes: 41 additions & 16 deletions spec/dom-to-image-more.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@
'use strict';

const assert = global.chai.assert;
const imagediff = global.imagediff;
const domtoimage = global.domtoimage;
const Promise = global.Promise;
const BASE_URL = '/base/spec/resources/';
Expand Down Expand Up @@ -384,20 +383,31 @@
.then(done).catch(done);
});

it('should honor zero-padding table elements', function (done) {
loadTestPage(
'padding/dom-node.html',
'padding/style.css',
'padding/control-image'
)
.then(renderAndCheck)
.then(done)
.catch(done);
});

function compareToControlImage(image, tolerance) {
const control = controlImage();
if (imagediff.equal(image, control, tolerance)) {
assert.isTrue(true, 'rendered and control images should be same');
} else {
// get the data representation so we can update the control images easily
const imageUrl = getImageBase64(image, 'image/png');
const controlUrl = getImageBase64(control, 'image/png');
assert.equal(imageUrl, controlUrl, 'rendered and control images should be same');
if (imageUrl !== controlUrl) {
console.log(` image: ${image.src}`);
console.log(` imageBase64: ${imageUrl}`);
console.log(`controlBase64: ${controlUrl}`);
}

const imageUrl = getImageBase64(image, 'image/png');
const controlUrl = getImageBase64(control, 'image/png');
assert.equal(
imageUrl,
controlUrl,
'rendered and control images should be same'
);
if (imageUrl !== controlUrl) {
console.log(` image: ${image.src}`);
console.log(` imageBase64: ${imageUrl}`);
console.log(`controlBase64: ${controlUrl}`);
}
}

Expand Down Expand Up @@ -463,8 +473,13 @@
return image;
}

function cloneCatcher(clone){
clonedNode().replaceChildren(clone);
return clone;
}

function renderToPng(node) {
return domtoimage.toPng(node || domNode());
return domtoimage.toPng(node || domNode(), { onclone: cloneCatcher });
}
});

Expand All @@ -474,8 +489,14 @@
it('should parse urls', function () {
const parse = domtoimage.impl.inliner.impl.readUrls;

assert.deepEqual(parse('url("http://acme.com/file")'), ['http://acme.com/file']);
assert.deepEqual(parse('url(foo.com), url(\'bar.org\')'), ['foo.com', 'bar.org']);
assert.deepEqual(parse('url("http://acme.com/file")'), [
'http://acme.com/file',
]);
// eslint-disable-next-line quotes
assert.deepEqual(parse("url(foo.com), url('bar.org')"), [
'foo.com',
'bar.org',
]);
});

it('should ignore data urls', function () {
Expand Down Expand Up @@ -678,6 +699,10 @@
return $('#dom-node')[0];
}

function clonedNode() {
return $('#cloned-node')[0];
}

function controlImage() {
return $('#control-image')[0];
}
Expand Down
1 change: 1 addition & 0 deletions spec/resources/padding/control-image
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@

51 changes: 51 additions & 0 deletions spec/resources/padding/dom-node.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
<div id="mywrap" class="wrapper">
<style type="text/css">
.tg {
border-collapse: collapse;
border-spacing: 0;
}

.tg .tg-lqy6 {
text-align: right;
vertical-align: top
}

.tg .tg-ogn4 {
background-color: #cb0000;
text-align: right;
vertical-align: top
}

.tg .tg-zv49 {
background-color: #6200c9;
color: #ffffff;
text-align: right;
vertical-align: top
}

.wrapper {
display: inline-block;
}
</style>
<table class="tg">
<thead>
<tr>
<th class="tg-lqy6"></th>
<th class="tg-lqy6" style="padding-left: 5px"></th>
<th class="tg-ogn4">aaaaa</th>
</tr>
</thead>
<tbody>
<tr>
<td class="tg-lqy6"></td>
<td class="tg-lqy6"></td>
<td class="tg-ogn4">aaaaaa</td>
</tr>
<tr>
<td class="tg-zv49">ssssss</td>
<td class="tg-zv49">sssss</td>
<td class="tg-zv49">aaaaaaa</td>
</tr>
</tbody>
</table>
</div>
17 changes: 17 additions & 0 deletions spec/resources/padding/style.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
th,
td {
padding: 0px;
border: 2px solid #585c5c;
}

* {
box-sizing: border-box;
}

table {
border-collapse: collapse;
}

.wrapper {
display: inline-block;
}
9 changes: 7 additions & 2 deletions spec/resources/page.html
Original file line number Diff line number Diff line change
Expand Up @@ -12,11 +12,16 @@ <h1>DOM node</h1>
</div>

<div>
<h1>rendered image</h1>
<h1>Cloned node</h1>
<div id="cloned-node"></div>
</div>

<div>
<h1>Rendered image</h1>
<canvas id="canvas"></canvas>
</div>

<div>
<h1>control image</h1>
<h1>Control image</h1>
<img id="control-image" alt="What we loaded from the spec">
</div>
Loading

0 comments on commit eeed471

Please sign in to comment.