Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

d3plus-common

Package Overview
Dependencies
Maintainers
1
Versions
121
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

d3plus-common

Common functions and methods used across D3plus modules.

  • 1.2.8
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
4.6K
increased by26.68%
Maintainers
1
Weekly downloads
 
Created
Source

d3plus-common

Common functions and methods used across D3plus modules.

Installing

If using npm, npm install d3plus-common. Otherwise, you can download the latest release from GitHub or load from a CDN.

import modules from "d3plus-common";

d3plus-common can be loaded as a standalone library or bundled as part of D3plus. ES modules, AMD, CommonJS, and vanilla environments are supported. In vanilla, a d3plus global is exported:

<script src="https://cdn.jsdelivr.net/npm/d3plus-common@1"></script>
<script>
  console.log(d3plus);
</script>

Examples

Live examples can be found on d3plus.org, which includes a collection of example visualizations using d3plus-react. These examples are powered by the d3plus-storybook repo, and PRs are always welcome. :beers:

API Reference

  • BaseClass - An abstract class that contains some global methods and functionality.
  • accessor - Wraps an object key in a simple accessor function.
  • assign - A deeply recursive version of Object.assign.
  • attrize - Applies each key/value in an object as an attr.
  • closest - Finds the closest numeric value in an array.
  • configPrep - Preps a config object for d3plus data, and optionally bubbles up a specific nested type. When using this function, you must bind a d3plus class' this context.
  • constant - Wraps non-function variables in a simple return function.
  • elem - Manages the enter/update/exit pattern for a single DOM element.
  • isObject - Detects if a variable is a javascript Object.
  • merge - Combines an Array of Objects together and returns a new Object.
  • parseSides - Converts a string of directional CSS shorthand values into an object with the values expanded.
  • prefix - Returns the appropriate CSS vendor prefix, given the current browser.
  • stylize - Applies each key/value in an object as a style.
  • unique - ES5 implementation to reduce an Array of values to unique instances.
  • uuid - Returns a unique identifier.
  • RESET - String constant used to reset an individual config property.

BaseClass <>

This is a global class.

# BaseClass.config([value]) <>

If value is specified, sets the methods that correspond to the key/value pairs and returns this class. If value is not specified, returns the current configuration.

This is a static method of BaseClass, and is chainable with other methods of this Class.

# BaseClass.locale([value]) <>

Sets the locale used for all text and number formatting. This method supports the locales defined in d3plus-format. The locale can be defined as a complex Object (like in d3plus-format), a locale code (like "en-US"), or a 2-digit language code (like "en"). If a 2-digit code is provided, the "findLocale" function is used to identify the most approximate locale from d3plus-format.

This is a static method of BaseClass, and is chainable with other methods of this Class.

{
        separator: "",
        suffixes: ["y", "z", "a", "f", "p", "n", "µ", "m", "", "k", "M", "B", "t", "q", "Q", "Z", "Y"],
        grouping: [3],
        delimiters: {
          thousands: ",",
          decimal: "."
        },
        currency: ["$", ""]
      }

# BaseClass.on([typenames], [listener]) <>

Adds or removes a listener to each object for the specified event typenames. If a listener is not specified, returns the currently assigned listener for the specified event typename. Mirrors the core d3-selection behavior.

This is a static method of BaseClass, and is chainable with other methods of this Class.

ParamType
[typenames]String
[listener]function

By default, listeners apply globally to all objects, however, passing a namespace with the class name gives control over specific elements:

new Plot
  .on("click.Shape", function(d) {
    console.log("data for shape clicked:", d);
  })
  .on("click.Legend", function(d) {
    console.log("data for legend clicked:", d);
  })

# BaseClass.translate([value]) <>

Defines how informational text strings should be displayed. By default, this function will try to find the string in question (which is the first argument provided to this function) inside of an internally managed translation Object. If you'd like to override to use custom text, simply pass this method your own custom formatting function.

This is a static method of BaseClass, and is chainable with other methods of this Class. For example, if we wanted to only change the string "Back" and allow all other string to return in English:

.translate(function(d) {
  return d === "Back" ? "Get outta here" : d;
})

d3plus.accessor(key, [def]) <>

Wraps an object key in a simple accessor function.

