# Introduction Avoid having multiple `isDefined` definition across our pacakges Also avoid importing `isDefined` from `twenty-ui` which exposes a huge barrel for a such little util function ## In a nutshell Removed own `isDefined.ts` definition from `twenty-ui` `twenty-front` and `twenty-server` to move it to `twenty-shared`. Updated imports for each packages, and added explicit dependencies to `twenty-shared` if not already in place Related PR https://github.com/twentyhq/twenty/pull/9941
33 lines
959 B
TypeScript
33 lines
959 B
TypeScript
import { isNonEmptyString } from '@sniptt/guards';
|
|
|
|
import { isDefined } from 'twenty-shared';
|
|
import { PROFILING_REPORTER_DIV_ID } from '~/testing/profiling/constants/ProfilingReporterDivId';
|
|
import { ProfilingReport } from '~/testing/profiling/types/ProfilingReportByRun';
|
|
import { parseProfilingReportString } from '~/testing/profiling/utils/parseProfilingReportString';
|
|
|
|
export const getProfilingReportFromDocument = (
|
|
documentElement: Element,
|
|
): ProfilingReport | null => {
|
|
const profilingReportElement = documentElement.querySelector(
|
|
`#${PROFILING_REPORTER_DIV_ID}`,
|
|
);
|
|
|
|
if (!isDefined(profilingReportElement)) {
|
|
return null;
|
|
}
|
|
|
|
const profilingReportString = profilingReportElement.getAttribute(
|
|
'data-profiling-report',
|
|
);
|
|
|
|
if (!isNonEmptyString(profilingReportString)) {
|
|
return null;
|
|
}
|
|
|
|
const parsedProfilingReport = parseProfilingReportString(
|
|
profilingReportString,
|
|
);
|
|
|
|
return parsedProfilingReport;
|
|
};
|