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

d3plus-text

Package Overview
Dependencies
Maintainers
1
Versions
89
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

d3plus-text

A smart SVG text box with line wrapping and automatic font size scaling.

  • 0.8.2
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
3.8K
increased by3.37%
Maintainers
1
Weekly downloads
 
Created
Source

d3plus-text

NPM Release Build Status Dependency Status

A smart SVG text box with line wrapping and automatic font size scaling.

Installing

If you use NPM, npm install d3plus-text. Otherwise, download the latest release. The released bundle supports AMD, CommonJS, and vanilla environments. Create a custom bundle using Rollup or your preferred bundler. You can also load directly from d3plus.org:

<script src="https://d3plus.org/js/d3plus-text.v0.8.full.min.js"></script>

Getting Started

Without a doubt, the most commonly used aspect of this module is textBox, which is used for intelligently wrapping SVG text. At it's core, you can simply pass along data points with "text" values and the generator will add them to the page using a set of defaults. Here is a data array containing 3 different sentences to be wrapped:

var data = [
  {text: "Here is some sample text that has been wrapped using d3plus.textBox."},
  {text: "...and here is a second sentence!"},
  {text: "这是句3号。这也即使包装没有空格!"}
];

And finally, this is how that data array would be passed to the textBox generator.

d3plus.textBox()
  .data(data)
  .fontSize(16)
  .width(200)
  .x(function(d, i) { return i * 250; })
  ();

While textBox comes with some handy defaults, this example shows how any of the methods can be overridden with static values or accessor functions. For more information on how the textSplit function splits strings, specifically in languages that don't use spaces, check out this blog post.

Please note the () at the end of the chain of commands. This is what tells the textBox to finally render to the page, and allows setting multiple properties of the textBox without it trying to render after each one is set.

Click here to view this example live on the web.

Getting Started

More Examples

API Reference

Functions

stringify(value)

Coerces value into a String.

textBox([data])

Creates a wrapped text box based on an array of data. If data is specified, immediately wraps the text based on the specified array and returns this generator. If data is not specified on instantiation, it can be passed/updated after instantiation using the data method. See this example for help getting started using the textBox function.

textSplit(sentence)

Splits a given sentence into an array of words.

textWidth(text, [style])

Given a text string, returns the predicted pixel width of the string when placed into DOM.

textWrap()

Based on the defined styles and dimensions, breaks a string into an array of strings for each line of text.

stringify(value)

Coerces value into a String.

Kind: global function

ParamType
valueString

textBox([data])

Creates a wrapped text box based on an array of data. If data is specified, immediately wraps the text based on the specified array and returns this generator. If data is not specified on instantiation, it can be passed/updated after instantiation using the data method. See this example for help getting started using the textBox function.

Kind: global function

ParamTypeDefaultDescription
[data]Array[]An array of text blocks to be wrapped.

textBox.config([value])

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

Kind: static method of textBox

ParamType
[value]Object

textBox.data([data])

If data is specified, sets the data array to the specified array and returns this generator. If data is not specified, returns the current data array. A text box will be drawn for each object in the array.

Kind: static method of textBox

ParamTypeDefault
[data]Array[]

textBox.delay([value])

If value is specified, sets the animation delay to the specified number and returns this generator. If value is not specified, returns the current animation delay.

Kind: static method of textBox

ParamTypeDefault
[value]Number0

textBox.duration([value])

If value is specified, sets the animation duration to the specified number and returns this generator. If value is not specified, returns the current animation duration.

Kind: static method of textBox

ParamTypeDefault
[value]Number0

textBox.ellipsis([value])

If value is specified, sets the ellipsis method to the specified function or string and returns this generator. If value is not specified, returns the current ellipsis method, which simply adds an ellipsis to the string by default.

Kind: static method of textBox

ParamType
[value]function | String

Example (default accessor)

function(d) {
  return d + "...";
}

textBox.fontColor([value])

If value is specified, sets the font color accessor to the specified function or string and returns this generator. If value is not specified, returns the current font color accessor, which is inferred from the container element by default.

Kind: static method of textBox

ParamType
[value]function | String

textBox.fontFamily([value])

If value is specified, sets the font family accessor to the specified function or string and returns this generator. If value is not specified, returns the current font family accessor, which is inferred from the container element by default.

Kind: static method of textBox

ParamType
[value]function | String

textBox.fontMax([value])

If value is specified, sets the maximum font size accessor to the specified function or number and returns this generator. If value is not specified, returns the current maximum font size accessor. The maximum font size is used when resizing fonts dynamically.

Kind: static method of textBox

ParamTypeDefault
[value]function | Number50

textBox.fontMin([value])

If value is specified, sets the minimum font size accessor to the specified function or number and returns this generator. If value is not specified, returns the current minimum font size accessor. The minimum font size is used when resizing fonts dynamically.

Kind: static method of textBox

ParamTypeDefault
[value]function | Number8

textBox.fontResize([value])

If value is specified, sets the font resizing accessor to the specified function or boolean and returns this generator. If value is not specified, returns the current font resizing accessor.

Kind: static method of textBox

ParamTypeDefault
[value]function | Booleanfalse

textBox.fontSize([value])

If value is specified, sets the font size accessor to the specified function or number and returns this generator. If value is not specified, returns the current font size accessor, which is inferred from the container element by default.

Kind: static method of textBox

ParamType
[value]function | Number

textBox.height([value])

If value is specified, sets the height accessor to the specified function or number and returns this generator. If value is not specified, returns the current height accessor.

Kind: static method of textBox

ParamType
[value]function | Number

