Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Monitoring: Update monitoring charts to get colors from color studio #95550

Merged
merged 4 commits into from
Oct 23, 2024

Conversation

matt-west
Copy link
Contributor

@matt-west matt-west commented Oct 21, 2024

Fixes https://github.com/Automattic/dotcom-forge/issues/9474

Proposed Changes

  • Update the color used by the charts on the Monitoring page to use our latest color palette.
  • Pull colors from the color-studio package so they are kept in-sync with future color updates.
  • Uses the chroma package to automatically generate transparent colors, future-proofing against future changes to the color-studio package.

Left: Before | Right: After

Screenshot 2024-10-21 at 12 59 48

Why are these changes being made?

  • To ensure colors used on the Monitoring page match our brand palette.

Testing Instructions

  • Go to /site-monitoring/[domain]

@matt-west matt-west self-assigned this Oct 21, 2024
@matticbot
Copy link
Contributor

matticbot commented Oct 21, 2024

This PR modifies the release build for the following Calypso Apps:

For info about this notification, see here: PCYsg-OT6-p2

  • blaze-dashboard
  • command-palette-wp-admin
  • help-center
  • notifications
  • odyssey-stats
  • whats-new

To test WordPress.com changes, run install-plugin.sh $pluginSlug fix/monitoring-chart-colors on your sandbox.

@matticbot
Copy link
Contributor

matticbot commented Oct 21, 2024

Here is how your PR affects size of JS and CSS bundles shipped to the user's browser:

Sections (~14102 bytes added 📈 [gzipped])

name             parsed_size           gzip_size
site-monitoring     +34428 B  (+2.4%)   +14102 B  (+3.4%)
site-logs           +34428 B  (+2.4%)   +14102 B  (+3.4%)

Sections contain code specific for a given set of routes. Is downloaded and parsed only when a particular route is navigated to.

Legend

What is parsed and gzip size?

Parsed Size: Uncompressed size of the JS and CSS files. This much code needs to be parsed and stored in memory.
Gzip Size: Compressed size of the JS and CSS files. This much data needs to be downloaded over network.

Generated by performance advisor bot at iscalypsofastyet.com.

@matt-west matt-west marked this pull request as ready for review October 21, 2024 13:28
@matt-west matt-west requested a review from a team October 21, 2024 13:28
@matticbot matticbot added the [Status] Needs Review The PR is ready for review. This also triggers e2e canary tests and wp-desktop tests automatically. label Oct 21, 2024
Copy link
Contributor

@wojtekn wojtekn left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The change looks clear, and works as expected.

@matt-west matt-west merged commit e8e8ba7 into trunk Oct 23, 2024
13 checks passed
@matt-west matt-west deleted the fix/monitoring-chart-colors branch October 23, 2024 11:16
@github-actions github-actions bot removed the [Status] Needs Review The PR is ready for review. This also triggers e2e canary tests and wp-desktop tests automatically. label Oct 23, 2024
Copy link
Member

@sejas sejas left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I confirm I see the new colors.
I'm unsure of using chroma-js, it adds ~14102 bytes added 📈 [gzipped] to the loaded JS .

@matt-west, what do you think about using regular constants for those colors?

Screenshot 2024-10-23 at 11 00 03

If we decide that loading that library is worth it for this use case, then we should move it to dependencies in pacakge.json.

@@ -260,7 +261,7 @@
"bunyan": "^1.8.15",
"chalk": "^4.1.2",
"check-node-version": "^4.0.2",
"chroma-js": "^2.1.2",
"chroma-js": "^2.6.0",
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm seeing chroma-js is imported as devDependencies. They only other place it's used is in NodeJS:

const chroma = require( 'chroma-js' );

@sejas
Copy link
Member

sejas commented Oct 23, 2024

We can consider creating a follow-up PR and undoing the changes about chroma-js.

@matt-west
Copy link
Contributor Author

@sejas I decided to use chroma-js here so that we can continue to pull colors from the colour-studio package. I’d rather not hard-code them as it’s easy for them to get outdated again.

Ideally we’d have a function in the colour-studio package itself to generate alpha hex codes, but we’re not quite there yet.

I'll create a follow-up that uses a different approach.

@matt-west
Copy link
Contributor Author

@sejas I’ve opened #95614 to remove chroma-js.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants