diff --git a/console/client/src/features/deployments/DeploymentCard.tsx b/console/client/src/features/deployments/DeploymentCard.tsx new file mode 100644 index 0000000000..63e0b6482f --- /dev/null +++ b/console/client/src/features/deployments/DeploymentCard.tsx @@ -0,0 +1,13 @@ +import { useNavigate } from 'react-router-dom' +import { Card } from '../../components/Card' +import { deploymentTextColor } from './deployment.utils' + +export const DeploymentCard = ({ name, className }: { name: string; className?: string }) => { + const navigate = useNavigate() + return ( + navigate(`/deployments/${name}`)}> + {name} +

{name}

+
+ ) +} diff --git a/console/client/src/features/deployments/DeploymentsPage.tsx b/console/client/src/features/deployments/DeploymentsPage.tsx index c854ef0760..75d372160a 100644 --- a/console/client/src/features/deployments/DeploymentsPage.tsx +++ b/console/client/src/features/deployments/DeploymentsPage.tsx @@ -1,13 +1,11 @@ import { RocketLaunchIcon } from '@heroicons/react/24/outline' import React from 'react' -import { useNavigate } from 'react-router-dom' -import { Card } from '../../components/Card' -import { modulesContext } from '../../providers/modules-provider' import { Page } from '../../layout' +import { modulesContext } from '../../providers/modules-provider' +import { DeploymentCard } from './DeploymentCard' export const DeploymentsPage = () => { const modules = React.useContext(modulesContext) - const navigate = useNavigate() return ( @@ -15,14 +13,7 @@ export const DeploymentsPage = () => {
{modules.modules.map((module) => ( - navigate(`/deployments/${module.deploymentName}`)} - > - {module.name} -

{module.deploymentName}

-
+ ))}
diff --git a/console/client/src/features/deployments/deployment.utils.ts b/console/client/src/features/deployments/deployment.utils.ts new file mode 100644 index 0000000000..b1e5527f4d --- /dev/null +++ b/console/client/src/features/deployments/deployment.utils.ts @@ -0,0 +1,22 @@ +import hash from 'fnv1a' + +const colorNames = [ + 'text-amber-500 dark:text-amber-400', + 'text-blue-500 dark:text-blue-400', + 'text-cyan-500 dark:text-cyan-400', + 'text-emerald-500 dark:text-emerald-400', + 'text-fuchsia-500 dark:text-fuchsia-400', + 'text-green-500 dark:text-green-400', + 'text-indigo-500 dark:text-indigo-400', + 'text-lime-500 dark:text-lime-400', + 'text-orange-500 dark:text-orange-400', + 'text-pink-500 dark:text-pink-400', + 'text-purple-500 dark:text-purple-400', + 'text-sky-500 dark:text-sky-400', + 'text-slate-500 dark:text-slate-400', + 'text-teal-500 dark:text-teal-400', + 'text-violet-500 dark:text-violet-400', + 'text-yellow-500 dark:text-yellow-400', +] + +export const deploymentTextColor = (name: string) => colorNames[hash(name) % colorNames.length] diff --git a/console/client/src/features/timeline/DeploymentLabel.tsx b/console/client/src/features/timeline/DeploymentLabel.tsx deleted file mode 100644 index e0de9095e2..0000000000 --- a/console/client/src/features/timeline/DeploymentLabel.tsx +++ /dev/null @@ -1,47 +0,0 @@ -import hash from 'fnv1a' - -// prettier-ignore -const colourTable = [ - '008000', '808000', '000080', '800080', '008080', 'c0c0c0', '00ff00', - 'ffff00', '0000ff', 'ff00ff', '00ffff', 'ffffff', '000000', '00005f', - '000087', '0000af', '0000d7', '0000ff', '005f00', '005f5f', '005f87', - '005faf', '005fd7', '005fff', '008700', '00875f', '008787', '0087af', - '0087d7', '0087ff', '00af00', '00af5f', '00af87', '00afaf', '00afd7', - '00afff', '00d700', '00d75f', '00d787', '00d7af', '00d7d7', '00d7ff', - '00ff00', '00ff5f', '00ff87', '00ffaf', '00ffd7', '00ffff', '5f0000', - '5f005f', '5f0087', '5f00af', '5f00d7', '5f00ff', '5f5f00', '5f5f5f', - '5f5f87', '5f5faf', '5f5fd7', '5f5fff', '5f8700', '5f875f', '5f8787', - '5f87af', '5f87d7', '5f87ff', '5faf00', '5faf5f', '5faf87', '5fafaf', - '5fafd7', '5fafff', '5fd700', '5fd75f', '5fd787', '5fd7af', '5fd7d7', - '5fd7ff', '5fff00', '5fff5f', '5fff87', '5fffaf', '5fffd7', '5fffff', - '870000', '87005f', '870087', '8700af', '8700d7', '8700ff', '875f00', - '875f5f', '875f87', '875faf', '875fd7', '875fff', '878700', '87875f', - '878787', '8787af', '8787d7', '8787ff', '87af00', '87af5f', '87af87', - '87afaf', '87afd7', '87afff', '87d700', '87d75f', '87d787', '87d7af', - '87d7d7', '87d7ff', '87ff00', '87ff5f', '87ff87', '87ffaf', '87ffd7', - '87ffff', 'af0000', 'af005f', 'af0087', 'af00af', 'af00d7', 'af00ff', - 'af5f00', 'af5f5f', 'af5f87', 'af5faf', 'af5fd7', 'af5fff', 'af8700', - 'af875f', 'af8787', 'af87af', 'af87d7', 'af87ff', 'afaf00', 'afaf5f', - 'afaf87', 'afafaf', 'afafd7', 'afafff', 'afd700', 'afd75f', 'afd787', - 'afd7af', 'afd7d7', 'afd7ff', 'afff00', 'afff5f', 'afff87', 'afffaf', - 'afffd7', 'afffff', 'd70000', 'd7005f', 'd70087', 'd700af', 'd700d7', - 'd700ff', 'd75f00', 'd75f5f', 'd75f87', 'd75faf', 'd75fd7', 'd75fff', - 'd78700', 'd7875f', 'd78787', 'd787af', 'd787d7', 'd787ff', 'd7af00', - 'd7af5f', 'd7af87', 'd7afaf', 'd7afd7', 'd7afff', 'd7d700', 'd7d75f', - 'd7d787', 'd7d7af', 'd7d7d7', 'd7d7ff', 'd7ff00', 'd7ff5f', 'd7ff87', - 'd7ffaf', 'd7ffd7', 'd7ffff', 'ff0000', 'ff005f', 'ff0087', 'ff00af', - 'ff00d7', 'ff00ff', 'ff5f00', 'ff5f5f', 'ff5f87', 'ff5faf', 'ff5fd7', - 'ff5fff', 'ff8700', 'ff875f', 'ff8787', 'ff87af', 'ff87d7', 'ff87ff', - 'ffaf00', 'ffaf5f', 'ffaf87', 'ffafaf', 'ffafd7', 'ffafff', 'ffd700', - 'ffd75f', 'ffd787', 'ffd7af', 'ffd7d7', 'ffd7ff', 'ffff00', 'ffff5f', - 'ffff87', 'ffffaf', 'ffffd7', 'ffffff', '080808', '121212', '1c1c1c', - '262626', '303030', '3a3a3a', '444444', '4e4e4e', '585858', '606060', - '666666', '767676', '808080', '8a8a8a', '949494', '9e9e9e', 'a8a8a8', - 'b2b2b2', 'bcbcbc', 'c6c6c6', 'd0d0d0', 'dadada', 'e4e4e4', 'eeeeee', -] - -/** Create a deterministically coloured label for a deployment name. */ -export const DeploymentLabel = ({ name }: { name: string }) => { - const colour = '#' + colourTable[hash(name) % colourTable.length] - return {name} -} diff --git a/console/client/src/features/timeline/Timeline.tsx b/console/client/src/features/timeline/Timeline.tsx index c74fc7aad0..63a846d050 100644 --- a/console/client/src/features/timeline/Timeline.tsx +++ b/console/client/src/features/timeline/Timeline.tsx @@ -6,6 +6,7 @@ import { SidePanelContext } from '../../providers/side-panel-provider.tsx' import { eventIdFilter, getEvents, streamEvents, timeFilter } from '../../services/console.service.ts' import { formatTimestampShort } from '../../utils/date.utils.ts' import { panelColor } from '../../utils/style.utils.ts' +import { deploymentTextColor } from '../deployments/deployment.utils.ts' import { TimelineCall } from './TimelineCall.tsx' import { TimelineDeploymentCreated } from './TimelineDeploymentCreated.tsx' import { TimelineDeploymentUpdated } from './TimelineDeploymentUpdated.tsx' @@ -16,7 +17,6 @@ import { TimelineDeploymentCreatedDetails } from './details/TimelineDeploymentCr import { TimelineDeploymentUpdatedDetails } from './details/TimelineDeploymentUpdatedDetails.tsx' import { TimelineLogDetails } from './details/TimelineLogDetails.tsx' import { TimeSettings } from './filters/TimelineTimeControls.tsx' -import { DeploymentLabel } from './DeploymentLabel.tsx' interface Props { timeSettings: TimeSettings @@ -165,9 +165,11 @@ export const Timeline = ({ timeSettings, filters }: Props) => { - + {deploymentName(entry)} {(() => { diff --git a/console/client/src/features/timeline/details/TimelineCallDetails.tsx b/console/client/src/features/timeline/details/TimelineCallDetails.tsx index b04ab6eebc..60d893ea7f 100644 --- a/console/client/src/features/timeline/details/TimelineCallDetails.tsx +++ b/console/client/src/features/timeline/details/TimelineCallDetails.tsx @@ -1,7 +1,5 @@ import { Timestamp } from '@bufbuild/protobuf' import React, { useEffect, useState } from 'react' -import { useNavigate } from 'react-router-dom' -import { Card } from '../../../components' import { AttributeBadge } from '../../../components/AttributeBadge' import { CloseButton } from '../../../components/CloseButton' import { CodeBlock } from '../../../components/CodeBlock' @@ -11,6 +9,7 @@ import { CallEvent } from '../../../protos/xyz/block/ftl/v1/console/console_pb' import { SidePanelContext } from '../../../providers/side-panel-provider' import { getRequestCalls } from '../../../services/console.service' import { formatDuration } from '../../../utils/date.utils' +import { DeploymentCard } from '../../deployments/DeploymentCard' import { RequestGraph } from '../../requests/RequestGraph' import { verbRefString } from '../../verbs/verb.utils' import { TimelineTimestamp } from './TimelineTimestamp' @@ -22,7 +21,6 @@ interface Props { export const TimelineCallDetails = ({ timestamp, call }: Props) => { const client = useClient(ConsoleService) - const navigate = useNavigate() const { closePanel } = React.useContext(SidePanelContext) const [requestCalls, setRequestCalls] = useState([]) const [selectedCall, setSelectedCall] = useState(call) @@ -86,15 +84,7 @@ export const TimelineCallDetails = ({ timestamp, call }: Props) => { )} - navigate(`/deployments/${call.deploymentName}`)} - > - {call.deploymentName} -

{call.deploymentName}

-
+
    {selectedCall.requestName && ( diff --git a/console/client/src/features/timeline/details/TimelineDeploymentCreatedDetails.tsx b/console/client/src/features/timeline/details/TimelineDeploymentCreatedDetails.tsx index 0abdd6952a..112b85b95b 100644 --- a/console/client/src/features/timeline/details/TimelineDeploymentCreatedDetails.tsx +++ b/console/client/src/features/timeline/details/TimelineDeploymentCreatedDetails.tsx @@ -1,11 +1,10 @@ import { Timestamp } from '@bufbuild/protobuf' import React from 'react' -import { useNavigate } from 'react-router-dom' import { AttributeBadge } from '../../../components/AttributeBadge' -import { Card } from '../../../components/Card' import { CloseButton } from '../../../components/CloseButton' import { DeploymentCreatedEvent, Event } from '../../../protos/xyz/block/ftl/v1/console/console_pb' import { SidePanelContext } from '../../../providers/side-panel-provider' +import { DeploymentCard } from '../../deployments/DeploymentCard' import { TimelineTimestamp } from './TimelineTimestamp' interface Props { @@ -15,7 +14,6 @@ interface Props { export const TimelineDeploymentCreatedDetails = ({ event, deployment }: Props) => { const { closePanel } = React.useContext(SidePanelContext) - const navigate = useNavigate() return ( <> @@ -35,15 +33,7 @@ export const TimelineDeploymentCreatedDetails = ({ event, deployment }: Props) = - navigate(`/deployments/${deployment.name}`)} - > - {deployment.name} -

    {deployment.name}

    -
    +
    • diff --git a/console/client/src/features/timeline/details/TimelineDeploymentUpdatedDetails.tsx b/console/client/src/features/timeline/details/TimelineDeploymentUpdatedDetails.tsx index 282c39b74c..15540a5ec7 100644 --- a/console/client/src/features/timeline/details/TimelineDeploymentUpdatedDetails.tsx +++ b/console/client/src/features/timeline/details/TimelineDeploymentUpdatedDetails.tsx @@ -1,11 +1,10 @@ import { Timestamp } from '@bufbuild/protobuf' import React from 'react' -import { useNavigate } from 'react-router-dom' import { AttributeBadge } from '../../../components/AttributeBadge' -import { Card } from '../../../components/Card' import { CloseButton } from '../../../components/CloseButton' import { DeploymentUpdatedEvent, Event } from '../../../protos/xyz/block/ftl/v1/console/console_pb' import { SidePanelContext } from '../../../providers/side-panel-provider' +import { DeploymentCard } from '../../deployments/DeploymentCard' import { TimelineTimestamp } from './TimelineTimestamp' interface Props { @@ -15,7 +14,6 @@ interface Props { export const TimelineDeploymentUpdatedDetails = ({ event, deployment }: Props) => { const { closePanel } = React.useContext(SidePanelContext) - const navigate = useNavigate() return ( <> @@ -35,15 +33,7 @@ export const TimelineDeploymentUpdatedDetails = ({ event, deployment }: Props) = - navigate(`/deployments/${deployment.name}`)} - > - {deployment.name} -

      {deployment.name}

      -
      +
      • diff --git a/console/client/src/features/timeline/details/TimelineLogDetails.tsx b/console/client/src/features/timeline/details/TimelineLogDetails.tsx index d5ecabb3d9..def700bdd4 100644 --- a/console/client/src/features/timeline/details/TimelineLogDetails.tsx +++ b/console/client/src/features/timeline/details/TimelineLogDetails.tsx @@ -1,13 +1,12 @@ import { Timestamp } from '@bufbuild/protobuf' import React from 'react' -import { useNavigate } from 'react-router-dom' import { AttributeBadge } from '../../../components/AttributeBadge' -import { Card } from '../../../components/Card' import { CloseButton } from '../../../components/CloseButton' import { CodeBlock } from '../../../components/CodeBlock' import { Event, LogEvent } from '../../../protos/xyz/block/ftl/v1/console/console_pb' import { SidePanelContext } from '../../../providers/side-panel-provider' import { textColor } from '../../../utils/style.utils' +import { DeploymentCard } from '../../deployments/DeploymentCard' import { LogLevelBadge } from '../../logs/LogLevelBadge' import { logLevelBgColor } from '../../logs/log.utils' import { TimelineTimestamp } from './TimelineTimestamp' @@ -19,7 +18,6 @@ interface Props { export const TimelineLogDetails = ({ event, log }: Props) => { const { closePanel } = React.useContext(SidePanelContext) - const navigate = useNavigate() return ( <> @@ -39,15 +37,8 @@ export const TimelineLogDetails = ({ event, log }: Props) => {

        Attributes

        - navigate(`/deployments/${log.deploymentName}`)} - > - {log.deploymentName} -

        {log.deploymentName}

        -
        + +
          {log.requestName && (