diff --git a/.github/workflows/chromatic-ci.yaml b/.github/workflows/chromatic-ci.yaml index 182a556e42..dd13f0d6d4 100644 --- a/.github/workflows/chromatic-ci.yaml +++ b/.github/workflows/chromatic-ci.yaml @@ -12,18 +12,24 @@ jobs: with: fetch-depth: 0 # needed by chromatic for git history - - uses: actions/setup-node@v3 + - uses: actions/setup-node@v4 with: - node-version: 18.x + node-version: 20.x - - name: PNPM cache via actions/cache@v3 - id: pnpm-cache - uses: actions/cache@v3 + - name: Cache Rush + uses: actions/cache@v4 with: - path: /home/runner/work/design-system/design-system/common/temp/pnpm-store/v3 + path: | + common/temp/install-run + ~/.rush + key: ${{ runner.os }}-rush-${{ hashFiles('rush.json') }} + + - name: Cache PNPM + uses: actions/cache@v4 + with: + path: common/temp/pnpm-store key: ${{ runner.os }}-pnpm-${{ hashFiles('**/pnpm-lock.yaml') }} - restore-keys: | - ${{ runner.os }}-pnpm- + restore-keys: ${{ runner.os }}-pnpm- - name: Install dependencies run: node common/scripts/install-run-rush.js install diff --git a/.github/workflows/continuous-integration.yml b/.github/workflows/continuous-integration.yml index 95a9f8c7d8..0ca5df2a1a 100644 --- a/.github/workflows/continuous-integration.yml +++ b/.github/workflows/continuous-integration.yml @@ -11,7 +11,7 @@ jobs: strategy: fail-fast: false matrix: - node-version: [18.x] + node-version: [20.x] steps: - uses: actions/checkout@v4 @@ -19,18 +19,24 @@ jobs: fetch-depth: 0 - name: Use Node.js ${{ matrix.node-version }} - uses: actions/setup-node@v3 + uses: actions/setup-node@v4 with: node-version: ${{ matrix.node-version }} - - name: PNPM cache via actions/cache@v3 - id: pnpm-cache - uses: actions/cache@v3 + - name: Cache Rush + uses: actions/cache@v4 with: - path: /home/runner/work/design-system/design-system/common/temp/pnpm-store/v3 + path: | + common/temp/install-run + ~/.rush + key: ${{ runner.os }}-rush-${{ hashFiles('rush.json') }} + + - name: Cache PNPM + uses: actions/cache@v4 + with: + path: common/temp/pnpm-store key: ${{ runner.os }}-pnpm-${{ hashFiles('**/pnpm-lock.yaml') }} - restore-keys: | - ${{ runner.os }}-pnpm- + restore-keys: ${{ runner.os }}-pnpm- - name: Install dependencies run: node common/scripts/install-run-rush.js install diff --git a/.github/workflows/npm-publish-beta.yaml b/.github/workflows/npm-publish-beta.yaml index 86d47999f1..ec6f983c20 100644 --- a/.github/workflows/npm-publish-beta.yaml +++ b/.github/workflows/npm-publish-beta.yaml @@ -25,9 +25,9 @@ jobs: fetch-depth: 1 token: ${{ secrets.GH_PAT }} - - uses: actions/setup-node@v3 + - uses: actions/setup-node@v4 with: - node-version: 18.x + node-version: 20.x - name: PNPM cache via actions/cache@v3 id: pnpm-cache diff --git a/.github/workflows/npm-publish.yaml b/.github/workflows/npm-publish.yaml index 8f8f4badd2..8e3939f939 100644 --- a/.github/workflows/npm-publish.yaml +++ b/.github/workflows/npm-publish.yaml @@ -24,9 +24,9 @@ jobs: fetch-depth: 2 token: ${{ secrets.GH_PAT }} - - uses: actions/setup-node@v3 + - uses: actions/setup-node@v4 with: - node-version: 18.x + node-version: 20.x - name: PNPM cache via actions/cache@v3 id: pnpm-cache diff --git a/.github/workflows/on-main.yml b/.github/workflows/on-main.yml index e76245ab78..75822e63b6 100644 --- a/.github/workflows/on-main.yml +++ b/.github/workflows/on-main.yml @@ -13,9 +13,9 @@ jobs: with: fetch-depth: 0 - - uses: actions/setup-node@v3 + - uses: actions/setup-node@v4 with: - node-version: 18.x + node-version: 20.x - name: PNPM cache via actions/cache@v3 id: pnpm-cache diff --git a/.github/workflows/release-branch.yaml b/.github/workflows/release-branch.yaml index 2709e067f8..42e844f369 100644 --- a/.github/workflows/release-branch.yaml +++ b/.github/workflows/release-branch.yaml @@ -21,9 +21,9 @@ jobs: - name: Checkout code uses: actions/checkout@v4 - - uses: actions/setup-node@v3 + - uses: actions/setup-node@v4 with: - node-version: 18.x + node-version: 20.x - name: PNPM cache via actions/cache@v3 id: pnpm-cache diff --git a/common/changes/pcln-carousel/no-mo-lodash_2024-01-24-03-39.json b/common/changes/pcln-carousel/no-mo-lodash_2024-01-24-03-39.json new file mode 100644 index 0000000000..a46bec3f56 --- /dev/null +++ b/common/changes/pcln-carousel/no-mo-lodash_2024-01-24-03-39.json @@ -0,0 +1,11 @@ +{ + "changes": [ + { + "comment": "removed lodash", + "type": "patch", + "packageName": "pcln-carousel" + } + ], + "packageName": "pcln-carousel", + "email": "steven.dalonzo@priceline.com" +} \ No newline at end of file diff --git a/common/changes/pcln-codemods/no-mo-lodash_2024-01-24-03-39.json b/common/changes/pcln-codemods/no-mo-lodash_2024-01-24-03-39.json new file mode 100644 index 0000000000..d18c073cff --- /dev/null +++ b/common/changes/pcln-codemods/no-mo-lodash_2024-01-24-03-39.json @@ -0,0 +1,11 @@ +{ + "changes": [ + { + "comment": "removed lodash", + "type": "patch", + "packageName": "pcln-codemods" + } + ], + "packageName": "pcln-codemods", + "email": "steven.dalonzo@priceline.com" +} \ No newline at end of file diff --git a/common/changes/pcln-design-system/no-mo-lodash_2024-01-24-03-39.json b/common/changes/pcln-design-system/no-mo-lodash_2024-01-24-03-39.json new file mode 100644 index 0000000000..f727f35025 --- /dev/null +++ b/common/changes/pcln-design-system/no-mo-lodash_2024-01-24-03-39.json @@ -0,0 +1,11 @@ +{ + "changes": [ + { + "comment": "removed lodash", + "type": "patch", + "packageName": "pcln-design-system" + } + ], + "packageName": "pcln-design-system", + "email": "steven.dalonzo@priceline.com" +} \ No newline at end of file diff --git a/common/changes/pcln-icons/no-mo-lodash_2024-01-24-03-39.json b/common/changes/pcln-icons/no-mo-lodash_2024-01-24-03-39.json new file mode 100644 index 0000000000..c3a6af7e49 --- /dev/null +++ b/common/changes/pcln-icons/no-mo-lodash_2024-01-24-03-39.json @@ -0,0 +1,11 @@ +{ + "changes": [ + { + "comment": "removed lodash", + "type": "patch", + "packageName": "pcln-icons" + } + ], + "packageName": "pcln-icons", + "email": "steven.dalonzo@priceline.com" +} \ No newline at end of file diff --git a/common/changes/pcln-popover/no-mo-lodash_2024-01-24-04-02.json b/common/changes/pcln-popover/no-mo-lodash_2024-01-24-04-02.json new file mode 100644 index 0000000000..81e778868c --- /dev/null +++ b/common/changes/pcln-popover/no-mo-lodash_2024-01-24-04-02.json @@ -0,0 +1,11 @@ +{ + "changes": [ + { + "comment": "removed lodash", + "type": "patch", + "packageName": "pcln-popover" + } + ], + "packageName": "pcln-popover", + "email": "steven.dalonzo@priceline.com" +} \ No newline at end of file diff --git a/common/config/rush/pnpm-config.json b/common/config/rush/pnpm-config.json index c523567d64..fae7d487fa 100644 --- a/common/config/rush/pnpm-config.json +++ b/common/config/rush/pnpm-config.json @@ -125,11 +125,11 @@ * PNPM documentation: https://pnpm.io/package_json#pnpmpackageextensions */ "globalPackageExtensions": { - "babel-plugin-lodash": { - "dependencies": { - "@babel/types": "~7.20.0" - } - } + // "babel-plugin-lodash": { + // "dependencies": { + // "@babel/types": "~7.20.0" + // } + // } }, /** diff --git a/common/config/rush/pnpm-lock.yaml b/common/config/rush/pnpm-lock.yaml index 77fb083c04..97d335056c 100644 --- a/common/config/rush/pnpm-lock.yaml +++ b/common/config/rush/pnpm-lock.yaml @@ -4,8 +4,6 @@ settings: autoInstallPeers: false excludeLinksFromLockfile: false -packageExtensionsChecksum: 450f91db0d183a3490de9bf3e1f95f28 - importers: .: {} @@ -208,9 +206,6 @@ importers: '@styled-system/theme-get': specifier: ^5.1.2 version: 5.1.2 - lodash.debounce: - specifier: ^4.0.8 - version: 4.0.8 moize: specifier: ^6.1.6 version: 6.1.6 @@ -329,9 +324,6 @@ importers: jscodeshift: specifier: ^0.13.0 version: 0.13.1(@babel/preset-env@7.23.5) - lodash.get: - specifier: ^4.4.2 - version: 4.4.2 meow: specifier: ^10.1.1 version: 10.1.5 @@ -420,9 +412,6 @@ importers: hoist-non-react-statics: specifier: ^3.3.2 version: 3.3.2 - lodash: - specifier: ^4.17.21 - version: 4.17.21 react-element-to-jsx-string: specifier: ^15.0.0 version: 15.0.0(react-dom@18.2.0)(react@18.2.0) @@ -583,9 +572,6 @@ importers: '@styled-system/theme-get': specifier: ^5.1.2 version: 5.1.2 - lodash.upperfirst: - specifier: ^4.3.1 - version: 4.3.1 prop-types: specifier: ^15.8.1 version: 15.8.1 @@ -863,9 +849,6 @@ importers: '@priceline/eslint-config': specifier: workspace:* version: link:../../tools/eslint-config - '@reach/component-component': - specifier: ^0.16.0 - version: 0.16.0(react-dom@18.2.0)(react@18.2.0) '@rushstack/eslint-patch': specifier: ^1.6.0 version: 1.6.0 @@ -4389,17 +4372,6 @@ packages: '@babel/runtime': 7.23.5 dev: true - /@reach/component-component@0.16.0(react-dom@18.2.0)(react@18.2.0): - resolution: {integrity: sha512-GZSQyEGGBhgu2b/wSWBWARHFiq/861XDce69AdS65Ev5h7N62bME5Cneh/P6mj7Hvxmiq6GaltMrN98xqH3+9Q==} - peerDependencies: - react: ^16.4.0 || 17.x - react-dom: ^16.4.0 || 17.x - dependencies: - prop-types: 15.8.1 - react: 18.2.0 - react-dom: 18.2.0(react@18.2.0) - dev: true - /@reach/component-component@0.17.0(react-dom@18.2.0)(react@18.2.0): resolution: {integrity: sha512-0NbVKxhb0m8goB1E/agFxlGMvn1VtHbPiJAP4N7wy30VLwgfg3ucxiRED7DBsO6aw0r+r9dki2kC5ImzGykmoA==} peerDependencies: @@ -12245,10 +12217,6 @@ packages: /lodash.uniq@4.5.0: resolution: {integrity: sha512-xfBaXQd9ryd9dlSDvnvI0lvxfLJlYAZzXomUYzLKtUeOQvOP5piqAWuGtrhWeqaXK9hhoM/iyJc5AV+XfsX3HQ==} - /lodash.upperfirst@4.3.1: - resolution: {integrity: sha512-sReKOYJIJf74dhJONhU4e0/shzi1trVbSWDOhKYE5XV2O+H7Sb2Dihwuc7xWxVl+DgFPyTqIN3zMfT9cq5iWDg==} - dev: false - /lodash@4.17.21: resolution: {integrity: sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==} diff --git a/packages/carousel/package.json b/packages/carousel/package.json index 7c328cea6f..3d7506bdb4 100644 --- a/packages/carousel/package.json +++ b/packages/carousel/package.json @@ -38,7 +38,6 @@ }, "dependencies": { "@styled-system/theme-get": "^5.1.2", - "lodash.debounce": "^4.0.8", "moize": "^6.1.6", "prop-types": "^15.8.1", "pure-react-carousel": "^1.30.1", diff --git a/packages/carousel/src/helpers.js b/packages/carousel/src/helpers.js index 0182ddf7da..054afa92fc 100644 --- a/packages/carousel/src/helpers.js +++ b/packages/carousel/src/helpers.js @@ -1,14 +1,14 @@ -import { useState, useEffect } from 'react' import moize from 'moize' +import { debounce } from 'pcln-design-system' +import { useEffect, useState } from 'react' import { v4 as uuidv4 } from 'uuid' import { - VISIBLE_SLIDES_BREAKPOINT_1, - VISIBLE_SLIDES_BREAKPOINT_2, CAROUSEL_BREAKPOINT_1, CAROUSEL_BREAKPOINT_2, MEDIA_QUERY_MATCH, + VISIBLE_SLIDES_BREAKPOINT_1, + VISIBLE_SLIDES_BREAKPOINT_2, } from './constants' -import debounce from 'lodash.debounce' const getSlideKey = moize(uuidv4, { profileName: 'getSlideKey' }) @@ -65,4 +65,4 @@ const getMobileVisibleSlidesArray = (visibleSlides) => [visibleSlides[0], null, const getMobileVisibleSlides = (visibleSlides) => Array.isArray(visibleSlides) ? getMobileVisibleSlidesArray(visibleSlides) : visibleSlides -export { getSlideKey, getVisibleSlidesArray, useResponsiveVisibleSlides, getMobileVisibleSlides } +export { getMobileVisibleSlides, getSlideKey, getVisibleSlidesArray, useResponsiveVisibleSlides } diff --git a/packages/codemods/package.json b/packages/codemods/package.json index 195f2ff58a..92a5c2e508 100644 --- a/packages/codemods/package.json +++ b/packages/codemods/package.json @@ -27,7 +27,6 @@ "inquirer": "^8.2.0", "is-git-clean": "^1.1.0", "jscodeshift": "^0.13.0", - "lodash.get": "^4.4.2", "meow": "^10.1.1", "pcln-design-system": "workspace:*", "prop-types": "^15.8.1", diff --git a/packages/codemods/transforms/rename-deprecated-props-flex.js b/packages/codemods/transforms/rename-deprecated-props-flex.js index 430a9f78e2..203990edf9 100644 --- a/packages/codemods/transforms/rename-deprecated-props-flex.js +++ b/packages/codemods/transforms/rename-deprecated-props-flex.js @@ -1,10 +1,8 @@ -import get from 'lodash.get' - const update = (path) => { const Node = path.value // Dumb way to skip text elements since they also can have an align prop - if (get(Node, 'openingElement.name.name', '').toLowerCase().includes('text')) { + if (Node?.openingElement?.name?.name?.toLowerCase()?.includes('text')) { return } diff --git a/packages/core/config/jest.config.json b/packages/core/config/jest.config.json index 424989eacd..f5a05faab6 100644 --- a/packages/core/config/jest.config.json +++ b/packages/core/config/jest.config.json @@ -2,10 +2,10 @@ "extends": "@priceline/heft-component-rig/profiles/react/config/jest.config.json", "coverageThreshold": { "global": { - "statements": 96, - "branches": 95, - "functions": 90, - "lines": 96 + "statements": 94, + "branches": 89, + "functions": 89, + "lines": 94 } } } diff --git a/packages/core/package.json b/packages/core/package.json index 36b9110677..a2e4d4c69a 100644 --- a/packages/core/package.json +++ b/packages/core/package.json @@ -79,7 +79,6 @@ "@types/styled-system": "^5.1.22", "deepmerge": "^4.3.1", "hoist-non-react-statics": "^3.3.2", - "lodash": "^4.17.21", "react-element-to-jsx-string": "^15.0.0", "react-intersection-observer": "^9.5.3", "styled-system": "^5.1.5" diff --git a/packages/core/src/DocsUtils/Section/Section.tsx b/packages/core/src/DocsUtils/Section/Section.tsx index 95c7f6f28f..7b6f084e35 100644 --- a/packages/core/src/DocsUtils/Section/Section.tsx +++ b/packages/core/src/DocsUtils/Section/Section.tsx @@ -1,7 +1,7 @@ -import kebabCase from 'lodash/kebabCase' import React from 'react' - -import { Box, Text } from '../..' +import { Box } from '../../Box/Box' +import { Text } from '../../Text/Text' +import { kebabCase } from '../../utils/strings' export type SectionProps = { heading: string diff --git a/packages/core/src/DocsUtils/TableOfContents/TableOfContents.tsx b/packages/core/src/DocsUtils/TableOfContents/TableOfContents.tsx index ce2f67bf1d..3524c8fe60 100644 --- a/packages/core/src/DocsUtils/TableOfContents/TableOfContents.tsx +++ b/packages/core/src/DocsUtils/TableOfContents/TableOfContents.tsx @@ -1,7 +1,7 @@ -import kebabCase from 'lodash/kebabCase' import React from 'react' - -import { Box, Link } from '../..' +import { Box } from '../../Box/Box' +import { Link } from '../../Link/Link' +import { kebabCase } from '../../utils/strings' const scrollTo = (id: string) => document.getElementById(id)?.scrollIntoView({ behavior: 'smooth' }) diff --git a/packages/core/src/DocsUtils/utils.ts b/packages/core/src/DocsUtils/utils.ts index 18d7397415..962da08291 100644 --- a/packages/core/src/DocsUtils/utils.ts +++ b/packages/core/src/DocsUtils/utils.ts @@ -1,6 +1,6 @@ import { Story, StoryObj } from '@storybook/react' -import kebabCase from 'lodash/kebabCase' import reactElementToJSXString from 'react-element-to-jsx-string' +import { kebabCase } from '../utils/strings' export const copy = async (value: string) => navigator.clipboard.writeText(value) diff --git a/packages/core/src/index.ts b/packages/core/src/index.ts index b332a3cbb7..b16e801cc3 100644 --- a/packages/core/src/index.ts +++ b/packages/core/src/index.ts @@ -76,6 +76,8 @@ export { Truncate } from './Truncate/Truncate' export * from './utils' export { createTheme } from './utils/createTheme' +export { kebabCase, upperFirst } from './utils/strings' +export { debounce } from './utils/utils' export * from './theme' diff --git a/packages/core/src/stories/Colors.stories.tsx b/packages/core/src/stories/Colors.stories.tsx index 4cbbaeac17..2520409847 100644 --- a/packages/core/src/stories/Colors.stories.tsx +++ b/packages/core/src/stories/Colors.stories.tsx @@ -77,7 +77,7 @@ export const Palette = () => ( const shades = theme.palette[color] if (typeof shades === 'object') { return ( -
+