Example (default accessor)

function(d) {
  return d.height || 200;
}

textBox.id([value])

If value is specified, sets the id accessor to the specified function or number and returns this generator. If value is not specified, returns the current id accessor.

Kind: static method of textBox

ParamType
[value]function | Number

Example (default accessor)

function(d, i) {
  return d.id || i + "";
}

textBox.lineHeight([value])

If value is specified, sets the line height accessor to the specified function or number and returns this generator. If value is not specified, returns the current line height accessor, which is 1.1 times the font size by default.

Kind: static method of textBox

ParamType
[value]function | Number

textBox.on([typenames], [listener])

Adds or removes a listener to each box 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.

Kind: static method of textBox

ParamType
[typenames]String
[listener]function

textBox.overflow([value])

If value is specified, sets the overflow accessor to the specified function or boolean and returns this generator. If value is not specified, returns the current overflow accessor.

Kind: static method of textBox

ParamTypeDefault
[value]function | Booleanfalse

textBox.select([selector])

If selector is specified, sets the SVG container element to the specified d3 selector or DOM element and returns this generator. If selector is not specified, returns the current SVG container element, which adds an SVG element to the page by default.

Kind: static method of textBox

ParamType
[selector]String | HTMLElement

textBox.split([value])

If value is specified, sets the word split function to the specified function and returns this generator. If value is not specified, returns the current word split function.

Kind: static method of textBox

ParamTypeDescription
[value]functionA function that, when passed a string, is expected to return that string split into an array of words to wrap. The default split function splits strings on the following characters: -, /, ;, :, &

textBox.text([value])

If value is specified, sets the text accessor to the specified function or string and returns this generator. If value is not specified, returns the current text accessor.

Kind: static method of textBox

ParamType
[value]function | String

Example (default accessor)

function(d) {
  return d.text;
}

textBox.textAnchor([value])

If value is specified, sets the horizontal text anchor accessor to the specified function or string and returns this generator. If value is not specified, returns the current horizontal text anchor accessor.

Kind: static method of textBox

ParamTypeDefaultDescription
[value]function | String"start"Analagous to the SVG text-anchor property.

textBox.verticalAlign([value])

If value is specified, sets the vertical alignment accessor to the specified function or string and returns this generator. If value is not specified, returns the current vertical alignment accessor.

Kind: static method of textBox

ParamTypeDefaultDescription
[value]function | String"top"Accepts "top", "middle", and "bottom".

textBox.width([value])

If value is specified, sets the width accessor to the specified function or number and returns this generator. If value is not specified, returns the current width accessor.

Kind: static method of textBox

ParamType
[value]function | Number

Example (default accessor)

function(d) {
  return d.width || 200;
}

textBox.x([value])

If value is specified, sets the x accessor to the specified function or number and returns this generator. If value is not specified, returns the current x accessor. The number returned should correspond to the left position of the textBox.

Kind: static method of textBox

ParamType
[value]function | Number

Example (default accessor)

function(d) {
  return d.x || 0;
}

textBox.y([value])

If value is specified, sets the y accessor to the specified function or number and returns this generator. If value is not specified, returns the current y accessor. The number returned should correspond to the top position of the textBox.

Kind: static method of textBox

ParamType
[value]function | Number

Example (default accessor)

function(d) {
  return d.y || 0;
}

textSplit(sentence)

Splits a given sentence into an array of words.

Kind: global function

ParamType
sentenceString

textWidth(text, [style])

Given a text string, returns the predicted pixel width of the string when placed into DOM.

Kind: global function

ParamTypeDescription
textString | ArrayCan be either a single string or an array of strings to analyze.
[style]ObjectAn object of CSS font styles to apply. Accepts any of the valid CSS font property values.

textWrap()

Based on the defined styles and dimensions, breaks a string into an array of strings for each line of text.

Kind: global function

textWrap.fontFamily([value])

If value is specified, sets the font family accessor to the specified function or string and returns this generator. If value is not specified, returns the current font family.

Kind: static method of textWrap

ParamType
[value]function | String

textWrap.fontSize([value])

If value is specified, sets the font size accessor to the specified function or number and returns this generator. If value is not specified, returns the current font size.

Kind: static method of textWrap

ParamType
[value]function | Number

textWrap.height([value])

If value is specified, sets height limit to the specified value and returns this generator. If value is not specified, returns the current value.

Kind: static method of textWrap

ParamTypeDefault
[value]Number200

textWrap.lineHeight([value])

If value is specified, sets the line height accessor to the specified function or number and returns this generator. If value is not specified, returns the current line height accessor, which is 1.1 times the font size by default.

Kind: static method of textWrap

ParamType
[value]function | Number

textWrap.overflow([value])

If value is specified, sets the overflow to the specified boolean and returns this generator. If value is not specified, returns the current overflow value.

Kind: static method of textWrap

ParamTypeDefault
[value]Booleanfalse

textWrap.split([value])

If value is specified, sets the word split function to the specified function and returns this generator. If value is not specified, returns the current word split function.

Kind: static method of textWrap

ParamTypeDescription
[value]functionA function that, when passed a string, is expected to return that string split into an array of words to textWrap. The default split function splits strings on the following characters: -, /, ;, :, &

textWrap.width([value])

If value is specified, sets width limit to the specified value and returns this generator. If value is not specified, returns the current value.

Kind: static method of textWrap

ParamTypeDefault
[value]Number200
Documentation generated on Fri, 22 Jul 2016 18:18:11 GMT

Keywords

FAQs

Package last updated on 22 Jul 2016

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