Skip to content

Commit

Permalink
fix: be more safe checking for presence of styles (#19095)
Browse files Browse the repository at this point in the history
* fix: be more safe checking for presence of styles

* svg border too

* default x and y to zero

* Fix
  • Loading branch information
pauldambra authored and Twixes committed Dec 6, 2023
1 parent c3aacf7 commit 2f54fe0
Show file tree
Hide file tree
Showing 3 changed files with 143 additions and 20 deletions.
81 changes: 78 additions & 3 deletions ee/frontend/mobile-replay/__snapshots__/transform.test.ts.snap
Original file line number Diff line number Diff line change
Expand Up @@ -157,7 +157,7 @@ exports[`replay/transform transform can convert rect with text 1`] = `
"height": 30,
"rx": "10px",
"stroke": "#ee3ee4",
"stroke-width": "4",
"stroke-width": "4px",
"width": 100,
"x": 0,
"y": 0,
Expand Down Expand Up @@ -451,12 +451,12 @@ exports[`replay/transform transform child wireframes are processed 1`] = `
"childNodes": [
{
"attributes": {
"style": "overflow:hidden;white-space:nowrap;",
"style": "position: fixed;left: 0px;top: 0px;overflow:hidden;white-space:nowrap;",
},
"childNodes": [
{
"attributes": {
"style": "overflow:hidden;white-space:nowrap;",
"style": "position: fixed;left: 0px;top: 0px;overflow:hidden;white-space:nowrap;",
},
"childNodes": [
{
Expand Down Expand Up @@ -540,6 +540,81 @@ exports[`replay/transform transform child wireframes are processed 1`] = `
]
`;

exports[`replay/transform transform omitting x and y is equivalent to setting them to 0 1`] = `
[
{
"data": {
"initialOffset": {
"left": 0,
"top": 0,
},
"node": {
"childNodes": [
{
"id": 2,
"name": "html",
"publicId": "",
"systemId": "",
"type": 1,
},
{
"attributes": {
"style": "height: 100vh; width: 100vw;",
},
"childNodes": [
{
"attributes": {},
"childNodes": [],
"id": 4,
"tagName": "head",
"type": 2,
},
{
"attributes": {
"style": "height: 100vh; width: 100vw;",
},
"childNodes": [
{
"attributes": {},
"childNodes": [
{
"attributes": {
"height": 30,
"src": "",
"style": "width: 100px;height: 30px;position: fixed;left: 0px;top: 0px;",
"width": 100,
},
"childNodes": [],
"id": 12345,
"tagName": "img",
"type": 2,
},
],
"id": 111,
"tagName": "div",
"type": 2,
},
],
"id": 5,
"tagName": "body",
"type": 2,
},
],
"id": 3,
"tagName": "html",
"type": 2,
},
],
"id": 1,
"type": 0,
},
},
"timestamp": 1,
"type": 2,
},
]
`;

exports[`replay/transform transform respect incremental ids, replace with body otherwise 1`] = `
[
{
Expand Down
20 changes: 20 additions & 0 deletions ee/frontend/mobile-replay/transform.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -346,5 +346,25 @@ describe('replay/transform', () => {
])
expect(textEvent).toMatchSnapshot()
})
test('omitting x and y is equivalent to setting them to 0', () => {
expect(
posthogEEModule.mobileReplay?.transformToWeb([
{
type: 2,
data: {
wireframes: [
{
id: 12345,
width: 100,
height: 30,
type: 'image',
},
],
},
timestamp: 1,
},
])
).toMatchSnapshot()
})
})
})
62 changes: 45 additions & 17 deletions ee/frontend/mobile-replay/wireframeStyle.ts
Original file line number Diff line number Diff line change
@@ -1,17 +1,33 @@
import { MobileStyles, wireframe } from './mobile.types'

function isNumber(candidate: unknown): candidate is number {
return typeof candidate === 'number'
}

function isString(candidate: unknown): candidate is string {
return typeof candidate === 'string'
}

function isUnitLike(candidate: unknown): candidate is string | number {
return isNumber(candidate) || (isString(candidate) && candidate.length > 0)
}

function ensureUnit(value: string | number): string {
return typeof value === 'number' ? `${value}px` : value.replace(/px$/g, '') + 'px'
return isNumber(value) ? `${value}px` : value.replace(/px$/g, '') + 'px'
}

function makeBorderStyles(wireframe: wireframe): string {
let styles = ''

if (wireframe.style?.borderWidth) {
if (!wireframe.style) {
return styles
}

if (isUnitLike(wireframe.style.borderWidth)) {
const borderWidth = ensureUnit(wireframe.style.borderWidth)
styles += `border-width: ${borderWidth};`
}
if (wireframe.style?.borderRadius) {
if (isUnitLike(wireframe.style.borderRadius)) {
const borderRadius = ensureUnit(wireframe.style.borderRadius)
styles += `border-radius: ${borderRadius};`
}
Expand All @@ -29,13 +45,17 @@ function makeBorderStyles(wireframe: wireframe): string {
export function makeSvgBorder(style: MobileStyles | undefined): Record<string, string> {
const svgBorderStyles: Record<string, string> = {}

if (style?.borderWidth) {
svgBorderStyles['stroke-width'] = style.borderWidth.toString()
if (!style) {
return svgBorderStyles
}

if (isUnitLike(style.borderWidth)) {
svgBorderStyles['stroke-width'] = ensureUnit(style.borderWidth)
}
if (style?.borderColor) {
if (style.borderColor) {
svgBorderStyles.stroke = style.borderColor
}
if (style?.borderRadius) {
if (isUnitLike(style.borderRadius)) {
svgBorderStyles.rx = ensureUnit(style.borderRadius)
}

Expand All @@ -44,19 +64,22 @@ export function makeSvgBorder(style: MobileStyles | undefined): Record<string, s

export function makePositionStyles(wireframe: wireframe): string {
let styles = ''
if (wireframe.width) {
if (isNumber(wireframe.width)) {
styles += `width: ${ensureUnit(wireframe.width)};`
}
if (wireframe.height) {
if (isNumber(wireframe.height)) {
styles += `height: ${ensureUnit(wireframe.height)};`
}
if (wireframe.x || wireframe.y) {

const posX = wireframe.x || 0
const posY = wireframe.y || 0
if (isNumber(posX) || isNumber(posY)) {
styles += `position: fixed;`
if (wireframe.x) {
styles += `left: ${ensureUnit(wireframe.x)};`
if (isNumber(posX)) {
styles += `left: ${ensureUnit(posX)};`
}
if (wireframe.y) {
styles += `top: ${ensureUnit(wireframe.y)};`
if (isNumber(posY)) {
styles += `top: ${ensureUnit(posY)};`
}
}
return styles
Expand All @@ -82,11 +105,16 @@ function makeLayoutStyles(wireframe: wireframe): string {

function makeFontStyles(wireframe: wireframe): string {
let styles = ''
if (wireframe.style?.fontSize) {

if (!wireframe.style) {
return styles
}

if (isUnitLike(wireframe.style.fontSize)) {
styles += `font-size: ${ensureUnit(wireframe.style?.fontSize)};`
}
if (wireframe.style?.fontFamily) {
styles += `font-family: ${wireframe.style?.fontFamily};`
if (wireframe.style.fontFamily) {
styles += `font-family: ${wireframe.style.fontFamily};`
}
return styles
}
Expand Down

0 comments on commit 2f54fe0

Please sign in to comment.