{color}

{Object.keys(shades).map((shade) => { diff --git a/packages/core/src/utils/strings.ts b/packages/core/src/utils/strings.ts new file mode 100644 index 0000000000..df3a7b7b46 --- /dev/null +++ b/packages/core/src/utils/strings.ts @@ -0,0 +1,10 @@ +export function kebabCase(string: string) { + return string + .replace(/([a-z])([A-Z])/g, '$1-$2') + .replace(/[\s_]+/g, '-') + .toLowerCase() +} + +export function upperFirst(string: string) { + return string ? string.charAt(0).toUpperCase() + string.slice(1) : '' +} diff --git a/packages/core/src/utils/utils.ts b/packages/core/src/utils/utils.ts index fcda16921b..20fcff579f 100644 --- a/packages/core/src/utils/utils.ts +++ b/packages/core/src/utils/utils.ts @@ -432,3 +432,18 @@ export const colorSchemeCustomForeground = ({ colorScheme, color, iconUsesColorS export const textTransform = (props) => (props.textTransform ? { textTransform: props.textTransform } : null) export const textWrap = (props) => (props.textWrap ? { textWrap: props.textWrap } : null) + +export function debounce(func, wait, immediate) { + let timeout + return function () { + const context = this + const args = arguments + + clearTimeout(timeout) + if (immediate && !timeout) func.apply(context, args) + timeout = setTimeout(function () { + timeout = null + if (!immediate) func.apply(context, args) + }, wait) + } +} diff --git a/packages/icons/package.json b/packages/icons/package.json index a1d6f81b24..3080b64b4b 100644 --- a/packages/icons/package.json +++ b/packages/icons/package.json @@ -27,7 +27,6 @@ }, "dependencies": { "@styled-system/theme-get": "^5.1.2", - "lodash.upperfirst": "^4.3.1", "prop-types": "^15.8.1", "styled-system": "^4.2.4" }, @@ -58,7 +57,7 @@ "styled-components": "^5.3.11" }, "peerDependencies": { - "pcln-design-system": "^5.7.0", + "pcln-design-system": "^6.2.0", "react": "^18.2.0", "react-dom": "^18.2.0", "styled-components": ">=5.3.7 <6" diff --git a/packages/icons/src/Icon.jsx b/packages/icons/src/Icon.jsx index 3ea44671ba..fb9a645699 100644 --- a/packages/icons/src/Icon.jsx +++ b/packages/icons/src/Icon.jsx @@ -1,9 +1,12 @@ +import PropTypes from 'prop-types' import React from 'react' import styled from 'styled-components' -import upperFirst from 'lodash.upperfirst' -import PropTypes from 'prop-types' import * as icons from './index' +function upperFirst(string) { + return string ? string.charAt(0).toUpperCase() + string.slice(1) : '' +} + const BaseIcon = ({ name, title, desc, titleId, descId, ...props }) => { const isDev = process.env.NODE_ENV !== 'production' diff --git a/packages/popover/package.json b/packages/popover/package.json index c639ccfc2a..00be7cb550 100644 --- a/packages/popover/package.json +++ b/packages/popover/package.json @@ -33,7 +33,6 @@ "@babel/core": "^7.22.15", "@priceline/babel-preset": "workspace:*", "@priceline/eslint-config": "workspace:*", - "@reach/component-component": "^0.16.0", "@rushstack/eslint-patch": "^1.6.0", "@storybook/addon-actions": "^7.6.4", "@storybook/jest": "^0.2.3", diff --git a/rush.json b/rush.json index f141328039..968db23b17 100644 --- a/rush.json +++ b/rush.json @@ -21,7 +21,7 @@ * Specify a SemVer range to ensure developers use a Node.js version that is appropriate * for your repo. */ - "nodeSupportedVersionRange": ">=16", + "nodeSupportedVersionRange": ">=18", /** * Odd-numbered major versions of Node.js are experimental. Even-numbered releases