From ff77b2fbe9124ebc10614dbeceeca5e30d864177 Mon Sep 17 00:00:00 2001 From: Joshua Israel <65822698+joshri@users.noreply.github.com> Date: Mon, 16 Oct 2023 16:18:57 -0400 Subject: [PATCH] Add colors and exports for new EE pipelines UI (#4084) * add compute ready to exports * additional pipeline colors * snaps * black and white will stay their respective colors in light/dark modes, while neutral colors will switch * a couple stragglers after local testing * missing hashtags --- ui/App.tsx | 2 +- ui/components/Alert.tsx | 6 +++--- ui/components/ChipGroup.tsx | 2 +- ui/components/DetailModal.tsx | 2 +- ui/components/ErrorList.tsx | 8 ++++++-- ui/components/FluxObjectsTable.tsx | 4 ++-- ui/components/GraphNode.tsx | 2 +- ui/components/HealthCheckStatusIndicator.tsx | 2 +- ui/components/KubeStatusIndicator.tsx | 2 +- ui/components/Modal.tsx | 2 +- ui/components/Page.tsx | 2 +- ui/components/PodDetail.tsx | 2 +- ui/components/Policies/Utils/Parameters.tsx | 2 +- ui/components/Policies/Utils/PolicyUtils.tsx | 2 +- ui/components/SyncButton.tsx | 2 +- ui/components/UserSettings.tsx | 4 ++-- .../__tests__/__snapshots__/Page.test.tsx.snap | 4 ++-- .../__snapshots__/SyncActions.test.tsx.snap | 6 +++--- ui/index.ts | 11 +++++++---- ui/lib/theme.ts | 12 ++++++++---- ui/pages/SignIn.tsx | 2 +- ui/typedefs/styled.d.ts | 2 ++ 22 files changed, 48 insertions(+), 35 deletions(-) diff --git a/ui/App.tsx b/ui/App.tsx index b7aa50018d..c38b2c77a8 100644 --- a/ui/App.tsx +++ b/ui/App.tsx @@ -3,9 +3,9 @@ import qs from "query-string"; import * as React from "react"; import { QueryClient, QueryClientProvider } from "react-query"; import { - BrowserRouter as Router, Redirect, Route, + BrowserRouter as Router, Switch, } from "react-router-dom"; import { ToastContainer } from "react-toastify"; diff --git a/ui/components/Alert.tsx b/ui/components/Alert.tsx index 0f4221c8bf..14f7071e69 100644 --- a/ui/components/Alert.tsx +++ b/ui/components/Alert.tsx @@ -1,4 +1,4 @@ -import { Alert as MaterialAlert, AlertTitle } from "@material-ui/lab"; +import { AlertTitle, Alert as MaterialAlert } from "@material-ui/lab"; import * as React from "react"; import styled from "styled-components"; import { ThemeTypes } from "../contexts/AppContext"; @@ -28,7 +28,7 @@ function UnstyledAlert({ center, title, message, severity, className }: Props) { severity={severity} > {title} - {message} + {message} ); @@ -46,7 +46,7 @@ const Alert = styled(UnstyledAlert)` background-color: ${(props) => props.theme.colors.alertLight}; } .MuiAlertTitle-root { - color: ${(props) => props.theme.colors.black}; + color: ${(props) => props.theme.colors.neutral40}; } .MuiAlert-standardInfo { svg { diff --git a/ui/components/ChipGroup.tsx b/ui/components/ChipGroup.tsx index bf565d651f..ddbdcb8da9 100644 --- a/ui/components/ChipGroup.tsx +++ b/ui/components/ChipGroup.tsx @@ -41,7 +41,7 @@ function ChipGroup({ className, chips = [], onChipRemove, onClearAll }: Props) { export default styled(ChipGroup).attrs({ className: ChipGroup.name })` .MuiChip-root { - color: ${(props) => props.theme.colors.black}; + color: ${(props) => props.theme.colors.neutral40}; margin-right: ${(props) => props.theme.spacing.xxs}; background-color: ${(props) => props.theme.colors.neutralGray}; transition: none; diff --git a/ui/components/DetailModal.tsx b/ui/components/DetailModal.tsx index b458d938b5..551d678355 100644 --- a/ui/components/DetailModal.tsx +++ b/ui/components/DetailModal.tsx @@ -62,6 +62,6 @@ export default styled(DetailModal).attrs({ className: DetailModal.name })` padding: ${(props) => props.theme.spacing.small + " " + props.theme.spacing.medium}; .MuiIconButton-root { - color: ${(props) => props.theme.colors.black}; + color: ${(props) => props.theme.colors.neutral40}; } `; diff --git a/ui/components/ErrorList.tsx b/ui/components/ErrorList.tsx index 9f038d39d8..62320c521b 100644 --- a/ui/components/ErrorList.tsx +++ b/ui/components/ErrorList.tsx @@ -57,7 +57,7 @@ const NavButton = styled(Button)` const ErrorsCount = styled.span` background: ${(props) => props.theme.colors.alertDark}; - color: ${(props) => props.theme.colors.white}; + color: ${(props) => props.theme.colors.neutral00}; padding: 4px; border-radius: 4px; margin: 0 4px; @@ -84,7 +84,11 @@ function ErrorList({ className, errors }: Props) { setExpand(false)}> - + {currentError.clusterName}:  {currentError.message} diff --git a/ui/components/FluxObjectsTable.tsx b/ui/components/FluxObjectsTable.tsx index 73dff31c52..b39461223e 100644 --- a/ui/components/FluxObjectsTable.tsx +++ b/ui/components/FluxObjectsTable.tsx @@ -13,10 +13,10 @@ import HealthCheckStatusIndicator, { } from "./HealthCheckStatusIndicator"; import ImageLink from "./ImageLink"; import KubeStatusIndicator, { - computeMessage, - createSyntheticCondition, ReadyStatusValue, SpecialObject, + computeMessage, + createSyntheticCondition, } from "./KubeStatusIndicator"; import Link from "./Link"; import Text from "./Text"; diff --git a/ui/components/GraphNode.tsx b/ui/components/GraphNode.tsx index f10e058567..9c82ae10f2 100644 --- a/ui/components/GraphNode.tsx +++ b/ui/components/GraphNode.tsx @@ -29,7 +29,7 @@ const GraphIcon = styled.img` `; const Node = styled(Flex)` - background: ${(props) => props.theme.colors.white}; + background: ${(props) => props.theme.colors.neutral00}; border: 5px solid ${(props) => props.theme.colors.grayToPrimary}; border-radius: ${nodeBorderRadius}px; user-select: none; diff --git a/ui/components/HealthCheckStatusIndicator.tsx b/ui/components/HealthCheckStatusIndicator.tsx index 2d01cc697c..34df864903 100644 --- a/ui/components/HealthCheckStatusIndicator.tsx +++ b/ui/components/HealthCheckStatusIndicator.tsx @@ -73,7 +73,7 @@ export default styled(HealthCheckStatusIndicator).attrs({ className: HealthCheckStatusIndicator.name, })` ${Icon} ${Text} { - color: ${(props) => props.theme.colors.black}; + color: ${(props) => props.theme.colors.neutral40}; font-weight: 400; } `; diff --git a/ui/components/KubeStatusIndicator.tsx b/ui/components/KubeStatusIndicator.tsx index 075b76083e..da433171f2 100644 --- a/ui/components/KubeStatusIndicator.tsx +++ b/ui/components/KubeStatusIndicator.tsx @@ -211,7 +211,7 @@ export default styled(KubeStatusIndicator).attrs({ className: KubeStatusIndicator.name, })` ${Icon} ${Text} { - color: ${(props) => props.theme.colors.black}; + color: ${(props) => props.theme.colors.neutral40}; font-weight: 400; } `; diff --git a/ui/components/Modal.tsx b/ui/components/Modal.tsx index 3791cd4851..7238edf73d 100644 --- a/ui/components/Modal.tsx +++ b/ui/components/Modal.tsx @@ -26,7 +26,7 @@ export const Body = styled.div` display: flex; flex-direction: column; justify-content: space-evenly; - background-color: ${(props) => props.theme.colors.white}; + background-color: ${(props) => props.theme.colors.neutral00}; margin: 0 auto; max-width: 540px; padding: 16px 32px; diff --git a/ui/components/Page.tsx b/ui/components/Page.tsx index 033a5f4da8..14701e4fcd 100644 --- a/ui/components/Page.tsx +++ b/ui/components/Page.tsx @@ -35,7 +35,7 @@ const PageLayout = styled(Flex)` overflow: hidden; `; export const Content = styled(Flex)` - background-color: ${(props) => props.theme.colors.white}; + background-color: ${(props) => props.theme.colors.neutral00}; border-radius: 10px; box-sizing: border-box; margin: 0 auto; diff --git a/ui/components/PodDetail.tsx b/ui/components/PodDetail.tsx index 19520c2a47..b0076b73b7 100644 --- a/ui/components/PodDetail.tsx +++ b/ui/components/PodDetail.tsx @@ -42,7 +42,7 @@ const ContainerDivider = styled(Flex)` border-bottom: 3px solid; border-image-slice: 1; border-image-source: ${(props) => - `linear-gradient(to right, ${props.theme.colors.neutral30} 0%, ${props.theme.colors.white} 100%)`}; + `linear-gradient(to right, ${props.theme.colors.neutral30} 0%, ${props.theme.colors.neutral00} 100%)`}; `; type ListProps = { diff --git a/ui/components/Policies/Utils/Parameters.tsx b/ui/components/Policies/Utils/Parameters.tsx index ea26f2074d..77e3ed94e9 100644 --- a/ui/components/Policies/Utils/Parameters.tsx +++ b/ui/components/Policies/Utils/Parameters.tsx @@ -22,7 +22,7 @@ export const ParameterCell = ({ return ( {label} - {value} + {value} ); }; diff --git a/ui/components/Policies/Utils/PolicyUtils.tsx b/ui/components/Policies/Utils/PolicyUtils.tsx index a17ac17859..7ec673d2ad 100644 --- a/ui/components/Policies/Utils/PolicyUtils.tsx +++ b/ui/components/Policies/Utils/PolicyUtils.tsx @@ -34,7 +34,7 @@ export const SectionWrapper = ({ title, children }) => { export const ChipWrap = styled(Chip)` &.MuiChip-root { - color: ${(props) => props.theme.colors.black}; + color: ${(props) => props.theme.colors.neutral40}; background-color: ${(props) => props.theme.colors.neutralGray}; padding: 2px 4px; height: inherit; diff --git a/ui/components/SyncButton.tsx b/ui/components/SyncButton.tsx index 92cec678e9..3ae7dec5a4 100644 --- a/ui/components/SyncButton.tsx +++ b/ui/components/SyncButton.tsx @@ -43,7 +43,7 @@ const Sync = styled(Button)<{ $hideDropdown: boolean }>` export const DropDown = styled(Flex)` position: absolute; overflow: hidden; - background: ${(props) => props.theme.colors.white}; + background: ${(props) => props.theme.colors.neutral00}; height: ${(props) => (props.open ? "100%" : "0px")}; transition-property: height; transition-duration: 0.2s; diff --git a/ui/components/UserSettings.tsx b/ui/components/UserSettings.tsx index a93a63ce22..a1f02a980e 100644 --- a/ui/components/UserSettings.tsx +++ b/ui/components/UserSettings.tsx @@ -26,7 +26,7 @@ const SettingsMenu = styled(Menu)` justify-content: flex-end; .MuiListItemIcon-root { min-width: 0; - color: ${(props) => props.theme.colors.black}; + color: ${(props) => props.theme.colors.neutral40}; } .MuiSvgIcon-root { padding-right: ${(props) => props.theme.spacing.xs}; @@ -40,7 +40,7 @@ const PersonButton = styled(IconButton)<{ open?: boolean }>` background-color: ${(props) => props.theme.colors.neutralGray}; color: ${(props) => props.theme.colors.neutral30}; :hover { - background-color: ${(props) => props.theme.colors.white}; + background-color: ${(props) => props.theme.colors.neutral00}; color: ${(props) => props.theme.colors.primary10}; } } diff --git a/ui/components/__tests__/__snapshots__/Page.test.tsx.snap b/ui/components/__tests__/__snapshots__/Page.test.tsx.snap index 21a52fe0e2..63c693b958 100644 --- a/ui/components/__tests__/__snapshots__/Page.test.tsx.snap +++ b/ui/components/__tests__/__snapshots__/Page.test.tsx.snap @@ -197,7 +197,7 @@ exports[`Page snapshots default 1`] = ` } .c10.MuiIconButton-root:hover { - background-color: #fff; + background-color: #ffffff; color: #009CCC; } @@ -221,7 +221,7 @@ exports[`Page snapshots default 1`] = ` } .c15 { - background-color: #fff; + background-color: #ffffff; border-radius: 10px; box-sizing: border-box; margin: 0 auto; diff --git a/ui/components/__tests__/__snapshots__/SyncActions.test.tsx.snap b/ui/components/__tests__/__snapshots__/SyncActions.test.tsx.snap index c3c2b33cf2..670a346298 100644 --- a/ui/components/__tests__/__snapshots__/SyncActions.test.tsx.snap +++ b/ui/components/__tests__/__snapshots__/SyncActions.test.tsx.snap @@ -57,7 +57,7 @@ exports[`SyncActions snapshots hideDropdown 1`] = ` .c5 { position: absolute; overflow: hidden; - background: #fff; + background: #ffffff; height: 0px; -webkit-transition-property: height; transition-property: height; @@ -330,7 +330,7 @@ exports[`SyncActions snapshots non-suspended 1`] = ` .c9 { position: absolute; overflow: hidden; - background: #fff; + background: #ffffff; height: 0px; -webkit-transition-property: height; transition-property: height; @@ -640,7 +640,7 @@ exports[`SyncActions snapshots suspended 1`] = ` .c9 { position: absolute; overflow: hidden; - background: #fff; + background: #ffffff; height: 0px; -webkit-transition-property: height; transition-property: height; diff --git a/ui/index.ts b/ui/index.ts index 4c0bbd8482..28c0376f17 100644 --- a/ui/index.ts +++ b/ui/index.ts @@ -35,7 +35,9 @@ import ImageAutomationUpdatesTable from "./components/ImageAutomation/updates/Im import InfoList, { InfoField } from "./components/InfoList"; import Input, { InputProps } from "./components/Input"; import Interval from "./components/Interval"; -import KubeStatusIndicator from "./components/KubeStatusIndicator"; +import KubeStatusIndicator, { + computeReady, +} from "./components/KubeStatusIndicator"; import KustomizationDetail from "./components/KustomizationDetail"; import LargeInfo from "./components/LargeInfo"; import Layout from "./components/Layout"; @@ -180,13 +182,13 @@ export { ImageAutomation, ImageAutomationDetails, ImageAutomationIcon, - ImageRepositoriesTable, ImageAutomationRepoDetails, - ImageAutomationUpdatesTable, ImageAutomationUpdatesDetails, - ImagePolicy, + ImageAutomationUpdatesTable, ImagePoliciesTable, + ImagePolicy, ImagePolicyDetails, + ImageRepositoriesTable, ImageRepository, ImageUpdateAutomation, InfoField, @@ -245,6 +247,7 @@ export { ViolationDetails, YamlView, baseTheme, + computeReady, coreClient, createYamlCommand, filterByStatusCallback, diff --git a/ui/lib/theme.ts b/ui/lib/theme.ts index 16931b38f6..2270551ad4 100644 --- a/ui/lib/theme.ts +++ b/ui/lib/theme.ts @@ -56,8 +56,8 @@ export const theme = (mode: ThemeTypes = ThemeTypes.Light): DefaultTheme => { return { ...baseTheme, colors: { - black: "#fff", - white: "#1a1a1a", + black: "#1a1a1a", + white: "#ffffff", primary: "#009CCC", //only used in nav text when collapsed + selected/hover primaryLight05: "rgba(0,179,236,0.05)", @@ -74,6 +74,7 @@ export const theme = (mode: ThemeTypes = ThemeTypes.Light): DefaultTheme => { alertOriginal: "#BC3B1D", alertDark: "#9F3119", neutralGray: "#32324B", + pipelineGray: "#4b5778", neutral00: "#1a1a1a", neutral10: "#737373", neutral20: "#d8d8d8", @@ -83,6 +84,7 @@ export const theme = (mode: ThemeTypes = ThemeTypes.Light): DefaultTheme => { grayToPrimary: "#009CCC", neutral20ToPrimary: "#32324B", backGray: "#32324B", + pipelinesBackGray: "#4b5778", blueWithOpacity: "rgba(0, 179, 236, 0.1)", feedbackLight: "#8A460A", feedbackMedium: "#F7BF8E", @@ -101,7 +103,7 @@ export const theme = (mode: ThemeTypes = ThemeTypes.Light): DefaultTheme => { ...baseTheme, colors: { black: "#1a1a1a", - white: "#fff", + white: "#ffffff", primary: "#00b3ec", primaryLight05: "#E5F7FD", primaryLight10: "#98E0F7", @@ -117,6 +119,7 @@ export const theme = (mode: ThemeTypes = ThemeTypes.Light): DefaultTheme => { alertOriginal: "#BC3B1D", alertDark: "#9F3119", neutralGray: "#F6F7F9", + pipelineGray: "#dde1e9", neutral00: "#ffffff", neutral10: "#f5f5f5", neutral20: "#d8d8d8", @@ -126,6 +129,7 @@ export const theme = (mode: ThemeTypes = ThemeTypes.Light): DefaultTheme => { grayToPrimary: "#737373", neutral20ToPrimary: "#d8d8d8", backGray: "#eef0f4", + pipelinesBackGray: "#eef0f4", blueWithOpacity: "rgba(0, 179, 236, 0.1)", feedbackLight: "#FCE6D2", feedbackMedium: "#F7BF8E", @@ -159,7 +163,7 @@ export const GlobalStyle = createGlobalStyle` body { font-family: ${(props) => props.theme.fontFamilies.regular}; font-size: ${(props) => props.theme.fontSizes.medium}; - color: ${(props) => props.theme.colors.black}; + color: ${(props) => props.theme.colors.neutral40}; padding: 0; margin: 0; min-width: fit-content; diff --git a/ui/pages/SignIn.tsx b/ui/pages/SignIn.tsx index d2d4f31c56..970c6887da 100644 --- a/ui/pages/SignIn.tsx +++ b/ui/pages/SignIn.tsx @@ -15,7 +15,7 @@ import images from "../lib/images"; import { withBasePath } from "../lib/utils"; export const FormWrapper = styled(Flex)` - background-color: ${(props) => props.theme.colors.white}; + background-color: ${(props) => props.theme.colors.neutral00}; border-radius: ${(props) => props.theme.borderRadius.soft}; width: 500px; align-content: space-between; diff --git a/ui/typedefs/styled.d.ts b/ui/typedefs/styled.d.ts index 012cc05a4c..b394cf754e 100644 --- a/ui/typedefs/styled.d.ts +++ b/ui/typedefs/styled.d.ts @@ -15,6 +15,7 @@ export namespace colors { const alertMedium: string; const alertDark: string; const neutralGray: string; + const pipelineGray: string; const neutral00: string; const neutral10: string; const neutral20: string; @@ -24,6 +25,7 @@ export namespace colors { const grayToPrimary: string; const neutral20ToPrimary: string; const backGray: string; + const pipelinesBackGray: string; const blueWithOpacity: string; const feedbackLight: string; const feedbackMedium: string;