From 3df4a26a1d172e53106bc73164366e3077c88516 Mon Sep 17 00:00:00 2001 From: makafsal Date: Tue, 24 Sep 2024 10:41:28 +0000 Subject: [PATCH] chore: update example gallery --- .../APIKeyModal/index.html | 9 +++ .../APIKeyModal/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../APIKeyModal/src/index.scss | 7 ++ .../APIKeyModal/vite.config.js | 7 ++ .../AboutModal/index.html | 9 +++ .../AboutModal/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../AboutModal/src/index.scss | 7 ++ .../AboutModal/vite.config.js | 7 ++ .../BigNumbers/index.html | 9 +++ .../BigNumbers/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../BigNumbers/src/index.scss | 7 ++ .../BigNumbers/vite.config.js | 7 ++ .../Cascade/index.html | 9 +++ .../Cascade/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../Cascade/src/index.scss | 7 ++ .../Cascade/vite.config.js | 7 ++ .../Coachmark/index.html | 9 +++ .../Coachmark/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../Coachmark/src/index.scss | 7 ++ .../Coachmark/vite.config.js | 7 ++ .../CoachmarkBeacon/index.html | 9 +++ .../CoachmarkBeacon/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../CoachmarkBeacon/src/index.scss | 7 ++ .../CoachmarkBeacon/vite.config.js | 7 ++ .../CoachmarkButton/index.html | 9 +++ .../CoachmarkButton/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../CoachmarkButton/src/index.scss | 7 ++ .../CoachmarkButton/vite.config.js | 7 ++ .../CoachmarkFixed/index.html | 9 +++ .../CoachmarkFixed/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../CoachmarkFixed/src/index.scss | 7 ++ .../CoachmarkFixed/vite.config.js | 7 ++ .../CoachmarkOverlayElement/index.html | 9 +++ .../CoachmarkOverlayElement/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../CoachmarkOverlayElement/src/index.scss | 7 ++ .../CoachmarkOverlayElement/vite.config.js | 7 ++ .../CoachmarkOverlayElements/index.html | 9 +++ .../CoachmarkOverlayElements/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../CoachmarkOverlayElements/src/index.scss | 7 ++ .../CoachmarkOverlayElements/vite.config.js | 7 ++ .../CoachmarkStack/index.html | 9 +++ .../CoachmarkStack/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../CoachmarkStack/src/index.scss | 7 ++ .../CoachmarkStack/vite.config.js | 7 ++ .../ConditionBuilder/README.md | 61 ++++++++++++++++ .../ConditionBuilder/index.html | 25 +++++++ .../ConditionBuilder/package.json | 54 +++++++++++++- .../ConditionBuilder/src/App.jsx | 18 +++++ .../src/ThemeSelector/ThemeContext.jsx | 61 ++++++++++++++++ .../src/ThemeSelector/ThemeDropdown.jsx | 31 ++++++++ .../src/ThemeSelector/_theme-dropdown.scss | 68 ++++++++++++++++++ .../ConditionBuilder/src/config.js | 3 + .../ConditionBuilder/src/favicon.svg | 4 ++ .../ConditionBuilder/src/index.scss | 11 +++ .../ConditionBuilder/src/main.jsx | 12 ++++ .../ConditionBuilder/vite.config.js | 18 +++++ .../CreateFullPage/index.html | 9 +++ .../CreateFullPage/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../CreateFullPage/src/index.scss | 7 ++ .../CreateFullPage/vite.config.js | 7 ++ .../CreateModal/index.html | 9 +++ .../CreateModal/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../CreateModal/src/index.scss | 7 ++ .../CreateModal/vite.config.js | 7 ++ .../CreateSidePanel/index.html | 9 +++ .../CreateSidePanel/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../CreateSidePanel/src/index.scss | 7 ++ .../CreateSidePanel/vite.config.js | 7 ++ .../CreateTearsheet/index.html | 9 +++ .../CreateTearsheet/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../CreateTearsheet/src/index.scss | 7 ++ .../CreateTearsheet/vite.config.js | 7 ++ .../CreateTearsheetNarrow/index.html | 9 +++ .../CreateTearsheetNarrow/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../CreateTearsheetNarrow/src/index.scss | 7 ++ .../CreateTearsheetNarrow/vite.config.js | 7 ++ .../DataSpreadsheet/index.html | 9 +++ .../DataSpreadsheet/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../DataSpreadsheet/src/index.scss | 7 ++ .../DataSpreadsheet/vite.config.js | 7 ++ .../Datagrid/index.html | 9 +++ .../Datagrid/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../Datagrid/src/index.scss | 7 ++ .../Datagrid/vite.config.js | 7 ++ .../Decorator/index.html | 9 +++ .../Decorator/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../Decorator/src/index.scss | 7 ++ .../Decorator/vite.config.js | 7 ++ .../DelimitedList/index.html | 9 +++ .../DelimitedList/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../DelimitedList/src/index.scss | 7 ++ .../DelimitedList/vite.config.js | 7 ++ .../DescriptionList/index.html | 9 +++ .../DescriptionList/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../DescriptionList/src/index.scss | 7 ++ .../DescriptionList/vite.config.js | 7 ++ .../EditInPlace/index.html | 9 +++ .../EditInPlace/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../EditInPlace/src/index.scss | 7 ++ .../EditInPlace/vite.config.js | 7 ++ .../EmptyStates/index.html | 9 +++ .../EmptyStates/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../EmptyStates/src/index.scss | 7 ++ .../EmptyStates/vite.config.js | 7 ++ .../ExportModal/index.html | 9 +++ .../ExportModal/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../ExportModal/src/index.scss | 7 ++ .../ExportModal/vite.config.js | 7 ++ .../ExpressiveCard/index.html | 9 +++ .../ExpressiveCard/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../ExpressiveCard/src/index.scss | 7 ++ .../ExpressiveCard/vite.config.js | 7 ++ .../FilterPanel/index.html | 9 +++ .../FilterPanel/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../FilterPanel/src/index.scss | 7 ++ .../FilterPanel/vite.config.js | 7 ++ .../FullPageError/index.html | 9 +++ .../FullPageError/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../FullPageError/src/index.scss | 7 ++ .../FullPageError/vite.config.js | 7 ++ .../GetStartedCard/README.md | 61 ++++++++++++++++ .../GetStartedCard/index.html | 25 +++++++ .../GetStartedCard/package.json | 55 +++++++++++++- .../GetStartedCard/src/App.jsx | 18 +++++ .../GetStartedCard/src/Example/Example.jsx | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 61 ++++++++++++++++ .../src/ThemeSelector/ThemeDropdown.jsx | 31 ++++++++ .../src/ThemeSelector/_theme-dropdown.scss | 68 ++++++++++++++++++ .../GetStartedCard/src/config.js | 3 + .../GetStartedCard/src/favicon.svg | 4 ++ .../GetStartedCard/src/index.scss | 11 +++ .../GetStartedCard/src/main.jsx | 12 ++++ .../GetStartedCard/vite.config.js | 18 +++++ .../HTTPErrors/index.html | 9 +++ .../HTTPErrors/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../HTTPErrors/src/index.scss | 7 ++ .../HTTPErrors/vite.config.js | 7 ++ .../ImportModal/index.html | 9 +++ .../ImportModal/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../ImportModal/src/index.scss | 7 ++ .../ImportModal/vite.config.js | 7 ++ .../InterstitialScreen/index.html | 9 +++ .../InterstitialScreen/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../InterstitialScreen/src/index.scss | 7 ++ .../InterstitialScreen/vite.config.js | 7 ++ .../InterstitialScreenView/index.html | 9 +++ .../InterstitialScreenView/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../InterstitialScreenView/src/index.scss | 7 ++ .../InterstitialScreenView/vite.config.js | 7 ++ .../InterstitialScreenViewModule/index.html | 9 +++ .../InterstitialScreenViewModule/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../src/index.scss | 7 ++ .../vite.config.js | 7 ++ .../carbon-for-ibm-products/Nav/index.html | 9 +++ .../carbon-for-ibm-products/Nav/package.json | 2 +- .../Nav/src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../Nav/src/index.scss | 7 ++ .../Nav/vite.config.js | 7 ++ .../NotificationsPanel/index.html | 9 +++ .../NotificationsPanel/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../NotificationsPanel/src/index.scss | 7 ++ .../NotificationsPanel/vite.config.js | 7 ++ .../OptionsTile/index.html | 9 +++ .../OptionsTile/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../OptionsTile/src/index.scss | 7 ++ .../OptionsTile/vite.config.js | 7 ++ .../PageHeader/index.html | 9 +++ .../PageHeader/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../PageHeader/src/index.scss | 7 ++ .../PageHeader/vite.config.js | 7 ++ .../ProductiveCard/index.html | 9 +++ .../ProductiveCard/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../ProductiveCard/src/index.scss | 7 ++ .../ProductiveCard/vite.config.js | 7 ++ .../RemoveModal/index.html | 9 +++ .../RemoveModal/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../RemoveModal/src/index.scss | 7 ++ .../RemoveModal/vite.config.js | 7 ++ .../carbon-for-ibm-products/Saving/index.html | 9 +++ .../Saving/package.json | 2 +- .../Saving/src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../Saving/src/index.scss | 7 ++ .../Saving/vite.config.js | 7 ++ .../ScrollGradient/index.html | 9 +++ .../ScrollGradient/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../ScrollGradient/src/index.scss | 7 ++ .../ScrollGradient/vite.config.js | 7 ++ .../SearchBar/index.html | 9 +++ .../SearchBar/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../SearchBar/src/index.scss | 7 ++ .../SearchBar/vite.config.js | 7 ++ .../SidePanel/index.html | 9 +++ .../SidePanel/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../SidePanel/src/index.scss | 7 ++ .../SidePanel/vite.config.js | 7 ++ .../StatusIcon/index.html | 9 +++ .../StatusIcon/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../StatusIcon/src/index.scss | 7 ++ .../StatusIcon/vite.config.js | 7 ++ .../StatusIndicator/index.html | 9 +++ .../StatusIndicator/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../StatusIndicator/src/index.scss | 7 ++ .../StatusIndicator/vite.config.js | 7 ++ .../StringFormatter/index.html | 9 +++ .../StringFormatter/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../StringFormatter/src/index.scss | 7 ++ .../StringFormatter/vite.config.js | 7 ++ .../TagOverflow/index.html | 9 +++ .../TagOverflow/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../TagOverflow/src/index.scss | 7 ++ .../TagOverflow/vite.config.js | 7 ++ .../carbon-for-ibm-products/TagSet/index.html | 9 +++ .../TagSet/package.json | 2 +- .../TagSet/src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../TagSet/src/index.scss | 7 ++ .../TagSet/vite.config.js | 7 ++ .../Tearsheet/index.html | 9 +++ .../Tearsheet/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../Tearsheet/src/index.scss | 7 ++ .../Tearsheet/vite.config.js | 7 ++ .../TruncatedList/index.html | 9 +++ .../TruncatedList/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../TruncatedList/src/index.scss | 7 ++ .../TruncatedList/vite.config.js | 7 ++ .../UserAvatar/index.html | 9 +++ .../UserAvatar/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../UserAvatar/src/index.scss | 7 ++ .../UserAvatar/vite.config.js | 7 ++ .../UserProfileImage/index.html | 9 +++ .../UserProfileImage/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../UserProfileImage/src/index.scss | 7 ++ .../UserProfileImage/vite.config.js | 7 ++ .../WebTerminal/index.html | 9 +++ .../WebTerminal/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../WebTerminal/src/index.scss | 7 ++ .../WebTerminal/vite.config.js | 7 ++ .../ConditionBuilder--thumbnail.png | Bin 0 -> 78602 bytes .../GetStartedCard--thumbnail.png | Bin 0 -> 78602 bytes .../src/gallery-config/index.js | 12 ++++ .../gallery-examples.test.js | 14 ++++ .../prefix-example/index.html | 9 +++ .../prefix-example/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../prefix-example/src/index.scss | 7 ++ .../prefix-example/vite.config.js | 7 ++ .../react-16-example/index.html | 9 +++ .../react-16-example/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../react-16-example/src/index.scss | 7 ++ .../react-16-example/vite.config.js | 7 ++ .../react-17-example/index.html | 9 +++ .../react-17-example/package.json | 2 +- .../src/ThemeSelector/ThemeContext.jsx | 15 ++-- .../src/ThemeSelector/_theme-dropdown.scss | 37 ++++++++++ .../react-17-example/src/index.scss | 7 ++ .../react-17-example/vite.config.js | 7 ++ 359 files changed, 4718 insertions(+), 278 deletions(-) create mode 100644 examples/carbon-for-ibm-products/ConditionBuilder/README.md create mode 100644 examples/carbon-for-ibm-products/ConditionBuilder/index.html create mode 100644 examples/carbon-for-ibm-products/ConditionBuilder/src/App.jsx create mode 100644 examples/carbon-for-ibm-products/ConditionBuilder/src/ThemeSelector/ThemeContext.jsx create mode 100644 examples/carbon-for-ibm-products/ConditionBuilder/src/ThemeSelector/ThemeDropdown.jsx create mode 100644 examples/carbon-for-ibm-products/ConditionBuilder/src/ThemeSelector/_theme-dropdown.scss create mode 100644 examples/carbon-for-ibm-products/ConditionBuilder/src/config.js create mode 100644 examples/carbon-for-ibm-products/ConditionBuilder/src/favicon.svg create mode 100644 examples/carbon-for-ibm-products/ConditionBuilder/src/index.scss create mode 100644 examples/carbon-for-ibm-products/ConditionBuilder/src/main.jsx create mode 100644 examples/carbon-for-ibm-products/ConditionBuilder/vite.config.js create mode 100644 examples/carbon-for-ibm-products/GetStartedCard/README.md create mode 100644 examples/carbon-for-ibm-products/GetStartedCard/index.html create mode 100644 examples/carbon-for-ibm-products/GetStartedCard/src/App.jsx create mode 100644 examples/carbon-for-ibm-products/GetStartedCard/src/ThemeSelector/ThemeContext.jsx create mode 100644 examples/carbon-for-ibm-products/GetStartedCard/src/ThemeSelector/ThemeDropdown.jsx create mode 100644 examples/carbon-for-ibm-products/GetStartedCard/src/ThemeSelector/_theme-dropdown.scss create mode 100644 examples/carbon-for-ibm-products/GetStartedCard/src/config.js create mode 100644 examples/carbon-for-ibm-products/GetStartedCard/src/favicon.svg create mode 100644 examples/carbon-for-ibm-products/GetStartedCard/src/index.scss create mode 100644 examples/carbon-for-ibm-products/GetStartedCard/src/main.jsx create mode 100644 examples/carbon-for-ibm-products/GetStartedCard/vite.config.js create mode 100644 examples/carbon-for-ibm-products/example-gallery/src/gallery-config/ConditionBuilder--thumbnail.png create mode 100644 examples/carbon-for-ibm-products/example-gallery/src/gallery-config/GetStartedCard--thumbnail.png diff --git a/examples/carbon-for-ibm-products/APIKeyModal/index.html b/examples/carbon-for-ibm-products/APIKeyModal/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/APIKeyModal/index.html +++ b/examples/carbon-for-ibm-products/APIKeyModal/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/APIKeyModal/package.json b/examples/carbon-for-ibm-products/APIKeyModal/package.json index 455895eab1..5195e76e59 100644 --- a/examples/carbon-for-ibm-products/APIKeyModal/package.json +++ b/examples/carbon-for-ibm-products/APIKeyModal/package.json @@ -21,7 +21,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/APIKeyModal/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/APIKeyModal/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/APIKeyModal/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/APIKeyModal/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/APIKeyModal/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/APIKeyModal/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/APIKeyModal/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/APIKeyModal/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/APIKeyModal/src/index.scss b/examples/carbon-for-ibm-products/APIKeyModal/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/APIKeyModal/src/index.scss +++ b/examples/carbon-for-ibm-products/APIKeyModal/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/APIKeyModal/vite.config.js b/examples/carbon-for-ibm-products/APIKeyModal/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/APIKeyModal/vite.config.js +++ b/examples/carbon-for-ibm-products/APIKeyModal/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/AboutModal/index.html b/examples/carbon-for-ibm-products/AboutModal/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/AboutModal/index.html +++ b/examples/carbon-for-ibm-products/AboutModal/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/AboutModal/package.json b/examples/carbon-for-ibm-products/AboutModal/package.json index 46c7e31f44..75a547c059 100644 --- a/examples/carbon-for-ibm-products/AboutModal/package.json +++ b/examples/carbon-for-ibm-products/AboutModal/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/AboutModal/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/AboutModal/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/AboutModal/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/AboutModal/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/AboutModal/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/AboutModal/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/AboutModal/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/AboutModal/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/AboutModal/src/index.scss b/examples/carbon-for-ibm-products/AboutModal/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/AboutModal/src/index.scss +++ b/examples/carbon-for-ibm-products/AboutModal/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/AboutModal/vite.config.js b/examples/carbon-for-ibm-products/AboutModal/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/AboutModal/vite.config.js +++ b/examples/carbon-for-ibm-products/AboutModal/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/BigNumbers/index.html b/examples/carbon-for-ibm-products/BigNumbers/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/BigNumbers/index.html +++ b/examples/carbon-for-ibm-products/BigNumbers/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/BigNumbers/package.json b/examples/carbon-for-ibm-products/BigNumbers/package.json index eb67588b2d..3580c253f2 100644 --- a/examples/carbon-for-ibm-products/BigNumbers/package.json +++ b/examples/carbon-for-ibm-products/BigNumbers/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/BigNumbers/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/BigNumbers/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/BigNumbers/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/BigNumbers/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/BigNumbers/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/BigNumbers/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/BigNumbers/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/BigNumbers/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/BigNumbers/src/index.scss b/examples/carbon-for-ibm-products/BigNumbers/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/BigNumbers/src/index.scss +++ b/examples/carbon-for-ibm-products/BigNumbers/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/BigNumbers/vite.config.js b/examples/carbon-for-ibm-products/BigNumbers/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/BigNumbers/vite.config.js +++ b/examples/carbon-for-ibm-products/BigNumbers/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/Cascade/index.html b/examples/carbon-for-ibm-products/Cascade/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/Cascade/index.html +++ b/examples/carbon-for-ibm-products/Cascade/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/Cascade/package.json b/examples/carbon-for-ibm-products/Cascade/package.json index 37ccd395d8..9771e460b2 100644 --- a/examples/carbon-for-ibm-products/Cascade/package.json +++ b/examples/carbon-for-ibm-products/Cascade/package.json @@ -18,7 +18,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/Cascade/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/Cascade/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/Cascade/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/Cascade/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/Cascade/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/Cascade/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/Cascade/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/Cascade/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/Cascade/src/index.scss b/examples/carbon-for-ibm-products/Cascade/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/Cascade/src/index.scss +++ b/examples/carbon-for-ibm-products/Cascade/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/Cascade/vite.config.js b/examples/carbon-for-ibm-products/Cascade/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/Cascade/vite.config.js +++ b/examples/carbon-for-ibm-products/Cascade/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/Coachmark/index.html b/examples/carbon-for-ibm-products/Coachmark/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/Coachmark/index.html +++ b/examples/carbon-for-ibm-products/Coachmark/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/Coachmark/package.json b/examples/carbon-for-ibm-products/Coachmark/package.json index fd38daec7e..aa6c71631f 100644 --- a/examples/carbon-for-ibm-products/Coachmark/package.json +++ b/examples/carbon-for-ibm-products/Coachmark/package.json @@ -18,7 +18,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/Coachmark/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/Coachmark/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/Coachmark/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/Coachmark/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/Coachmark/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/Coachmark/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/Coachmark/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/Coachmark/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/Coachmark/src/index.scss b/examples/carbon-for-ibm-products/Coachmark/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/Coachmark/src/index.scss +++ b/examples/carbon-for-ibm-products/Coachmark/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/Coachmark/vite.config.js b/examples/carbon-for-ibm-products/Coachmark/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/Coachmark/vite.config.js +++ b/examples/carbon-for-ibm-products/Coachmark/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/CoachmarkBeacon/index.html b/examples/carbon-for-ibm-products/CoachmarkBeacon/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/CoachmarkBeacon/index.html +++ b/examples/carbon-for-ibm-products/CoachmarkBeacon/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/CoachmarkBeacon/package.json b/examples/carbon-for-ibm-products/CoachmarkBeacon/package.json index 340c8be191..06799b38e6 100644 --- a/examples/carbon-for-ibm-products/CoachmarkBeacon/package.json +++ b/examples/carbon-for-ibm-products/CoachmarkBeacon/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/CoachmarkBeacon/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/CoachmarkBeacon/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/CoachmarkBeacon/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/CoachmarkBeacon/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/CoachmarkBeacon/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/CoachmarkBeacon/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/CoachmarkBeacon/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/CoachmarkBeacon/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/CoachmarkBeacon/src/index.scss b/examples/carbon-for-ibm-products/CoachmarkBeacon/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/CoachmarkBeacon/src/index.scss +++ b/examples/carbon-for-ibm-products/CoachmarkBeacon/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/CoachmarkBeacon/vite.config.js b/examples/carbon-for-ibm-products/CoachmarkBeacon/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/CoachmarkBeacon/vite.config.js +++ b/examples/carbon-for-ibm-products/CoachmarkBeacon/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/CoachmarkButton/index.html b/examples/carbon-for-ibm-products/CoachmarkButton/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/CoachmarkButton/index.html +++ b/examples/carbon-for-ibm-products/CoachmarkButton/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/CoachmarkButton/package.json b/examples/carbon-for-ibm-products/CoachmarkButton/package.json index d38893a482..a8ff773d89 100644 --- a/examples/carbon-for-ibm-products/CoachmarkButton/package.json +++ b/examples/carbon-for-ibm-products/CoachmarkButton/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/CoachmarkButton/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/CoachmarkButton/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/CoachmarkButton/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/CoachmarkButton/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/CoachmarkButton/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/CoachmarkButton/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/CoachmarkButton/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/CoachmarkButton/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/CoachmarkButton/src/index.scss b/examples/carbon-for-ibm-products/CoachmarkButton/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/CoachmarkButton/src/index.scss +++ b/examples/carbon-for-ibm-products/CoachmarkButton/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/CoachmarkButton/vite.config.js b/examples/carbon-for-ibm-products/CoachmarkButton/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/CoachmarkButton/vite.config.js +++ b/examples/carbon-for-ibm-products/CoachmarkButton/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/CoachmarkFixed/index.html b/examples/carbon-for-ibm-products/CoachmarkFixed/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/CoachmarkFixed/index.html +++ b/examples/carbon-for-ibm-products/CoachmarkFixed/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/CoachmarkFixed/package.json b/examples/carbon-for-ibm-products/CoachmarkFixed/package.json index 50f617a948..66f9c42faa 100644 --- a/examples/carbon-for-ibm-products/CoachmarkFixed/package.json +++ b/examples/carbon-for-ibm-products/CoachmarkFixed/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/CoachmarkFixed/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/CoachmarkFixed/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/CoachmarkFixed/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/CoachmarkFixed/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/CoachmarkFixed/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/CoachmarkFixed/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/CoachmarkFixed/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/CoachmarkFixed/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/CoachmarkFixed/src/index.scss b/examples/carbon-for-ibm-products/CoachmarkFixed/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/CoachmarkFixed/src/index.scss +++ b/examples/carbon-for-ibm-products/CoachmarkFixed/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/CoachmarkFixed/vite.config.js b/examples/carbon-for-ibm-products/CoachmarkFixed/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/CoachmarkFixed/vite.config.js +++ b/examples/carbon-for-ibm-products/CoachmarkFixed/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/CoachmarkOverlayElement/index.html b/examples/carbon-for-ibm-products/CoachmarkOverlayElement/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/CoachmarkOverlayElement/index.html +++ b/examples/carbon-for-ibm-products/CoachmarkOverlayElement/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/CoachmarkOverlayElement/package.json b/examples/carbon-for-ibm-products/CoachmarkOverlayElement/package.json index 529c8c7162..d321f1346f 100644 --- a/examples/carbon-for-ibm-products/CoachmarkOverlayElement/package.json +++ b/examples/carbon-for-ibm-products/CoachmarkOverlayElement/package.json @@ -21,7 +21,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/CoachmarkOverlayElement/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/CoachmarkOverlayElement/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/CoachmarkOverlayElement/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/CoachmarkOverlayElement/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/CoachmarkOverlayElement/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/CoachmarkOverlayElement/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/CoachmarkOverlayElement/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/CoachmarkOverlayElement/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/CoachmarkOverlayElement/src/index.scss b/examples/carbon-for-ibm-products/CoachmarkOverlayElement/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/CoachmarkOverlayElement/src/index.scss +++ b/examples/carbon-for-ibm-products/CoachmarkOverlayElement/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/CoachmarkOverlayElement/vite.config.js b/examples/carbon-for-ibm-products/CoachmarkOverlayElement/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/CoachmarkOverlayElement/vite.config.js +++ b/examples/carbon-for-ibm-products/CoachmarkOverlayElement/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/CoachmarkOverlayElements/index.html b/examples/carbon-for-ibm-products/CoachmarkOverlayElements/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/CoachmarkOverlayElements/index.html +++ b/examples/carbon-for-ibm-products/CoachmarkOverlayElements/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/CoachmarkOverlayElements/package.json b/examples/carbon-for-ibm-products/CoachmarkOverlayElements/package.json index 9d9c6dc8e8..25b3009a87 100644 --- a/examples/carbon-for-ibm-products/CoachmarkOverlayElements/package.json +++ b/examples/carbon-for-ibm-products/CoachmarkOverlayElements/package.json @@ -21,7 +21,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/CoachmarkOverlayElements/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/CoachmarkOverlayElements/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/CoachmarkOverlayElements/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/CoachmarkOverlayElements/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/CoachmarkOverlayElements/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/CoachmarkOverlayElements/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/CoachmarkOverlayElements/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/CoachmarkOverlayElements/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/CoachmarkOverlayElements/src/index.scss b/examples/carbon-for-ibm-products/CoachmarkOverlayElements/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/CoachmarkOverlayElements/src/index.scss +++ b/examples/carbon-for-ibm-products/CoachmarkOverlayElements/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/CoachmarkOverlayElements/vite.config.js b/examples/carbon-for-ibm-products/CoachmarkOverlayElements/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/CoachmarkOverlayElements/vite.config.js +++ b/examples/carbon-for-ibm-products/CoachmarkOverlayElements/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/CoachmarkStack/index.html b/examples/carbon-for-ibm-products/CoachmarkStack/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/CoachmarkStack/index.html +++ b/examples/carbon-for-ibm-products/CoachmarkStack/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/CoachmarkStack/package.json b/examples/carbon-for-ibm-products/CoachmarkStack/package.json index 06ae1696a3..10ca37c6fc 100644 --- a/examples/carbon-for-ibm-products/CoachmarkStack/package.json +++ b/examples/carbon-for-ibm-products/CoachmarkStack/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/CoachmarkStack/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/CoachmarkStack/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/CoachmarkStack/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/CoachmarkStack/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/CoachmarkStack/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/CoachmarkStack/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/CoachmarkStack/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/CoachmarkStack/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/CoachmarkStack/src/index.scss b/examples/carbon-for-ibm-products/CoachmarkStack/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/CoachmarkStack/src/index.scss +++ b/examples/carbon-for-ibm-products/CoachmarkStack/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/CoachmarkStack/vite.config.js b/examples/carbon-for-ibm-products/CoachmarkStack/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/CoachmarkStack/vite.config.js +++ b/examples/carbon-for-ibm-products/CoachmarkStack/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/ConditionBuilder/README.md b/examples/carbon-for-ibm-products/ConditionBuilder/README.md new file mode 100644 index 0000000000..7fe2245096 --- /dev/null +++ b/examples/carbon-for-ibm-products/ConditionBuilder/README.md @@ -0,0 +1,61 @@ +# Carbon for IBM Products `ConditionBuilder` example + +This example was initially generated by `@carbon/ibm-products` using the script `update-gallery-config` found in `package.json`. + +## Adding an example + +If using the `generate` script then a base example should be created for you. If for some reason this is not the case do the following: + +1. Duplicate an existing example e.g. `examples/carbon-for-ibm-products/AboutModal` and rename it to your match your component e.g. `MyComponent` +2. Edit `gallery.config.json` which has the following form. + +```json +{ + "label": "Name of example in gallery", + "package-config": { + "flags": { + "component": { + "MyComponent": true + }, + "feature": { + "MyFeature": true + } + "prefix": "alt-prefix", + }, + "templates-variation": "templates-react-16" + } +} +``` + +NOTE: All fields are optional, although most specify a label. + +The `package-config` section is used to specify the config used with the example, including prefix and any flags enabled. + +The `template-variation` is used to specify an alternative to the default template. This is currently used for React versions only. + +3. Edit the `src/Example` folder to show your component. +4. Run the example and replace `thumbnail.png` with a picture of your example. + +NOTE 2: The only files retained after each run of the update script are `thumbnail.png`, `gallery.config.json`, and those in `src/Example`, so ensure all of your example source sits in the `src/Example` folder. + +## Updating examples + +Skip step 1 for `Adding an example` otherwise the same. + +## Adding / Updating a template or variant + +The simplest way to update a template is as follows. + +1. Copy the a generated example to the `scripts/example-gallery-builder/update-example` folder. +2. Update it as necessary. +3. Test that it works. +4. Remove the folder `scripts/example-gallery-builder/update-example/templates` and rename your folder to this. +5. Review the changes made and restore/rectify the template TAGS typically in capitals. These are replaced as part of the build process. E.g. ConditionBuilder, 2024, import './config' +. For a full set of current tags review the code in `scripts/example-gallery-builder/update-example/index.js`. +6. Remove the files `gallery.config.json`, `thumbnail.png` and the folder `src/Example`. + +### If a variant + +To reduce maintenance variants only need files which differ from the core `templates` folder. Delete any new files you did not intend to add. + +Variants are selected by folder name in the `gallery.config.json` file. diff --git a/examples/carbon-for-ibm-products/ConditionBuilder/index.html b/examples/carbon-for-ibm-products/ConditionBuilder/index.html new file mode 100644 index 0000000000..5d37ff8603 --- /dev/null +++ b/examples/carbon-for-ibm-products/ConditionBuilder/index.html @@ -0,0 +1,25 @@ + + + + + + + + + + Vite + React + + + +
+ + + + \ No newline at end of file diff --git a/examples/carbon-for-ibm-products/ConditionBuilder/package.json b/examples/carbon-for-ibm-products/ConditionBuilder/package.json index 1d0d023863..204aa71c49 100644 --- a/examples/carbon-for-ibm-products/ConditionBuilder/package.json +++ b/examples/carbon-for-ibm-products/ConditionBuilder/package.json @@ -1,4 +1,56 @@ { "name": "ConditionBuilder-component-example", - "note": "Run `update-gallery-config to generate." + "description": "An example showing use of the ConditionBuilder component from the @carbon/ibm-products component library.", + "keywords": [ + "carbon", + "ibm", + "ibm-products", + "component", + "conditionbuilder", + "condition", + "builder" + ], + "license": "Apache-2.0", + "type": "module", + "scripts": { + "dev": "vite", + "build": "vite build", + "lint": "eslint src --ext js,jsx --report-unused-disable-directives --max-warnings 0", + "preview": "vite preview" + }, + "dependencies": { + "@carbon/ibm-products": "^2.21.0", + "@carbon/react": "^1.60.3", + "lodash": "^4.17.21", + "react": "^18.2.0", + "react-dom": "^18.2.0", + "sass": "^1.70.0" + }, + "devDependencies": { + "@types/react": "^18.2.48", + "@types/react-dom": "^18.2.18", + "@vitejs/plugin-react": "^4.2.1", + "eslint": "^8.56.0", + "eslint-plugin-react": "^7.33.2", + "eslint-plugin-react-hooks": "^4.6.0", + "eslint-plugin-react-refresh": "^0.4.5", + "vite": "^4.5.3" + }, + "browserslist": { + "production": [ + ">0.2%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 1 chrome version", + "last 1 firefox version", + "last 1 safari version" + ] + }, + "eslintConfig": { + "extends": [ + "react-app" + ] + } } diff --git a/examples/carbon-for-ibm-products/ConditionBuilder/src/App.jsx b/examples/carbon-for-ibm-products/ConditionBuilder/src/App.jsx new file mode 100644 index 0000000000..3406fb08c3 --- /dev/null +++ b/examples/carbon-for-ibm-products/ConditionBuilder/src/App.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import { ThemeProvider } from './ThemeSelector/ThemeContext'; +import { ThemeDropdown } from './ThemeSelector/ThemeDropdown'; +import './config'; +import Example from './Example/Example'; + +function App() { + return ( +
+ + + + +
+ ); +} + +export default App; diff --git a/examples/carbon-for-ibm-products/ConditionBuilder/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/ConditionBuilder/src/ThemeSelector/ThemeContext.jsx new file mode 100644 index 0000000000..c3972fc82c --- /dev/null +++ b/examples/carbon-for-ibm-products/ConditionBuilder/src/ThemeSelector/ThemeContext.jsx @@ -0,0 +1,61 @@ +import React, { createContext, useReducer } from 'react'; + +export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, + { + text: 'White', + value: 'carbon-theme--white', + }, + { + text: 'Gray 10', + value: 'carbon-theme--g10', + }, + { + text: 'Gray 90', + value: 'carbon-theme--g90', + }, + { + text: 'Gray 100', + value: 'carbon-theme--g100', + }, +]; + +export const ThemeContext = createContext(); + +const initialState = { + currentTheme: themeData[1], +}; + +const themeReducer = (state, action) => { + switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': + case 'carbon-theme--white': + case 'carbon-theme--g10': + case 'carbon-theme--g90': + case 'carbon-theme--g100': + return { currentTheme: action.type }; + default: + return state; + } +}; + +export function ThemeProvider(props) { + const [state, dispatch] = useReducer(themeReducer, initialState); + + return ( + + { + // eslint-disable-next-line react/prop-types + props.children + } + + ); +} diff --git a/examples/carbon-for-ibm-products/ConditionBuilder/src/ThemeSelector/ThemeDropdown.jsx b/examples/carbon-for-ibm-products/ConditionBuilder/src/ThemeSelector/ThemeDropdown.jsx new file mode 100644 index 0000000000..091f7241da --- /dev/null +++ b/examples/carbon-for-ibm-products/ConditionBuilder/src/ThemeSelector/ThemeDropdown.jsx @@ -0,0 +1,31 @@ +import React, { useContext } from 'react'; +import { Dropdown } from '@carbon/react'; +import { ThemeContext, themeData } from './ThemeContext'; + +import './_theme-dropdown.scss'; + +export const ThemeDropdown = () => { + const theme = useContext(ThemeContext); + + const setTheme = (selectedItem) => { + const bodyElement = document.body; + bodyElement.className = selectedItem.value; + theme.dispatch({ type: selectedItem }); + }; + + return ( +
+ (item ? item.text : '')} + onChange={(event) => setTheme(event.selectedItem)} + selectedItem={theme.state.currentTheme} + label="Select a Carbon theme" + titleText="Select a Carbon theme" + /> +
+ ); +}; diff --git a/examples/carbon-for-ibm-products/ConditionBuilder/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/ConditionBuilder/src/ThemeSelector/_theme-dropdown.scss new file mode 100644 index 0000000000..dfffdea257 --- /dev/null +++ b/examples/carbon-for-ibm-products/ConditionBuilder/src/ThemeSelector/_theme-dropdown.scss @@ -0,0 +1,68 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + +@use '@carbon/styles/scss/theme' as *; +@use '@carbon/styles/scss/themes'; +@use '@carbon/styles/scss/type'; +@use '@carbon/styles/scss/config'; + +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + +.carbon-theme--white { + @include theme(themes.$white, true); +} + +.carbon-theme--g10 { + @include theme(themes.$g10, true); +} + +.carbon-theme--g90 { + @include theme(themes.$g90, true); +} + +.carbon-theme--g100 { + @include theme(themes.$g100, true); +} + +.carbon-theme-dropdown { + position: fixed; + bottom: 1rem; // stylelint-disable-line carbon/layout-token-use + left: 1rem; // stylelint-disable-line carbon/layout-token-use + min-width: 11.5rem; +} + +.carbon-theme-dropdown .#{config.$prefix}--label { + @include type.type-style('label-01'); +} diff --git a/examples/carbon-for-ibm-products/ConditionBuilder/src/config.js b/examples/carbon-for-ibm-products/ConditionBuilder/src/config.js new file mode 100644 index 0000000000..e733b064bd --- /dev/null +++ b/examples/carbon-for-ibm-products/ConditionBuilder/src/config.js @@ -0,0 +1,3 @@ +import { pkg } from '@carbon/ibm-products'; + +pkg.component.ConditionBuilder = true; diff --git a/examples/carbon-for-ibm-products/ConditionBuilder/src/favicon.svg b/examples/carbon-for-ibm-products/ConditionBuilder/src/favicon.svg new file mode 100644 index 0000000000..9fef3d7aab --- /dev/null +++ b/examples/carbon-for-ibm-products/ConditionBuilder/src/favicon.svg @@ -0,0 +1,4 @@ + + + diff --git a/examples/carbon-for-ibm-products/ConditionBuilder/src/index.scss b/examples/carbon-for-ibm-products/ConditionBuilder/src/index.scss new file mode 100644 index 0000000000..b008a957c7 --- /dev/null +++ b/examples/carbon-for-ibm-products/ConditionBuilder/src/index.scss @@ -0,0 +1,11 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + +@use '@carbon/react' with ( + $font-path: '@ibm/plex' +); +@use '@carbon/ibm-products/css/index'; diff --git a/examples/carbon-for-ibm-products/ConditionBuilder/src/main.jsx b/examples/carbon-for-ibm-products/ConditionBuilder/src/main.jsx new file mode 100644 index 0000000000..91e8d06798 --- /dev/null +++ b/examples/carbon-for-ibm-products/ConditionBuilder/src/main.jsx @@ -0,0 +1,12 @@ +import React from 'react'; +import { createRoot } from 'react-dom'; +import App from './App.jsx'; +import './index.scss'; + +const root = createRoot(document.getElementById('root')); + +root.render( + + + +); diff --git a/examples/carbon-for-ibm-products/ConditionBuilder/vite.config.js b/examples/carbon-for-ibm-products/ConditionBuilder/vite.config.js new file mode 100644 index 0000000000..5ad2480f5b --- /dev/null +++ b/examples/carbon-for-ibm-products/ConditionBuilder/vite.config.js @@ -0,0 +1,18 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + +import { defineConfig } from 'vite'; +import react from '@vitejs/plugin-react'; + +// https://vitejs.dev/config/ +export default defineConfig({ + plugins: [ + react({ + jsxRuntime: 'classic', + }), + ], +}); diff --git a/examples/carbon-for-ibm-products/CreateFullPage/index.html b/examples/carbon-for-ibm-products/CreateFullPage/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/CreateFullPage/index.html +++ b/examples/carbon-for-ibm-products/CreateFullPage/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/CreateFullPage/package.json b/examples/carbon-for-ibm-products/CreateFullPage/package.json index 4d7acd901d..b0af7b2212 100644 --- a/examples/carbon-for-ibm-products/CreateFullPage/package.json +++ b/examples/carbon-for-ibm-products/CreateFullPage/package.json @@ -21,7 +21,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/CreateFullPage/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/CreateFullPage/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/CreateFullPage/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/CreateFullPage/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/CreateFullPage/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/CreateFullPage/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/CreateFullPage/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/CreateFullPage/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/CreateFullPage/src/index.scss b/examples/carbon-for-ibm-products/CreateFullPage/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/CreateFullPage/src/index.scss +++ b/examples/carbon-for-ibm-products/CreateFullPage/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/CreateFullPage/vite.config.js b/examples/carbon-for-ibm-products/CreateFullPage/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/CreateFullPage/vite.config.js +++ b/examples/carbon-for-ibm-products/CreateFullPage/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/CreateModal/index.html b/examples/carbon-for-ibm-products/CreateModal/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/CreateModal/index.html +++ b/examples/carbon-for-ibm-products/CreateModal/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/CreateModal/package.json b/examples/carbon-for-ibm-products/CreateModal/package.json index b585c4a9d4..ffb43676f7 100644 --- a/examples/carbon-for-ibm-products/CreateModal/package.json +++ b/examples/carbon-for-ibm-products/CreateModal/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/CreateModal/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/CreateModal/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/CreateModal/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/CreateModal/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/CreateModal/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/CreateModal/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/CreateModal/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/CreateModal/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/CreateModal/src/index.scss b/examples/carbon-for-ibm-products/CreateModal/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/CreateModal/src/index.scss +++ b/examples/carbon-for-ibm-products/CreateModal/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/CreateModal/vite.config.js b/examples/carbon-for-ibm-products/CreateModal/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/CreateModal/vite.config.js +++ b/examples/carbon-for-ibm-products/CreateModal/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/CreateSidePanel/index.html b/examples/carbon-for-ibm-products/CreateSidePanel/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/CreateSidePanel/index.html +++ b/examples/carbon-for-ibm-products/CreateSidePanel/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/CreateSidePanel/package.json b/examples/carbon-for-ibm-products/CreateSidePanel/package.json index e216378cf9..5ec9821ce4 100644 --- a/examples/carbon-for-ibm-products/CreateSidePanel/package.json +++ b/examples/carbon-for-ibm-products/CreateSidePanel/package.json @@ -21,7 +21,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/CreateSidePanel/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/CreateSidePanel/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/CreateSidePanel/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/CreateSidePanel/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/CreateSidePanel/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/CreateSidePanel/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/CreateSidePanel/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/CreateSidePanel/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/CreateSidePanel/src/index.scss b/examples/carbon-for-ibm-products/CreateSidePanel/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/CreateSidePanel/src/index.scss +++ b/examples/carbon-for-ibm-products/CreateSidePanel/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/CreateSidePanel/vite.config.js b/examples/carbon-for-ibm-products/CreateSidePanel/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/CreateSidePanel/vite.config.js +++ b/examples/carbon-for-ibm-products/CreateSidePanel/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/CreateTearsheet/index.html b/examples/carbon-for-ibm-products/CreateTearsheet/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/CreateTearsheet/index.html +++ b/examples/carbon-for-ibm-products/CreateTearsheet/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/CreateTearsheet/package.json b/examples/carbon-for-ibm-products/CreateTearsheet/package.json index 03af588001..ae8b6244ab 100644 --- a/examples/carbon-for-ibm-products/CreateTearsheet/package.json +++ b/examples/carbon-for-ibm-products/CreateTearsheet/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/CreateTearsheet/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/CreateTearsheet/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/CreateTearsheet/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/CreateTearsheet/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/CreateTearsheet/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/CreateTearsheet/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/CreateTearsheet/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/CreateTearsheet/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/CreateTearsheet/src/index.scss b/examples/carbon-for-ibm-products/CreateTearsheet/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/CreateTearsheet/src/index.scss +++ b/examples/carbon-for-ibm-products/CreateTearsheet/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/CreateTearsheet/vite.config.js b/examples/carbon-for-ibm-products/CreateTearsheet/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/CreateTearsheet/vite.config.js +++ b/examples/carbon-for-ibm-products/CreateTearsheet/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/CreateTearsheetNarrow/index.html b/examples/carbon-for-ibm-products/CreateTearsheetNarrow/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/CreateTearsheetNarrow/index.html +++ b/examples/carbon-for-ibm-products/CreateTearsheetNarrow/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/CreateTearsheetNarrow/package.json b/examples/carbon-for-ibm-products/CreateTearsheetNarrow/package.json index 01a1cf9a51..8a9de6d4b3 100644 --- a/examples/carbon-for-ibm-products/CreateTearsheetNarrow/package.json +++ b/examples/carbon-for-ibm-products/CreateTearsheetNarrow/package.json @@ -21,7 +21,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/CreateTearsheetNarrow/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/CreateTearsheetNarrow/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/CreateTearsheetNarrow/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/CreateTearsheetNarrow/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/CreateTearsheetNarrow/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/CreateTearsheetNarrow/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/CreateTearsheetNarrow/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/CreateTearsheetNarrow/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/CreateTearsheetNarrow/src/index.scss b/examples/carbon-for-ibm-products/CreateTearsheetNarrow/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/CreateTearsheetNarrow/src/index.scss +++ b/examples/carbon-for-ibm-products/CreateTearsheetNarrow/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/CreateTearsheetNarrow/vite.config.js b/examples/carbon-for-ibm-products/CreateTearsheetNarrow/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/CreateTearsheetNarrow/vite.config.js +++ b/examples/carbon-for-ibm-products/CreateTearsheetNarrow/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/DataSpreadsheet/index.html b/examples/carbon-for-ibm-products/DataSpreadsheet/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/DataSpreadsheet/index.html +++ b/examples/carbon-for-ibm-products/DataSpreadsheet/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/DataSpreadsheet/package.json b/examples/carbon-for-ibm-products/DataSpreadsheet/package.json index dae7371559..7e42a5c6c7 100644 --- a/examples/carbon-for-ibm-products/DataSpreadsheet/package.json +++ b/examples/carbon-for-ibm-products/DataSpreadsheet/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/DataSpreadsheet/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/DataSpreadsheet/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/DataSpreadsheet/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/DataSpreadsheet/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/DataSpreadsheet/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/DataSpreadsheet/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/DataSpreadsheet/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/DataSpreadsheet/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/DataSpreadsheet/src/index.scss b/examples/carbon-for-ibm-products/DataSpreadsheet/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/DataSpreadsheet/src/index.scss +++ b/examples/carbon-for-ibm-products/DataSpreadsheet/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/DataSpreadsheet/vite.config.js b/examples/carbon-for-ibm-products/DataSpreadsheet/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/DataSpreadsheet/vite.config.js +++ b/examples/carbon-for-ibm-products/DataSpreadsheet/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/Datagrid/index.html b/examples/carbon-for-ibm-products/Datagrid/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/Datagrid/index.html +++ b/examples/carbon-for-ibm-products/Datagrid/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/Datagrid/package.json b/examples/carbon-for-ibm-products/Datagrid/package.json index d9c638341e..f9ff272137 100644 --- a/examples/carbon-for-ibm-products/Datagrid/package.json +++ b/examples/carbon-for-ibm-products/Datagrid/package.json @@ -18,7 +18,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/Datagrid/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/Datagrid/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/Datagrid/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/Datagrid/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/Datagrid/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/Datagrid/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/Datagrid/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/Datagrid/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/Datagrid/src/index.scss b/examples/carbon-for-ibm-products/Datagrid/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/Datagrid/src/index.scss +++ b/examples/carbon-for-ibm-products/Datagrid/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/Datagrid/vite.config.js b/examples/carbon-for-ibm-products/Datagrid/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/Datagrid/vite.config.js +++ b/examples/carbon-for-ibm-products/Datagrid/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/Decorator/index.html b/examples/carbon-for-ibm-products/Decorator/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/Decorator/index.html +++ b/examples/carbon-for-ibm-products/Decorator/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/Decorator/package.json b/examples/carbon-for-ibm-products/Decorator/package.json index 304402e3ce..2f38d6da63 100644 --- a/examples/carbon-for-ibm-products/Decorator/package.json +++ b/examples/carbon-for-ibm-products/Decorator/package.json @@ -18,7 +18,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/Decorator/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/Decorator/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/Decorator/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/Decorator/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/Decorator/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/Decorator/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/Decorator/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/Decorator/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/Decorator/src/index.scss b/examples/carbon-for-ibm-products/Decorator/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/Decorator/src/index.scss +++ b/examples/carbon-for-ibm-products/Decorator/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/Decorator/vite.config.js b/examples/carbon-for-ibm-products/Decorator/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/Decorator/vite.config.js +++ b/examples/carbon-for-ibm-products/Decorator/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/DelimitedList/index.html b/examples/carbon-for-ibm-products/DelimitedList/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/DelimitedList/index.html +++ b/examples/carbon-for-ibm-products/DelimitedList/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/DelimitedList/package.json b/examples/carbon-for-ibm-products/DelimitedList/package.json index d5368f7282..0d732d302d 100644 --- a/examples/carbon-for-ibm-products/DelimitedList/package.json +++ b/examples/carbon-for-ibm-products/DelimitedList/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/DelimitedList/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/DelimitedList/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/DelimitedList/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/DelimitedList/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/DelimitedList/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/DelimitedList/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/DelimitedList/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/DelimitedList/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/DelimitedList/src/index.scss b/examples/carbon-for-ibm-products/DelimitedList/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/DelimitedList/src/index.scss +++ b/examples/carbon-for-ibm-products/DelimitedList/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/DelimitedList/vite.config.js b/examples/carbon-for-ibm-products/DelimitedList/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/DelimitedList/vite.config.js +++ b/examples/carbon-for-ibm-products/DelimitedList/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/DescriptionList/index.html b/examples/carbon-for-ibm-products/DescriptionList/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/DescriptionList/index.html +++ b/examples/carbon-for-ibm-products/DescriptionList/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/DescriptionList/package.json b/examples/carbon-for-ibm-products/DescriptionList/package.json index 3df2fbdbd2..b6f27d8283 100644 --- a/examples/carbon-for-ibm-products/DescriptionList/package.json +++ b/examples/carbon-for-ibm-products/DescriptionList/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/DescriptionList/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/DescriptionList/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/DescriptionList/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/DescriptionList/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/DescriptionList/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/DescriptionList/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/DescriptionList/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/DescriptionList/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/DescriptionList/src/index.scss b/examples/carbon-for-ibm-products/DescriptionList/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/DescriptionList/src/index.scss +++ b/examples/carbon-for-ibm-products/DescriptionList/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/DescriptionList/vite.config.js b/examples/carbon-for-ibm-products/DescriptionList/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/DescriptionList/vite.config.js +++ b/examples/carbon-for-ibm-products/DescriptionList/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/EditInPlace/index.html b/examples/carbon-for-ibm-products/EditInPlace/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/EditInPlace/index.html +++ b/examples/carbon-for-ibm-products/EditInPlace/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/EditInPlace/package.json b/examples/carbon-for-ibm-products/EditInPlace/package.json index 26b52351dd..b5ccf763a7 100644 --- a/examples/carbon-for-ibm-products/EditInPlace/package.json +++ b/examples/carbon-for-ibm-products/EditInPlace/package.json @@ -21,7 +21,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/EditInPlace/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/EditInPlace/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/EditInPlace/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/EditInPlace/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/EditInPlace/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/EditInPlace/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/EditInPlace/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/EditInPlace/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/EditInPlace/src/index.scss b/examples/carbon-for-ibm-products/EditInPlace/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/EditInPlace/src/index.scss +++ b/examples/carbon-for-ibm-products/EditInPlace/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/EditInPlace/vite.config.js b/examples/carbon-for-ibm-products/EditInPlace/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/EditInPlace/vite.config.js +++ b/examples/carbon-for-ibm-products/EditInPlace/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/EmptyStates/index.html b/examples/carbon-for-ibm-products/EmptyStates/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/EmptyStates/index.html +++ b/examples/carbon-for-ibm-products/EmptyStates/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/EmptyStates/package.json b/examples/carbon-for-ibm-products/EmptyStates/package.json index 92ac884733..dc8e303e36 100644 --- a/examples/carbon-for-ibm-products/EmptyStates/package.json +++ b/examples/carbon-for-ibm-products/EmptyStates/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/EmptyStates/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/EmptyStates/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/EmptyStates/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/EmptyStates/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/EmptyStates/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/EmptyStates/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/EmptyStates/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/EmptyStates/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/EmptyStates/src/index.scss b/examples/carbon-for-ibm-products/EmptyStates/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/EmptyStates/src/index.scss +++ b/examples/carbon-for-ibm-products/EmptyStates/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/EmptyStates/vite.config.js b/examples/carbon-for-ibm-products/EmptyStates/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/EmptyStates/vite.config.js +++ b/examples/carbon-for-ibm-products/EmptyStates/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/ExportModal/index.html b/examples/carbon-for-ibm-products/ExportModal/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/ExportModal/index.html +++ b/examples/carbon-for-ibm-products/ExportModal/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/ExportModal/package.json b/examples/carbon-for-ibm-products/ExportModal/package.json index 463587d9c2..6f365993e2 100644 --- a/examples/carbon-for-ibm-products/ExportModal/package.json +++ b/examples/carbon-for-ibm-products/ExportModal/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/ExportModal/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/ExportModal/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/ExportModal/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/ExportModal/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/ExportModal/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/ExportModal/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/ExportModal/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/ExportModal/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/ExportModal/src/index.scss b/examples/carbon-for-ibm-products/ExportModal/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/ExportModal/src/index.scss +++ b/examples/carbon-for-ibm-products/ExportModal/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/ExportModal/vite.config.js b/examples/carbon-for-ibm-products/ExportModal/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/ExportModal/vite.config.js +++ b/examples/carbon-for-ibm-products/ExportModal/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/ExpressiveCard/index.html b/examples/carbon-for-ibm-products/ExpressiveCard/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/ExpressiveCard/index.html +++ b/examples/carbon-for-ibm-products/ExpressiveCard/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/ExpressiveCard/package.json b/examples/carbon-for-ibm-products/ExpressiveCard/package.json index 1f49187cc8..5926568931 100644 --- a/examples/carbon-for-ibm-products/ExpressiveCard/package.json +++ b/examples/carbon-for-ibm-products/ExpressiveCard/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/ExpressiveCard/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/ExpressiveCard/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/ExpressiveCard/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/ExpressiveCard/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/ExpressiveCard/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/ExpressiveCard/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/ExpressiveCard/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/ExpressiveCard/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/ExpressiveCard/src/index.scss b/examples/carbon-for-ibm-products/ExpressiveCard/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/ExpressiveCard/src/index.scss +++ b/examples/carbon-for-ibm-products/ExpressiveCard/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/ExpressiveCard/vite.config.js b/examples/carbon-for-ibm-products/ExpressiveCard/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/ExpressiveCard/vite.config.js +++ b/examples/carbon-for-ibm-products/ExpressiveCard/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/FilterPanel/index.html b/examples/carbon-for-ibm-products/FilterPanel/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/FilterPanel/index.html +++ b/examples/carbon-for-ibm-products/FilterPanel/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/FilterPanel/package.json b/examples/carbon-for-ibm-products/FilterPanel/package.json index cd4bc43a12..af247dea3a 100644 --- a/examples/carbon-for-ibm-products/FilterPanel/package.json +++ b/examples/carbon-for-ibm-products/FilterPanel/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/FilterPanel/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/FilterPanel/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/FilterPanel/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/FilterPanel/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/FilterPanel/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/FilterPanel/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/FilterPanel/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/FilterPanel/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/FilterPanel/src/index.scss b/examples/carbon-for-ibm-products/FilterPanel/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/FilterPanel/src/index.scss +++ b/examples/carbon-for-ibm-products/FilterPanel/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/FilterPanel/vite.config.js b/examples/carbon-for-ibm-products/FilterPanel/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/FilterPanel/vite.config.js +++ b/examples/carbon-for-ibm-products/FilterPanel/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/FullPageError/index.html b/examples/carbon-for-ibm-products/FullPageError/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/FullPageError/index.html +++ b/examples/carbon-for-ibm-products/FullPageError/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/FullPageError/package.json b/examples/carbon-for-ibm-products/FullPageError/package.json index 51dcb6635e..fd1dbd22f8 100644 --- a/examples/carbon-for-ibm-products/FullPageError/package.json +++ b/examples/carbon-for-ibm-products/FullPageError/package.json @@ -21,7 +21,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/FullPageError/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/FullPageError/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/FullPageError/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/FullPageError/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/FullPageError/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/FullPageError/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/FullPageError/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/FullPageError/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/FullPageError/src/index.scss b/examples/carbon-for-ibm-products/FullPageError/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/FullPageError/src/index.scss +++ b/examples/carbon-for-ibm-products/FullPageError/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/FullPageError/vite.config.js b/examples/carbon-for-ibm-products/FullPageError/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/FullPageError/vite.config.js +++ b/examples/carbon-for-ibm-products/FullPageError/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/GetStartedCard/README.md b/examples/carbon-for-ibm-products/GetStartedCard/README.md new file mode 100644 index 0000000000..102e05b63c --- /dev/null +++ b/examples/carbon-for-ibm-products/GetStartedCard/README.md @@ -0,0 +1,61 @@ +# Carbon for IBM Products `GetStartedCard` example + +This example was initially generated by `@carbon/ibm-products` using the script `update-gallery-config` found in `package.json`. + +## Adding an example + +If using the `generate` script then a base example should be created for you. If for some reason this is not the case do the following: + +1. Duplicate an existing example e.g. `examples/carbon-for-ibm-products/AboutModal` and rename it to your match your component e.g. `MyComponent` +2. Edit `gallery.config.json` which has the following form. + +```json +{ + "label": "Name of example in gallery", + "package-config": { + "flags": { + "component": { + "MyComponent": true + }, + "feature": { + "MyFeature": true + } + "prefix": "alt-prefix", + }, + "templates-variation": "templates-react-16" + } +} +``` + +NOTE: All fields are optional, although most specify a label. + +The `package-config` section is used to specify the config used with the example, including prefix and any flags enabled. + +The `template-variation` is used to specify an alternative to the default template. This is currently used for React versions only. + +3. Edit the `src/Example` folder to show your component. +4. Run the example and replace `thumbnail.png` with a picture of your example. + +NOTE 2: The only files retained after each run of the update script are `thumbnail.png`, `gallery.config.json`, and those in `src/Example`, so ensure all of your example source sits in the `src/Example` folder. + +## Updating examples + +Skip step 1 for `Adding an example` otherwise the same. + +## Adding / Updating a template or variant + +The simplest way to update a template is as follows. + +1. Copy the a generated example to the `scripts/example-gallery-builder/update-example` folder. +2. Update it as necessary. +3. Test that it works. +4. Remove the folder `scripts/example-gallery-builder/update-example/templates` and rename your folder to this. +5. Review the changes made and restore/rectify the template TAGS typically in capitals. These are replaced as part of the build process. E.g. GetStartedCard, 2024, import './config' +. For a full set of current tags review the code in `scripts/example-gallery-builder/update-example/index.js`. +6. Remove the files `gallery.config.json`, `thumbnail.png` and the folder `src/Example`. + +### If a variant + +To reduce maintenance variants only need files which differ from the core `templates` folder. Delete any new files you did not intend to add. + +Variants are selected by folder name in the `gallery.config.json` file. diff --git a/examples/carbon-for-ibm-products/GetStartedCard/index.html b/examples/carbon-for-ibm-products/GetStartedCard/index.html new file mode 100644 index 0000000000..5d37ff8603 --- /dev/null +++ b/examples/carbon-for-ibm-products/GetStartedCard/index.html @@ -0,0 +1,25 @@ + + + + + + + + + + Vite + React + + + +
+ + + + \ No newline at end of file diff --git a/examples/carbon-for-ibm-products/GetStartedCard/package.json b/examples/carbon-for-ibm-products/GetStartedCard/package.json index 60b3d26b2c..275a582394 100644 --- a/examples/carbon-for-ibm-products/GetStartedCard/package.json +++ b/examples/carbon-for-ibm-products/GetStartedCard/package.json @@ -1,4 +1,57 @@ { "name": "GetStartedCard-component-example", - "note": "Run `update-gallery-config to generate." + "description": "An example showing use of the GetStartedCard component from the @carbon/ibm-products component library.", + "keywords": [ + "carbon", + "ibm", + "ibm-products", + "component", + "getstartedcard", + "get", + "started", + "card" + ], + "license": "Apache-2.0", + "type": "module", + "scripts": { + "dev": "vite", + "build": "vite build", + "lint": "eslint src --ext js,jsx --report-unused-disable-directives --max-warnings 0", + "preview": "vite preview" + }, + "dependencies": { + "@carbon/ibm-products": "^2.21.0", + "@carbon/react": "^1.60.3", + "lodash": "^4.17.21", + "react": "^18.2.0", + "react-dom": "^18.2.0", + "sass": "^1.70.0" + }, + "devDependencies": { + "@types/react": "^18.2.48", + "@types/react-dom": "^18.2.18", + "@vitejs/plugin-react": "^4.2.1", + "eslint": "^8.56.0", + "eslint-plugin-react": "^7.33.2", + "eslint-plugin-react-hooks": "^4.6.0", + "eslint-plugin-react-refresh": "^0.4.5", + "vite": "^4.5.3" + }, + "browserslist": { + "production": [ + ">0.2%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 1 chrome version", + "last 1 firefox version", + "last 1 safari version" + ] + }, + "eslintConfig": { + "extends": [ + "react-app" + ] + } } diff --git a/examples/carbon-for-ibm-products/GetStartedCard/src/App.jsx b/examples/carbon-for-ibm-products/GetStartedCard/src/App.jsx new file mode 100644 index 0000000000..3406fb08c3 --- /dev/null +++ b/examples/carbon-for-ibm-products/GetStartedCard/src/App.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import { ThemeProvider } from './ThemeSelector/ThemeContext'; +import { ThemeDropdown } from './ThemeSelector/ThemeDropdown'; +import './config'; +import Example from './Example/Example'; + +function App() { + return ( +
+ + + + +
+ ); +} + +export default App; diff --git a/examples/carbon-for-ibm-products/GetStartedCard/src/Example/Example.jsx b/examples/carbon-for-ibm-products/GetStartedCard/src/Example/Example.jsx index 7442b7df03..d5859358ea 100644 --- a/examples/carbon-for-ibm-products/GetStartedCard/src/Example/Example.jsx +++ b/examples/carbon-for-ibm-products/GetStartedCard/src/Example/Example.jsx @@ -32,7 +32,7 @@ export const Example = () => { footerActionIcon: () => , onClick: () => {}, step: 3, - status: 'incomplete' + status: 'incomplete', }; return ( diff --git a/examples/carbon-for-ibm-products/GetStartedCard/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/GetStartedCard/src/ThemeSelector/ThemeContext.jsx new file mode 100644 index 0000000000..c3972fc82c --- /dev/null +++ b/examples/carbon-for-ibm-products/GetStartedCard/src/ThemeSelector/ThemeContext.jsx @@ -0,0 +1,61 @@ +import React, { createContext, useReducer } from 'react'; + +export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, + { + text: 'White', + value: 'carbon-theme--white', + }, + { + text: 'Gray 10', + value: 'carbon-theme--g10', + }, + { + text: 'Gray 90', + value: 'carbon-theme--g90', + }, + { + text: 'Gray 100', + value: 'carbon-theme--g100', + }, +]; + +export const ThemeContext = createContext(); + +const initialState = { + currentTheme: themeData[1], +}; + +const themeReducer = (state, action) => { + switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': + case 'carbon-theme--white': + case 'carbon-theme--g10': + case 'carbon-theme--g90': + case 'carbon-theme--g100': + return { currentTheme: action.type }; + default: + return state; + } +}; + +export function ThemeProvider(props) { + const [state, dispatch] = useReducer(themeReducer, initialState); + + return ( + + { + // eslint-disable-next-line react/prop-types + props.children + } + + ); +} diff --git a/examples/carbon-for-ibm-products/GetStartedCard/src/ThemeSelector/ThemeDropdown.jsx b/examples/carbon-for-ibm-products/GetStartedCard/src/ThemeSelector/ThemeDropdown.jsx new file mode 100644 index 0000000000..091f7241da --- /dev/null +++ b/examples/carbon-for-ibm-products/GetStartedCard/src/ThemeSelector/ThemeDropdown.jsx @@ -0,0 +1,31 @@ +import React, { useContext } from 'react'; +import { Dropdown } from '@carbon/react'; +import { ThemeContext, themeData } from './ThemeContext'; + +import './_theme-dropdown.scss'; + +export const ThemeDropdown = () => { + const theme = useContext(ThemeContext); + + const setTheme = (selectedItem) => { + const bodyElement = document.body; + bodyElement.className = selectedItem.value; + theme.dispatch({ type: selectedItem }); + }; + + return ( +
+ (item ? item.text : '')} + onChange={(event) => setTheme(event.selectedItem)} + selectedItem={theme.state.currentTheme} + label="Select a Carbon theme" + titleText="Select a Carbon theme" + /> +
+ ); +}; diff --git a/examples/carbon-for-ibm-products/GetStartedCard/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/GetStartedCard/src/ThemeSelector/_theme-dropdown.scss new file mode 100644 index 0000000000..dfffdea257 --- /dev/null +++ b/examples/carbon-for-ibm-products/GetStartedCard/src/ThemeSelector/_theme-dropdown.scss @@ -0,0 +1,68 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + +@use '@carbon/styles/scss/theme' as *; +@use '@carbon/styles/scss/themes'; +@use '@carbon/styles/scss/type'; +@use '@carbon/styles/scss/config'; + +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + +.carbon-theme--white { + @include theme(themes.$white, true); +} + +.carbon-theme--g10 { + @include theme(themes.$g10, true); +} + +.carbon-theme--g90 { + @include theme(themes.$g90, true); +} + +.carbon-theme--g100 { + @include theme(themes.$g100, true); +} + +.carbon-theme-dropdown { + position: fixed; + bottom: 1rem; // stylelint-disable-line carbon/layout-token-use + left: 1rem; // stylelint-disable-line carbon/layout-token-use + min-width: 11.5rem; +} + +.carbon-theme-dropdown .#{config.$prefix}--label { + @include type.type-style('label-01'); +} diff --git a/examples/carbon-for-ibm-products/GetStartedCard/src/config.js b/examples/carbon-for-ibm-products/GetStartedCard/src/config.js new file mode 100644 index 0000000000..c4927216b3 --- /dev/null +++ b/examples/carbon-for-ibm-products/GetStartedCard/src/config.js @@ -0,0 +1,3 @@ +import { pkg } from '@carbon/ibm-products'; + +pkg.component.GetStartedCard = true; diff --git a/examples/carbon-for-ibm-products/GetStartedCard/src/favicon.svg b/examples/carbon-for-ibm-products/GetStartedCard/src/favicon.svg new file mode 100644 index 0000000000..9fef3d7aab --- /dev/null +++ b/examples/carbon-for-ibm-products/GetStartedCard/src/favicon.svg @@ -0,0 +1,4 @@ + + + diff --git a/examples/carbon-for-ibm-products/GetStartedCard/src/index.scss b/examples/carbon-for-ibm-products/GetStartedCard/src/index.scss new file mode 100644 index 0000000000..b008a957c7 --- /dev/null +++ b/examples/carbon-for-ibm-products/GetStartedCard/src/index.scss @@ -0,0 +1,11 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + +@use '@carbon/react' with ( + $font-path: '@ibm/plex' +); +@use '@carbon/ibm-products/css/index'; diff --git a/examples/carbon-for-ibm-products/GetStartedCard/src/main.jsx b/examples/carbon-for-ibm-products/GetStartedCard/src/main.jsx new file mode 100644 index 0000000000..91e8d06798 --- /dev/null +++ b/examples/carbon-for-ibm-products/GetStartedCard/src/main.jsx @@ -0,0 +1,12 @@ +import React from 'react'; +import { createRoot } from 'react-dom'; +import App from './App.jsx'; +import './index.scss'; + +const root = createRoot(document.getElementById('root')); + +root.render( + + + +); diff --git a/examples/carbon-for-ibm-products/GetStartedCard/vite.config.js b/examples/carbon-for-ibm-products/GetStartedCard/vite.config.js new file mode 100644 index 0000000000..5ad2480f5b --- /dev/null +++ b/examples/carbon-for-ibm-products/GetStartedCard/vite.config.js @@ -0,0 +1,18 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + +import { defineConfig } from 'vite'; +import react from '@vitejs/plugin-react'; + +// https://vitejs.dev/config/ +export default defineConfig({ + plugins: [ + react({ + jsxRuntime: 'classic', + }), + ], +}); diff --git a/examples/carbon-for-ibm-products/HTTPErrors/index.html b/examples/carbon-for-ibm-products/HTTPErrors/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/HTTPErrors/index.html +++ b/examples/carbon-for-ibm-products/HTTPErrors/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/HTTPErrors/package.json b/examples/carbon-for-ibm-products/HTTPErrors/package.json index bc310e95c7..a9c28e1612 100644 --- a/examples/carbon-for-ibm-products/HTTPErrors/package.json +++ b/examples/carbon-for-ibm-products/HTTPErrors/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/HTTPErrors/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/HTTPErrors/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/HTTPErrors/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/HTTPErrors/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/HTTPErrors/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/HTTPErrors/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/HTTPErrors/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/HTTPErrors/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/HTTPErrors/src/index.scss b/examples/carbon-for-ibm-products/HTTPErrors/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/HTTPErrors/src/index.scss +++ b/examples/carbon-for-ibm-products/HTTPErrors/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/HTTPErrors/vite.config.js b/examples/carbon-for-ibm-products/HTTPErrors/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/HTTPErrors/vite.config.js +++ b/examples/carbon-for-ibm-products/HTTPErrors/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/ImportModal/index.html b/examples/carbon-for-ibm-products/ImportModal/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/ImportModal/index.html +++ b/examples/carbon-for-ibm-products/ImportModal/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/ImportModal/package.json b/examples/carbon-for-ibm-products/ImportModal/package.json index efd5456f0c..eda8799e41 100644 --- a/examples/carbon-for-ibm-products/ImportModal/package.json +++ b/examples/carbon-for-ibm-products/ImportModal/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/ImportModal/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/ImportModal/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/ImportModal/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/ImportModal/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/ImportModal/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/ImportModal/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/ImportModal/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/ImportModal/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/ImportModal/src/index.scss b/examples/carbon-for-ibm-products/ImportModal/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/ImportModal/src/index.scss +++ b/examples/carbon-for-ibm-products/ImportModal/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/ImportModal/vite.config.js b/examples/carbon-for-ibm-products/ImportModal/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/ImportModal/vite.config.js +++ b/examples/carbon-for-ibm-products/ImportModal/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/InterstitialScreen/index.html b/examples/carbon-for-ibm-products/InterstitialScreen/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/InterstitialScreen/index.html +++ b/examples/carbon-for-ibm-products/InterstitialScreen/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/InterstitialScreen/package.json b/examples/carbon-for-ibm-products/InterstitialScreen/package.json index bc5cbf4793..b4afccc1de 100644 --- a/examples/carbon-for-ibm-products/InterstitialScreen/package.json +++ b/examples/carbon-for-ibm-products/InterstitialScreen/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/InterstitialScreen/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/InterstitialScreen/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/InterstitialScreen/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/InterstitialScreen/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/InterstitialScreen/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/InterstitialScreen/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/InterstitialScreen/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/InterstitialScreen/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/InterstitialScreen/src/index.scss b/examples/carbon-for-ibm-products/InterstitialScreen/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/InterstitialScreen/src/index.scss +++ b/examples/carbon-for-ibm-products/InterstitialScreen/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/InterstitialScreen/vite.config.js b/examples/carbon-for-ibm-products/InterstitialScreen/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/InterstitialScreen/vite.config.js +++ b/examples/carbon-for-ibm-products/InterstitialScreen/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/InterstitialScreenView/index.html b/examples/carbon-for-ibm-products/InterstitialScreenView/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/InterstitialScreenView/index.html +++ b/examples/carbon-for-ibm-products/InterstitialScreenView/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/InterstitialScreenView/package.json b/examples/carbon-for-ibm-products/InterstitialScreenView/package.json index a0968dc6e3..501ed04010 100644 --- a/examples/carbon-for-ibm-products/InterstitialScreenView/package.json +++ b/examples/carbon-for-ibm-products/InterstitialScreenView/package.json @@ -21,7 +21,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/InterstitialScreenView/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/InterstitialScreenView/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/InterstitialScreenView/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/InterstitialScreenView/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/InterstitialScreenView/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/InterstitialScreenView/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/InterstitialScreenView/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/InterstitialScreenView/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/InterstitialScreenView/src/index.scss b/examples/carbon-for-ibm-products/InterstitialScreenView/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/InterstitialScreenView/src/index.scss +++ b/examples/carbon-for-ibm-products/InterstitialScreenView/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/InterstitialScreenView/vite.config.js b/examples/carbon-for-ibm-products/InterstitialScreenView/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/InterstitialScreenView/vite.config.js +++ b/examples/carbon-for-ibm-products/InterstitialScreenView/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/InterstitialScreenViewModule/index.html b/examples/carbon-for-ibm-products/InterstitialScreenViewModule/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/InterstitialScreenViewModule/index.html +++ b/examples/carbon-for-ibm-products/InterstitialScreenViewModule/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/InterstitialScreenViewModule/package.json b/examples/carbon-for-ibm-products/InterstitialScreenViewModule/package.json index 80302d07f9..afddec23b3 100644 --- a/examples/carbon-for-ibm-products/InterstitialScreenViewModule/package.json +++ b/examples/carbon-for-ibm-products/InterstitialScreenViewModule/package.json @@ -22,7 +22,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/InterstitialScreenViewModule/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/InterstitialScreenViewModule/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/InterstitialScreenViewModule/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/InterstitialScreenViewModule/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/InterstitialScreenViewModule/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/InterstitialScreenViewModule/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/InterstitialScreenViewModule/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/InterstitialScreenViewModule/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/InterstitialScreenViewModule/src/index.scss b/examples/carbon-for-ibm-products/InterstitialScreenViewModule/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/InterstitialScreenViewModule/src/index.scss +++ b/examples/carbon-for-ibm-products/InterstitialScreenViewModule/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/InterstitialScreenViewModule/vite.config.js b/examples/carbon-for-ibm-products/InterstitialScreenViewModule/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/InterstitialScreenViewModule/vite.config.js +++ b/examples/carbon-for-ibm-products/InterstitialScreenViewModule/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/Nav/index.html b/examples/carbon-for-ibm-products/Nav/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/Nav/index.html +++ b/examples/carbon-for-ibm-products/Nav/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/Nav/package.json b/examples/carbon-for-ibm-products/Nav/package.json index 82ffc44344..1834566d56 100644 --- a/examples/carbon-for-ibm-products/Nav/package.json +++ b/examples/carbon-for-ibm-products/Nav/package.json @@ -18,7 +18,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/Nav/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/Nav/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/Nav/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/Nav/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/Nav/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/Nav/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/Nav/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/Nav/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/Nav/src/index.scss b/examples/carbon-for-ibm-products/Nav/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/Nav/src/index.scss +++ b/examples/carbon-for-ibm-products/Nav/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/Nav/vite.config.js b/examples/carbon-for-ibm-products/Nav/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/Nav/vite.config.js +++ b/examples/carbon-for-ibm-products/Nav/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/NotificationsPanel/index.html b/examples/carbon-for-ibm-products/NotificationsPanel/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/NotificationsPanel/index.html +++ b/examples/carbon-for-ibm-products/NotificationsPanel/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/NotificationsPanel/package.json b/examples/carbon-for-ibm-products/NotificationsPanel/package.json index e0507282fc..a726156d2d 100644 --- a/examples/carbon-for-ibm-products/NotificationsPanel/package.json +++ b/examples/carbon-for-ibm-products/NotificationsPanel/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/NotificationsPanel/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/NotificationsPanel/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/NotificationsPanel/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/NotificationsPanel/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/NotificationsPanel/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/NotificationsPanel/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/NotificationsPanel/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/NotificationsPanel/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/NotificationsPanel/src/index.scss b/examples/carbon-for-ibm-products/NotificationsPanel/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/NotificationsPanel/src/index.scss +++ b/examples/carbon-for-ibm-products/NotificationsPanel/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/NotificationsPanel/vite.config.js b/examples/carbon-for-ibm-products/NotificationsPanel/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/NotificationsPanel/vite.config.js +++ b/examples/carbon-for-ibm-products/NotificationsPanel/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/OptionsTile/index.html b/examples/carbon-for-ibm-products/OptionsTile/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/OptionsTile/index.html +++ b/examples/carbon-for-ibm-products/OptionsTile/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/OptionsTile/package.json b/examples/carbon-for-ibm-products/OptionsTile/package.json index c51cf574b6..1c55b2ab99 100644 --- a/examples/carbon-for-ibm-products/OptionsTile/package.json +++ b/examples/carbon-for-ibm-products/OptionsTile/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/OptionsTile/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/OptionsTile/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/OptionsTile/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/OptionsTile/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/OptionsTile/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/OptionsTile/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/OptionsTile/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/OptionsTile/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/OptionsTile/src/index.scss b/examples/carbon-for-ibm-products/OptionsTile/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/OptionsTile/src/index.scss +++ b/examples/carbon-for-ibm-products/OptionsTile/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/OptionsTile/vite.config.js b/examples/carbon-for-ibm-products/OptionsTile/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/OptionsTile/vite.config.js +++ b/examples/carbon-for-ibm-products/OptionsTile/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/PageHeader/index.html b/examples/carbon-for-ibm-products/PageHeader/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/PageHeader/index.html +++ b/examples/carbon-for-ibm-products/PageHeader/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/PageHeader/package.json b/examples/carbon-for-ibm-products/PageHeader/package.json index 2a536617fc..c088d2f455 100644 --- a/examples/carbon-for-ibm-products/PageHeader/package.json +++ b/examples/carbon-for-ibm-products/PageHeader/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/PageHeader/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/PageHeader/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/PageHeader/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/PageHeader/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/PageHeader/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/PageHeader/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/PageHeader/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/PageHeader/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/PageHeader/src/index.scss b/examples/carbon-for-ibm-products/PageHeader/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/PageHeader/src/index.scss +++ b/examples/carbon-for-ibm-products/PageHeader/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/PageHeader/vite.config.js b/examples/carbon-for-ibm-products/PageHeader/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/PageHeader/vite.config.js +++ b/examples/carbon-for-ibm-products/PageHeader/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/ProductiveCard/index.html b/examples/carbon-for-ibm-products/ProductiveCard/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/ProductiveCard/index.html +++ b/examples/carbon-for-ibm-products/ProductiveCard/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/ProductiveCard/package.json b/examples/carbon-for-ibm-products/ProductiveCard/package.json index a914080780..f172e2a7e0 100644 --- a/examples/carbon-for-ibm-products/ProductiveCard/package.json +++ b/examples/carbon-for-ibm-products/ProductiveCard/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/ProductiveCard/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/ProductiveCard/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/ProductiveCard/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/ProductiveCard/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/ProductiveCard/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/ProductiveCard/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/ProductiveCard/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/ProductiveCard/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/ProductiveCard/src/index.scss b/examples/carbon-for-ibm-products/ProductiveCard/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/ProductiveCard/src/index.scss +++ b/examples/carbon-for-ibm-products/ProductiveCard/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/ProductiveCard/vite.config.js b/examples/carbon-for-ibm-products/ProductiveCard/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/ProductiveCard/vite.config.js +++ b/examples/carbon-for-ibm-products/ProductiveCard/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/RemoveModal/index.html b/examples/carbon-for-ibm-products/RemoveModal/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/RemoveModal/index.html +++ b/examples/carbon-for-ibm-products/RemoveModal/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/RemoveModal/package.json b/examples/carbon-for-ibm-products/RemoveModal/package.json index 40359b6828..878c51c980 100644 --- a/examples/carbon-for-ibm-products/RemoveModal/package.json +++ b/examples/carbon-for-ibm-products/RemoveModal/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/RemoveModal/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/RemoveModal/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/RemoveModal/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/RemoveModal/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/RemoveModal/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/RemoveModal/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/RemoveModal/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/RemoveModal/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/RemoveModal/src/index.scss b/examples/carbon-for-ibm-products/RemoveModal/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/RemoveModal/src/index.scss +++ b/examples/carbon-for-ibm-products/RemoveModal/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/RemoveModal/vite.config.js b/examples/carbon-for-ibm-products/RemoveModal/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/RemoveModal/vite.config.js +++ b/examples/carbon-for-ibm-products/RemoveModal/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/Saving/index.html b/examples/carbon-for-ibm-products/Saving/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/Saving/index.html +++ b/examples/carbon-for-ibm-products/Saving/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/Saving/package.json b/examples/carbon-for-ibm-products/Saving/package.json index 5465344921..eb05fae3b2 100644 --- a/examples/carbon-for-ibm-products/Saving/package.json +++ b/examples/carbon-for-ibm-products/Saving/package.json @@ -18,7 +18,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/Saving/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/Saving/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/Saving/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/Saving/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/Saving/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/Saving/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/Saving/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/Saving/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/Saving/src/index.scss b/examples/carbon-for-ibm-products/Saving/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/Saving/src/index.scss +++ b/examples/carbon-for-ibm-products/Saving/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/Saving/vite.config.js b/examples/carbon-for-ibm-products/Saving/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/Saving/vite.config.js +++ b/examples/carbon-for-ibm-products/Saving/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/ScrollGradient/index.html b/examples/carbon-for-ibm-products/ScrollGradient/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/ScrollGradient/index.html +++ b/examples/carbon-for-ibm-products/ScrollGradient/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/ScrollGradient/package.json b/examples/carbon-for-ibm-products/ScrollGradient/package.json index 4b77daa246..f8d7229379 100644 --- a/examples/carbon-for-ibm-products/ScrollGradient/package.json +++ b/examples/carbon-for-ibm-products/ScrollGradient/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/ScrollGradient/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/ScrollGradient/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/ScrollGradient/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/ScrollGradient/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/ScrollGradient/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/ScrollGradient/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/ScrollGradient/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/ScrollGradient/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/ScrollGradient/src/index.scss b/examples/carbon-for-ibm-products/ScrollGradient/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/ScrollGradient/src/index.scss +++ b/examples/carbon-for-ibm-products/ScrollGradient/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/ScrollGradient/vite.config.js b/examples/carbon-for-ibm-products/ScrollGradient/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/ScrollGradient/vite.config.js +++ b/examples/carbon-for-ibm-products/ScrollGradient/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/SearchBar/index.html b/examples/carbon-for-ibm-products/SearchBar/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/SearchBar/index.html +++ b/examples/carbon-for-ibm-products/SearchBar/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/SearchBar/package.json b/examples/carbon-for-ibm-products/SearchBar/package.json index 22eae19228..7caf69d21a 100644 --- a/examples/carbon-for-ibm-products/SearchBar/package.json +++ b/examples/carbon-for-ibm-products/SearchBar/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/SearchBar/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/SearchBar/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/SearchBar/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/SearchBar/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/SearchBar/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/SearchBar/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/SearchBar/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/SearchBar/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/SearchBar/src/index.scss b/examples/carbon-for-ibm-products/SearchBar/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/SearchBar/src/index.scss +++ b/examples/carbon-for-ibm-products/SearchBar/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/SearchBar/vite.config.js b/examples/carbon-for-ibm-products/SearchBar/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/SearchBar/vite.config.js +++ b/examples/carbon-for-ibm-products/SearchBar/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/SidePanel/index.html b/examples/carbon-for-ibm-products/SidePanel/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/SidePanel/index.html +++ b/examples/carbon-for-ibm-products/SidePanel/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/SidePanel/package.json b/examples/carbon-for-ibm-products/SidePanel/package.json index a5226bdf87..a0b6e663d5 100644 --- a/examples/carbon-for-ibm-products/SidePanel/package.json +++ b/examples/carbon-for-ibm-products/SidePanel/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/SidePanel/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/SidePanel/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/SidePanel/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/SidePanel/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/SidePanel/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/SidePanel/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/SidePanel/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/SidePanel/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/SidePanel/src/index.scss b/examples/carbon-for-ibm-products/SidePanel/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/SidePanel/src/index.scss +++ b/examples/carbon-for-ibm-products/SidePanel/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/SidePanel/vite.config.js b/examples/carbon-for-ibm-products/SidePanel/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/SidePanel/vite.config.js +++ b/examples/carbon-for-ibm-products/SidePanel/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/StatusIcon/index.html b/examples/carbon-for-ibm-products/StatusIcon/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/StatusIcon/index.html +++ b/examples/carbon-for-ibm-products/StatusIcon/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/StatusIcon/package.json b/examples/carbon-for-ibm-products/StatusIcon/package.json index 2cd3910008..d9af656e1a 100644 --- a/examples/carbon-for-ibm-products/StatusIcon/package.json +++ b/examples/carbon-for-ibm-products/StatusIcon/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/StatusIcon/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/StatusIcon/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/StatusIcon/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/StatusIcon/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/StatusIcon/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/StatusIcon/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/StatusIcon/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/StatusIcon/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/StatusIcon/src/index.scss b/examples/carbon-for-ibm-products/StatusIcon/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/StatusIcon/src/index.scss +++ b/examples/carbon-for-ibm-products/StatusIcon/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/StatusIcon/vite.config.js b/examples/carbon-for-ibm-products/StatusIcon/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/StatusIcon/vite.config.js +++ b/examples/carbon-for-ibm-products/StatusIcon/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/StatusIndicator/index.html b/examples/carbon-for-ibm-products/StatusIndicator/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/StatusIndicator/index.html +++ b/examples/carbon-for-ibm-products/StatusIndicator/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/StatusIndicator/package.json b/examples/carbon-for-ibm-products/StatusIndicator/package.json index 0ad6ab4e29..f7cf1e5d98 100644 --- a/examples/carbon-for-ibm-products/StatusIndicator/package.json +++ b/examples/carbon-for-ibm-products/StatusIndicator/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/StatusIndicator/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/StatusIndicator/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/StatusIndicator/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/StatusIndicator/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/StatusIndicator/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/StatusIndicator/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/StatusIndicator/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/StatusIndicator/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/StatusIndicator/src/index.scss b/examples/carbon-for-ibm-products/StatusIndicator/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/StatusIndicator/src/index.scss +++ b/examples/carbon-for-ibm-products/StatusIndicator/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/StatusIndicator/vite.config.js b/examples/carbon-for-ibm-products/StatusIndicator/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/StatusIndicator/vite.config.js +++ b/examples/carbon-for-ibm-products/StatusIndicator/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/StringFormatter/index.html b/examples/carbon-for-ibm-products/StringFormatter/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/StringFormatter/index.html +++ b/examples/carbon-for-ibm-products/StringFormatter/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/StringFormatter/package.json b/examples/carbon-for-ibm-products/StringFormatter/package.json index 55de72b79e..23ed6debac 100644 --- a/examples/carbon-for-ibm-products/StringFormatter/package.json +++ b/examples/carbon-for-ibm-products/StringFormatter/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/StringFormatter/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/StringFormatter/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/StringFormatter/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/StringFormatter/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/StringFormatter/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/StringFormatter/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/StringFormatter/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/StringFormatter/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/StringFormatter/src/index.scss b/examples/carbon-for-ibm-products/StringFormatter/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/StringFormatter/src/index.scss +++ b/examples/carbon-for-ibm-products/StringFormatter/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/StringFormatter/vite.config.js b/examples/carbon-for-ibm-products/StringFormatter/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/StringFormatter/vite.config.js +++ b/examples/carbon-for-ibm-products/StringFormatter/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/TagOverflow/index.html b/examples/carbon-for-ibm-products/TagOverflow/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/TagOverflow/index.html +++ b/examples/carbon-for-ibm-products/TagOverflow/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/TagOverflow/package.json b/examples/carbon-for-ibm-products/TagOverflow/package.json index dc2410eb39..b71f6a199f 100644 --- a/examples/carbon-for-ibm-products/TagOverflow/package.json +++ b/examples/carbon-for-ibm-products/TagOverflow/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/TagOverflow/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/TagOverflow/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/TagOverflow/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/TagOverflow/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/TagOverflow/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/TagOverflow/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/TagOverflow/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/TagOverflow/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/TagOverflow/src/index.scss b/examples/carbon-for-ibm-products/TagOverflow/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/TagOverflow/src/index.scss +++ b/examples/carbon-for-ibm-products/TagOverflow/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/TagOverflow/vite.config.js b/examples/carbon-for-ibm-products/TagOverflow/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/TagOverflow/vite.config.js +++ b/examples/carbon-for-ibm-products/TagOverflow/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/TagSet/index.html b/examples/carbon-for-ibm-products/TagSet/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/TagSet/index.html +++ b/examples/carbon-for-ibm-products/TagSet/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/TagSet/package.json b/examples/carbon-for-ibm-products/TagSet/package.json index ca98899ea4..4a2064de6b 100644 --- a/examples/carbon-for-ibm-products/TagSet/package.json +++ b/examples/carbon-for-ibm-products/TagSet/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/TagSet/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/TagSet/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/TagSet/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/TagSet/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/TagSet/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/TagSet/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/TagSet/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/TagSet/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/TagSet/src/index.scss b/examples/carbon-for-ibm-products/TagSet/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/TagSet/src/index.scss +++ b/examples/carbon-for-ibm-products/TagSet/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/TagSet/vite.config.js b/examples/carbon-for-ibm-products/TagSet/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/TagSet/vite.config.js +++ b/examples/carbon-for-ibm-products/TagSet/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/Tearsheet/index.html b/examples/carbon-for-ibm-products/Tearsheet/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/Tearsheet/index.html +++ b/examples/carbon-for-ibm-products/Tearsheet/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/Tearsheet/package.json b/examples/carbon-for-ibm-products/Tearsheet/package.json index 9a9c6fb8ec..4de13f2738 100644 --- a/examples/carbon-for-ibm-products/Tearsheet/package.json +++ b/examples/carbon-for-ibm-products/Tearsheet/package.json @@ -18,7 +18,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/Tearsheet/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/Tearsheet/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/Tearsheet/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/Tearsheet/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/Tearsheet/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/Tearsheet/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/Tearsheet/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/Tearsheet/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/Tearsheet/src/index.scss b/examples/carbon-for-ibm-products/Tearsheet/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/Tearsheet/src/index.scss +++ b/examples/carbon-for-ibm-products/Tearsheet/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/Tearsheet/vite.config.js b/examples/carbon-for-ibm-products/Tearsheet/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/Tearsheet/vite.config.js +++ b/examples/carbon-for-ibm-products/Tearsheet/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/TruncatedList/index.html b/examples/carbon-for-ibm-products/TruncatedList/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/TruncatedList/index.html +++ b/examples/carbon-for-ibm-products/TruncatedList/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/TruncatedList/package.json b/examples/carbon-for-ibm-products/TruncatedList/package.json index 48620b9dd3..6cbbca0d1e 100644 --- a/examples/carbon-for-ibm-products/TruncatedList/package.json +++ b/examples/carbon-for-ibm-products/TruncatedList/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/TruncatedList/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/TruncatedList/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/TruncatedList/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/TruncatedList/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/TruncatedList/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/TruncatedList/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/TruncatedList/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/TruncatedList/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/TruncatedList/src/index.scss b/examples/carbon-for-ibm-products/TruncatedList/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/TruncatedList/src/index.scss +++ b/examples/carbon-for-ibm-products/TruncatedList/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/TruncatedList/vite.config.js b/examples/carbon-for-ibm-products/TruncatedList/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/TruncatedList/vite.config.js +++ b/examples/carbon-for-ibm-products/TruncatedList/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/UserAvatar/index.html b/examples/carbon-for-ibm-products/UserAvatar/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/UserAvatar/index.html +++ b/examples/carbon-for-ibm-products/UserAvatar/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/UserAvatar/package.json b/examples/carbon-for-ibm-products/UserAvatar/package.json index 5e032f9fc4..dfef026ffd 100644 --- a/examples/carbon-for-ibm-products/UserAvatar/package.json +++ b/examples/carbon-for-ibm-products/UserAvatar/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/UserAvatar/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/UserAvatar/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/UserAvatar/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/UserAvatar/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/UserAvatar/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/UserAvatar/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/UserAvatar/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/UserAvatar/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/UserAvatar/src/index.scss b/examples/carbon-for-ibm-products/UserAvatar/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/UserAvatar/src/index.scss +++ b/examples/carbon-for-ibm-products/UserAvatar/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/UserAvatar/vite.config.js b/examples/carbon-for-ibm-products/UserAvatar/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/UserAvatar/vite.config.js +++ b/examples/carbon-for-ibm-products/UserAvatar/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/UserProfileImage/index.html b/examples/carbon-for-ibm-products/UserProfileImage/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/UserProfileImage/index.html +++ b/examples/carbon-for-ibm-products/UserProfileImage/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/UserProfileImage/package.json b/examples/carbon-for-ibm-products/UserProfileImage/package.json index 706fdcb7b3..3474869192 100644 --- a/examples/carbon-for-ibm-products/UserProfileImage/package.json +++ b/examples/carbon-for-ibm-products/UserProfileImage/package.json @@ -21,7 +21,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/UserProfileImage/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/UserProfileImage/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/UserProfileImage/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/UserProfileImage/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/UserProfileImage/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/UserProfileImage/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/UserProfileImage/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/UserProfileImage/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/UserProfileImage/src/index.scss b/examples/carbon-for-ibm-products/UserProfileImage/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/UserProfileImage/src/index.scss +++ b/examples/carbon-for-ibm-products/UserProfileImage/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/UserProfileImage/vite.config.js b/examples/carbon-for-ibm-products/UserProfileImage/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/UserProfileImage/vite.config.js +++ b/examples/carbon-for-ibm-products/UserProfileImage/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/WebTerminal/index.html b/examples/carbon-for-ibm-products/WebTerminal/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/WebTerminal/index.html +++ b/examples/carbon-for-ibm-products/WebTerminal/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/WebTerminal/package.json b/examples/carbon-for-ibm-products/WebTerminal/package.json index 5e9ee74ded..a47f40c66d 100644 --- a/examples/carbon-for-ibm-products/WebTerminal/package.json +++ b/examples/carbon-for-ibm-products/WebTerminal/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/WebTerminal/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/WebTerminal/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/WebTerminal/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/WebTerminal/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/WebTerminal/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/WebTerminal/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/WebTerminal/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/WebTerminal/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/WebTerminal/src/index.scss b/examples/carbon-for-ibm-products/WebTerminal/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/WebTerminal/src/index.scss +++ b/examples/carbon-for-ibm-products/WebTerminal/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/WebTerminal/vite.config.js b/examples/carbon-for-ibm-products/WebTerminal/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/WebTerminal/vite.config.js +++ b/examples/carbon-for-ibm-products/WebTerminal/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/example-gallery/src/gallery-config/ConditionBuilder--thumbnail.png b/examples/carbon-for-ibm-products/example-gallery/src/gallery-config/ConditionBuilder--thumbnail.png new file mode 100644 index 0000000000000000000000000000000000000000..d35ccc6b99330e9963a6484e822b1a817002e577 GIT binary patch literal 78602 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%0A@T(~jg!Ij~R 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 literal 0 HcmV?d00001 diff --git a/examples/carbon-for-ibm-products/example-gallery/src/gallery-config/GetStartedCard--thumbnail.png b/examples/carbon-for-ibm-products/example-gallery/src/gallery-config/GetStartedCard--thumbnail.png new file mode 100644 index 0000000000000000000000000000000000000000..d35ccc6b99330e9963a6484e822b1a817002e577 GIT binary patch literal 78602 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%0A@T(~jg!Ij~R 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 literal 0 HcmV?d00001 diff --git a/examples/carbon-for-ibm-products/example-gallery/src/gallery-config/index.js b/examples/carbon-for-ibm-products/example-gallery/src/gallery-config/index.js index a2b0aed845..9faf0beebf 100644 --- a/examples/carbon-for-ibm-products/example-gallery/src/gallery-config/index.js +++ b/examples/carbon-for-ibm-products/example-gallery/src/gallery-config/index.js @@ -19,6 +19,7 @@ import imageCoachmarkFixed from './CoachmarkFixed--thumbnail.png'; import imageCoachmarkOverlayElement from './CoachmarkOverlayElement--thumbnail.png'; import imageCoachmarkOverlayElements from './CoachmarkOverlayElements--thumbnail.png'; import imageCoachmarkStack from './CoachmarkStack--thumbnail.png'; +import imageConditionBuilder from './ConditionBuilder--thumbnail.png'; import imageCreateFullPage from './CreateFullPage--thumbnail.png'; import imageCreateModal from './CreateModal--thumbnail.png'; import imageCreateSidePanel from './CreateSidePanel--thumbnail.png'; @@ -35,6 +36,7 @@ import imageExportModal from './ExportModal--thumbnail.png'; import imageExpressiveCard from './ExpressiveCard--thumbnail.png'; import imageFilterPanel from './FilterPanel--thumbnail.png'; import imageFullPageError from './FullPageError--thumbnail.png'; +import imageGetStartedCard from './GetStartedCard--thumbnail.png'; import imageHTTPErrors from './HTTPErrors--thumbnail.png'; import imageImportModal from './ImportModal--thumbnail.png'; import imageInterstitialScreen from './InterstitialScreen--thumbnail.png'; @@ -115,6 +117,11 @@ const config = [ directory: 'CoachmarkStack', thumbnail: `url(${imageCoachmarkStack}`, }, + { + label: 'Condition-Builder', + directory: 'ConditionBuilder', + thumbnail: `url(${imageConditionBuilder}`, + }, { label: 'Create Full Page', directory: 'CreateFullPage', @@ -195,6 +202,11 @@ const config = [ directory: 'FullPageError', thumbnail: `url(${imageFullPageError}`, }, + { + label: 'Get-Started-Card', + directory: 'GetStartedCard', + thumbnail: `url(${imageGetStartedCard}`, + }, { label: 'HTTP Error', directory: 'HTTPErrors', diff --git a/examples/carbon-for-ibm-products/gallery-examples.test.js b/examples/carbon-for-ibm-products/gallery-examples.test.js index ce69653da4..39d8593fc7 100644 --- a/examples/carbon-for-ibm-products/gallery-examples.test.js +++ b/examples/carbon-for-ibm-products/gallery-examples.test.js @@ -20,6 +20,7 @@ import { Example as CoachmarkFixedExample } from './CoachmarkFixed/src/Example/E import { Example as CoachmarkOverlayElementExample } from './CoachmarkOverlayElement/src/Example/Example'; import { Example as CoachmarkOverlayElementsExample } from './CoachmarkOverlayElements/src/Example/Example'; import { Example as CoachmarkStackExample } from './CoachmarkStack/src/Example/Example'; +import { Example as ConditionBuilderExample } from './ConditionBuilder/src/Example/Example'; import { Example as CreateFullPageExample } from './CreateFullPage/src/Example/Example'; import { Example as CreateModalExample } from './CreateModal/src/Example/Example'; import { Example as CreateSidePanelExample } from './CreateSidePanel/src/Example/Example'; @@ -36,6 +37,7 @@ import { Example as ExportModalExample } from './ExportModal/src/Example/Example import { Example as ExpressiveCardExample } from './ExpressiveCard/src/Example/Example'; import { Example as FilterPanelExample } from './FilterPanel/src/Example/Example'; import { Example as FullPageErrorExample } from './FullPageError/src/Example/Example'; +import { Example as GetStartedCardExample } from './GetStartedCard/src/Example/Example'; import { Example as HTTPErrorsExample } from './HTTPErrors/src/Example/Example'; import { Example as ImportModalExample } from './ImportModal/src/Example/Example'; import { Example as InterstitialScreenExample } from './InterstitialScreen/src/Example/Example'; @@ -134,6 +136,12 @@ describe('All examples', () => { expect(console.error).not.toHaveBeenCalled(); }); + it('ConditionBuilder renders', () => { + render(); + // expect no errors int the console + expect(console.error).not.toHaveBeenCalled(); + }); + it('CreateFullPage renders', () => { render(); // expect no errors int the console @@ -230,6 +238,12 @@ describe('All examples', () => { expect(console.error).not.toHaveBeenCalled(); }); + it('GetStartedCard renders', () => { + render(); + // expect no errors int the console + expect(console.error).not.toHaveBeenCalled(); + }); + it('HTTPErrors renders', () => { render(); // expect no errors int the console diff --git a/examples/carbon-for-ibm-products/prefix-example/index.html b/examples/carbon-for-ibm-products/prefix-example/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/prefix-example/index.html +++ b/examples/carbon-for-ibm-products/prefix-example/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/prefix-example/package.json b/examples/carbon-for-ibm-products/prefix-example/package.json index e714cf2c87..dfbeea9277 100644 --- a/examples/carbon-for-ibm-products/prefix-example/package.json +++ b/examples/carbon-for-ibm-products/prefix-example/package.json @@ -20,7 +20,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^18.2.0", "react-dom": "^18.2.0", diff --git a/examples/carbon-for-ibm-products/prefix-example/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/prefix-example/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/prefix-example/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/prefix-example/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/prefix-example/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/prefix-example/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/prefix-example/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/prefix-example/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/prefix-example/src/index.scss b/examples/carbon-for-ibm-products/prefix-example/src/index.scss index da5000a4af..f5e1f035ea 100644 --- a/examples/carbon-for-ibm-products/prefix-example/src/index.scss +++ b/examples/carbon-for-ibm-products/prefix-example/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/prefix-example/vite.config.js b/examples/carbon-for-ibm-products/prefix-example/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/prefix-example/vite.config.js +++ b/examples/carbon-for-ibm-products/prefix-example/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/react-16-example/index.html b/examples/carbon-for-ibm-products/react-16-example/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/react-16-example/index.html +++ b/examples/carbon-for-ibm-products/react-16-example/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/react-16-example/package.json b/examples/carbon-for-ibm-products/react-16-example/package.json index bd5e7ca18a..88d5fc537c 100644 --- a/examples/carbon-for-ibm-products/react-16-example/package.json +++ b/examples/carbon-for-ibm-products/react-16-example/package.json @@ -21,7 +21,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^16.14.0", "react-dom": "^16.14.0", diff --git a/examples/carbon-for-ibm-products/react-16-example/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/react-16-example/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/react-16-example/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/react-16-example/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/react-16-example/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/react-16-example/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/react-16-example/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/react-16-example/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/react-16-example/src/index.scss b/examples/carbon-for-ibm-products/react-16-example/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/react-16-example/src/index.scss +++ b/examples/carbon-for-ibm-products/react-16-example/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/react-16-example/vite.config.js b/examples/carbon-for-ibm-products/react-16-example/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/react-16-example/vite.config.js +++ b/examples/carbon-for-ibm-products/react-16-example/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react'; diff --git a/examples/carbon-for-ibm-products/react-17-example/index.html b/examples/carbon-for-ibm-products/react-17-example/index.html index 56d5e127b5..5d37ff8603 100644 --- a/examples/carbon-for-ibm-products/react-17-example/index.html +++ b/examples/carbon-for-ibm-products/react-17-example/index.html @@ -1,3 +1,12 @@ + + diff --git a/examples/carbon-for-ibm-products/react-17-example/package.json b/examples/carbon-for-ibm-products/react-17-example/package.json index 62ada8fe0c..ec2d93e3d1 100644 --- a/examples/carbon-for-ibm-products/react-17-example/package.json +++ b/examples/carbon-for-ibm-products/react-17-example/package.json @@ -21,7 +21,7 @@ }, "dependencies": { "@carbon/ibm-products": "^2.21.0", - "@carbon/react": "^1.51.1", + "@carbon/react": "^1.60.3", "lodash": "^4.17.21", "react": "^17.0.2", "react-dom": "^17.0.2", diff --git a/examples/carbon-for-ibm-products/react-17-example/src/ThemeSelector/ThemeContext.jsx b/examples/carbon-for-ibm-products/react-17-example/src/ThemeSelector/ThemeContext.jsx index 55a9b2dda8..c3972fc82c 100644 --- a/examples/carbon-for-ibm-products/react-17-example/src/ThemeSelector/ThemeContext.jsx +++ b/examples/carbon-for-ibm-products/react-17-example/src/ThemeSelector/ThemeContext.jsx @@ -1,6 +1,14 @@ import React, { createContext, useReducer } from 'react'; export const themeData = [ + { + text: 'System W/90', + value: 'carbon-theme--user-preference-white-90', + }, + { + text: 'System 10/100', + value: 'carbon-theme--user-preference-10-100', + }, { text: 'White', value: 'carbon-theme--white', @@ -22,17 +30,16 @@ export const themeData = [ export const ThemeContext = createContext(); const initialState = { - currentTheme: themeData[0], + currentTheme: themeData[1], }; const themeReducer = (state, action) => { switch (action.type.value) { + case 'carbon-theme--user-preference-white-90': + case 'carbon-theme--user-preference-10-100': case 'carbon-theme--white': - return { currentTheme: action.type }; case 'carbon-theme--g10': - return { currentTheme: action.type }; case 'carbon-theme--g90': - return { currentTheme: action.type }; case 'carbon-theme--g100': return { currentTheme: action.type }; default: diff --git a/examples/carbon-for-ibm-products/react-17-example/src/ThemeSelector/_theme-dropdown.scss b/examples/carbon-for-ibm-products/react-17-example/src/ThemeSelector/_theme-dropdown.scss index 01378bd385..dfffdea257 100644 --- a/examples/carbon-for-ibm-products/react-17-example/src/ThemeSelector/_theme-dropdown.scss +++ b/examples/carbon-for-ibm-products/react-17-example/src/ThemeSelector/_theme-dropdown.scss @@ -1,8 +1,45 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/styles/scss/theme' as *; @use '@carbon/styles/scss/themes'; @use '@carbon/styles/scss/type'; @use '@carbon/styles/scss/config'; +// Best to stick with user preference - DARK +@media (prefers-color-scheme: dark) { + :root { + @include theme(themes.$g100, true); // dark default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g100, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$g90, true); + } +} + +// Best to stick with user preference - LIGHT +@media (prefers-color-scheme: light) { + :root { + @include theme(themes.$white, true); // light default + } + + .carbon-theme--user-preference-10-100 { + @include theme(themes.$g10, true); + } + + .carbon-theme--user-preference-white-90 { + @include theme(themes.$white, true); + } +} + .carbon-theme--white { @include theme(themes.$white, true); } diff --git a/examples/carbon-for-ibm-products/react-17-example/src/index.scss b/examples/carbon-for-ibm-products/react-17-example/src/index.scss index 603100b1c9..b008a957c7 100644 --- a/examples/carbon-for-ibm-products/react-17-example/src/index.scss +++ b/examples/carbon-for-ibm-products/react-17-example/src/index.scss @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + @use '@carbon/react' with ( $font-path: '@ibm/plex' ); diff --git a/examples/carbon-for-ibm-products/react-17-example/vite.config.js b/examples/carbon-for-ibm-products/react-17-example/vite.config.js index a50be4eeb4..5ad2480f5b 100644 --- a/examples/carbon-for-ibm-products/react-17-example/vite.config.js +++ b/examples/carbon-for-ibm-products/react-17-example/vite.config.js @@ -1,3 +1,10 @@ +/** + * Copyright IBM Corp. 2024 + * + * This source code is licensed under the Apache-2.0 license found in the + * LICENSE file in the root directory of this source tree. + */ + import { defineConfig } from 'vite'; import react from '@vitejs/plugin-react';