Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pdwaggoner/ygdesign
YouGov Design Tools
https://github.com/pdwaggoner/ygdesign
Last synced: 22 days ago
JSON representation
YouGov Design Tools
- Host: GitHub
- URL: https://github.com/pdwaggoner/ygdesign
- Owner: pdwaggoner
- License: mit
- Created: 2022-02-09T18:03:35.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2022-02-09T18:39:43.000Z (about 3 years ago)
- Last Synced: 2024-11-29T18:49:42.087Z (3 months ago)
- Language: R
- Size: 373 KB
- Stars: 0
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# `ygdesign`: YouGov Design Tools
[data:image/s3,"s3://crabby-images/417cf/417cf692c0336cfb986af7b59a727791bd7cd66d" alt="Project Status: Moved to https://github.com/yougov-datascience/ygdesign – The project has been moved to a new location, and the version at that location should be considered authoritative."](https://www.repostatus.org/#moved) to the [ygverse](https://github.com/yougov-datascience/ygdesign)
The goal of `ygdesign` is to offer a suite of tools to aid in the design and production of data visualization. The package will eventually include many tools, e.g., `ggplot2` theme's, geoms, etc. But for now, the package only includes a color palette generator for all color palettes from the 2022 YouGov brand refresh.
## Use
Users simply pass the name of the desired palette in the main function `yg_palette()`, along with the number of colors desired from the palette (e.g., only 4 from a 5-color palette), and whether "continuous" or "discrete" `type` mapping is desired. If the number of colors, `n`, is `null`, then all colors in the palette will be returned.
## Palettes
1. `ps_core`: five colors including the primary (1) and secondary (4) core shades
2. `secondary_core`: four colors including the secondary core shades
3. `grapefruit`: five shades of the primary color, "grapefruit"
4. `plum`: five shades of the first secondary color, "plum"
5. `pomegranate`: five shades of the second secondary color, "pomegranate"
6. `blueberry`: five shades of the third secondary color, "blueberry"
7. `avocado`: five shades of the fourth secondary color, "avocado"
8. `full`: 24 colors giving an extensive palette for larger applications
9. `grayscale`: eight colors in the gray scale from "stone gray 7" to "black"## Displaying palettes
To display or use a specific palette, pass the palette name in quotes to `yg_palette()`.
```{r}
yg_palette("ps_core")
```
data:image/s3,"s3://crabby-images/31a7d/31a7dc85df0d5405fad5156cd6e7e950fd9675ef" alt=""```{r}
yg_palette("secondary_core")
```
data:image/s3,"s3://crabby-images/20aa3/20aa3c11fe01c81519b5ba31c8dbd48d3ca57321" alt=""```{r}
yg_palette("grapefruit")
```
data:image/s3,"s3://crabby-images/7d3b6/7d3b634b28eb1b277cf95f9c32275c60c1eda2c0" alt=""```{r}
yg_palette("plum")
```
data:image/s3,"s3://crabby-images/178a2/178a299adbbf105612bb6085f679d9d8771f866b" alt=""```{r}
yg_palette("pomegranate")
```
data:image/s3,"s3://crabby-images/3a5fa/3a5fad8b22cdde4262236dbfd75a79816cee2362" alt=""```{r}
yg_palette("blueberry")
```
data:image/s3,"s3://crabby-images/23f59/23f599baf277b9877ae91c0be2093975d1b81da6" alt=""```{r}
yg_palette("avocado")
```
data:image/s3,"s3://crabby-images/a0946/a0946569812a7c777bc51a049611654483d8358a" alt=""```{r}
yg_palette("full")
```
data:image/s3,"s3://crabby-images/df654/df6548af793428e9a5dc56158d3669439f8b3927" alt=""```{r}
yg_palette("grayscale")
```
data:image/s3,"s3://crabby-images/87914/87914b4cd4b3ce883a9465fd37324c92042135e3" alt=""## Interpolation via the "continuous" `type`
To interpolate between existing colors in a given palette, pass the number of desired shades (`n`), the palette name (`name`), and the type (`type`) to `yg_palette()`. For example, interpolate 50 shades for the "ps_core" and "grayscale" palette:
```{r}
yg_palette(n = 50, name = "ps_core", type = "continuous")
```
data:image/s3,"s3://crabby-images/51fde/51fdeedd64546e617c3a66428076dbe5e55f67bb" alt=""```{r}
yg_palette(n = 50, name = "grayscale", type = "continuous")
```
data:image/s3,"s3://crabby-images/5046c/5046c40a2df29cedeeb32c66acfeec387bd8db38" alt=""Further, users can increase `n` for larger contexts or to eliminate separation between interpolated shades. Start with:
```{r}
yg_palette(n = length(yg_palette("full")), name = "full", type = "continuous")
```
data:image/s3,"s3://crabby-images/0a9bc/0a9bc753206f16ae86bc17c2de137f9f4141e924" alt=""which is equivalent to:
```{r}
yg_palette("full")
```But note the difference with, e.g., `n = 150`:
```{r}
yg_palette(n = 150, name = "full", type = "continuous")
```
data:image/s3,"s3://crabby-images/1f4d1/1f4d15feabb1c8668116ddd504e50caf43736f49" alt=""Or with `n = 500`:
```{r}
yg_palette(n = 500, name = "full", type = "continuous")
```
data:image/s3,"s3://crabby-images/870fb/870fb52452a8cdec0d67b69d752086d0c8cbb7a8" alt=""Of note, users can declare "discrete" in the `type` argument if working with discrete class data (e.g., factors).
## How do I get `ygdesign`?
`ygdesign` is under active development at this repo. Engagement and collaboration of any kind is encouraged, whether via filing an [issue](https://github.com/pdwaggoner/ygdesign/issues) or submitting a [pull request](https://github.com/pdwaggoner/ygdesign/pulls) with enhancements or bug fixes.