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

feat mask all text pr #94

Closed
wants to merge 23 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
23 commits
Select commit Hold shift + click to select a range
555d3fc
Feat: Add support for replaying :defined pseudo-class of custom elements
YunFeng0817 Feb 27, 2023
cef51f3
add isCustom flag to serialized elements
YunFeng0817 Mar 2, 2023
56e0bb5
Merge branch 'master' into defined-pseudo-class
YunFeng0817 Mar 4, 2023
5302912
fix code lint error
YunFeng0817 Mar 4, 2023
d5dae21
add custom element event
YunFeng0817 Mar 5, 2023
3016fb6
support for mask all and unmask by selector and class #1096
mdellanoce Jan 6, 2023
4fc4dce
apply text mask settings to inputs #1096
mdellanoce Jan 12, 2023
db8c328
remove default for unmaskTextClass #1096
mdellanoce Feb 10, 2023
726e7ca
skip mask distance if unmask is not found and maskAllText is true #1096
mdellanoce Feb 10, 2023
4ceaf2a
optimize mask/unmask rule matching #1096
mdellanoce Feb 13, 2023
f482f58
optimization for when maskAllText is false #1096
mdellanoce Apr 6, 2023
32b726b
add benchmarks for text masking #1096
mdellanoce Apr 10, 2023
5ffcb9f
Apply formatting changes
mdellanoce Apr 10, 2023
3a14f29
feat: add forked sentry tests
billyvg Jul 6, 2023
bfc4c1a
update snapshots
billyvg Jul 7, 2023
95ba6d5
Merge remote-tracking branch 'pendo-io/md-mask-enhancements-1096' int…
billyvg Jul 7, 2023
11819e7
forgot to save
billyvg Jul 7, 2023
db05c67
update tests for maskAllText
billyvg Jul 7, 2023
da60bca
Merge remote-tracking branch 'upstream/defined-pseudo-class' into fea…
billyvg Jul 7, 2023
b9b97f4
remove old sentry test
billyvg Jul 7, 2023
061689c
fix types for custom element
billyvg Jul 7, 2023
7a38121
update snapshot expectations
billyvg Jul 7, 2023
f286fb5
Apply formatting changes
billyvg Jul 7, 2023
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
5 changes: 5 additions & 0 deletions .changeset/fluffy-planes-retire.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'rrweb': patch
---

Feat: Add support for replaying :defined pseudo-class of custom elements
7 changes: 7 additions & 0 deletions .changeset/smart-ears-refuse.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
---
'rrweb-snapshot': patch
---

Feat: Add 'isCustom' flag to serialized elements.

This flag is used to indicate whether the element is a custom element or not. This is useful for replaying the :defined pseudo-class of custom elements.
9 changes: 8 additions & 1 deletion .github/workflows/ci-cd.yml
Original file line number Diff line number Diff line change
@@ -1,13 +1,20 @@
name: Tests

on: [push, pull_request]
on:
push:
branches:
- master
- release/**
pull_request:

concurrency: ${{ github.workflow }}-${{ github.ref }}

jobs:
release:
name: Tests
runs-on: ubuntu-latest
# For now, we know this will fail, so we allow failures
continue-on-error: true
steps:
- name: Checkout Repo
uses: actions/checkout@v3
Expand Down
4 changes: 4 additions & 0 deletions guide.md
Original file line number Diff line number Diff line change
Expand Up @@ -144,8 +144,11 @@ The parameter of `rrweb.record` accepts the following options.
| blockSelector | null | Use a string to configure which selector should be blocked, refer to the [privacy](#privacy) chapter |
| ignoreClass | 'rr-ignore' | Use a string or RegExp to configure which elements should be ignored, refer to the [privacy](#privacy) chapter |
| ignoreCSSAttributes | null | array of CSS attributes that should be ignored |
| maskAllText | false | mask all text content as \* |
| maskTextClass | 'rr-mask' | Use a string or RegExp to configure which elements should be masked, refer to the [privacy](#privacy) chapter |
| unmaskTextClass | null | Use a string or RegExp to configure which elements should be unmasked, refer to the [privacy](#privacy) chapter |
| maskTextSelector | null | Use a string to configure which selector should be masked, refer to the [privacy](#privacy) chapter |
| unmaskTextSelector | null | Use a string to configure which selector should be unmasked, refer to the [privacy](#privacy) chapter |
| maskAllInputs | false | mask all input content as \* |
| maskInputOptions | { password: true } | mask some kinds of input \*<br />refer to the [list](https://github.com/rrweb-io/rrweb/blob/588164aa12f1d94576f89ae0210b98f6e971c895/packages/rrweb-snapshot/src/types.ts#L77-L95) |
| maskInputFn | - | customize mask input content recording logic |
Expand All @@ -172,6 +175,7 @@ You may find some contents on the webpage which are not willing to be recorded,
- An element with the class name `.rr-block` will not be recorded. Instead, it will replay as a placeholder with the same dimension.
- An element with the class name `.rr-ignore` will not record its input events.
- All text of elements with the class name `.rr-mask` and their children will be masked.
- All text of elements with the optional unmasking class name `unmaskTextClass` and their children will be unmasked, unless any child is marked with `.rr-mask`.
- `input[type="password"]` will be masked by default.
- Mask options to mask the content in input elements.

Expand Down
12 changes: 12 additions & 0 deletions packages/rrweb-snapshot/src/rebuild.ts
Original file line number Diff line number Diff line change
Expand Up @@ -142,6 +142,18 @@ function buildNode(
if (n.isSVG) {
node = doc.createElementNS('http://www.w3.org/2000/svg', tagName);
} else {
if (
// If the tag name is a custom element name
n.isCustom &&
// If the browser supports custom elements
doc.defaultView?.customElements &&
// If the custom element hasn't been defined yet
!doc.defaultView.customElements.get(n.tagName)
)
doc.defaultView.customElements.define(
n.tagName,
class extends doc.defaultView.HTMLElement {},
);
node = doc.createElement(tagName);
}
/**
Expand Down
Loading