From 4bef3ee6bd83bdcb3f56dd3469256a70b0236e87 Mon Sep 17 00:00:00 2001 From: TJ Egan Date: Tue, 24 Nov 2020 10:28:23 -0500 Subject: [PATCH 1/2] fix(data-viz): ensure color palette updates on theme change --- src/components/ColorPalette/ColorPalette.js | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/src/components/ColorPalette/ColorPalette.js b/src/components/ColorPalette/ColorPalette.js index 016cb453649..348e9d72b3e 100644 --- a/src/components/ColorPalette/ColorPalette.js +++ b/src/components/ColorPalette/ColorPalette.js @@ -1,4 +1,4 @@ -import React, { useState } from 'react'; +import React, { useState, useEffect } from 'react'; import { ContentSwitcher, Switch, Dropdown } from 'carbon-components-react'; import cx from 'classnames'; import { @@ -84,11 +84,13 @@ const ColorPalette = ({ type, isMono, isDiverging }) => { ]; const onDropdownChange = (e) => { + const id = e.selectedItem ? e.selectedItem.id : e; + // update selected option - setGroupNumber(e.selectedItem.id); + setGroupNumber(id); // update colors rendered - switch (e.selectedItem.id) { + switch (id) { case 1: setColorGroup(oneColor); break; @@ -108,6 +110,11 @@ const ColorPalette = ({ type, isMono, isDiverging }) => { } }; + // Rerender color group values when theme is toggled + useEffect(() => { + onDropdownChange(groupNumber); + }, [dark]); + // SWITCHER STUFF const activateFirstSwitcher = () => { if (type === 'sequential') { From 008fe95ba38354482bc833bff049a03c18322773 Mon Sep 17 00:00:00 2001 From: TJ Egan Date: Tue, 24 Nov 2020 16:03:55 -0500 Subject: [PATCH 2/2] fix(data-viz): update alert colors --- src/components/ColorPalette/ColorPalette.js | 7 ++--- src/data/data-visualization/palettes.js | 29 ++++++++++++++++++--- 2 files changed, 30 insertions(+), 6 deletions(-) diff --git a/src/components/ColorPalette/ColorPalette.js b/src/components/ColorPalette/ColorPalette.js index 348e9d72b3e..eb3b334ea3e 100644 --- a/src/components/ColorPalette/ColorPalette.js +++ b/src/components/ColorPalette/ColorPalette.js @@ -16,7 +16,8 @@ import { fiveColorDark, monoColors, divergingColors, - alert, + alertLight, + alertDark, } from '../../data/data-visualization/palettes'; import ColorPaletteColor from './ColorPaletteColor'; import PalettesContainer from './PalettesContainer'; @@ -46,6 +47,7 @@ const ColorPalette = ({ type, isMono, isDiverging }) => { const threeColor = dark ? threeColorDark : threeColorLight; const fourColor = dark ? fourColorDark : fourColorLight; const fiveColor = dark ? fiveColorDark : fiveColorLight; + const alertColor = dark ? alertDark : alertLight; // SET RENDERED COLORS const [colorGroup, setColorGroup] = useState(oneColor); // used to render type === "grouped" colors @@ -56,7 +58,7 @@ const ColorPalette = ({ type, isMono, isDiverging }) => { } else if (type === 'categorical') { colors = categorical; } else if (type === 'alert') { - colors = alert; + colors = alertColor; } // DROPDOWN STUFF @@ -166,7 +168,6 @@ const ColorPalette = ({ type, isMono, isDiverging }) => { label="Color group selection" id="color-group-dropdown" size="xl" - light items={dropdownItems} onChange={onDropdownChange} selectedItem={dropdownItems[groupNumber - 1]} diff --git a/src/data/data-visualization/palettes.js b/src/data/data-visualization/palettes.js index 06df0cf8c96..11b661d7d76 100644 --- a/src/data/data-visualization/palettes.js +++ b/src/data/data-visualization/palettes.js @@ -1168,7 +1168,7 @@ export const divergingColors = [ }, ]; -export const alert = [ +export const alertLight = [ { name: 'Red 60', hex: 'da1e28', @@ -1180,8 +1180,26 @@ export const alert = [ light: false, }, { - name: 'Green 50', - hex: '24a148', + name: 'Yellow 30', + hex: 'f1c21b', + light: false, + }, + { + name: 'Green 60', + hex: '198038', + light: true, + }, +]; + +export const alertDark = [ + { + name: 'Red 50', + hex: 'fa4d56', + light: false, + }, + { + name: 'Orange 40', + hex: 'ff832b', light: false, }, { @@ -1189,4 +1207,9 @@ export const alert = [ hex: 'f1c21b', light: false, }, + { + name: 'Green 50', + hex: '24a148', + light: false, + }, ];