fix: merge tti components, use css file
This commit is contained in:
parent
fb7e1c64fd
commit
9bc373d87a
2 changed files with 64 additions and 40 deletions
23
src/plugins/startupTimings/StartupTimingPage.css
Normal file
23
src/plugins/startupTimings/StartupTimingPage.css
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
.vc-startuptimings-server-trace {
|
||||||
|
color: var(--header-primary);
|
||||||
|
user-select: text;
|
||||||
|
}
|
||||||
|
|
||||||
|
.vc-startuptimings-grid {
|
||||||
|
color: var(--header-primary);
|
||||||
|
display: grid;
|
||||||
|
gap: 2px 10px;
|
||||||
|
user-select: text;
|
||||||
|
}
|
||||||
|
|
||||||
|
.vc-startuptimings-4-cols {
|
||||||
|
grid-template-columns: repeat(3, auto) 1fr;
|
||||||
|
}
|
||||||
|
|
||||||
|
.vc-startuptimings-3-cols {
|
||||||
|
grid-template-columns: repeat(2, auto) 1fr;
|
||||||
|
}
|
||||||
|
|
||||||
|
.vc-startuptimings-2-cols {
|
||||||
|
grid-template-columns: auto 1fr;
|
||||||
|
}
|
|
@ -16,6 +16,9 @@
|
||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
import "./StartupTimingPage.css";
|
||||||
|
|
||||||
|
import { classNameFactory } from "@api/Styles";
|
||||||
import ErrorBoundary from "@components/ErrorBoundary";
|
import ErrorBoundary from "@components/ErrorBoundary";
|
||||||
import { Flex } from "@components/Flex";
|
import { Flex } from "@components/Flex";
|
||||||
import { Margins } from "@utils/margins";
|
import { Margins } from "@utils/margins";
|
||||||
|
@ -23,6 +26,9 @@ import { classes } from "@utils/misc";
|
||||||
import { findByPropsLazy } from "@webpack";
|
import { findByPropsLazy } from "@webpack";
|
||||||
import { Forms, React } from "@webpack/common";
|
import { Forms, React } from "@webpack/common";
|
||||||
|
|
||||||
|
|
||||||
|
export const cl = classNameFactory("vc-startuptimings-");
|
||||||
|
|
||||||
interface ITTITrackerEvent {
|
interface ITTITrackerEvent {
|
||||||
emoji: string;
|
emoji: string;
|
||||||
name: string;
|
name: string;
|
||||||
|
@ -109,11 +115,11 @@ function TimingSection({ title, logs, traceEnd }: TimingSectionProps) {
|
||||||
<Forms.FormSection title={title} tag="h1">
|
<Forms.FormSection title={title} tag="h1">
|
||||||
<code>
|
<code>
|
||||||
{traceEnd && (
|
{traceEnd && (
|
||||||
<div style={{ color: "var(--header-primary)", marginBottom: 5, userSelect: "text" }}>
|
<div className={cl("server-trace")} style={{ marginBottom: 5 }}>
|
||||||
Trace ended at: {(new Date(traceEnd)).toTimeString()}
|
Trace ended at: {(new Date(traceEnd)).toTimeString()}
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
<div style={{ color: "var(--header-primary)", display: "grid", gridTemplateColumns: "repeat(3, auto) 1fr", gap: "2px 10px", userSelect: "text" }}>
|
<div className={classes(cl("grid"), cl("4-cols"))}>
|
||||||
<span>Start</span>
|
<span>Start</span>
|
||||||
<span>Interval</span>
|
<span>Interval</span>
|
||||||
<span>Delta</span>
|
<span>Delta</span>
|
||||||
|
@ -137,25 +143,25 @@ function ServerTrace({ trace }: ServerTraceProps) {
|
||||||
return (
|
return (
|
||||||
<Forms.FormSection title="Server Trace" tag="h2">
|
<Forms.FormSection title="Server Trace" tag="h2">
|
||||||
<code>
|
<code>
|
||||||
<Flex flexDirection="column" style={{ color: "var(--header-primary)", gap: 5, userSelect: "text" }}>
|
<Flex flexDirection="column" className={cl("server-trace")} style={{ gap: 5 }}>
|
||||||
{lines.map(line => (
|
{lines.map(line => (
|
||||||
<span>{line}</span>
|
<span>{line}</span>
|
||||||
))}
|
))}
|
||||||
</Flex>
|
</Flex>
|
||||||
</code>
|
</code>
|
||||||
</Forms.FormSection>
|
</Forms.FormSection >
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
function TTIAnalytics() {
|
function TTIAnalytics() {
|
||||||
const analytics = TTITracker.serializeTTITracker();
|
const analytics = TTITracker.serializeTTITracker();
|
||||||
const filteredAnalytics = Object.entries(analytics).filter(([key, value]) => !/_start$|_end$/.test(key) && value !== null && value !== undefined);
|
const filteredAnalytics = Object.entries(analytics).filter(([key, value]) => value != null && !/_start$|_end$/.test(key));
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<ErrorBoundary>
|
<ErrorBoundary>
|
||||||
<Forms.FormSection title="TTI Analytics" tag="h2">
|
<Forms.FormSection title="TTI Analytics" tag="h2">
|
||||||
<code>
|
<code>
|
||||||
<div style={{ color: "var(--header-primary)", display: "grid", gridTemplateColumns: "auto 1fr", gap: "2px 10px", userSelect: "text" }}>
|
<div className={classes(cl("grid"), cl("2-cols"))}>
|
||||||
{filteredAnalytics.map(([key, value]) => (
|
{filteredAnalytics.map(([key, value]) => (
|
||||||
<React.Fragment>
|
<React.Fragment>
|
||||||
<span><pre>{key}</pre></span>
|
<span><pre>{key}</pre></span>
|
||||||
|
@ -169,45 +175,26 @@ function TTIAnalytics() {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
function TTITimings() {
|
interface TTITimingsProps {
|
||||||
const records: [string, ITTITrackerEvent][] = (Object.entries(TTITracker) as [string, ITTITrackerEvent][])
|
records: [string, ITTITrackerEvent][];
|
||||||
.filter(([, value]) => value instanceof Object && value.hasData?.()) as any;
|
title: string;
|
||||||
|
type: "registered" | "unregistered";
|
||||||
|
}
|
||||||
|
|
||||||
|
function TTITimings({ records, title, type }: TTITimingsProps) {
|
||||||
|
const isRegistered = type === "registered";
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<ErrorBoundary>
|
<ErrorBoundary>
|
||||||
<Forms.FormSection title="Registered TTI Timings" tag="h2">
|
<Forms.FormSection title={title} tag="h2">
|
||||||
<code>
|
<code>
|
||||||
<div style={{ color: "var(--header-primary)", display: "grid", gridTemplateColumns: "repeat(2, auto) 1fr", gap: "2px 10px", userSelect: "text" }}>
|
<div className={classes(cl("grid"), cl(isRegistered ? "3-cols" : "2-cols"))}>
|
||||||
<span>Duration</span>
|
{isRegistered && <span>Duration</span>}
|
||||||
<span>Key</span>
|
<span>Key</span>
|
||||||
<span style={{ marginBottom: 5 }}>Event</span>
|
<span style={{ marginBottom: 5 }}>Event</span>
|
||||||
{records.map(([key, event]) => (
|
{records.map(([key, event]) => (
|
||||||
<React.Fragment>
|
<React.Fragment key={key}>
|
||||||
<span><pre>{event.end - event.start}ms</pre></span>
|
{isRegistered && <span><pre>{event.end - event.start}ms</pre></span>}
|
||||||
<span><pre>{key}</pre></span>
|
|
||||||
<span><pre>{event.emoji} {event.name}</pre></span>
|
|
||||||
</React.Fragment>
|
|
||||||
))}
|
|
||||||
</div>
|
|
||||||
</code>
|
|
||||||
</Forms.FormSection>
|
|
||||||
</ErrorBoundary>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
function UnregisteredTimings() {
|
|
||||||
const records: [string, ITTITrackerEvent][] = (Object.entries(TTITracker) as [string, ITTITrackerEvent][])
|
|
||||||
.filter(([, value]) => value instanceof Object && value.hasData && !value.hasData()) as any;
|
|
||||||
|
|
||||||
return (
|
|
||||||
<ErrorBoundary>
|
|
||||||
<Forms.FormSection title="Unregistered TTI Timings" tag="h2">
|
|
||||||
<code>
|
|
||||||
<div style={{ color: "var(--header-primary)", display: "grid", gridTemplateColumns: "auto 1fr", gap: "2px 10px", userSelect: "text" }}>
|
|
||||||
<span>Key</span>
|
|
||||||
<span>Name</span>
|
|
||||||
{records.map(([key, event]) => (
|
|
||||||
<React.Fragment>
|
|
||||||
<span><pre>{key}</pre></span>
|
<span><pre>{key}</pre></span>
|
||||||
<span><pre>{event.emoji} {event.name}</pre></span>
|
<span><pre>{event.emoji} {event.name}</pre></span>
|
||||||
</React.Fragment>
|
</React.Fragment>
|
||||||
|
@ -224,6 +211,12 @@ function StartupTimingPage() {
|
||||||
|
|
||||||
const serverTrace = AppStartPerformance.logGroups.find(g => g.serverTrace)?.serverTrace;
|
const serverTrace = AppStartPerformance.logGroups.find(g => g.serverTrace)?.serverTrace;
|
||||||
|
|
||||||
|
const registeredTTITimings: [string, ITTITrackerEvent][] = (Object.entries(TTITracker))
|
||||||
|
.filter(([, value]) => value?.hasData?.());
|
||||||
|
|
||||||
|
const unregisteredTTITimings: [string, ITTITrackerEvent][] = (Object.entries(TTITracker))
|
||||||
|
.filter(([, value]) => value?.hasData && !value.hasData());
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<React.Fragment>
|
<React.Fragment>
|
||||||
<TimingSection
|
<TimingSection
|
||||||
|
@ -239,10 +232,18 @@ function StartupTimingPage() {
|
||||||
<TTIAnalytics />
|
<TTIAnalytics />
|
||||||
<Forms.FormDivider className={classes(Margins.top16, Margins.bottom16)} />
|
<Forms.FormDivider className={classes(Margins.top16, Margins.bottom16)} />
|
||||||
|
|
||||||
<TTITimings />
|
<TTITimings
|
||||||
|
title="Registered TTI Timings"
|
||||||
|
records={registeredTTITimings}
|
||||||
|
type="registered"
|
||||||
|
/>
|
||||||
<Forms.FormDivider className={classes(Margins.top16, Margins.bottom16)} />
|
<Forms.FormDivider className={classes(Margins.top16, Margins.bottom16)} />
|
||||||
|
|
||||||
<UnregisteredTimings />
|
<TTITimings
|
||||||
|
title="Unregistered TTI Timings"
|
||||||
|
records={unregisteredTTITimings}
|
||||||
|
type="unregistered"
|
||||||
|
/>
|
||||||
</React.Fragment>
|
</React.Fragment>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue