@flourish/pocket-knife
v2.0.0
Published
Flourish module with handy tools
Downloads
2,013
Maintainers
Keywords
Readme
Flourish pocket knife 🇨🇭
A module with handy tools that you can use in Flourish templates.
import { isUrl, isImage } from "@flourish/pocket-knife"
Functions
createScreenshotSVG(target, id)
Create a temporary SVG element that can be used in the SVG export. Takes a target
element, which it uses to set the boundaries and position of the main svg container; and an id
which is used to set a unique id of the SVG element.
This function returns an .addTextElements(els)
, .addCircleElements(els)
, .addGradient(el, colorFunction, domain)
, and .remove()
method. .remove()
will remove the SVG. addTextElements
takes a node list (els
) and will convert them to an SVG <text>
elements, incorporating the element's font styles and line height. Similarly, addCircleElements
takes elements (e.g. divs with a background color) and converts them to SVG <circle>
elements. addGradient
takes an element, a color function, and a domain; the domain should be an object with a min
and max
representing the starting and ending values the gradient represents, and the color function should take a number within the domain and return the color which represents that number.
This function can be used in the template's screenshot()
function to temporarily create an SVG that will be included in the SVG export.
getTextDimensions(string, font)
Gets dimensions of text. First argument contains the text you want to calculate the width for. The second argument is optional and lets you set font settings for the text in the standard css font property, eg. bold 16px arial
. If font
is empty, it uses 10px sans-serif
. Returns an object with properties width
and height
.
getTextDirection()
Gets computed text direction on document.body. Returns a "ltr" or "rtl".
getTextHeight(string, font)
Gets height of text. Uses same arguments as getTextDimensions
. Returns a number.
getTextWidth(string, font)
Gets width of text. Uses same arguments as getTextDimensions
. Returns a number.
getUniqueValuesFromBinding(data, binding, index)
Gets all the unique values in a column associated to a data binding. If it is a multi column binding you can pass in index that is used to work out which of the bound columns it should look at. If you pass it no index and it is a multi column binding it will default to zero.
hexToColor(hex_string, opacity)
Converts hex to d3 color object as described here
hexToColor("#00ff00", 0.5); // {r: 0, g: 255, b: 0, a: 0.5}
hexToRgba(hex_string, opacity)
Converts hex to rgba string
hexToRgba("#00ff00", 0.5); // rgba(0, 255, 0, 0.5)
isImage(string)
Checks if string looks like valid image URL. Returns true
or false
isPale(color_value)
Returns if color is pale or not
isUrl(string)
Checks if string looks like valid URL. Returns true
or false
remToPx(rem)
Converts value specified in rems to px
wrapStringToLines(label, label_styles, text_max_lines, max_width)
Takes a string, and returns an array of strings where each string is one lines worth of text.
- Label is a string, that you want to be broken up into lines
- label_styles is a string that can include font weight, font size and font family in the structure: 'bold 48px serif'. it is what is given to the canvas context font method, and is used to measure the text.
- text_max_lines is a number that says the maximum amount of lines you want (if you dont have a maximum you can give it null)
- max_width is a number that states in px the maximum width for the label.