Skip to content

Commit

Permalink
Theme next heading font switch
Browse files Browse the repository at this point in the history
  • Loading branch information
origami-z committed May 13, 2024
1 parent 1ccb29a commit 8415c76
Show file tree
Hide file tree
Showing 11 changed files with 85 additions and 2 deletions.
11 changes: 11 additions & 0 deletions .changeset/theme-next-heading-font-core.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
---
"@salt-ds/core": minor
---

Added a new `headingFont` prop to `UNSTABLE_SaltProviderNext` with `"Open Sans"` or `"Amplitude"` option. To try it out, use

```
<UNSTABLE_SaltProviderNext headingFont="Amplitude">
```

Refer to [documentation](https://storybook.saltdesignsystem.com/?path=/docs/experimental-theme-next--docs) for more information.
7 changes: 7 additions & 0 deletions .changeset/theme-next-heading-font-theme.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
---
"@salt-ds/theme": minor
---

Supports heading font switch when using `UNSTABLE_SaltProviderNext`.

Refer to [documentation](https://storybook.saltdesignsystem.com/?path=/docs/experimental-theme-next--docs) for more information.
10 changes: 10 additions & 0 deletions .storybook/preview.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -138,6 +138,16 @@ export const globalTypes: GlobalTypes = {
title: "Corner",
},
},
headingFont: {
name: "Experimental heading font",
description: "Switch heading font to open sans / amplitude",
defaultValue: "Open Sans",
toolbar: {
icon: "beaker",
items: ["Open Sans", "Amplitude"],
title: "Heading font",
},
},
};

export const argTypes: ArgTypes = {
Expand Down
7 changes: 6 additions & 1 deletion docs/decorators/withTheme.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,10 @@ function SetBackground({ viewMode, id }: { viewMode: string; id: string }) {
}

export const withTheme: Decorator = (StoryFn, context) => {
const { density, mode, styleInjection, themeNext, corner } = context.globals;
const { density, mode, styleInjection, themeNext, corner, headingFont } =
context.globals;

console.log("withTheme", { headingFont });

Check failure on line 71 in docs/decorators/withTheme.tsx

View workflow job for this annotation

GitHub Actions / lint

Unsafe assignment of an `any` value

const Provider =
themeNext === "enable" ? UNSTABLE_SaltProviderNext : SaltProvider;
Expand Down Expand Up @@ -95,6 +98,7 @@ export const withTheme: Decorator = (StoryFn, context) => {
key={`${mode}-${styleInjection}`}
enableStyleInjection={styleInjection === "enable"}
corner={corner}

Check failure on line 100 in docs/decorators/withTheme.tsx

View workflow job for this annotation

GitHub Actions / lint

Unsafe assignment of an `any` value
headingFont={headingFont}
>
<Panel>
<StoryFn />
Expand All @@ -112,6 +116,7 @@ export const withTheme: Decorator = (StoryFn, context) => {
key={`${mode}-${styleInjection}`}
enableStyleInjection={styleInjection === "enable"}
corner={corner}
headingFont={headingFont}
>
<SetBackground viewMode={context.viewMode} id={context.id} />
<StoryFn />
Expand Down
19 changes: 18 additions & 1 deletion packages/core/src/salt-provider/SaltProvider.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ import {
StyleInjectionProvider,
} from "@salt-ds/styles";
import { UNSTABLE_Corner } from "../theme/Corner";
import { UNSTABLE_HeadingFont } from "../theme/HeadingFont";

export const DEFAULT_DENSITY = "medium";

Expand All @@ -33,13 +34,15 @@ const UNSTABLE_ADDITIONAL_THEME_NAME = "salt-theme-next";

const DEFAULT_MODE = "light";
const DEFAULT_CORNER: UNSTABLE_Corner = "sharp";
const DEFAULT_HEADING_FONT: UNSTABLE_HeadingFont = "Open Sans";
export interface ThemeContextProps {
theme: ThemeName;
mode: Mode;
window?: WindowContextType;
/** Only available when using SaltProviderNext. */
themeNext: boolean;
UNSTABLE_corner: UNSTABLE_Corner;
UNSTABLE_headingFont: UNSTABLE_HeadingFont;
}

export const DensityContext = createContext<Density>(DEFAULT_DENSITY);
Expand All @@ -49,6 +52,7 @@ export const ThemeContext = createContext<ThemeContextProps>({
mode: DEFAULT_MODE,
themeNext: false,
UNSTABLE_corner: DEFAULT_CORNER,
UNSTABLE_headingFont: DEFAULT_HEADING_FONT,
});

export const BreakpointContext =
Expand Down Expand Up @@ -83,6 +87,7 @@ const createThemedChildren = ({
applyClassesTo,
themeNext,
corner,
headingFont,
}: {
children: ReactNode;
themeName: ThemeName;
Expand All @@ -94,6 +99,7 @@ const createThemedChildren = ({
const themeNames = getThemeNames(themeName, themeNext);
const themeNextProps = {
"data-corner": corner,
"data-heading-font": headingFont,
};
if (applyClassesTo === "root") {
return children;
Expand Down Expand Up @@ -174,6 +180,7 @@ function InternalSaltProvider({
breakpoints: breakpointsProp,
themeNext,
corner: cornerProp,
headingFont: headingFontProp,
}: Omit<
SaltProviderProps & ThemeNextProps & UNSTABLE_SaltProviderNextProps,
"enableStyleInjection"
Expand All @@ -184,6 +191,7 @@ function InternalSaltProvider({
mode: inheritedMode,
window: inheritedWindow,
UNSTABLE_corner: inheritedCorner,
UNSTABLE_headingFont: inheritedHeadingFont,
} = useContext(ThemeContext);

const isRootProvider = inheritedTheme === undefined || inheritedTheme === "";
Expand All @@ -193,6 +201,8 @@ function InternalSaltProvider({
const mode = modeProp ?? inheritedMode;
const breakpoints = breakpointsProp ?? DEFAULT_BREAKPOINTS;
const corner = cornerProp ?? inheritedCorner ?? DEFAULT_CORNER;
const headingFont =
headingFontProp ?? inheritedHeadingFont ?? DEFAULT_HEADING_FONT;

const applyClassesTo =
applyClassesToProp ?? (isRootProvider ? "root" : "scope");
Expand All @@ -211,8 +221,9 @@ function InternalSaltProvider({
window: targetWindow,
themeNext: Boolean(themeNext),
UNSTABLE_corner: corner,
UNSTABLE_headingFont: headingFont,
}),
[themeName, mode, targetWindow, themeNext, corner]
[themeName, mode, targetWindow, themeNext, corner, headingFont]
);

const themedChildren = createThemedChildren({
Expand All @@ -223,6 +234,7 @@ function InternalSaltProvider({
applyClassesTo,
themeNext,
corner: corner,
headingFont,
});

useIsomorphicLayoutEffect(() => {
Expand All @@ -238,6 +250,8 @@ function InternalSaltProvider({
targetWindow.document.documentElement.dataset.mode = mode;
if (themeNext) {
targetWindow.document.documentElement.dataset.corner = corner;
targetWindow.document.documentElement.dataset.headingFont =
headingFont;
}
} else {
console.warn(
Expand All @@ -255,6 +269,7 @@ function InternalSaltProvider({
targetWindow.document.documentElement.dataset.mode = undefined;
if (themeNext) {
delete targetWindow.document.documentElement.dataset.corner;
delete targetWindow.document.documentElement.dataset.headingFont;
}
}
};
Expand All @@ -267,6 +282,7 @@ function InternalSaltProvider({
inheritedWindow,
themeNext,
corner,
headingFont,
]);

const matchedBreakpoints = useMatchedBreakpoints(breakpoints);
Expand Down Expand Up @@ -303,6 +319,7 @@ export function SaltProvider({

interface UNSTABLE_SaltProviderNextAdditionalProps {
corner?: UNSTABLE_Corner;
headingFont?: UNSTABLE_HeadingFont;
}

export type UNSTABLE_SaltProviderNextProps = SaltProviderProps &
Expand Down
3 changes: 3 additions & 0 deletions packages/core/src/theme/HeadingFont.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
export const UNSTABLE_HeadingFontValues = ["Open Sans", "Amplitude"] as const;

export type UNSTABLE_HeadingFont = (typeof UNSTABLE_HeadingFontValues)[number];
1 change: 1 addition & 0 deletions packages/core/src/theme/index.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
export * from "./Density";
export * from "./HeadingFont";
export * from "./Theme";
export * from "./Mode";
export * from "./Corner";
20 changes: 20 additions & 0 deletions packages/core/stories/salt-provider/salt-provider-next.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -111,3 +111,23 @@ These components use `--salt-palette-corner-strongest` token

- Avatar
- Badge

## Heading font switch

A new `headingFont` prop is added to switch display and heading font family between Open Sans and Amplitude.

```
<UNSTABLE_SaltProviderNext headingFont="Amplitude">
```

You'll need to install Amplitude font to your application to make sure every user will see the font correctly, e.g.,

```css
@font-face {
font-family: "Amplitude";
font-style: normal;
font-display: swap;
font-weight: 400;
src: url("PATH/TO/FONT.woff2") format("woff2");
}
```
1 change: 1 addition & 0 deletions packages/theme/css/foundations/typography.css
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
.salt-theme {
--salt-typography-fontFamily-openSans: "Open Sans";
--salt-typography-fontFamily-amplitude: "Amplitude";
--salt-typography-fontFamily-ptMono: "PT Mono";

--salt-typography-fontWeight-light: 300;
Expand Down
7 changes: 7 additions & 0 deletions packages/theme/css/palette/text-next.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
.salt-theme-next.salt-theme[data-heading-font="Open Sans"] {
--salt-palette-text-fontFamily-heading: var(--salt-typography-fontFamily-openSans);
}

.salt-theme-next.salt-theme[data-heading-font="Amplitude"] {
--salt-palette-text-fontFamily-heading: var(--salt-typography-fontFamily-amplitude);
}
1 change: 1 addition & 0 deletions packages/theme/css/theme-next.css
Original file line number Diff line number Diff line change
@@ -1,2 +1,3 @@
@import url(foundations/curve-next.css);
@import url(palette/corner-next.css);
@import url(palette/text-next.css);

0 comments on commit 8415c76

Please sign in to comment.