@wise/components-theming 0.5.3 → 0.6.1-beta-76ef568819.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/index.d.ts +4 -3
- package/dist/cjs/index.js +21 -14
- package/dist/cjs/index.js.map +1 -1
- package/dist/es/index.d.ts +4 -3
- package/dist/es/index.js +21 -14
- package/dist/es/index.js.map +1 -1
- package/package.json +6 -3
- package/src/ThemeProvider.tsx +19 -12
- package/src/const.ts +1 -1
- package/src/helpers.ts +12 -4
- package/src/useTheme.spec.tsx +38 -19
- package/src/useTheme.ts +8 -4
package/dist/cjs/index.d.ts
CHANGED
|
@@ -6,7 +6,8 @@ declare const baseThemes: readonly [
|
|
|
6
6
|
"personal"
|
|
7
7
|
];
|
|
8
8
|
declare const extraThemes: readonly [
|
|
9
|
-
"forest-green"
|
|
9
|
+
"forest-green",
|
|
10
|
+
"bright-green"
|
|
10
11
|
];
|
|
11
12
|
declare const screenModes: readonly [
|
|
12
13
|
"light",
|
|
@@ -21,8 +22,8 @@ type Theming = {
|
|
|
21
22
|
theme?: ComponentTheme | BaseTheme | ExtraTheme;
|
|
22
23
|
screenMode?: ScreenMode;
|
|
23
24
|
};
|
|
24
|
-
declare const isThemeModern: (theme: ComponentTheme | BaseTheme | ExtraTheme) => theme is "personal" | "forest-green";
|
|
25
|
-
declare const isExtraTheme: (theme: ComponentTheme | BaseTheme | ExtraTheme) => theme is "forest-green";
|
|
25
|
+
declare const isThemeModern: (theme: ComponentTheme | BaseTheme | ExtraTheme) => theme is "personal" | "forest-green" | "bright-green";
|
|
26
|
+
declare const isExtraTheme: (theme: ComponentTheme | BaseTheme | ExtraTheme) => theme is "forest-green" | "bright-green";
|
|
26
27
|
declare const isScreenModeDark: (theme: ComponentTheme | BaseTheme | ExtraTheme, screenMode: ScreenMode) => screenMode is "dark";
|
|
27
28
|
declare const getThemeClassName: (theme: ComponentTheme | BaseTheme | ExtraTheme, screenMode: ScreenMode) => string;
|
|
28
29
|
type ThemeProviderProps = PropsWithChildren<Theming>;
|
package/dist/cjs/index.js
CHANGED
|
@@ -5,7 +5,7 @@ var react = require('react');
|
|
|
5
5
|
|
|
6
6
|
// TODO: Change 'light' with 'legacy' in the future
|
|
7
7
|
var baseThemes = ['light', 'personal'];
|
|
8
|
-
var extraThemes = ['forest-green'];
|
|
8
|
+
var extraThemes = ['forest-green', 'bright-green'];
|
|
9
9
|
var screenModes = ['light', 'dark'];
|
|
10
10
|
var modernThemes = [baseThemes[1]].concat(extraThemes);
|
|
11
11
|
var DEFAULT_BASE_THEME = 'light';
|
|
@@ -36,11 +36,18 @@ var getThemeClassName = function getThemeClassName(theme, screenMode) {
|
|
|
36
36
|
return classes;
|
|
37
37
|
};
|
|
38
38
|
|
|
39
|
+
var FALLBACK_VALUES = {
|
|
40
|
+
theme: DEFAULT_BASE_THEME,
|
|
41
|
+
screenMode: DEFAULT_SCREEN_MODE
|
|
42
|
+
};
|
|
39
43
|
var useTheme = function useTheme() {
|
|
40
|
-
var _useContext
|
|
44
|
+
var _useContext;
|
|
45
|
+
|
|
46
|
+
var _ref = (_useContext = react.useContext(ThemeContext)) !== null && _useContext !== void 0 ? _useContext : FALLBACK_VALUES,
|
|
47
|
+
theme = _ref.theme,
|
|
48
|
+
contextScreenMode = _ref.screenMode;
|
|
41
49
|
|
|
42
|
-
var
|
|
43
|
-
var screenMode = theme !== DEFAULT_BASE_THEME ? (_useContext$screenMod = react.useContext(ThemeContext).screenMode) !== null && _useContext$screenMod !== void 0 ? _useContext$screenMod : DEFAULT_SCREEN_MODE : DEFAULT_SCREEN_MODE;
|
|
50
|
+
var screenMode = theme === DEFAULT_BASE_THEME ? DEFAULT_SCREEN_MODE : contextScreenMode;
|
|
44
51
|
return react.useMemo(function () {
|
|
45
52
|
return {
|
|
46
53
|
theme: theme,
|
|
@@ -64,17 +71,14 @@ var ThemedChildren = function ThemedChildren(_ref) {
|
|
|
64
71
|
});
|
|
65
72
|
};
|
|
66
73
|
|
|
67
|
-
var ThemeContext = /*#__PURE__*/react.createContext(
|
|
68
|
-
theme: undefined,
|
|
69
|
-
screenMode: undefined
|
|
70
|
-
});
|
|
74
|
+
var ThemeContext = /*#__PURE__*/react.createContext(undefined);
|
|
71
75
|
var ThemeProvider = function ThemeProvider(_ref) {
|
|
72
76
|
var _ref$theme = _ref.theme,
|
|
73
77
|
theme = _ref$theme === void 0 ? DEFAULT_BASE_THEME : _ref$theme,
|
|
74
78
|
_ref$screenMode = _ref.screenMode,
|
|
75
79
|
screenMode = _ref$screenMode === void 0 ? DEFAULT_SCREEN_MODE : _ref$screenMode,
|
|
76
80
|
children = _ref.children;
|
|
77
|
-
var isRootProvider = react.useContext(ThemeContext)
|
|
81
|
+
var isRootProvider = react.useContext(ThemeContext) === undefined; // RegEx to check for `np-theme-` class name
|
|
78
82
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
79
83
|
|
|
80
84
|
var themeClass = new RegExp(/\bnp-theme-[a-z-]+\b/, 'g'); // useEffect hook used to apply the theme class to the HTML element
|
|
@@ -84,19 +88,22 @@ var ThemeProvider = function ThemeProvider(_ref) {
|
|
|
84
88
|
var _document$documentEle;
|
|
85
89
|
|
|
86
90
|
// Remove all the theme classes from the documentElement
|
|
87
|
-
(_document$documentEle = document.documentElement.className.match(themeClass)) === null || _document$documentEle === void 0 ? void 0 : _document$documentEle.
|
|
91
|
+
(_document$documentEle = document.documentElement.className.match(themeClass)) === null || _document$documentEle === void 0 ? void 0 : _document$documentEle.forEach(function (item) {
|
|
88
92
|
document.documentElement.classList.remove(item);
|
|
89
93
|
});
|
|
90
94
|
getThemeClassName(theme, screenMode).split(' ').forEach(function (item) {
|
|
91
95
|
document.documentElement.classList.add(item);
|
|
92
96
|
});
|
|
93
97
|
}
|
|
94
|
-
}, [isRootProvider, theme, screenMode]);
|
|
95
|
-
|
|
96
|
-
|
|
98
|
+
}, [isRootProvider, theme, screenMode, themeClass]);
|
|
99
|
+
var contextValue = react.useMemo(function () {
|
|
100
|
+
return {
|
|
97
101
|
theme: theme,
|
|
98
102
|
screenMode: screenMode
|
|
99
|
-
}
|
|
103
|
+
};
|
|
104
|
+
}, [screenMode, theme]);
|
|
105
|
+
return jsxRuntime.jsx(ThemeContext.Provider, {
|
|
106
|
+
value: contextValue,
|
|
100
107
|
children: jsxRuntime.jsx(ThemedChildren, {
|
|
101
108
|
children: children
|
|
102
109
|
})
|
package/dist/cjs/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../src/const.ts","../../src/helpers.ts","../../src/useTheme.ts","../../src/ThemedChildren.tsx","../../src/ThemeProvider.tsx"],"sourcesContent":["// TODO: Change 'light' with 'legacy' in the future\nexport const baseThemes = ['light', 'personal'] as const;\nexport const extraThemes = ['forest-green'] as const;\nexport const screenModes = ['light', 'dark'] as const;\nexport const modernThemes = [baseThemes[1], ...extraThemes] as const;\n\n// TODO: componentThemes returned back for backward compatibility, refactor this place in the future\nexport type ComponentTheme = typeof baseThemes[number];\nexport type ModernTheme = typeof modernThemes[number];\nexport type BaseTheme = typeof baseThemes[number];\nexport type ExtraTheme = typeof extraThemes[number];\nexport type ScreenMode = typeof screenModes[number];\nexport type ScreenModeDark = typeof screenModes[1];\n\nexport const DEFAULT_BASE_THEME = 'light' as const;\nexport const DEFAULT_SCREEN_MODE = 'light' as const;\n\nexport type Theming = {\n theme?: ComponentTheme | BaseTheme | ExtraTheme;\n screenMode?: ScreenMode;\n};\n","import type {
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../src/const.ts","../../src/helpers.ts","../../src/useTheme.ts","../../src/ThemedChildren.tsx","../../src/ThemeProvider.tsx"],"sourcesContent":["// TODO: Change 'light' with 'legacy' in the future\nexport const baseThemes = ['light', 'personal'] as const;\nexport const extraThemes = ['forest-green', 'bright-green'] as const;\nexport const screenModes = ['light', 'dark'] as const;\nexport const modernThemes = [baseThemes[1], ...extraThemes] as const;\n\n// TODO: componentThemes returned back for backward compatibility, refactor this place in the future\nexport type ComponentTheme = typeof baseThemes[number];\nexport type ModernTheme = typeof modernThemes[number];\nexport type BaseTheme = typeof baseThemes[number];\nexport type ExtraTheme = typeof extraThemes[number];\nexport type ScreenMode = typeof screenModes[number];\nexport type ScreenModeDark = typeof screenModes[1];\n\nexport const DEFAULT_BASE_THEME = 'light' as const;\nexport const DEFAULT_SCREEN_MODE = 'light' as const;\n\nexport type Theming = {\n theme?: ComponentTheme | BaseTheme | ExtraTheme;\n screenMode?: ScreenMode;\n};\n","import type {\n ComponentTheme,\n ModernTheme,\n BaseTheme,\n ExtraTheme,\n ScreenMode,\n ScreenModeDark,\n} from './const';\nimport { extraThemes, screenModes, modernThemes } from './const';\n\nexport const isThemeModern = (\n theme: ComponentTheme | BaseTheme | ExtraTheme,\n): theme is ModernTheme => modernThemes.includes(theme as ModernTheme);\n\nexport const isExtraTheme = (theme: ComponentTheme | BaseTheme | ExtraTheme): theme is ExtraTheme =>\n extraThemes.includes(theme as ExtraTheme);\n\nexport const isScreenModeDark = (\n theme: ComponentTheme | BaseTheme | ExtraTheme,\n screenMode: ScreenMode,\n): screenMode is ScreenModeDark =>\n isThemeModern(theme as ModernTheme) && screenModes[1] === screenMode;\n\nexport const getThemeClassName = (\n theme: ComponentTheme | BaseTheme | ExtraTheme,\n screenMode: ScreenMode,\n) => {\n if (!isThemeModern(theme)) {\n return `np-theme-${theme}`;\n }\n\n let classes = `np-theme-personal`;\n\n if (isExtraTheme(theme)) {\n classes += ` ${classes}--${theme}`;\n } else if (screenModes[1] === screenMode) {\n classes += ` ${classes}--${screenMode}`;\n }\n\n return classes;\n};\n","import { useContext, useMemo } from 'react';\n\nimport { ThemeContext } from './ThemeProvider';\nimport type { ComponentTheme, BaseTheme, ScreenMode, ExtraTheme } from './const';\nimport { DEFAULT_BASE_THEME, DEFAULT_SCREEN_MODE } from './const';\nimport { isThemeModern, isScreenModeDark, getThemeClassName } from './helpers';\n\ninterface ThemeHookValue {\n theme: ComponentTheme | BaseTheme | ExtraTheme;\n screenMode: ScreenMode;\n isModern: boolean;\n isScreenModeDark: boolean;\n className: string;\n}\n\nconst FALLBACK_VALUES = {\n theme: DEFAULT_BASE_THEME,\n screenMode: DEFAULT_SCREEN_MODE,\n};\n\nexport const useTheme = (): ThemeHookValue => {\n const { theme, screenMode: contextScreenMode } = useContext(ThemeContext) ?? FALLBACK_VALUES;\n\n const screenMode = theme === DEFAULT_BASE_THEME ? DEFAULT_SCREEN_MODE : contextScreenMode;\n\n return useMemo(\n () => ({\n theme,\n screenMode,\n isModern: isThemeModern(theme),\n isScreenModeDark: isScreenModeDark(theme, screenMode),\n className: getThemeClassName(theme, screenMode),\n }),\n [theme, screenMode],\n );\n};\n","import { ReactNode } from 'react';\n\nimport { useTheme } from './useTheme';\n\ntype ThemedChildrenProps = { children: ReactNode };\n\nexport const ThemedChildren = ({ children }: ThemedChildrenProps) => {\n const { className } = useTheme();\n\n return <div className={className}>{children}</div>;\n};\n","import { createContext, PropsWithChildren, useContext, useEffect, useMemo } from 'react';\n\nimport { ThemedChildren } from './ThemedChildren';\nimport type { ComponentTheme, BaseTheme, ExtraTheme, ScreenMode, Theming } from './const';\nimport { DEFAULT_BASE_THEME, DEFAULT_SCREEN_MODE } from './const';\nimport { getThemeClassName } from './helpers';\n\nexport const ThemeContext = createContext<\n | {\n theme: ComponentTheme | BaseTheme | ExtraTheme;\n screenMode: ScreenMode;\n }\n | undefined\n>(undefined);\n\ntype ThemeProviderProps = PropsWithChildren<Theming>;\n\nexport const ThemeProvider = ({\n theme = DEFAULT_BASE_THEME,\n screenMode = DEFAULT_SCREEN_MODE,\n children,\n}: ThemeProviderProps) => {\n const isRootProvider = useContext(ThemeContext) === undefined;\n\n // RegEx to check for `np-theme-` class name\n // eslint-disable-next-line react-hooks/exhaustive-deps\n const themeClass = new RegExp(/\\bnp-theme-[a-z-]+\\b/, 'g');\n\n // useEffect hook used to apply the theme class to the HTML element\n useEffect(() => {\n if (isRootProvider) {\n // Remove all the theme classes from the documentElement\n document.documentElement.className.match(themeClass)?.forEach((item) => {\n document.documentElement.classList.remove(item);\n });\n getThemeClassName(theme, screenMode)\n .split(' ')\n .forEach((item) => {\n document.documentElement.classList.add(item);\n });\n }\n }, [isRootProvider, theme, screenMode, themeClass]);\n\n const contextValue = useMemo(() => ({ theme, screenMode }), [screenMode, theme]);\n\n return (\n <ThemeContext.Provider value={contextValue}>\n <ThemedChildren>{children}</ThemedChildren>\n </ThemeContext.Provider>\n );\n};\n"],"names":["baseThemes","extraThemes","screenModes","modernThemes","DEFAULT_BASE_THEME","DEFAULT_SCREEN_MODE","isThemeModern","theme","includes","isExtraTheme","isScreenModeDark","screenMode","getThemeClassName","classes","FALLBACK_VALUES","useTheme","useContext","ThemeContext","contextScreenMode","useMemo","isModern","className","ThemedChildren","children","_jsx","createContext","undefined","ThemeProvider","isRootProvider","themeClass","RegExp","useEffect","documentElement","match","forEach","item","document","classList","remove","split","add","contextValue","Provider","value"],"mappings":"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"}
|
package/dist/es/index.d.ts
CHANGED
|
@@ -6,7 +6,8 @@ declare const baseThemes: readonly [
|
|
|
6
6
|
"personal"
|
|
7
7
|
];
|
|
8
8
|
declare const extraThemes: readonly [
|
|
9
|
-
"forest-green"
|
|
9
|
+
"forest-green",
|
|
10
|
+
"bright-green"
|
|
10
11
|
];
|
|
11
12
|
declare const screenModes: readonly [
|
|
12
13
|
"light",
|
|
@@ -21,8 +22,8 @@ type Theming = {
|
|
|
21
22
|
theme?: ComponentTheme | BaseTheme | ExtraTheme;
|
|
22
23
|
screenMode?: ScreenMode;
|
|
23
24
|
};
|
|
24
|
-
declare const isThemeModern: (theme: ComponentTheme | BaseTheme | ExtraTheme) => theme is "personal" | "forest-green";
|
|
25
|
-
declare const isExtraTheme: (theme: ComponentTheme | BaseTheme | ExtraTheme) => theme is "forest-green";
|
|
25
|
+
declare const isThemeModern: (theme: ComponentTheme | BaseTheme | ExtraTheme) => theme is "personal" | "forest-green" | "bright-green";
|
|
26
|
+
declare const isExtraTheme: (theme: ComponentTheme | BaseTheme | ExtraTheme) => theme is "forest-green" | "bright-green";
|
|
26
27
|
declare const isScreenModeDark: (theme: ComponentTheme | BaseTheme | ExtraTheme, screenMode: ScreenMode) => screenMode is "dark";
|
|
27
28
|
declare const getThemeClassName: (theme: ComponentTheme | BaseTheme | ExtraTheme, screenMode: ScreenMode) => string;
|
|
28
29
|
type ThemeProviderProps = PropsWithChildren<Theming>;
|
package/dist/es/index.js
CHANGED
|
@@ -3,7 +3,7 @@ import { useContext, useMemo, createContext, useEffect } from 'react';
|
|
|
3
3
|
|
|
4
4
|
// TODO: Change 'light' with 'legacy' in the future
|
|
5
5
|
var baseThemes = ['light', 'personal'];
|
|
6
|
-
var extraThemes = ['forest-green'];
|
|
6
|
+
var extraThemes = ['forest-green', 'bright-green'];
|
|
7
7
|
var screenModes = ['light', 'dark'];
|
|
8
8
|
var modernThemes = [baseThemes[1]].concat(extraThemes);
|
|
9
9
|
var DEFAULT_BASE_THEME = 'light';
|
|
@@ -34,11 +34,18 @@ var getThemeClassName = function getThemeClassName(theme, screenMode) {
|
|
|
34
34
|
return classes;
|
|
35
35
|
};
|
|
36
36
|
|
|
37
|
+
var FALLBACK_VALUES = {
|
|
38
|
+
theme: DEFAULT_BASE_THEME,
|
|
39
|
+
screenMode: DEFAULT_SCREEN_MODE
|
|
40
|
+
};
|
|
37
41
|
var useTheme = function useTheme() {
|
|
38
|
-
var _useContext
|
|
42
|
+
var _useContext;
|
|
43
|
+
|
|
44
|
+
var _ref = (_useContext = useContext(ThemeContext)) !== null && _useContext !== void 0 ? _useContext : FALLBACK_VALUES,
|
|
45
|
+
theme = _ref.theme,
|
|
46
|
+
contextScreenMode = _ref.screenMode;
|
|
39
47
|
|
|
40
|
-
var
|
|
41
|
-
var screenMode = theme !== DEFAULT_BASE_THEME ? (_useContext$screenMod = useContext(ThemeContext).screenMode) !== null && _useContext$screenMod !== void 0 ? _useContext$screenMod : DEFAULT_SCREEN_MODE : DEFAULT_SCREEN_MODE;
|
|
48
|
+
var screenMode = theme === DEFAULT_BASE_THEME ? DEFAULT_SCREEN_MODE : contextScreenMode;
|
|
42
49
|
return useMemo(function () {
|
|
43
50
|
return {
|
|
44
51
|
theme: theme,
|
|
@@ -62,17 +69,14 @@ var ThemedChildren = function ThemedChildren(_ref) {
|
|
|
62
69
|
});
|
|
63
70
|
};
|
|
64
71
|
|
|
65
|
-
var ThemeContext = /*#__PURE__*/createContext(
|
|
66
|
-
theme: undefined,
|
|
67
|
-
screenMode: undefined
|
|
68
|
-
});
|
|
72
|
+
var ThemeContext = /*#__PURE__*/createContext(undefined);
|
|
69
73
|
var ThemeProvider = function ThemeProvider(_ref) {
|
|
70
74
|
var _ref$theme = _ref.theme,
|
|
71
75
|
theme = _ref$theme === void 0 ? DEFAULT_BASE_THEME : _ref$theme,
|
|
72
76
|
_ref$screenMode = _ref.screenMode,
|
|
73
77
|
screenMode = _ref$screenMode === void 0 ? DEFAULT_SCREEN_MODE : _ref$screenMode,
|
|
74
78
|
children = _ref.children;
|
|
75
|
-
var isRootProvider = useContext(ThemeContext)
|
|
79
|
+
var isRootProvider = useContext(ThemeContext) === undefined; // RegEx to check for `np-theme-` class name
|
|
76
80
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
77
81
|
|
|
78
82
|
var themeClass = new RegExp(/\bnp-theme-[a-z-]+\b/, 'g'); // useEffect hook used to apply the theme class to the HTML element
|
|
@@ -82,19 +86,22 @@ var ThemeProvider = function ThemeProvider(_ref) {
|
|
|
82
86
|
var _document$documentEle;
|
|
83
87
|
|
|
84
88
|
// Remove all the theme classes from the documentElement
|
|
85
|
-
(_document$documentEle = document.documentElement.className.match(themeClass)) === null || _document$documentEle === void 0 ? void 0 : _document$documentEle.
|
|
89
|
+
(_document$documentEle = document.documentElement.className.match(themeClass)) === null || _document$documentEle === void 0 ? void 0 : _document$documentEle.forEach(function (item) {
|
|
86
90
|
document.documentElement.classList.remove(item);
|
|
87
91
|
});
|
|
88
92
|
getThemeClassName(theme, screenMode).split(' ').forEach(function (item) {
|
|
89
93
|
document.documentElement.classList.add(item);
|
|
90
94
|
});
|
|
91
95
|
}
|
|
92
|
-
}, [isRootProvider, theme, screenMode]);
|
|
93
|
-
|
|
94
|
-
|
|
96
|
+
}, [isRootProvider, theme, screenMode, themeClass]);
|
|
97
|
+
var contextValue = useMemo(function () {
|
|
98
|
+
return {
|
|
95
99
|
theme: theme,
|
|
96
100
|
screenMode: screenMode
|
|
97
|
-
}
|
|
101
|
+
};
|
|
102
|
+
}, [screenMode, theme]);
|
|
103
|
+
return jsx(ThemeContext.Provider, {
|
|
104
|
+
value: contextValue,
|
|
98
105
|
children: jsx(ThemedChildren, {
|
|
99
106
|
children: children
|
|
100
107
|
})
|
package/dist/es/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../src/const.ts","../../src/helpers.ts","../../src/useTheme.ts","../../src/ThemedChildren.tsx","../../src/ThemeProvider.tsx"],"sourcesContent":["// TODO: Change 'light' with 'legacy' in the future\nexport const baseThemes = ['light', 'personal'] as const;\nexport const extraThemes = ['forest-green'] as const;\nexport const screenModes = ['light', 'dark'] as const;\nexport const modernThemes = [baseThemes[1], ...extraThemes] as const;\n\n// TODO: componentThemes returned back for backward compatibility, refactor this place in the future\nexport type ComponentTheme = typeof baseThemes[number];\nexport type ModernTheme = typeof modernThemes[number];\nexport type BaseTheme = typeof baseThemes[number];\nexport type ExtraTheme = typeof extraThemes[number];\nexport type ScreenMode = typeof screenModes[number];\nexport type ScreenModeDark = typeof screenModes[1];\n\nexport const DEFAULT_BASE_THEME = 'light' as const;\nexport const DEFAULT_SCREEN_MODE = 'light' as const;\n\nexport type Theming = {\n theme?: ComponentTheme | BaseTheme | ExtraTheme;\n screenMode?: ScreenMode;\n};\n","import type {
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../src/const.ts","../../src/helpers.ts","../../src/useTheme.ts","../../src/ThemedChildren.tsx","../../src/ThemeProvider.tsx"],"sourcesContent":["// TODO: Change 'light' with 'legacy' in the future\nexport const baseThemes = ['light', 'personal'] as const;\nexport const extraThemes = ['forest-green', 'bright-green'] as const;\nexport const screenModes = ['light', 'dark'] as const;\nexport const modernThemes = [baseThemes[1], ...extraThemes] as const;\n\n// TODO: componentThemes returned back for backward compatibility, refactor this place in the future\nexport type ComponentTheme = typeof baseThemes[number];\nexport type ModernTheme = typeof modernThemes[number];\nexport type BaseTheme = typeof baseThemes[number];\nexport type ExtraTheme = typeof extraThemes[number];\nexport type ScreenMode = typeof screenModes[number];\nexport type ScreenModeDark = typeof screenModes[1];\n\nexport const DEFAULT_BASE_THEME = 'light' as const;\nexport const DEFAULT_SCREEN_MODE = 'light' as const;\n\nexport type Theming = {\n theme?: ComponentTheme | BaseTheme | ExtraTheme;\n screenMode?: ScreenMode;\n};\n","import type {\n ComponentTheme,\n ModernTheme,\n BaseTheme,\n ExtraTheme,\n ScreenMode,\n ScreenModeDark,\n} from './const';\nimport { extraThemes, screenModes, modernThemes } from './const';\n\nexport const isThemeModern = (\n theme: ComponentTheme | BaseTheme | ExtraTheme,\n): theme is ModernTheme => modernThemes.includes(theme as ModernTheme);\n\nexport const isExtraTheme = (theme: ComponentTheme | BaseTheme | ExtraTheme): theme is ExtraTheme =>\n extraThemes.includes(theme as ExtraTheme);\n\nexport const isScreenModeDark = (\n theme: ComponentTheme | BaseTheme | ExtraTheme,\n screenMode: ScreenMode,\n): screenMode is ScreenModeDark =>\n isThemeModern(theme as ModernTheme) && screenModes[1] === screenMode;\n\nexport const getThemeClassName = (\n theme: ComponentTheme | BaseTheme | ExtraTheme,\n screenMode: ScreenMode,\n) => {\n if (!isThemeModern(theme)) {\n return `np-theme-${theme}`;\n }\n\n let classes = `np-theme-personal`;\n\n if (isExtraTheme(theme)) {\n classes += ` ${classes}--${theme}`;\n } else if (screenModes[1] === screenMode) {\n classes += ` ${classes}--${screenMode}`;\n }\n\n return classes;\n};\n","import { useContext, useMemo } from 'react';\n\nimport { ThemeContext } from './ThemeProvider';\nimport type { ComponentTheme, BaseTheme, ScreenMode, ExtraTheme } from './const';\nimport { DEFAULT_BASE_THEME, DEFAULT_SCREEN_MODE } from './const';\nimport { isThemeModern, isScreenModeDark, getThemeClassName } from './helpers';\n\ninterface ThemeHookValue {\n theme: ComponentTheme | BaseTheme | ExtraTheme;\n screenMode: ScreenMode;\n isModern: boolean;\n isScreenModeDark: boolean;\n className: string;\n}\n\nconst FALLBACK_VALUES = {\n theme: DEFAULT_BASE_THEME,\n screenMode: DEFAULT_SCREEN_MODE,\n};\n\nexport const useTheme = (): ThemeHookValue => {\n const { theme, screenMode: contextScreenMode } = useContext(ThemeContext) ?? FALLBACK_VALUES;\n\n const screenMode = theme === DEFAULT_BASE_THEME ? DEFAULT_SCREEN_MODE : contextScreenMode;\n\n return useMemo(\n () => ({\n theme,\n screenMode,\n isModern: isThemeModern(theme),\n isScreenModeDark: isScreenModeDark(theme, screenMode),\n className: getThemeClassName(theme, screenMode),\n }),\n [theme, screenMode],\n );\n};\n","import { ReactNode } from 'react';\n\nimport { useTheme } from './useTheme';\n\ntype ThemedChildrenProps = { children: ReactNode };\n\nexport const ThemedChildren = ({ children }: ThemedChildrenProps) => {\n const { className } = useTheme();\n\n return <div className={className}>{children}</div>;\n};\n","import { createContext, PropsWithChildren, useContext, useEffect, useMemo } from 'react';\n\nimport { ThemedChildren } from './ThemedChildren';\nimport type { ComponentTheme, BaseTheme, ExtraTheme, ScreenMode, Theming } from './const';\nimport { DEFAULT_BASE_THEME, DEFAULT_SCREEN_MODE } from './const';\nimport { getThemeClassName } from './helpers';\n\nexport const ThemeContext = createContext<\n | {\n theme: ComponentTheme | BaseTheme | ExtraTheme;\n screenMode: ScreenMode;\n }\n | undefined\n>(undefined);\n\ntype ThemeProviderProps = PropsWithChildren<Theming>;\n\nexport const ThemeProvider = ({\n theme = DEFAULT_BASE_THEME,\n screenMode = DEFAULT_SCREEN_MODE,\n children,\n}: ThemeProviderProps) => {\n const isRootProvider = useContext(ThemeContext) === undefined;\n\n // RegEx to check for `np-theme-` class name\n // eslint-disable-next-line react-hooks/exhaustive-deps\n const themeClass = new RegExp(/\\bnp-theme-[a-z-]+\\b/, 'g');\n\n // useEffect hook used to apply the theme class to the HTML element\n useEffect(() => {\n if (isRootProvider) {\n // Remove all the theme classes from the documentElement\n document.documentElement.className.match(themeClass)?.forEach((item) => {\n document.documentElement.classList.remove(item);\n });\n getThemeClassName(theme, screenMode)\n .split(' ')\n .forEach((item) => {\n document.documentElement.classList.add(item);\n });\n }\n }, [isRootProvider, theme, screenMode, themeClass]);\n\n const contextValue = useMemo(() => ({ theme, screenMode }), [screenMode, theme]);\n\n return (\n <ThemeContext.Provider value={contextValue}>\n <ThemedChildren>{children}</ThemedChildren>\n </ThemeContext.Provider>\n );\n};\n"],"names":["baseThemes","extraThemes","screenModes","modernThemes","DEFAULT_BASE_THEME","DEFAULT_SCREEN_MODE","isThemeModern","theme","includes","isExtraTheme","isScreenModeDark","screenMode","getThemeClassName","classes","FALLBACK_VALUES","useTheme","useContext","ThemeContext","contextScreenMode","useMemo","isModern","className","ThemedChildren","children","_jsx","createContext","undefined","ThemeProvider","isRootProvider","themeClass","RegExp","useEffect","documentElement","match","forEach","item","document","classList","remove","split","add","contextValue","Provider","value"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@wise/components-theming",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.6.1-beta-76ef568819.2+76ef568819",
|
|
4
4
|
"description": "Provides theming support for the Wise Design system components",
|
|
5
5
|
"license": "Apache-2.0",
|
|
6
6
|
"keywords": [
|
|
@@ -28,7 +28,10 @@
|
|
|
28
28
|
"scripts": {
|
|
29
29
|
"build": "rollup --config --sourcemap --configPlugin rollup-plugin-ts",
|
|
30
30
|
"test": "jest --env=jsdom --maxWorkers=4 --config=../../node_modules/@transferwise/test-config/jest.config.js",
|
|
31
|
-
"test:watch": "jest --watch --env=jsdom --config=../../node_modules/@transferwise/test-config/jest.config.js"
|
|
31
|
+
"test:watch": "jest --watch --env=jsdom --config=../../node_modules/@transferwise/test-config/jest.config.js",
|
|
32
|
+
"lint": "jest --maxWorkers=4 --config ../../node_modules/@transferwise/test-config/test/jest.lint.js && yarn lint:ts",
|
|
33
|
+
"lint:ts": "tsc --noEmit --emitDeclarationOnly false",
|
|
34
|
+
"lint:fix": "eslint 'src/**/*.js' --fix"
|
|
32
35
|
},
|
|
33
36
|
"exports": {
|
|
34
37
|
".": {
|
|
@@ -43,5 +46,5 @@
|
|
|
43
46
|
"dist/",
|
|
44
47
|
"src/"
|
|
45
48
|
],
|
|
46
|
-
"gitHead": "
|
|
49
|
+
"gitHead": "76ef56881924cafc06dc80d49b3a8b6454c1bae4"
|
|
47
50
|
}
|
package/src/ThemeProvider.tsx
CHANGED
|
@@ -1,14 +1,17 @@
|
|
|
1
|
-
import { createContext, PropsWithChildren, useContext, useEffect } from 'react';
|
|
1
|
+
import { createContext, PropsWithChildren, useContext, useEffect, useMemo } from 'react';
|
|
2
2
|
|
|
3
3
|
import { ThemedChildren } from './ThemedChildren';
|
|
4
4
|
import type { ComponentTheme, BaseTheme, ExtraTheme, ScreenMode, Theming } from './const';
|
|
5
5
|
import { DEFAULT_BASE_THEME, DEFAULT_SCREEN_MODE } from './const';
|
|
6
6
|
import { getThemeClassName } from './helpers';
|
|
7
7
|
|
|
8
|
-
export const ThemeContext = createContext<
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
8
|
+
export const ThemeContext = createContext<
|
|
9
|
+
| {
|
|
10
|
+
theme: ComponentTheme | BaseTheme | ExtraTheme;
|
|
11
|
+
screenMode: ScreenMode;
|
|
12
|
+
}
|
|
13
|
+
| undefined
|
|
14
|
+
>(undefined);
|
|
12
15
|
|
|
13
16
|
type ThemeProviderProps = PropsWithChildren<Theming>;
|
|
14
17
|
|
|
@@ -17,7 +20,7 @@ export const ThemeProvider = ({
|
|
|
17
20
|
screenMode = DEFAULT_SCREEN_MODE,
|
|
18
21
|
children,
|
|
19
22
|
}: ThemeProviderProps) => {
|
|
20
|
-
const isRootProvider = useContext(ThemeContext)
|
|
23
|
+
const isRootProvider = useContext(ThemeContext) === undefined;
|
|
21
24
|
|
|
22
25
|
// RegEx to check for `np-theme-` class name
|
|
23
26
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
@@ -27,17 +30,21 @@ export const ThemeProvider = ({
|
|
|
27
30
|
useEffect(() => {
|
|
28
31
|
if (isRootProvider) {
|
|
29
32
|
// Remove all the theme classes from the documentElement
|
|
30
|
-
document.documentElement.className.match(themeClass)?.
|
|
33
|
+
document.documentElement.className.match(themeClass)?.forEach((item) => {
|
|
31
34
|
document.documentElement.classList.remove(item);
|
|
32
35
|
});
|
|
33
|
-
getThemeClassName(theme, screenMode)
|
|
34
|
-
|
|
35
|
-
|
|
36
|
+
getThemeClassName(theme, screenMode)
|
|
37
|
+
.split(' ')
|
|
38
|
+
.forEach((item) => {
|
|
39
|
+
document.documentElement.classList.add(item);
|
|
40
|
+
});
|
|
36
41
|
}
|
|
37
|
-
}, [isRootProvider, theme, screenMode]);
|
|
42
|
+
}, [isRootProvider, theme, screenMode, themeClass]);
|
|
43
|
+
|
|
44
|
+
const contextValue = useMemo(() => ({ theme, screenMode }), [screenMode, theme]);
|
|
38
45
|
|
|
39
46
|
return (
|
|
40
|
-
<ThemeContext.Provider value={
|
|
47
|
+
<ThemeContext.Provider value={contextValue}>
|
|
41
48
|
<ThemedChildren>{children}</ThemedChildren>
|
|
42
49
|
</ThemeContext.Provider>
|
|
43
50
|
);
|
package/src/const.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
// TODO: Change 'light' with 'legacy' in the future
|
|
2
2
|
export const baseThemes = ['light', 'personal'] as const;
|
|
3
|
-
export const extraThemes = ['forest-green'] as const;
|
|
3
|
+
export const extraThemes = ['forest-green', 'bright-green'] as const;
|
|
4
4
|
export const screenModes = ['light', 'dark'] as const;
|
|
5
5
|
export const modernThemes = [baseThemes[1], ...extraThemes] as const;
|
|
6
6
|
|
package/src/helpers.ts
CHANGED
|
@@ -1,15 +1,23 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type {
|
|
2
|
+
ComponentTheme,
|
|
3
|
+
ModernTheme,
|
|
4
|
+
BaseTheme,
|
|
5
|
+
ExtraTheme,
|
|
6
|
+
ScreenMode,
|
|
7
|
+
ScreenModeDark,
|
|
8
|
+
} from './const';
|
|
2
9
|
import { extraThemes, screenModes, modernThemes } from './const';
|
|
3
10
|
|
|
4
|
-
export const isThemeModern = (
|
|
5
|
-
|
|
11
|
+
export const isThemeModern = (
|
|
12
|
+
theme: ComponentTheme | BaseTheme | ExtraTheme,
|
|
13
|
+
): theme is ModernTheme => modernThemes.includes(theme as ModernTheme);
|
|
6
14
|
|
|
7
15
|
export const isExtraTheme = (theme: ComponentTheme | BaseTheme | ExtraTheme): theme is ExtraTheme =>
|
|
8
16
|
extraThemes.includes(theme as ExtraTheme);
|
|
9
17
|
|
|
10
18
|
export const isScreenModeDark = (
|
|
11
19
|
theme: ComponentTheme | BaseTheme | ExtraTheme,
|
|
12
|
-
screenMode: ScreenMode
|
|
20
|
+
screenMode: ScreenMode,
|
|
13
21
|
): screenMode is ScreenModeDark =>
|
|
14
22
|
isThemeModern(theme as ModernTheme) && screenModes[1] === screenMode;
|
|
15
23
|
|
package/src/useTheme.spec.tsx
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { renderHook } from '@testing-library/react-hooks';
|
|
2
2
|
|
|
3
|
-
import { DEFAULT_BASE_THEME, DEFAULT_SCREEN_MODE } from './const';
|
|
4
3
|
import { ThemeProvider } from './ThemeProvider';
|
|
4
|
+
import { DEFAULT_BASE_THEME, DEFAULT_SCREEN_MODE } from './const';
|
|
5
5
|
import { useTheme } from './useTheme';
|
|
6
6
|
|
|
7
7
|
describe('useTheme', () => {
|
|
@@ -38,62 +38,81 @@ describe('useTheme', () => {
|
|
|
38
38
|
});
|
|
39
39
|
});
|
|
40
40
|
|
|
41
|
-
it('returns
|
|
41
|
+
it('returns forest-green theme', () => {
|
|
42
42
|
const {
|
|
43
43
|
result: { current },
|
|
44
44
|
} = renderHook(() => useTheme(), {
|
|
45
45
|
wrapper: ThemeProvider,
|
|
46
46
|
initialProps: {
|
|
47
|
-
theme:
|
|
48
|
-
screenMode: 'dark' as const,
|
|
47
|
+
theme: 'forest-green' as const,
|
|
49
48
|
},
|
|
50
49
|
});
|
|
51
50
|
|
|
52
51
|
expect(current).toStrictEqual({
|
|
53
|
-
theme:
|
|
52
|
+
theme: 'forest-green',
|
|
54
53
|
screenMode: DEFAULT_SCREEN_MODE,
|
|
55
|
-
isModern:
|
|
54
|
+
isModern: true,
|
|
56
55
|
isScreenModeDark: false,
|
|
57
|
-
className: 'np-theme-
|
|
56
|
+
className: 'np-theme-personal np-theme-personal--forest-green',
|
|
58
57
|
});
|
|
59
58
|
});
|
|
60
59
|
|
|
61
|
-
it('returns
|
|
60
|
+
it('returns bright-green theme', () => {
|
|
62
61
|
const {
|
|
63
62
|
result: { current },
|
|
64
63
|
} = renderHook(() => useTheme(), {
|
|
65
64
|
wrapper: ThemeProvider,
|
|
66
65
|
initialProps: {
|
|
67
|
-
theme: '
|
|
68
|
-
screenMode: 'dark' as const,
|
|
66
|
+
theme: 'bright-green' as const,
|
|
69
67
|
},
|
|
70
68
|
});
|
|
71
69
|
|
|
72
70
|
expect(current).toStrictEqual({
|
|
73
|
-
theme: '
|
|
74
|
-
screenMode:
|
|
71
|
+
theme: 'bright-green',
|
|
72
|
+
screenMode: DEFAULT_SCREEN_MODE,
|
|
75
73
|
isModern: true,
|
|
76
|
-
isScreenModeDark:
|
|
77
|
-
className: 'np-theme-personal np-theme-personal--
|
|
74
|
+
isScreenModeDark: false,
|
|
75
|
+
className: 'np-theme-personal np-theme-personal--bright-green',
|
|
78
76
|
});
|
|
79
77
|
});
|
|
80
78
|
|
|
81
|
-
it('returns
|
|
79
|
+
it('returns default screen mode if used default light theme', () => {
|
|
82
80
|
const {
|
|
83
81
|
result: { current },
|
|
84
82
|
} = renderHook(() => useTheme(), {
|
|
85
83
|
wrapper: ThemeProvider,
|
|
86
84
|
initialProps: {
|
|
87
|
-
theme:
|
|
85
|
+
theme: DEFAULT_BASE_THEME,
|
|
86
|
+
screenMode: 'dark' as const,
|
|
88
87
|
},
|
|
89
88
|
});
|
|
90
89
|
|
|
91
90
|
expect(current).toStrictEqual({
|
|
92
|
-
theme:
|
|
91
|
+
theme: DEFAULT_BASE_THEME,
|
|
93
92
|
screenMode: DEFAULT_SCREEN_MODE,
|
|
94
|
-
isModern:
|
|
93
|
+
isModern: false,
|
|
95
94
|
isScreenModeDark: false,
|
|
96
|
-
className: 'np-theme-
|
|
95
|
+
className: 'np-theme-light',
|
|
96
|
+
});
|
|
97
|
+
});
|
|
98
|
+
|
|
99
|
+
it('returns dark screen mode', () => {
|
|
100
|
+
const {
|
|
101
|
+
result: { current },
|
|
102
|
+
} = renderHook(() => useTheme(), {
|
|
103
|
+
wrapper: ThemeProvider,
|
|
104
|
+
initialProps: {
|
|
105
|
+
theme: 'personal' as const,
|
|
106
|
+
screenMode: 'dark' as const,
|
|
107
|
+
},
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
expect(current).toStrictEqual({
|
|
111
|
+
theme: 'personal',
|
|
112
|
+
screenMode: 'dark',
|
|
113
|
+
isModern: true,
|
|
114
|
+
isScreenModeDark: true,
|
|
115
|
+
className: 'np-theme-personal np-theme-personal--dark',
|
|
97
116
|
});
|
|
98
117
|
});
|
|
99
118
|
});
|
package/src/useTheme.ts
CHANGED
|
@@ -13,11 +13,15 @@ interface ThemeHookValue {
|
|
|
13
13
|
className: string;
|
|
14
14
|
}
|
|
15
15
|
|
|
16
|
+
const FALLBACK_VALUES = {
|
|
17
|
+
theme: DEFAULT_BASE_THEME,
|
|
18
|
+
screenMode: DEFAULT_SCREEN_MODE,
|
|
19
|
+
};
|
|
20
|
+
|
|
16
21
|
export const useTheme = (): ThemeHookValue => {
|
|
17
|
-
const theme:
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
: DEFAULT_SCREEN_MODE;
|
|
22
|
+
const { theme, screenMode: contextScreenMode } = useContext(ThemeContext) ?? FALLBACK_VALUES;
|
|
23
|
+
|
|
24
|
+
const screenMode = theme === DEFAULT_BASE_THEME ? DEFAULT_SCREEN_MODE : contextScreenMode;
|
|
21
25
|
|
|
22
26
|
return useMemo(
|
|
23
27
|
() => ({
|