From 5ee235b7a54e0c774483738ee8f3ccfc58b2bc6b Mon Sep 17 00:00:00 2001 From: Peter Kulko <93188219+PKulkoRaccoonGang@users.noreply.github.com> Date: Fri, 15 Sep 2023 10:15:00 +0300 Subject: [PATCH] docs: replaced SCSS variables with CSS variables on the Colors page (#2376) * docs: replaced SCSS variables with CSS variables on the Colors page of the documentation site * refactor: refactoring after review * refactor: refactoring after review * fix: removed extra commons.css generation * refactor: code refactoring * refactor: removed Colors package --- www/package.json | 6 +- www/src/components/PageLayout.tsx | 5 - www/src/components/_doc-elements.scss | 6 + www/src/pages/foundations/colors.tsx | 176 +++++++------------------- 4 files changed, 57 insertions(+), 136 deletions(-) diff --git a/www/package.json b/www/package.json index ac60345b42..6b5f81fbac 100644 --- a/www/package.json +++ b/www/package.json @@ -11,7 +11,6 @@ "analytics-node": "^6.0.0", "axios": "^0.27.2", "classnames": "^2.3.1", - "color": "^4.2.3", "gatsby": "^4.23.1", "gatsby-plugin-manifest": "^4.17.0", "gatsby-plugin-mdx": "^3.17.0", @@ -37,8 +36,8 @@ "rehype-slug": "^4.0.1", "sass": "^1.53.0", "sass-loader": "12.6.0", - "uuid": "^9.0.0", - "slugify": "^1.6.5" + "slugify": "^1.6.5", + "uuid": "^9.0.0" }, "keywords": [ "paragon", @@ -69,7 +68,6 @@ "@babel/preset-typescript": "^7.16.7", "@edx/eslint-config": "^3.1.0", "@svgr/webpack": "6.5.1", - "@types/color": "^3.0.3", "@types/mdx": "^2.0.3", "@types/mdx-js__react": "^1.5.5", "@types/react-helmet": "^6.1.6", diff --git a/www/src/components/PageLayout.tsx b/www/src/components/PageLayout.tsx index 440e9f4577..a5e1375819 100644 --- a/www/src/components/PageLayout.tsx +++ b/www/src/components/PageLayout.tsx @@ -27,11 +27,6 @@ import { SettingsContext } from '../context/SettingsContext'; import LeaveFeedback from './LeaveFeedback'; import AutoToc from './AutoToc'; -if (process.env.NODE_ENV === 'development') { - /* eslint-disable-next-line global-require */ - require('~paragon-style/scss/core/core.scss'); -} - export interface ILayout { children: React.ReactNode, showMinimizedTitle: boolean, diff --git a/www/src/components/_doc-elements.scss b/www/src/components/_doc-elements.scss index e2c29574f2..94d3e937cd 100644 --- a/www/src/components/_doc-elements.scss +++ b/www/src/components/_doc-elements.scss @@ -324,3 +324,9 @@ .pgn-doc__box-shadow-toolkit--controls-box--remove-btn svg { color: var(--pgn-color-white); } + +.color-palette { + display: grid; + grid-template-columns: repeat(auto-fit, minmax(19rem, 1fr)); + grid-row-gap: 2rem; +} diff --git a/www/src/pages/foundations/colors.tsx b/www/src/pages/foundations/colors.tsx index c0da271087..695243d62d 100644 --- a/www/src/pages/foundations/colors.tsx +++ b/www/src/pages/foundations/colors.tsx @@ -2,10 +2,8 @@ import React, { useContext } from 'react'; import { graphql } from 'gatsby'; import PropTypes from 'prop-types'; import classNames from 'classnames'; -import Color from 'color'; import { Container, DataTable } from '~paragon-react'; import SEO from '../../components/SEO'; -import MeasuredItem from '../../components/MeasuredItem'; import Layout from '../../components/PageLayout'; import { SettingsContext } from '../../context/SettingsContext'; @@ -52,36 +50,36 @@ function parseColors(cssSelectors: { selector: string; declarations: string; }[] }); } +export type CSSStyleDeclarationType = CSSStyleDeclaration | null; + export interface ISwatch { name: string, colorClassName: string, isUnused?: boolean, + styles: CSSStyleDeclarationType, } -function Swatch({ name, colorClassName, isUnused }: ISwatch) { +function Swatch({ + name, colorClassName, isUnused, styles, +}: ISwatch) { + const computedValue = styles?.getPropertyValue(name); + return (
- {name}
-
- {measurements['background-color'] && (
-
- {Color(measurements['background-color']).hex()}
-
- )}
-
+ {`var(${name})`}
+
+
+
+ {computedValue}
+
+ {themeName}
{levels.map(level => (accents
-Include these colors in scss files in one of two ways:
+
- {'// $color_name-level '}
+ {'// var(--pgn-color-name-level) '}
- $primary-100
+ var(--pgn-color-primary-100)
- $primary-200
+ var(--pgn-color-primary-200)
- $brand-100
+ var(--pgn-color-brand-100)
- $brand-200
-
-
-
- theme-color($color-name, $variant)
+ var(--pgn-color-brand-200)
+ - Using the variable name instead of the theme-color mixin will make - later upgrade paths easier. Paragon may begin to adopt CSS variables - for theming and attempt to eliminate mixins from the public api. + Using a default value in CSS variables allows to set a default value for a variable, + which will be used if the primary value of the variable is not defined or not available.
- -
- Color Name
- A theme color - |
-
- {colors.map(({ themeName }) => (
-
- {themeName}
-
- ))}
- |
-
- Variant
- - A number level or element type - |
-
- Levels
- {levels.map((level) => (
-
- {level}
-
- ))}
- - Element types - {[ - 'background', - 'disabled-border', - 'border', - 'icon', - 'active-border', - 'focus', - 'graphic', - 'default', - 'light-text', - 'hover', - 'text', - 'active', - 'dark-text', - ].map((element) => ( -
- {element}
-
- ))}
- |
-
- border: solid 1px $gray-300;
-
-
-
- border: solid 1px{' '}
- theme-color(“gray”, “border”)
- ;
-
-
-
- border: solid 1px{' '}
- theme-color(“gray”, 300);
+
+ {'// var(--pgn-color-name-level), default variable '}
+
+ var(--pgn-color-brand-100, var(--pgn-color-primary-200))
CSS Class Utilities