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

[BD-46] feat: Paragon theme CSS is built and published independently of consuming applications #2102

Merged

Conversation

PKulkoRaccoonGang
Copy link
Contributor

@PKulkoRaccoonGang PKulkoRaccoonGang commented Feb 28, 2023

Description

Paragon CLI

  • Ensure there is a Paragon CLI to compile Paragon's design tokens and SCSS styles to generated CSS files (e.g., perhaps similar to the build-scss.js Node script in www).

Core CSS

  • Core styles (i.e., foundation, layout, component styles, all the previously @include'd Bootstrap styles, CSS utility classes, usages of the CSS variables generated by the design tokens, etc.).

Light CSS

  • All CSS variable definitions for the core Paragon light theme variant.
  • Each generated CSS file could be output twice: once minimifed and once unminified. This would make debugging easier for our future selves and for consumers than only generating a minified CSS file.
  • Consider the impacts on the @edx/brand NPM packages for theme authors. The CLI to compile the CSS into the appropriate files should be exposed to @edx/brand theme authors.

NPM

  • Verify the output CSS files will be included in the published NPM package such that it can be hosted on a CDN (we should be able to use an open source CDN for initial release like jsdelivr or unpkg).
  • Ensure consuming applications can still optionally import the necessary styles for core/light from installed copies of @edx/paragon and/or @edx/brand at the versions defined in package.json should an application not want to pull from a CDN (e.g., still supporting @import "~@edx/paragon/scss/core/core"; as an alternative to core.css and light.css).

Issue: #2014

Merge Checklist

  • If your update includes visual changes, have they been reviewed by a designer? Send them a link to the Netlify deploy preview, if applicable.
  • Does your change adhere to the documented style conventions?
  • Do any prop types have missing descriptions in the Props API tables in the documentation site (check deploy preview)?
  • Were your changes tested using all available themes (see theme switcher in the header of the deploy preview, under the "Settings" icon)?
  • Were your changes tested in the example app?
  • Is there adequate test coverage for your changes?
  • Consider whether this change needs to reviewed/QA'ed for accessibility (a11y). If so, please add wittjeff and adamstankiewicz as reviewers on this PR.

Post-merge Checklist

  • Verify your changes were released to NPM at the expected version.
  • If you'd like, share your contribution in #show-and-tell.
  • 🎉 🙌 Celebrate! Thanks for your contribution.

@openedx-webhooks openedx-webhooks added the blended PR is managed through 2U's blended developmnt program label Feb 28, 2023
@openedx-webhooks
Copy link

Thanks for the pull request, @PKulkoRaccoonGang!

When this pull request is ready, tag your edX technical lead.

@PKulkoRaccoonGang PKulkoRaccoonGang force-pushed the Peter_Kulko/paragon-css-build branch 4 times, most recently from c39ee86 to 1eb1263 Compare February 28, 2023 13:03
@codecov
Copy link

codecov bot commented Feb 28, 2023

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 90.76%. Comparing base (6d6fa91) to head (29b86a7).
Report is 1026 commits behind head on alpha.

Additional details and impacted files
@@           Coverage Diff           @@
##            alpha    #2102   +/-   ##
=======================================
  Coverage   90.76%   90.76%           
=======================================
  Files         213      213           
  Lines        3499     3499           
  Branches      843      843           
=======================================
  Hits         3176     3176           
  Misses        315      315           
  Partials        8        8           

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

Copy link
Contributor

@viktorrusakov viktorrusakov left a comment

Choose a reason for hiding this comment

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

@PKulkoRaccoonGang left initial feedback, I think we can also improve build-tokens.js file more, I'll take a look a little later

tokens/style-dictionary.js Outdated Show resolved Hide resolved
tokens/style-dictionary.js Outdated Show resolved Hide resolved
build-css.js Outdated Show resolved Hide resolved
tokens/build-tokens.js Outdated Show resolved Hide resolved
build-css.js Outdated Show resolved Hide resolved
tokens/build-tokens.js Outdated Show resolved Hide resolved
@PKulkoRaccoonGang PKulkoRaccoonGang changed the title [BD-46] DRAFT: Paragon theme CSS is built and published independently of consuming applications [BD-46] : Paragon theme CSS is built and published independently of consuming applications Mar 3, 2023
@PKulkoRaccoonGang PKulkoRaccoonGang changed the title [BD-46] : Paragon theme CSS is built and published independently of consuming applications [BD-46] feat: Paragon theme CSS is built and published independently of consuming applications Mar 3, 2023
@@ -15,7 +15,7 @@
@import "~bootstrap/scss/utilities/stretched-link";
@import "~bootstrap/scss/utilities/visibility";
@import "./bootstrap-override/utilities";
@import "css/utility-classes";
@import "css/light/utility-classes";
Copy link
Member

Choose a reason for hiding this comment

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

[curious/clarification] Given that _utilities.scss is imported into core.scss which is compiled to core.css, should we be including anything related to a specific theme variant (e.g., light) in this file? Or should these utilities classes be imported into the light.css file instead?

Copy link
Contributor

Choose a reason for hiding this comment

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

yeah, makes sense, we moved it to to the light.css file

build-scss.js Outdated
const compileThemeStyleSheets = (themeVariant) => {
fs.writeFileSync(
`./dist/${themeVariant}.css`,
compileStyleSheet(`./scss/core/css/${themeVariant}/variables.css`).css
Copy link
Member

Choose a reason for hiding this comment

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

[consideration] We may want to generate these CSS files based on the tokens outside of the scss directory (i.e., its beginning to feel a bit odd to generate CSS files in a folder that intends to be for SCSS files haha).

Copy link
Contributor

Choose a reason for hiding this comment

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

True, I had similar thoughts haha. I've refactored our styles structure by creating new root styles directory with separate css and scss subdirectories there, this is a breaking change for the consumers, but so is almost every change in alpha branch, so I think that's ok. (it just didn't feel right to create a separate css directory without grouping it with scss, I think introducing styles directory is more intuitive)

Copy link
Member

@adamstankiewicz adamstankiewicz Mar 24, 2023

Choose a reason for hiding this comment

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

I think introducing a styles directory makes sense! Would it contain both a scss and css directory?

build-scss.js Outdated
@@ -12,12 +11,35 @@ var tildaImporter = function(url, prev, done) {
return { file: url };
};

const compileStyleSheet = (path, output = 'expanded') => {
return sass.renderSync({
Copy link
Member

Choose a reason for hiding this comment

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

[curious] Does compileStyleSheet also generate map files when its output file is compressed? Say an MFE has loaded the core.min.css file, but wants to debug it. Given its minified, it won't be all that useful for debugging unless we ensure to also ship with an associated *.css.map file. According to the Dart SASS docs, it generates map files by default.

Copy link
Contributor

Choose a reason for hiding this comment

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

It didn't generate map files at first, but now it does 🙂 Good suggestion, thanks!

build-scss.js Outdated
@@ -12,12 +11,35 @@ var tildaImporter = function(url, prev, done) {
return { file: url };
};

const compileStyleSheet = (path, output = 'expanded') => {
return sass.renderSync({
Copy link
Member

Choose a reason for hiding this comment

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

Looks like sass.renderSync may be deprecated. This might be a good time to try to move away from renderSync in favor of what Dart SASS recommends for its replacement (i.e., compile - docs).

Copy link
Member

@adamstankiewicz adamstankiewicz Mar 3, 2023

Choose a reason for hiding this comment

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

Let's at least do discovery to see if we can replace; if not, defer for now.

Copy link
Contributor

Choose a reason for hiding this comment

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

Turns out we can pretty easily, I don't know why I thought it wasn't possible 🤦. Updated, thanks!

@import "css/custom-media-breakpoints";
@import "css/core/variables";
@import "css/core/custom-media-breakpoints";
@import "css/light/variables";
Copy link
Member

Choose a reason for hiding this comment

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

[curious/clarification] Similar question to the css/light/utility-classes import above, should core.scss be including the css/light/variables or only the css/core/variables given the light variables are also defined in light.css itself.

Copy link
Contributor

Choose a reason for hiding this comment

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

We've updated these import too, good catch!

@import "css/variables";
@import "css/custom-media-breakpoints";
@import "css/core/variables";
@import "css/core/custom-media-breakpoints";
Copy link
Member

Choose a reason for hiding this comment

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

[curious] Have we been able to verify the new @custom-media CSS media queries are usable solely based on the output core.css and light.css files?

We did add the postcss-custom-media PostCSS plugin to @edx/frontend-build to ensure the Webpack config for MFEs can transform @custom-media definitions into native CSS. While this is useful for MFEs (e.g., they can define/use their own @custom-media queries), I realized it may not be as relevant if MFEs are injecting an already compiled CSS file into the app. This is because the already-compiled CSS file would not be going through Webpack; it's injected at runtime, not build time.

Given this, I wonder if we may need to look into whether we need to either:

  • Only compile SCSS -> CSS with PostCSS (and any necessary plugins like postcss-custom-media) instead of Dart SASS.
  • Compile SCSS -> CSS with Dart SASS and then take the output from Dart SASS and run it through PostCSS.

Copy link
Contributor

Choose a reason for hiding this comment

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

We've chosen to go with second approach for now to first compile SCSS with Dart SASS and then process resulting CSS with PostCSS.

We could probably install a bunch of plugins to allow PostCSS compile SCSS and drop Dart SASS this way, but I think PostCSS is intended to work with CSS files only and mixing SCSS here would be messy (at least for me haha). I like the separation of concerns we introduce be leavng Dart SASS, i.e. Dart SASS is responsible only for SCSS compilation and PostCSS is responsible for transforming resulting CSS files.

Copy link
Member

Choose a reason for hiding this comment

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

I completely agree here :)

@PKulkoRaccoonGang PKulkoRaccoonGang changed the title [BD-46] feat: Paragon theme CSS is built and published independently of consuming applications [BD-46] DRAFT: Paragon theme CSS is built and published independently of consuming applications Mar 6, 2023
@PKulkoRaccoonGang PKulkoRaccoonGang force-pushed the Peter_Kulko/paragon-css-build branch from ced516b to e986834 Compare March 9, 2023 00:25
@PKulkoRaccoonGang PKulkoRaccoonGang self-assigned this Mar 9, 2023
@PKulkoRaccoonGang PKulkoRaccoonGang changed the title [BD-46] DRAFT: Paragon theme CSS is built and published independently of consuming applications [BD-46] feat: Paragon theme CSS is built and published independently of consuming applications Mar 17, 2023
@PKulkoRaccoonGang PKulkoRaccoonGang force-pushed the Peter_Kulko/paragon-css-build branch from 8cd4d48 to 2c2d961 Compare April 7, 2023 07:49
@PKulkoRaccoonGang PKulkoRaccoonGang force-pushed the Peter_Kulko/paragon-css-build branch from 2c2d961 to 29b86a7 Compare April 7, 2023 08:33
@adamstankiewicz adamstankiewicz merged commit 4fbe4ac into openedx:alpha Apr 7, 2023
@openedx-webhooks
Copy link

@PKulkoRaccoonGang 🎉 Your pull request was merged! Please take a moment to answer a two question survey so we can improve your experience in the future.

@edx-semantic-release
Copy link
Contributor

🎉 This PR is included in version 21.0.0-alpha.18 🎉

The release is available on:

Your semantic-release bot 📦🚀

monteri pushed a commit to raccoongang/paragon that referenced this pull request Aug 17, 2023
PKulkoRaccoonGang added a commit to raccoongang/paragon that referenced this pull request Aug 18, 2023
@edx-semantic-release
Copy link
Contributor

🎉 This PR is included in version 22.0.0-alpha.1 🎉

The release is available on:

Your semantic-release bot 📦🚀

@openedx-semantic-release-bot

🎉 This PR is included in version 23.0.0-alpha.1 🎉

The release is available on:

Your semantic-release bot 📦🚀

@openedx-semantic-release-bot

🎉 This PR is included in version 23.0.0 🎉

The release is available on:

Your semantic-release bot 📦🚀

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
blended PR is managed through 2U's blended developmnt program released on @alpha released
Projects
No open projects
Status: Done
Development

Successfully merging this pull request may close these issues.

Ensure core Paragon theme CSS is built and published independently of consuming applications
6 participants