From 1be67387157e9e6d6f9249d22cc07902ef8494d5 Mon Sep 17 00:00:00 2001 From: Lewis Crichton Date: Sun, 10 Sep 2023 14:23:19 +0100 Subject: [PATCH] perf: memoize relatively intensively computed values --- .../components/SettingColorComponent.tsx | 6 +++--- .../components/SettingRangeComponent.tsx | 16 ++++++++++------ .../components/SettingSelectComponent.tsx | 6 +++--- 3 files changed, 16 insertions(+), 12 deletions(-) diff --git a/src/components/ThemeSettings/components/SettingColorComponent.tsx b/src/components/ThemeSettings/components/SettingColorComponent.tsx index 9b2befc0a..bec185e44 100644 --- a/src/components/ThemeSettings/components/SettingColorComponent.tsx +++ b/src/components/ThemeSettings/components/SettingColorComponent.tsx @@ -9,7 +9,7 @@ import "./colorStyles.css"; import { classNameFactory } from "@api/Styles"; import { LazyComponent } from "@utils/react"; import { find, findByCodeLazy } from "@webpack"; -import { Forms, Popout, useState } from "@webpack/common"; +import { Forms, Popout, useMemo, useState } from "@webpack/common"; interface ColorPickerProps { value: number | null; @@ -69,14 +69,14 @@ export function SettingColorComponent({ label, name, themeSettings }: Props) { themeSettings[name] = corrected; } - const normalizedValue = TinyColor(value).toHex(); + const normalizedValue = useMemo(() => parseInt(TinyColor(value).toHex(), 16), [value]); return ( {label} diff --git a/src/components/ThemeSettings/components/SettingRangeComponent.tsx b/src/components/ThemeSettings/components/SettingRangeComponent.tsx index ac2746824..6bb15ff8b 100644 --- a/src/components/ThemeSettings/components/SettingRangeComponent.tsx +++ b/src/components/ThemeSettings/components/SettingRangeComponent.tsx @@ -4,7 +4,7 @@ * SPDX-License-Identifier: GPL-3.0-or-later */ -import { Forms, Slider, useState } from "@webpack/common"; +import { Forms, Slider, useMemo, useState } from "@webpack/common"; interface Props { label: string; @@ -27,12 +27,16 @@ export function SettingRangeComponent({ label, name, default: def, min, max, ste themeSettings[name] = corrected; } - const markers: number[] = []; + const markers = useMemo(() => { + const markers: number[] = []; - // defaults taken from https://github.com/openstyles/stylus/wiki/Writing-UserCSS#default-value - for (let i = (min ?? 0); i <= (max ?? 10); i += (step ?? 1)) { - markers.push(i); - } + // defaults taken from https://github.com/openstyles/stylus/wiki/Writing-UserCSS#default-value + for (let i = (min ?? 0); i <= (max ?? 10); i += (step ?? 1)) { + markers.push(i); + } + + return markers; + }, [min, max, step]); return ( diff --git a/src/components/ThemeSettings/components/SettingSelectComponent.tsx b/src/components/ThemeSettings/components/SettingSelectComponent.tsx index 5e20a958b..07085dc3e 100644 --- a/src/components/ThemeSettings/components/SettingSelectComponent.tsx +++ b/src/components/ThemeSettings/components/SettingSelectComponent.tsx @@ -5,7 +5,7 @@ */ import { identity } from "@utils/misc"; -import { ComponentTypes, Forms, Select, useState } from "@webpack/common"; +import { ComponentTypes, Forms, Select, useMemo, useState } from "@webpack/common"; interface Props { label: string; @@ -28,14 +28,14 @@ export function SettingSelectComponent({ label, name, options, default: def, the themeSettings[name] = value; } - const opts = options.map(option => ({ + const opts = useMemo(() => options.map(option => ({ disabled: false, key: option.name, value: option.value, default: def === option.name, label: option.label - } as ComponentTypes.SelectOption)); + } satisfies ComponentTypes.SelectOption)), [options, def]); return (