Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/clhenrick/color-legend-element
A custom element (web component) suitable for use as a legend in data visualizations
https://github.com/clhenrick/color-legend-element
custom-elements d3 d3js data-visualization lit-element web-components
Last synced: 5 days ago
JSON representation
A custom element (web component) suitable for use as a legend in data visualizations
- Host: GitHub
- URL: https://github.com/clhenrick/color-legend-element
- Owner: clhenrick
- License: mit
- Created: 2021-11-29T16:07:28.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2024-07-18T00:19:24.000Z (6 months ago)
- Last Synced: 2024-10-12T05:07:09.893Z (3 months ago)
- Topics: custom-elements, d3, d3js, data-visualization, lit-element, web-components
- Language: TypeScript
- Homepage: https://clhenrick.github.io/color-legend-element/
- Size: 1.96 MB
- Stars: 79
- Watchers: 2
- Forks: 6
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Color Legend Element
![Screenshot of color-legend-element](./docs-src/assets/color-legend-element.png)
```html
```
A [Custom Element](https://developer.mozilla.org/en-US/docs/Web/Web_Components/Using_custom_elements) suitable for use as a legend in data visualizations. Built with [Lit](https://lit.dev/) and [D3JS](https://d3js.org/).
## Features
- Render legends for continuous, discrete, threshold, and categorical scales.
- Uses `d3-scale`'s concept of a `domain` and a `range` for mapping values to visual marks.
- Compatible with color interpolators from `d3-scale-chromatic`
- Customizable via its [properties / attributes](#properties) and [CSS variables](#css-variables).
- Framework and bundler not required, just add a `` tag and use it!
- [Small bundle size](https://bundlephobia.com/package/color-legend-element): 27kb minified and 9kb gzipped.## Installation
**NOTE:** the `<color-legend>` assumes D3JS is available as a _peer dependency._ At the very least this should include the following modules from the D3JS library: `d3-scale`, `d3-array`, `d3-format`, `d3-interpolate`, and possibly `d3-scale-chromatic` if using one of d3's color schemes.
Install via [npm](https://www.npmjs.com/package/color-legend-element):
```bash
npm install color-legend-element
```Or via [Yarn](https://yarnpkg.com/):
```bash
yarn add color-legend-element
```You may then `import` the `<color-legend>` in the desired ES Module:
```js
import "color-legend-element";
```To use without a frontend build tool, add the `<color-legend>` via a `<script>` tag in your HTML document.
```html
<script
type="module"
src="color-legend-element/build/color-legend-element.js"
>
```If you prefer to not use the ESM build, you may instead use the UMD build:
```html
```
### Windows OS Install
Note that Windows OS users may experience a problem with module bundlers where the D3JS dependencies are not found by the CLE. To work around this, it is recommended to be sure to use the ESM build:
```js
import "color-legend-element/build/color-legend-element.js";
```## Example Usage
The `` will render using its default settings as follows:
```html
```
It may be customized by settings its properties and CSS variables (full list below).
See [the color-legend website](https://clhenrick.github.io/color-legend-element) for more examples of how to use the Color Legend Element.
## Properties
The following table lists the Color Legend Element's properties, most of which have a corresponding HTML attribute. All attributes use a lowercase naming convention, so for example the property `scaleType` corresponds to the attribute `scaletype`. See [the color-legend website](https://clhenrick.github.io/color-legend-element) for examples of how these properties and attributes may be configured to customize the ``.
| Property | Type | Default Value | Description | Has Attribute |
| ------------- | ------------------------- | ---------------------- | ------------------------------------------------------------------------------------------------------ | ------------- |
| titleText | string | "Color Legend Element" | The title text that displays at the top of the legend. | Yes |
| width | number | 325 | The width of the SVG or categorical legend div element. | Yes |
| height | number | 32 | The height of the SVG element. | Yes |
| marginTop | number | 6 | The spacing between the legend bar and top most extent of the SVG. | Yes |
| marginRight | number | 12 | The spacing between the legend bar and right most extent of the SVG. | Yes |
| marginBottom | number | 16 | The spacing between the legend bar and bottom most extent of the SVG. | Yes |
| marginLeft | number | 12 | The spacing between the legend bar and left most extent of the SVG. | Yes |
| scaleType | ScaleType | "continuous" | The type of legend to render (e.g. data classification scheme the legend represents). | Yes |
| domain | (number \| string)[] | `[0, 1]` | The color scale's domain values. | Yes |
| range | string[] | `d3.schemeYlGnBu[5]` | The color scale's range values. | Yes |
| markType | MarkType | "circle" | The symbology used for categorical legends. | Yes |
| ticks | number | 5 | The desired number of axis ticks. | Yes |
| tickFormat | string | ".1f" | The d3-format specifier to format axis tick values. | Yes |
| tickFormatter | (value: number) => string | `d3.format(".1f")` | A function that handles formatting the tick values. | No |
| tickSize | number | 6 | The size or length of the axis ticks. | Yes |
| tickValues | number[] | `undefined` | The explicit values to be used for axis ticks. | Yes |
| interpolator | Interpolator | `d3.interpolateHcl` | The color interpolator function to use from [`d3-interpolate`](https://d3js.org/d3-interpolate/color). | No |Notes on the above properties:
- See [src/types.ts](./src/types.ts) for type definitions of `ScaleType`, `MarkType`, and `Interpolator`.
- If the `tickFormatter` property is not explicitly set, it will be set internally using the value of `tickFormat` by passing the `tickFormat` string to [`d3.format`](https://d3js.org/d3-format).
- The properties `tickFormat` and `tickFormatter` cannot be used simultaneously, they are both mechanisms for formatting the axis tick text. Setting the `tickFormatter` property explicitly will override the value of `tickFormat`, if it was previously set.
## CSS Variables
The internal styling (CSS) of the Color Legend Element may be altered via the following [CSS variables / custom properties](https://developer.mozilla.org/en-US/docs/Web/CSS/Using_CSS_custom_properties):
| Custom Property | Default Value | Description |
| -------------------------- | ---------------------- | ----------------------------------------------------------------------- |
| --cle-font-family | sans-serif | Font used for tick and legend item text |
| --cle-font-family-title | var(--cle-font-family) | Font used for the legend's title text |
| --cle-font-size | 0.75rem | Font size for the tick and legend item text |
| --cle-font-size-title | 0.875rem | Font size for the legend title text |
| --cle-letter-spacing | 0.3px | Letter spacing for tick and legend item text |
| --cle-letter-spacing-title | 0.25px | Letter spacing for the legend title text |
| --cle-font-weight | 400 | Font weight for the tick and legend item text |
| --cle-font-weight-title | 500 | Font weight for the title text |
| --cle-color | currentColor | Font color for all text and tick lines |
| --cle-background | #fff | Background color for the legend |
| --cle-padding | 0.375rem | Padding in the legend's container div |
| --cle-border | none | Border style of the legend's container div |
| --cle-border-radius | 0 | Border radius of the legend's container div |
| --cle-box-sizing | content-box | Box-sizing property of the legend's container div |
| --cle-columns | 2 | Number of columns for categorical legends |
| --cle-column-width | auto | Column width for categorical legends |
| --cle-item-margin | 0.375rem 0.75rem 0 0 | Margin property for categorical legend items |
| --cle-line-width | 24px | Width of the "line" markType for categorical legends |
| --cle-line-height | 2px | Height of the "line" markType for categorical legends |
| --cle-swatch-size | 10px | Height & Width of "rect" and "circle" markTypes for categorical legends |
| --cle-swatch-width | var(--cle-swatch-size) | Width of the "rect" and "circle" markTypes for categorical legends |
| --cle-swatch-height | var(--cle-swatch-size) | Height of the "rect" and "circle" markTypes for categorical legends |
| --cle-swatch-margin | 0 0.5rem 0 0 | Margin of the mark (line, square, circle) for categorical legends |The following example demonstrates how to override the default values of the ``'s CSS variables:
```css
color-legend {
--cle-font-family: serif;
--cle-font-family-title: Impact;
--cle-letter-spacing-title: 0.5px;
--cle-color: white;
--cle-background: #222;
--cle-border-radius: 6px;
--cle-padding: 0.25rem 0.25rem 0.75rem;
}
```## Local Development
Requires Node.js v16.13.0 and NPM >=8.
In the root of this repository first install dependencies:
```bash
npm install
```### Building from src
All compiled files will be outputted in the `build/` directory.
To create the ESM build:
```bash
npm run build
```or to watch for changes:
```bash
npm run build:watch
```To create both the ESM & UMD bundles:
```bash
npm run bundle
```### Develop
To view the `` without bundling it:
```
npm run serve
```or
```
npm run serve:prod
```This will start up a local web server for `dev/index.html`. You may then modify the contents of `src/` and/or `dev/index.html` and inspect the changes in your browser.
### Running tests
Tests are located in [`src/test`](./src/test) and may be run in either a development or production environment via:
```
npm run test:dev
```or:
```
npm run test:prod
```To run tests in both a development and a production environment do:
```
npm run test
```To have the tests run when making changes to `src/`:
```
npm run test:watch
```or
```
npm run test:prod:watch
```### Building the docs
To generate the `docs` directory:
```bash
npm run docs
```This will first remove the `docs/` directory, build files from the `src/`, and build files from the `docs-src/` directory into the `docs/` directory. All necessary files will be copied into `docs/` directory (e.g. from `build/` and `node_modules/`) in order for the `` render as it would in a production environment.
To serve the docs directory and watch for changes:
```bash
npm run docs:serve
```Then open your browser to `localhost:8080` to view the site.
### Updating the custom-elements.json
According to [Open Web Components](https://github.com/open-wc/custom-elements-manifest#custom-elements-manifest):
> Custom Elements Manifest is a file format that describes custom elements. This format will allow tooling and IDEs to give rich information about the custom elements in a given project.
To update the `custom-elements.json` manifest:
```bash
npm run analyze
```## License
Licensed under the MIT License, Copyright 2021 Chris L Henrick.
## Credits
🙏 Some project boilerplate has been borrowed from the [Lit Element TypeScript Starter Kit](https://github.com/lit/lit-element-starter-ts) under the BSD-3-Clause License, Copyright 2017 Google LLC.
🙏 Inspired by the [Color Legend](https://observablehq.com/@d3/color-legend) on [Observable](https://observablehq.com) by [Mike Bostock](https://observablehq.com/@mbostock) under the ISC License, Copyright 2019–2020 Observable, Inc.