This is a global function.

ParamTypeDescription
keyStringThe key to be returned from each Object passed to the function.
[def]*A default value to be returned if the key is not present.

this

accessor("id");
    

returns this

function(d) {
  return d["id"];
}

d3plus.assign(...objects) <>

A deeply recursive version of Object.assign.

This is a global function. this

assign({id: "foo", deep: {group: "A"}}, {id: "bar", deep: {value: 20}}));
    

returns this

{id: "bar", deep: {group: "A", value: 20}}

d3plus.attrize(elem, attrs) <>

Applies each key/value in an object as an attr.

This is a global function.

ParamTypeDescription
elemD3selectionThe D3 element to apply the styles to.
attrsObjectAn object of key/value attr pairs.

d3plus.closest(n, arr) <>

Finds the closest numeric value in an array.

This is a global function.

ParamTypeDescription
nNumberThe number value to use when searching the array.
arrArrayThe array of values to test against.

d3plus.configPrep([config], [type], [nest]) <>

Preps a config object for d3plus data, and optionally bubbles up a specific nested type. When using this function, you must bind a d3plus class' this context.

This is a global function.

ParamTypeDefaultDescription
[config]Objectthis._shapeConfigThe configuration object to parse.
[type]String"shape"The event classifier to user for "on" events. For example, the default event type of "shape" will apply all events in the "on" config object with that key, like "click.shape" and "mouseleave.shape", in addition to any gloval events like "click" and "mouseleave".
[nest]StringAn optional nested key to bubble up to the parent config level.

d3plus.constant(value) <>

Wraps non-function variables in a simple return function.

This is a global function. this

constant(42);
    

returns this

function() {
  return 42;
}

d3plus.elem(selector, params) <>

Manages the enter/update/exit pattern for a single DOM element.

This is a global function.

ParamTypeDefaultDescription
selectorStringA D3 selector, which must include the tagname and a class and/or ID.
paramsObjectAdditional parameters.
[params.condition]BooleantrueWhether or not the element should be rendered (or removed).
[params.enter]Object{}A collection of key/value pairs that map to attributes to be given on enter.
[params.exit]Object{}A collection of key/value pairs that map to attributes to be given on exit.
[params.parent]D3Selectiond3.select("body")The parent element for this new element to be appended to.
[params.duration]Number0The duration for the d3 transition.
[params.update]Object{}A collection of key/value pairs that map to attributes to be given on update.

d3plus.isObject(item) <>

Detects if a variable is a javascript Object.

This is a global function.


d3plus.merge(objects, aggs) <>

Combines an Array of Objects together and returns a new Object.

This is a global function.

ParamTypeDescription
objectsArrayThe Array of objects to be merged together.
aggsObjectAn object containing specific aggregation methods (functions) for each key type. By default, numbers are summed and strings are returned as an array of unique values.

this

merge([
  {id: "foo", group: "A", value: 10, links: [1, 2]},
  {id: "bar", group: "A", value: 20, links: [1, 3]}
]);
    

returns this

{id: ["bar", "foo"], group: "A", value: 30, links: [1, 2, 3]}

d3plus.parseSides(sides) <>

Converts a string of directional CSS shorthand values into an object with the values expanded.

This is a global function.


d3plus.prefix() <>

Returns the appropriate CSS vendor prefix, given the current browser.

This is a global function.


d3plus.stylize(elem, styles) <>

Applies each key/value in an object as a style.

This is a global function.

ParamTypeDescription
elemD3selectionThe D3 element to apply the styles to.
stylesObjectAn object of key/value style pairs.

d3plus.unique(arr, [accessor]) <>

ES5 implementation to reduce an Array of values to unique instances.

This is a global function.

ParamTypeDescription
arrArrayThe Array of objects to be filtered.
[accessor]functionAn optional accessor function used to extract data points from an Array of Objects.

this

unique(["apple", "banana", "apple"]);
    

returns this

["apple", "banana"]

d3plus.uuid() <>

This is a global function.


RESET <>

String constant used to reset an individual config property.

This is a global constant.


Documentation generated on Thu, 03 Oct 2024 16:19:47 GMT

Keywords

FAQs

Package last updated on 03 Oct 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc