Skip to content

Commit

Permalink
APP-304: Add semantic design variables (#2499)
Browse files Browse the repository at this point in the history
  • Loading branch information
wgardiner authored Oct 14, 2024
1 parent 4a295a8 commit 03d6132
Show file tree
Hide file tree
Showing 12 changed files with 9,459 additions and 33 deletions.
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,9 @@ node_modules
# production
/build

# generated design token styles
/design/build

# misc
.DS_Store
.env.local
Expand Down
176 changes: 176 additions & 0 deletions design/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,176 @@
build/
# Based on https://raw.githubusercontent.com/github/gitignore/main/Node.gitignore

# Logs

logs
_.log
npm-debug.log_
yarn-debug.log*
yarn-error.log*
lerna-debug.log*
.pnpm-debug.log*

# Caches

.cache

# Diagnostic reports (https://nodejs.org/api/report.html)

report.[0-9]_.[0-9]_.[0-9]_.[0-9]_.json

# Runtime data

pids
_.pid
_.seed
*.pid.lock

# Directory for instrumented libs generated by jscoverage/JSCover

lib-cov

# Coverage directory used by tools like istanbul

coverage
*.lcov

# nyc test coverage

.nyc_output

# Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files)

.grunt

# Bower dependency directory (https://bower.io/)

bower_components

# node-waf configuration

.lock-wscript

# Compiled binary addons (https://nodejs.org/api/addons.html)

build/Release

# Dependency directories

node_modules/
jspm_packages/

# Snowpack dependency directory (https://snowpack.dev/)

web_modules/

# TypeScript cache

*.tsbuildinfo

# Optional npm cache directory

.npm

# Optional eslint cache

.eslintcache

# Optional stylelint cache

.stylelintcache

# Microbundle cache

.rpt2_cache/
.rts2_cache_cjs/
.rts2_cache_es/
.rts2_cache_umd/

# Optional REPL history

.node_repl_history

# Output of 'npm pack'

*.tgz

# Yarn Integrity file

.yarn-integrity

# dotenv environment variable files

.env
.env.development.local
.env.test.local
.env.production.local
.env.local

# parcel-bundler cache (https://parceljs.org/)

.parcel-cache

# Next.js build output

.next
out

# Nuxt.js build / generate output

.nuxt
dist

# Gatsby files

# Comment in the public line in if your project uses Gatsby and not Next.js

# https://nextjs.org/blog/next-9-1#public-directory-support

# public

# vuepress build output

.vuepress/dist

# vuepress v2.x temp and cache directory

.temp

# Docusaurus cache and generated files

.docusaurus

# Serverless directories

.serverless/

# FuseBox cache

.fusebox/

# DynamoDB Local files

.dynamodb/

# TernJS port file

.tern-port

# Stores VSCode versions used for testing VSCode extensions

.vscode-test

# yarn v2

.yarn/cache
.yarn/unplugged
.yarn/build-state.yml
.yarn/install-state.gz
.pnp.*

# IntelliJ based IDEs
.idea

# Finder (MacOS) folder config
.DS_Store
23 changes: 23 additions & 0 deletions design/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
# Design

This package processes [design tokens](https://tr.designtokens.org/format/) to generate CSS variables and a Tailwind config. It expects the design tokens exported from our Figma with the [Design Tokens plugin](https://www.figma.com/community/plugin/888356646278934516/design-tokens).

```
bun run build-tokens
```

It parses `tokens/tokens.json` and generates
- `base-regen.css`: base colors for Regen theme
- `base-terrasos.css`: base colors for Terrasos theme
- `alias-regen.css`: aliased colors that reference theme base colors (e.g. `primary.400` => `green.400`)
- `alias-terrasos.css`: aliased colors that reference theme base colors
- `semantic-regen-dark.css`: semantic colors for elements with a dark theme
- `semantic-regen-light.css`: semantic colors for elements with a light theme
- `semantic-terrasos-dark.css`: semantic colors for elements with a dark theme
- `semantic-terrasos-light.css`: semantic colors for elements with a light theme
- `tailwind.common.js`: a shared js file that can reference the relevant css variables for all theme clients

These files can then be integrated into our app's theming system, by updating
- `tailwind.common.js`: shared interface
- `tailwind.css`: default theme variables
- `web-marketplace/src/clients/*/*.tailwind.css`: client specific theme variables
Loading

0 comments on commit 03d6132

Please sign in to comment.