Add nested scroll support (#31)
This commit is contained in:
@@ -102,7 +102,7 @@ function buildNode(
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
let value = n.attributes[name];
|
let value = n.attributes[name];
|
||||||
value = typeof value === 'boolean' ? '' : value;
|
value = typeof value === 'boolean' || typeof value === 'number' ? '' : value;
|
||||||
// attribute names start with rr_ are internal attributes added by rrweb
|
// attribute names start with rr_ are internal attributes added by rrweb
|
||||||
if (!name.startsWith('rr_')) {
|
if (!name.startsWith('rr_')) {
|
||||||
const isTextarea = tagName === 'textarea' && name === 'value';
|
const isTextarea = tagName === 'textarea' && name === 'value';
|
||||||
@@ -220,6 +220,29 @@ export function buildNodeWithSN(
|
|||||||
return node as INode;
|
return node as INode;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function sideEffects(idNodeMap: idNodeMap) {
|
||||||
|
for(let id in idNodeMap) {
|
||||||
|
const node = idNodeMap[id];
|
||||||
|
const n = node.__sn;
|
||||||
|
if (n.type !== NodeType.Element) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
const el = node as Node as HTMLElement;
|
||||||
|
for(const name in n.attributes) {
|
||||||
|
if (!(n.attributes.hasOwnProperty(name) && name.startsWith('rr_'))) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
const value = n.attributes[name];
|
||||||
|
if (name === 'rr_scrollLeft') {
|
||||||
|
el.scrollLeft = value as number;
|
||||||
|
}
|
||||||
|
if (name === 'rr_scrollTop') {
|
||||||
|
el.scrollTop = value as number;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function rebuild(
|
function rebuild(
|
||||||
n: serializedNodeWithId,
|
n: serializedNodeWithId,
|
||||||
doc: Document,
|
doc: Document,
|
||||||
@@ -229,7 +252,9 @@ function rebuild(
|
|||||||
HACK_CSS: boolean = true,
|
HACK_CSS: boolean = true,
|
||||||
): [Node | null, idNodeMap] {
|
): [Node | null, idNodeMap] {
|
||||||
const idNodeMap: idNodeMap = {};
|
const idNodeMap: idNodeMap = {};
|
||||||
return [buildNodeWithSN(n, doc, idNodeMap, false, HACK_CSS), idNodeMap];
|
const node = buildNodeWithSN(n, doc, idNodeMap, false, HACK_CSS);
|
||||||
|
sideEffects(idNodeMap);
|
||||||
|
return [node, idNodeMap];
|
||||||
}
|
}
|
||||||
|
|
||||||
export default rebuild;
|
export default rebuild;
|
||||||
|
|||||||
@@ -269,6 +269,13 @@ function serializeNode(
|
|||||||
? 'paused'
|
? 'paused'
|
||||||
: 'played';
|
: 'played';
|
||||||
}
|
}
|
||||||
|
// scroll
|
||||||
|
if ((n as HTMLElement).scrollLeft) {
|
||||||
|
attributes.rr_scrollLeft = (n as HTMLElement).scrollLeft;
|
||||||
|
}
|
||||||
|
if ((n as HTMLElement).scrollTop) {
|
||||||
|
attributes.rr_scrollTop = (n as HTMLElement).scrollTop;
|
||||||
|
}
|
||||||
if (needBlock) {
|
if (needBlock) {
|
||||||
const { width, height } = (n as HTMLElement).getBoundingClientRect();
|
const { width, height } = (n as HTMLElement).getBoundingClientRect();
|
||||||
attributes.rr_width = `${width}px`;
|
attributes.rr_width = `${width}px`;
|
||||||
|
|||||||
@@ -20,7 +20,7 @@ export type documentTypeNode = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
export type attributes = {
|
export type attributes = {
|
||||||
[key: string]: string | boolean;
|
[key: string]: string | number | boolean;
|
||||||
};
|
};
|
||||||
export type elementNode = {
|
export type elementNode = {
|
||||||
type: NodeType.Element;
|
type: NodeType.Element;
|
||||||
|
|||||||
2
typings/types.d.ts
vendored
2
typings/types.d.ts
vendored
@@ -17,7 +17,7 @@ export declare type documentTypeNode = {
|
|||||||
systemId: string;
|
systemId: string;
|
||||||
};
|
};
|
||||||
export declare type attributes = {
|
export declare type attributes = {
|
||||||
[key: string]: string | boolean;
|
[key: string]: string | number | boolean;
|
||||||
};
|
};
|
||||||
export declare type elementNode = {
|
export declare type elementNode = {
|
||||||
type: NodeType.Element;
|
type: NodeType.Element;
|
||||||
|
|||||||
Reference in New Issue
Block a user