mirror of
https://github.com/acid-info/lsd.git
synced 2025-01-11 17:44:14 +00:00
fix(lsd-react): use theme's name as the cache key when generating global styles
This commit is contained in:
parent
28e42de46c
commit
6fd888078e
@ -17,7 +17,7 @@ const createThemes = () => {
|
||||
const themes = fonts.map((font) => [
|
||||
createTheme(
|
||||
{
|
||||
name: `${defaultThemes.light.name} (${font})`,
|
||||
// name: `${defaultThemes.light.name} (${font})`,
|
||||
...themeProps,
|
||||
typographyGlobal: {
|
||||
genericFontFamily: font,
|
||||
|
@ -1,4 +1,5 @@
|
||||
import { css } from '@emotion/react'
|
||||
import { createCounter } from '../../utils/counter.util'
|
||||
import { pairs } from '../../utils/object.utils'
|
||||
import { baseTheme } from './baseTheme'
|
||||
import { THEME_BREAKPOINTS, THEME_TYPOGRAPHY_VARIANTS } from './constants'
|
||||
@ -13,6 +14,9 @@ import type {
|
||||
VariantThemeProperties,
|
||||
} from './types'
|
||||
|
||||
const counter = createCounter()
|
||||
const generateName = (prefix: string) => `${prefix}-${counter()}`
|
||||
|
||||
const createTypographyStyles = (theme: CreateThemeProps, defaultTheme: Theme) =>
|
||||
pairs<TypographyVariants>(THEME_TYPOGRAPHY_VARIANTS, (variant) => ({
|
||||
...defaultTheme.typography[variant],
|
||||
@ -130,7 +134,7 @@ export const createTheme = (
|
||||
from = baseTheme,
|
||||
): Theme => {
|
||||
const theme: Theme = {
|
||||
name: props.name ?? from.name,
|
||||
name: props.name ?? generateName(from.name),
|
||||
typography: createTypographyStyles(props, from),
|
||||
typographyGlobal: createTypographyGlobalStyles(props, from),
|
||||
breakpoints: createBreakpointStyles(props, from),
|
||||
|
@ -117,7 +117,7 @@ export const createThemeGlobalStyles = (() => {
|
||||
const cache: any = {}
|
||||
|
||||
return (theme: Theme): ReturnType<typeof generateThemeGlobalStyles> => {
|
||||
const key = theme as any as string
|
||||
const key = theme.name
|
||||
|
||||
if (
|
||||
cache[key] &&
|
||||
|
Loading…
x
Reference in New Issue
Block a user