Content
View differences
Updated by Parimal Satyal about 1 year ago
#### **Context**
Ever since we moved to Primer, colour definitions have also changed. The big benefit of using Primer's named colours, among others, is that they automatically adapt to different colour modes like Dark or High contrast. This is because each colour has already-defined variants in different modes.
However, the named colours offered by Primer are not enough for all the uses we have in Open Project. A good example are the colours used for Meeting statuses; we _could_ misuse available colours like `bgColor/attention-emphasis` or `bgColor/neutral-emphasis` but this would be misusing them, since we are ignoring the semantics of these colour definitions.
#### Primer named colours
Primer has a number of [**named colours**](https://primer.style/foundations/primitives/color) that we can use as-is. However, some colours are missing from this library, and quite a few of these named colours are not available in Figma.
Some of these colours that are _not_ available or properly documented are more useful to us in our designs because they are semantically ambiguous, eg. `display-blue-fgColor`.
#### **Identified limitations**
* Really light background colours don't exist (for restricted visibility comments, for example, we went with the default background)
* Some background colours have transparency in dark mode, so there's some inconsistency there
* Border colours like `display-brown-borderColor-muted` don't seem to adapt well to high-contrast mode and remain low-contrast. This makes borders a lot less versatile.
* We might sometimes have to use non-semantic names, eg. `--label-orange-bgColor-hover` for something that isn't a label and isn't on hover
* Extracted the light/dark colours into an HTML colour palette that's easier to navigate and browse through
####
#### Figma library
I've prepared a Figma library with all of these named colours in light and dark modes. To use these colours, add the "Named Primer Colours" library to your Figma file.
The naming convention is a bit strange for now:
`:light | --fgColor-onEmphasis` --**fgColor-onEmphasis**`
Only the bold part is probably needed in code.
<img class="image_resized op-uc-image op-uc-image_inline" style="width:508px;" src="/api/v3/attachments/372686/content">
**Helpful links**
* [**Named colours in Primer**](https://primer.style/foundations/primitives/color) that we can use as-is
* [**Base scales**](https://primer.style/foundations/color/base-scales#all-color-scales) that "should only be used to construct functional and component/pattern design tokens, never used directly in code"; we can use them to construct our own semantic colour set.
#### Archived
~~**Suggestion**~~
~~We can define and maintain our own set of semantic colours using Primer's approach, either by basing them on existing scales that already work in different modes out of the box, or by defining our own custom colours that we maintain (with HEX values for different modes for each named colour).~~
### ~~**Approach**~~
* ~~Include base scales (we currently don't), and point~~ _~~our~~_ ~~semantic named colours to these base scale colours.~~
* ~~Note: they~~ _~~do~~_ ~~seem to adapt to different colour modes.~~
* ~~Architecture: How do we structure that in code so that we avoid devs randomly adding new colour variables?~~
* _~~To be discussed~~_
* ~~Process:~~
* ~~Only the Primer team can define new semantic colours based on identified needs. (New additions need to be new features/documented in Lookbook and Figma). Similar to what we do today for Octicons.~~
* ~~Add an automated test in GitHub to detect the use of base colours and throw a test failed.~~
* ~~Prefix:~~ `~~op-role-state~~` ~~eg.~~ `~~op-restricted-emphasis~~`
* ~~How do we handle dark mode for example?~~
* _~~\[open\] Base colours don't know if they're foreground/background; automatic mode adjustments might not be accurate.~~_
* ~~\[open\] Can our semantic colours point to~~ _~~other~~_ ~~named colours instead of base colours?~~
* ~~Generally, no, we should stick to base colours.~~
* ~~BUT, we have to first establish if we will even~~ _~~need~~_ ~~more colours than the base colours.~~
* ~~Risk: we create too many specific colours that are component-specific. (Eg.~~ `~~date-picker-selected-start-date~~` ~~is not a good idea)~~
* ~~We will keep the existing a parallel system for user-defined hex colours (for work pacakge status and types etc) that adapt to the dark modes. We'll need a different feature for linking "created colours" (user) to named semantic colours later. It's out of scope for this.~~
* ~~The only input needed with this system is the hex code in light mode.~~
* ~~When using semantic colours, more colours need to be manually defined, eg:~~
* ~~Background/muted~~
* ~~Text colour/foreground~~
* ~~Border, if any~~
* ~~We'll allow transparency only for border colours (not for fg and bg).~~
* ~~For every new semantic colour added, it needs to also assign base scale colours to:~~
* ~~light mode~~
* ~~dark mode~~
* ~~high contrast~~
### ~~**Identified semantic colour needs**~~
<figure class="table op-uc-figure_align-center op-uc-figure"><table class="op-uc-table"><tbody><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="background-color:hsl(0, 0%, 90%);height:95.9896px;width:120px;"><p class="op-uc-p"><s>Page/Module</s></p></td><td class="op-uc-table--cell" style="background-color:hsl(0, 0%, 90%);height:95.9896px;width:120px;"><p class="op-uc-p"><s>Object</s></p></td><td class="op-uc-table--cell" style="background-color:hsl(0, 0%, 90%);height:95.9896px;width:25.676%;"><p class="op-uc-p"><s>State / Specifics</s></p></td><td class="op-uc-table--cell" style="background-color:hsl(0, 0%, 90%);height:95.9896px;width:17.5098%;"><p class="op-uc-p"><s>Existing Primer colour</s></p></td><td class="op-uc-table--cell" style="background-color:hsl(0, 0%, 90%);height:95.9896px;width:25.676%;"><p class="op-uc-p"><s>Names semantic colour</s></p></td><td class="op-uc-table--cell" style="background-color:hsl(0, 0%, 90%);height:95.9896px;width:17.5098%;"><p class="op-uc-p"><s>Base colour</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:120px;"><p class="op-uc-p"><s><strong>Meetings</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:120px;"><p class="op-uc-p"><s><strong>Meeting status</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:17.5098%;"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>Open</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-status-open</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>base-color-green-5</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>In progress</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-status-inprogress</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>base-color-yellow-5</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>Closed</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-status-closed</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>base-colour-neutral-8</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:71.9922px;width:120px;"><p class="op-uc-p"><s><strong>Activity tab</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:71.9922px;width:120px;"><p class="op-uc-p"><s><strong>Restricted visibility comments</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:71.9922px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:71.9922px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:17.5098%;"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:25.676%;"><p class="op-uc-p"><s>RVC header background</s></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-restricted-emphasis</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>light: base-color-coral-0</s><br><s>dark: - </s><br><s>hight contrast: -</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:25.676%;"><p class="op-uc-p"><s>RVC body background </s></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-restricted-muted</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>base-color-orange-0</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:25.676%;"><p class="op-uc-p"><s>RVC border</s></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:17.5098%;"><p class="op-uc-p"><s>--borderColor-default</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><i><s>op-restricted-border</s></i></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><i><s>base-color-orange-0 at 40%</s></i></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>RDV text</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>--fgColor-default</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:120px;"><p class="op-uc-p"><s><strong>Scheduling</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:120px;"><p class="op-uc-p"><s><strong>Date picker</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:17.5098%;"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:25.676%;"><p class="op-uc-p"><s>Current date background</s></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:17.5098%;"><p class="op-uc-p"><s>--label-yellow-bgColor-active</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>Non-working days</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>--bgColor-disabled</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:25.676%;"><p class="op-uc-p"><s>Selection: start/end date background</s></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:17.5098%;"><p class="op-uc-p"><s>--bgColor-accent-emphasis</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:25.676%;"><p class="op-uc-p"><s>Selection: in-between dates background</s></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:17.5098%;"><p class="op-uc-p"><i><s>(re-evaluate, we might be able to use existing values)</s></i></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-date-range</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>base-color-blue-0</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:71.9922px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:71.9922px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:71.9922px;width:25.676%;"><p class="op-uc-p"><s>Selection: start/end date background (disabled)</s></p></td><td class="op-uc-table--cell" style="height:71.9922px;width:17.5098%;"><p class="op-uc-p"><i><s>(re-evaluate, we might be able to use existing values)</s></i></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-date-range-ends</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>base-color-neutral-8</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:71.9922px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:71.9922px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:71.9922px;width:25.676%;"><p class="op-uc-p"><s>Selection: in-between dates background (disabled)</s></p></td><td class="op-uc-table--cell" style="height:71.9922px;width:17.5098%;"><p class="op-uc-p"><i><s>(re-evaluate, we might be able to use existing values)</s></i></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-date-range-disabled</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>base-color-neutral-5</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:25.676%;"><p class="op-uc-p"><s>Active field (not focus) border</s></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:17.5098%;"><p class="op-uc-p"><s>--button-outline-bgColor-active</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>"Closest" label</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><s>--fgColor-neutral</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>"Inactive" label</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><s>--fgColor-neutral</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:120px;"><p class="op-uc-p"><s><strong>Notifications</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:17.5098%;"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><s>Notification center</s></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:25.676%;"><p class="op-uc-p"><s>Unread badge</s></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:17.5098%;"><p class="op-uc-p"><i><s>update</s></i></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-unread</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>base-color-blue-5</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><s>Top navigation</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>Red unread badge</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><s>--display-red-bgColor-emphasis</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-notification</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>base-color-red-4</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:120px;"><p class="op-uc-p"><s><strong>Projects</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:120px;"><p class="op-uc-p"><s><strong>Statuses</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:17.5098%;"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:25.676%;"><p class="op-uc-p"><s>On track</s></p></td><td class="op-uc-table--cell" style="width:17.5098%;"><p class="op-uc-p"><s> --bgColor-success-emphasis</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>At risk</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><s>--bgColor-severe-emphasis</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>Off track</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><s>--bgColor-danger-emphasis</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>Not started</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><s>--bgColor-neutral-emphasis</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>Finished</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><s>--bgColor-done-emphasis</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>Discontinued</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><s>--bgColor-attention-emphasis</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );width:120px;"><p class="op-uc-p"><s><strong>Enterprise plans</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:17.5098%;"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:25.676%;"><p class="op-uc-p"><s>Community</s></p></td><td class="op-uc-table--cell" style="width:17.5098%;"><p class="op-uc-p"><s>-</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:25.676%;"><p class="op-uc-p"><s>Basic BG</s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 100%, 91% );width:17.5098%;"><p class="op-uc-p"><s>--bgColor-severe-muted</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-basic-bg?</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>Basic FG</s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 100%, 91% );"><p class="op-uc-p"><s>--fgColor-severe</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>ob-basic-fg?</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:25.676%;"><p class="op-uc-p"><s>Professional BG</s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 100%, 91% );width:17.5098%;"><p class="op-uc-p"><s>--bgColor-sponsors-muted</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-professional-bg?</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>Professional FB</s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 100%, 91% );"><p class="op-uc-p"><s>--fgColor-sponsors</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-professional-fg?</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:25.676%;"><p class="op-uc-p"><s>Premium BG</s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 100%, 91% );width:17.5098%;"><p class="op-uc-p"><s>--bgColor-open-muted</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-premium-bg?</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>Premium FG</s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 100%, 91% );"><p class="op-uc-p"><s>--fgColor-open</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-premium-fg?</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:25.676%;"><p class="op-uc-p"><s>Corporate BG</s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 100%, 91% );width:17.5098%;"><p class="op-uc-p"><s>--bgColor-accent-muted</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-corporate-bg?</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>Corportate FG</s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 100%, 91% );"><p class="op-uc-p"><s>--fgColor-accent</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-corporate-fg?</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr></tbody></table></figure><br>
### ~~**Technical notes**~~
* ~~The colours will need to adapt to different modes (dark, high contrast...) the way Primer's own named colours do~~
### ~~**Out of scope**~~
* ~~Front-end colour picker~~
Ever since we moved to Primer, colour definitions have also changed. The big benefit of using Primer's named colours, among others, is that they automatically adapt to different colour modes like Dark or High contrast. This is because each colour has already-defined variants in different modes.
However, the named colours offered by Primer are not enough for all the uses we have in Open Project. A good example are the colours used for Meeting statuses; we _could_ misuse available colours like `bgColor/attention-emphasis` or `bgColor/neutral-emphasis` but this would be misusing them, since we are ignoring the semantics of these colour definitions.
#### Primer named colours
Primer has a number of [**named colours**](https://primer.style/foundations/primitives/color) that we can use as-is. However, some colours are missing from this library, and quite a few of these named colours are not available in Figma.
Some of these colours that are _not_ available or properly documented are more useful to us in our designs because they are semantically ambiguous, eg. `display-blue-fgColor`.
#### **Identified limitations**
* Really light background colours don't exist (for restricted visibility comments, for example, we went with the default background)
* Some background colours have transparency in dark mode, so there's some inconsistency there
* Border colours like `display-brown-borderColor-muted` don't seem to adapt well to high-contrast mode and remain low-contrast. This makes borders a lot less versatile.
* We might sometimes have to use non-semantic names, eg. `--label-orange-bgColor-hover` for something that isn't a label and isn't on hover
* Extracted the light/dark colours into an HTML colour palette that's easier to navigate and browse through
####
#### Figma library
I've prepared a Figma library with all of these named colours in light and dark modes. To use these colours, add the "Named Primer Colours" library to your Figma file.
The naming convention is a bit strange for now:
`:light | --fgColor-onEmphasis`
Only the bold part is probably needed in code.
<img class="image_resized op-uc-image op-uc-image_inline" style="width:508px;" src="/api/v3/attachments/372686/content">
**Helpful links**
* [**Named colours in Primer**](https://primer.style/foundations/primitives/color) that we can use as-is
* [**Base scales**](https://primer.style/foundations/color/base-scales#all-color-scales) that "should only be used to construct functional and component/pattern design tokens, never used directly in code"; we can use them to construct our own semantic colour set.
#### Archived
~~**Suggestion**~~
~~We can define and maintain our own set of semantic colours using Primer's approach, either by basing them on existing scales that already work in different modes out of the box, or by defining our own custom colours that we maintain (with HEX values for different modes for each named colour).~~
### ~~**Approach**~~
* ~~Include base scales (we currently don't), and point~~ _~~our~~_ ~~semantic named colours to these base scale colours.~~
* ~~Note: they~~ _~~do~~_ ~~seem to adapt to different colour modes.~~
* ~~Architecture: How do we structure that in code so that we avoid devs randomly adding new colour variables?~~
* _~~To be discussed~~_
* ~~Process:~~
* ~~Only the Primer team can define new semantic colours based on identified needs. (New additions need to be new features/documented in Lookbook and Figma). Similar to what we do today for Octicons.~~
* ~~Add an automated test in GitHub to detect the use of base colours and throw a test failed.~~
* ~~Prefix:~~ `~~op-role-state~~` ~~eg.~~ `~~op-restricted-emphasis~~`
* ~~How do we handle dark mode for example?~~
* _~~\[open\] Base colours don't know if they're foreground/background; automatic mode adjustments might not be accurate.~~_
* ~~\[open\] Can our semantic colours point to~~ _~~other~~_ ~~named colours instead of base colours?~~
* ~~Generally, no, we should stick to base colours.~~
* ~~BUT, we have to first establish if we will even~~ _~~need~~_ ~~more colours than the base colours.~~
* ~~Risk: we create too many specific colours that are component-specific. (Eg.~~ `~~date-picker-selected-start-date~~` ~~is not a good idea)~~
* ~~We will keep the existing a parallel system for user-defined hex colours (for work pacakge status and types etc) that adapt to the dark modes. We'll need a different feature for linking "created colours" (user) to named semantic colours later. It's out of scope for this.~~
* ~~The only input needed with this system is the hex code in light mode.~~
* ~~When using semantic colours, more colours need to be manually defined, eg:~~
* ~~Background/muted~~
* ~~Text colour/foreground~~
* ~~Border, if any~~
* ~~We'll allow transparency only for border colours (not for fg and bg).~~
* ~~For every new semantic colour added, it needs to also assign base scale colours to:~~
* ~~light mode~~
* ~~dark mode~~
* ~~high contrast~~
### ~~**Identified semantic colour needs**~~
<figure class="table op-uc-figure_align-center op-uc-figure"><table class="op-uc-table"><tbody><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="background-color:hsl(0, 0%, 90%);height:95.9896px;width:120px;"><p class="op-uc-p"><s>Page/Module</s></p></td><td class="op-uc-table--cell" style="background-color:hsl(0, 0%, 90%);height:95.9896px;width:120px;"><p class="op-uc-p"><s>Object</s></p></td><td class="op-uc-table--cell" style="background-color:hsl(0, 0%, 90%);height:95.9896px;width:25.676%;"><p class="op-uc-p"><s>State / Specifics</s></p></td><td class="op-uc-table--cell" style="background-color:hsl(0, 0%, 90%);height:95.9896px;width:17.5098%;"><p class="op-uc-p"><s>Existing Primer colour</s></p></td><td class="op-uc-table--cell" style="background-color:hsl(0, 0%, 90%);height:95.9896px;width:25.676%;"><p class="op-uc-p"><s>Names semantic colour</s></p></td><td class="op-uc-table--cell" style="background-color:hsl(0, 0%, 90%);height:95.9896px;width:17.5098%;"><p class="op-uc-p"><s>Base colour</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:120px;"><p class="op-uc-p"><s><strong>Meetings</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:120px;"><p class="op-uc-p"><s><strong>Meeting status</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:17.5098%;"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>Open</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-status-open</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>base-color-green-5</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>In progress</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-status-inprogress</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>base-color-yellow-5</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>Closed</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-status-closed</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>base-colour-neutral-8</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:71.9922px;width:120px;"><p class="op-uc-p"><s><strong>Activity tab</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:71.9922px;width:120px;"><p class="op-uc-p"><s><strong>Restricted visibility comments</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:71.9922px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:71.9922px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:17.5098%;"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:25.676%;"><p class="op-uc-p"><s>RVC header background</s></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-restricted-emphasis</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>light: base-color-coral-0</s><br><s>dark: - </s><br><s>hight contrast: -</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:25.676%;"><p class="op-uc-p"><s>RVC body background </s></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-restricted-muted</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>base-color-orange-0</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:25.676%;"><p class="op-uc-p"><s>RVC border</s></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:17.5098%;"><p class="op-uc-p"><s>--borderColor-default</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><i><s>op-restricted-border</s></i></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><i><s>base-color-orange-0 at 40%</s></i></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>RDV text</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>--fgColor-default</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:120px;"><p class="op-uc-p"><s><strong>Scheduling</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:120px;"><p class="op-uc-p"><s><strong>Date picker</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:17.5098%;"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:25.676%;"><p class="op-uc-p"><s>Current date background</s></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:17.5098%;"><p class="op-uc-p"><s>--label-yellow-bgColor-active</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>Non-working days</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>--bgColor-disabled</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:25.676%;"><p class="op-uc-p"><s>Selection: start/end date background</s></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:17.5098%;"><p class="op-uc-p"><s>--bgColor-accent-emphasis</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:25.676%;"><p class="op-uc-p"><s>Selection: in-between dates background</s></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:17.5098%;"><p class="op-uc-p"><i><s>(re-evaluate, we might be able to use existing values)</s></i></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-date-range</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>base-color-blue-0</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:71.9922px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:71.9922px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:71.9922px;width:25.676%;"><p class="op-uc-p"><s>Selection: start/end date background (disabled)</s></p></td><td class="op-uc-table--cell" style="height:71.9922px;width:17.5098%;"><p class="op-uc-p"><i><s>(re-evaluate, we might be able to use existing values)</s></i></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-date-range-ends</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>base-color-neutral-8</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:71.9922px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:71.9922px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:71.9922px;width:25.676%;"><p class="op-uc-p"><s>Selection: in-between dates background (disabled)</s></p></td><td class="op-uc-table--cell" style="height:71.9922px;width:17.5098%;"><p class="op-uc-p"><i><s>(re-evaluate, we might be able to use existing values)</s></i></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-date-range-disabled</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>base-color-neutral-5</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:25.676%;"><p class="op-uc-p"><s>Active field (not focus) border</s></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:17.5098%;"><p class="op-uc-p"><s>--button-outline-bgColor-active</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>"Closest" label</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><s>--fgColor-neutral</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>"Inactive" label</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><s>--fgColor-neutral</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:120px;"><p class="op-uc-p"><s><strong>Notifications</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:17.5098%;"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:120px;"><p class="op-uc-p"><s>Notification center</s></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:25.676%;"><p class="op-uc-p"><s>Unread badge</s></p></td><td class="op-uc-table--cell" style="height:47.9948px;width:17.5098%;"><p class="op-uc-p"><i><s>update</s></i></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-unread</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>base-color-blue-5</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><s>Top navigation</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>Red unread badge</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><s>--display-red-bgColor-emphasis</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-notification</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>base-color-red-4</s></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:120px;"><p class="op-uc-p"><s><strong>Projects</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:120px;"><p class="op-uc-p"><s><strong>Statuses</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:23.9974px;width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:17.5098%;"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:25.676%;"><p class="op-uc-p"><s>On track</s></p></td><td class="op-uc-table--cell" style="width:17.5098%;"><p class="op-uc-p"><s> --bgColor-success-emphasis</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>At risk</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><s>--bgColor-severe-emphasis</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>Off track</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><s>--bgColor-danger-emphasis</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>Not started</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><s>--bgColor-neutral-emphasis</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>Finished</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><s>--bgColor-done-emphasis</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:25.676%;"><p class="op-uc-p"><s>Discontinued</s></p></td><td class="op-uc-table--cell" style="height:23.9974px;width:17.5098%;"><p class="op-uc-p"><s>--bgColor-attention-emphasis</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );width:120px;"><p class="op-uc-p"><s><strong>Enterprise plans</strong></s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );width:17.5098%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:25.676%;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 0%, 92% );height:47.9948px;width:17.5098%;"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:25.676%;"><p class="op-uc-p"><s>Community</s></p></td><td class="op-uc-table--cell" style="width:17.5098%;"><p class="op-uc-p"><s>-</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:25.676%;"><p class="op-uc-p"><s>Basic BG</s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 100%, 91% );width:17.5098%;"><p class="op-uc-p"><s>--bgColor-severe-muted</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-basic-bg?</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>Basic FG</s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 100%, 91% );"><p class="op-uc-p"><s>--fgColor-severe</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>ob-basic-fg?</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:25.676%;"><p class="op-uc-p"><s>Professional BG</s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 100%, 91% );width:17.5098%;"><p class="op-uc-p"><s>--bgColor-sponsors-muted</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-professional-bg?</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>Professional FB</s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 100%, 91% );"><p class="op-uc-p"><s>--fgColor-sponsors</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-professional-fg?</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:25.676%;"><p class="op-uc-p"><s>Premium BG</s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 100%, 91% );width:17.5098%;"><p class="op-uc-p"><s>--bgColor-open-muted</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-premium-bg?</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>Premium FG</s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 100%, 91% );"><p class="op-uc-p"><s>--fgColor-open</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-premium-fg?</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:120px;"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell" style="width:25.676%;"><p class="op-uc-p"><s>Corporate BG</s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 100%, 91% );width:17.5098%;"><p class="op-uc-p"><s>--bgColor-accent-muted</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-corporate-bg?</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr><tr class="op-uc-table--row"><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>Corportate FG</s></p></td><td class="op-uc-table--cell" style="background-color:hsl( 0, 100%, 91% );"><p class="op-uc-p"><s>--fgColor-accent</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><s>op-corporate-fg?</s></p></td><td class="op-uc-table--cell"><p class="op-uc-p"><br></p></td></tr></tbody></table></figure><br>
### ~~**Technical notes**~~
* ~~The colours will need to adapt to different modes (dark, high contrast...) the way Primer's own named colours do~~
### ~~**Out of scope**~~
* ~~Front-end colour picker~~