• 0 Posts
  • 4 Comments
Joined 2 years ago
cake
Cake day: June 17th, 2023

help-circle

  • Sorry, just saw your reply. Great question! That’s the beauty of a variable. If they’re all supposed to use the same values, then it’s one place to control them, one place to update them. Single Responsibility Principal! 😎

    That means you won’t run into the bug of updating it in one place, but forgetting /not knowing to update it in another.

    It’s also where tokens (ie: 2-layered variables) shine. All links should use the accent colour. Single variable for that high level concept, but each theme can specify what the low level concept should be (eg: theme 1 uses your design system’s green-bright)

    And if that concept’s concretion (ie: actual / raw value) needs to change (eg: the green is now a different shade), it’s still only one place that needs to change

    It also helps identify what areas use the same concept (eg: how many use the accent colour) and opportunities to combine/ deduplicate



  • Tokenise your styles with variable layers. Eg: put a class on your body tag for each theme, eg: dark-mode, high-contrast

    Then define your components by abstract style variables, eg: button-color, heading-weight,

    Then define the style variables for each theme:

    body { –button-color: green; }

    body.dark-mode { –button-color: blue; }

    button { backgroud: var(–button-color); }

    Then all you need to do is a simple JS function to set the appropriate theme class on your document body!

    This way your components are compliant to your style guide, without needing to know the implementation details of your themeing Very SRP, much Demeter, such OCP

    Apologies for psudocode, LMK if you have any furthers :)