Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add option to filter style properties #200

Merged
merged 2 commits into from
Jan 16, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
15 changes: 14 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ var domtoimage = require('dom-to-image-more');
## Usage

All the top level functions accept DOM node and rendering options, and return promises,
which are fulfilled with corresponding data URLs.
which are fulfilled with corresponding data URLs.
Get a PNG image base64-encoded data URL and display right away:

```javascript
Expand Down Expand Up @@ -168,6 +168,19 @@ A function taking DOM node as argument. Should return true if passed node should
included in the output (excluding node means excluding it's children as well). Not called
on the root node.

#### filterStyles

A function taking style propertie name as argument. Should return true if passed propertie should be
included in the output

Sample use:

```
filterStyles(node, propertyName) {
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

looks like the first parameter node is not passed here. Even though the issue being fix does not require it, I think it's better to include just in case. WDYT?
Or maybe let's fix the README

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice catch @NogaMan ... I think we should add the node as a parameter

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

OK, I'll make the change

return !propertyName.startssWith('--'); // to filter out CSS variables
}
```

#### adjustClonedNode

A function that will be invoked on each node as they are cloned. Useful to adjust nodes in
Expand Down
16 changes: 16 additions & 0 deletions spec/dom-to-image-more.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,22 @@
.catch(done);
});

it('should handle filterStyles', function (done) {
function filterStyles(node, propertyName) {
return propertyName !== 'background-color';
}

loadTestPage(
'filterStyles/dom-node.html',
'filterStyles/style.css',
'filterStyles/control-image'
)
.then(() => renderToPng(domNode(), { filterStyles: filterStyles }))
.then(check)
.then(done)
.catch(done);
});

it('should render to svg', function (done) {
loadTestPage(
'small/dom-node.html',
Expand Down
1 change: 1 addition & 0 deletions spec/resources/filterStyles/control-image
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@

2 changes: 2 additions & 0 deletions spec/resources/filterStyles/dom-node.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
<div class="rect1">15</div>
<div class="rect2">22</div>
15 changes: 15 additions & 0 deletions spec/resources/filterStyles/style.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
#dom-node {
width: 100px;
}

.rect1 {
height: 50px;
background-color: green;
font-size: x-large;
}

.rect2 {
height: 50px;
background-color: red;
font-size: x-large;
}
9 changes: 9 additions & 0 deletions src/dom-to-image-more.js
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,8 @@
corsImg: undefined,
// Callback for adjustClonedNode eventing (to allow adjusting clone's properties)
adjustClonedNode: undefined,
// Callback to filter style properties to be included in the output
filterStyles: undefined,
};

const domtoimage = {
Expand Down Expand Up @@ -89,6 +91,7 @@
* - @param {Object} headers - eg: { "Content-Type", "application/json;charset=UTF-8" }
* - @param {Object} data - post payload
* @param {Function} options.adjustClonedNode - callback for adjustClonedNode eventing (to allow adjusting clone's properties)
* @param {Function} options.filterStyles - Should return true if passed propertyName should be included in the output
* @return {Promise} - A promise that is fulfilled with a SVG image data URL
* */
function toSvg(node, options) {
Expand Down Expand Up @@ -1272,6 +1275,12 @@
const targetStyle = targetElement.style;

util.asArray(sourceComputedStyles).forEach(function (name) {
if (options.filterStyles) {
if (!options.filterStyles(sourceElement, name)) {
return;
}
}

const sourceValue = sourceComputedStyles.getPropertyValue(name);
const defaultValue = defaultStyle[name];
const parentValue = parentComputedStyles
Expand Down
Loading