55 lines
1.3 KiB
TypeScript
55 lines
1.3 KiB
TypeScript
// Copyright 2022 Signal Messenger, LLC
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
/* eslint-disable no-console */
|
|
|
|
import React from 'react';
|
|
|
|
export abstract class PureComponentProfiler<
|
|
Props extends Record<string, unknown>,
|
|
State extends Record<string, unknown>,
|
|
> extends React.Component<Props, State> {
|
|
public override shouldComponentUpdate(
|
|
nextProps: Props,
|
|
nextState: State
|
|
): boolean {
|
|
console.group(`PureComponentProfiler(${this.props.id})`);
|
|
|
|
const propKeys = new Set([
|
|
...Object.keys(nextProps),
|
|
...Object.keys(this.props),
|
|
]);
|
|
|
|
const stateKeys = new Set([
|
|
...Object.keys(nextState ?? {}),
|
|
...Object.keys(this.state ?? {}),
|
|
]);
|
|
|
|
let result = false;
|
|
for (const key of propKeys) {
|
|
if (nextProps[key] !== this.props[key]) {
|
|
console.error(
|
|
`propUpdated(${key})`,
|
|
this.props[key],
|
|
'=>',
|
|
nextProps[key]
|
|
);
|
|
result = true;
|
|
}
|
|
}
|
|
for (const key of stateKeys) {
|
|
if (nextState[key] !== this.state[key]) {
|
|
console.error(
|
|
`stateUpdated(${key}):`,
|
|
this.state[key],
|
|
'=>',
|
|
nextState[key]
|
|
);
|
|
result = true;
|
|
}
|
|
}
|
|
|
|
console.groupEnd();
|
|
|
|
return result;
|
|
}
|
|
}
|