diff --git a/.changeset/tonic-ui-963.md b/.changeset/tonic-ui-963.md new file mode 100644 index 0000000000..fbdc0aac7e --- /dev/null +++ b/.changeset/tonic-ui-963.md @@ -0,0 +1,5 @@ +--- +"@tonic-ui/react": minor +--- + +feat: eliminate the `lodash.get` dependency diff --git a/packages/react/package.json b/packages/react/package.json index a0485d8b84..45fef698a9 100644 --- a/packages/react/package.json +++ b/packages/react/package.json @@ -32,7 +32,6 @@ "@tonic-ui/utils": "^2.1.1", "date-fns": "2.x", "ensure-type": "^1.5.1", - "lodash.get": "4.x", "micro-memoize": "4.x", "react-focus-lock": "2.x", "react-is": "^16.14.0 || ^17 || ^18", diff --git a/packages/react/src/css-baseline/base-css.js b/packages/react/src/css-baseline/base-css.js index d0cd3a49ea..a64b384107 100644 --- a/packages/react/src/css-baseline/base-css.js +++ b/packages/react/src/css-baseline/base-css.js @@ -1,7 +1,9 @@ import { css } from '@emotion/react'; -import _get from 'lodash.get'; const baseCSS = theme => { + const baseFonts = theme?.fonts?.['base'] ?? 'inherit'; + const monoFonts = theme?.fonts?.['mono'] ?? 'inherit'; + return css` /** * Apply a natural box layout model to all elements, but allowing components to change. @@ -14,14 +16,14 @@ const baseCSS = theme => { } html { - font-family: ${_get(theme, 'fonts.base')}; + font-family: ${baseFonts}; } pre, code, kbd, samp { - font-family: ${_get(theme, 'fonts.mono')}; + font-family: ${monoFonts}; } `; }; diff --git a/packages/react/src/drawer/styles.js b/packages/react/src/drawer/styles.js index 981154c3e2..e97ffaebf3 100644 --- a/packages/react/src/drawer/styles.js +++ b/packages/react/src/drawer/styles.js @@ -1,8 +1,8 @@ -import _get from 'lodash.get'; import { useColorMode } from '../color-mode'; import { useColorStyle } from '../color-style'; import { useIconButtonStyle } from '../shared/styles'; import { useTheme } from '../theme'; +import pixelize from '../utils/pixelize'; const defaultPlacement = 'right'; const defaultSize = 'auto'; @@ -219,7 +219,7 @@ const useDrawerBodyStyle = ({ _firstOfType: { // Sets the margin area on the top if it is the first child // 4x (padding-top) + xl (line-height) + 3x (padding-bottom) - marginTop: `calc(${_get(sizes, '4x')} + ${_get(lineHeights, 'xl')} + ${_get(sizes, '3x')})`, + marginTop: `calc(${pixelize(sizes['4x'])} + ${pixelize(lineHeights['xl'])} + ${pixelize(sizes['3x'])})`, }, }; }; @@ -240,7 +240,7 @@ const useDrawerFooterStyle = ({ _firstOfType: { // Sets the margin area on the top if it is the first child // 4x (padding-top) + xl (line-height) + 3x (padding-bottom) - marginTop: `calc(${_get(sizes, '4x')} + ${_get(lineHeights, 'xl')} + ${_get(sizes, '3x')})`, + marginTop: `calc(${pixelize(sizes['4x'])} + ${pixelize(lineHeights['xl'])} + ${pixelize(sizes['3x'])})`, }, }; }; diff --git a/packages/react/src/modal/styles.js b/packages/react/src/modal/styles.js index b465510900..d50966b70e 100644 --- a/packages/react/src/modal/styles.js +++ b/packages/react/src/modal/styles.js @@ -1,8 +1,8 @@ -import _get from 'lodash.get'; import { useColorMode } from '../color-mode'; import { useColorStyle } from '../color-style'; import { useIconButtonStyle } from '../shared/styles'; import { useTheme } from '../theme'; +import pixelize from '../utils/pixelize'; const defaultSize = 'auto'; @@ -197,7 +197,7 @@ const useModalBodyStyle = ({ _firstOfType: { // Sets the margin area on the top if it is the first child // 4x (padding-top) + xl (line-height) + 3x (padding-bottom) - marginTop: `calc(${_get(sizes, '4x')} + ${_get(lineHeights, 'xl')} + ${_get(sizes, '3x')})`, + marginTop: `calc(${pixelize(sizes['4x'])} + ${pixelize(lineHeights['xl'])} + ${pixelize(sizes['3x'])})`, }, }; }; @@ -220,7 +220,7 @@ const useModalFooterStyle = () => { _firstOfType: { // Sets the margin area on the top if it is the first child // 4x (padding-top) + xl (line-height) + 3x (padding-bottom) - marginTop: `calc(${_get(sizes, '4x')} + ${_get(lineHeights, 'xl')} + ${_get(sizes, '3x')})`, + marginTop: `calc(${pixelize(sizes['4x'])} + ${pixelize(lineHeights['xl'])} + ${pixelize(sizes['3x'])})`, }, }; }; diff --git a/yarn.lock b/yarn.lock index b0c3eb32de..10fdfd71da 100644 --- a/yarn.lock +++ b/yarn.lock @@ -4727,7 +4727,6 @@ __metadata: jest-axe: ^8.0.0 jest-environment-jsdom: ^29.0.0 jest-extended: ^4.0.0 - lodash.get: 4.x micro-memoize: 4.x react: ^16.14.0 || ^17 || ^18 react-dom: ^16.14.0 || ^17 || ^18 @@ -11626,13 +11625,6 @@ __metadata: languageName: node linkType: hard -"lodash.get@npm:4.x": - version: 4.4.2 - resolution: "lodash.get@npm:4.4.2" - checksum: e403047ddb03181c9d0e92df9556570e2b67e0f0a930fcbbbd779370972368f5568e914f913e93f3b08f6d492abc71e14d4e9b7a18916c31fa04bd2306efe545 - languageName: node - linkType: hard - "lodash.isfunction@npm:^3.0.9": version: 3.0.9 resolution: "lodash.isfunction@npm:3.0.9"