@tubular/util
v4.16.1
Published
Miscellaneous utility functions
Downloads
193
Maintainers
Readme
@tubular/util
An assortment of general-purpose utility functions, including string manipulation, non-exception-throwing safe string-to-number conversions, array functions, object cloning, web browser graphics, CSS support, and more.
- Installation
- Type conversions
- Type/class checking
- Array/object comparison and manipulation
- String functions
- Date and number formatting
- Browser-oriented functions
- Browser identification
- Browser graphics
- Other functions
- Deprecated functions
Installation
Via npm
npm install @tubular/util
import { toBoolean, toNumber, compareCaseSecondary
...} from '@tubular/time'; // ESM
...or...
const { toBoolean, toNumber, compareCaseSecondary
...} = require('@tubular/time/cjs'); // CommonJS
Documentation examples will assume @tubular/util has been imported as above.
Via <script>
tag
To remotely download the full code as an ES module:
<script type="module">
import('https://unpkg.com/@tubular/util/dist/fesm2015/index.mjs').then(pkg => {
const { toBoolean, toNumber, compareCaseSecondary } = pkg;
// ...
});
</script>
For the old-fashioned UMD approach:
<script src="https://unpkg.com/@tubular/util/dist/umd/index.js"></script>
The @tubular/util package will be made available via the global variable tbUtil
. Functions, classes, and constants will also be available via this variable, such as tbUtil.toBoolean
, tbUtil.toNumber
, tbUtil.compareCaseSecondary
, etc.
Type conversions
function toBoolean(value: any, defaultValue?: boolean, forHtmlAttribute?: boolean): boolean;
function toBoolean(value: any, defaultValue: null, forHtmlAttribute?: boolean): boolean | null;
Converts a value
of any type to a boolean
value (or possibly null
, if defaultValue
is null
).
null
,undefined
, orNaN
becomedefaultValue
(the defaultdefaultValue
isfalse
).- Any non-zero number (represented as
number
orstring
),'true'
,'t'
,'yes'
, or'y'
(case-insensitive) are all consideredtrue
. - Zero (0),
'false'
,'f'
,'no'
, or'n'
(case insensitive) are all consideredfalse
. - An empty string becomes
defaultValue
unless theforHtmlAttribute
option istrue
, in which case an empty string meanstrue
. - Anything other
value
which is not of typenumber
orstring
is converted to!!value
.
function toInt(value: any, defaultValue?: number, radix?: number): number;
function toInt(value: any, defaultValue: null, radix?: number): number | null;
Converts a value
of any type to an integer number
(or possibly null
, if defaultValue
is null
).
- Any
value
of typenumber
is returned asMath.floor(value)
. null
,undefined
, orNaN
becomedefaultValue
(the defaultdefaultValue
is 0).- Any
value
of typestring
composed completely of valid digits for the givenradix
(default 10) is returned asparseInt(value, radix)
, unless the result ofparseInt
isNaN
or an infinite value, in which casedefaultValue
is returned. - Any other
string
value results indefaultValue
. - Any
value
of typebigint
is returned asNumber(value)
, unless the result ofNumber
isNaN
or an infinite value, in which casedefaultValue
is returned. - Any other type of
value
results indefaultValue
.
function toNumber(value: any, defaultValue?: number): number;
function toNumber(value: any, defaultValue: null): number | null;
Converts a value
of any type to a number
(or possibly null
, if defaultValue
is null
).
- Any
value
of typenumber
is returned as itself. null
orundefined
becomedefaultValue
(the defaultdefaultValue
is 0).- Any
value
of typestring
is returned asparseFloat(value)
, unless the result ofparseFloat
isNaN
or an infinite value, in which casedefaultValue
is returned. - Any
value
of typebigint
is returned asNumber(value)
, unless the result ofNumber
isNaN
or an infinite value, in which casedefaultValue
is returned. - Any other type of
value
results indefaultValue
.
function toValidInt(value: any, defaultValue = 0, radix = 10): number;
This function returns the same results as toInt
unless value
is NaN
or an infinite, in which case a non-null defaultValue
is returned.
function toValidNumber(value: any, defaultValue = 0): number
This function returns the same results as toNumber
unless value
is NaN
or an infinite, in which case defaultValue
is returned.
Type/class checking
function classOf(a: unknown, noClassResult = false): string | null;
If a
is an instance of a class, the name of the class is returned. Otherwise null
is returned, or, if noClassResult
is true
, the string 'no-class:
type'
is returned.
function isArray(a: unknown): a is any[];
Returns true
if a
is an array.
function isArrayLike(a: unknown): a is ArrayLike<any>;
Returns true
if a
is array-like.
function isBigint(a: unknown): a is bigint;
Returns true
if a
is a bigint
value.
function isBoolean(a: unknown): a is boolean
Returns true
if a
is a boolean
value.
function isFunction(a: unknown): a is Function;
Returns true
if a
is a function.
function isNonFunctionObject(a: unknown): a is Exclude<Record<string | symbol, any>, Function>;
Returns true
if a
is an object which is not a function.
function isNumber(a: unknown): a is number;
Returns true
if a
is a number
value.
function isObject(a: unknown): a is Record<string | symbol, any>;
Returns true
if a
is an object. Unlike typeof a === 'object'
, isObject(null)
returns false
.
function isString(a: unknown): a is string;
Returns true
if a
is a string
value.
function isSymbol(a: unknown): a is symbol;
Returns true
if a
is a symbol
value.
Array/object comparison and manipulation
function clone<T>(orig: T, shallow: boolean | Set<Function> | ((value: any, depth: number) => boolean) = false): T;
This function clones a value, array, or object. Any primitive orig
value will simply be return as-is.
The shallow
parameter controls which descendants of an object are either cloned or retained as-is.
- When
shallow
istrue
: Only the root array or object will be converted into a new array or object reference. All descendant arrays and objects will retain their original reference values. - When
shallow
isfalse
(the default): All objects, root and descendants, will be converted into a new object references. - When
shallow
is aSet
: All objects, root and descendants, will be converted into a new object references except for class instances of classes contained inshallow
. - When
shallow
is a function: The root object is always converted into a new object, but descendants are only cloned when the callback function, provided with the descendantvalue
and itsdepth
in object tree, returnsfalse
.
function first<T>(array: ArrayLike<T> | null | undefined, defaultValue?: T): T | undefined
Return the first element of an array, or defaultValue
(undefined
if not specified) if a first element does not exist.
function flatten(a: any[]): any[];
This function “flattens” an array by replacing any arrays within the array with the children of the inner array. For example:
flatten([1, [2, 3], 4]))
returns [1, 2, 3, 4]
.
The original array is not altered.
function flattenDeep(a: any[]): any[];
Same as flatten
, except flattening is recursive. For example:
flattenDeep([1, [2, [3, 4]], 5]))
returns 1, 2, 3, 4, 5]
.
function isEqual(a: any, b: any, mustBeSameClass = false): boolean;
This function determines if two values a
and b
are equal to each other, by deep comparison when necessary.
- As a first check,
a
andb
are equal considered equal ifa === b
orObject.is(a, b)
istrue
. Please note: | Equal? | a = 0, b = -0 | a = NaN, b = NaN | | ----------------- | ------------- | ---------------- | |a === b
| true | false | |Object.is(a, b)
| false | true | |isEqual(a, b)
| true | true | - If
a
andb
are not the same type (as determined bytypeof
), they are not considered equal. - If one of
a
andb
is an array, and the other is not, they are not considered equal. - If
a
andb
are both arrays, but of unequal length, they are not considered equal. - If
mustBeSameClass
istrue
,a
andb
must either be instances of the same class, or both must not be an instance of any class, otherwise they are not considered equal. - Otherwise, all object children/array slots of
a
andb
must be equal, by recursive application ofisEqual
, fora
andb
to be considered equal. Neithera
norb
can own a property or index that the other does not have.For example,isEqual([1, , 3], [1, undefined, 3])
isfalse
, even though[1, , 3][1] === [1, undefined, 3][1]
istrue
.
export function numSort(a: any, b: any): number
The default array sorting behavior of JavaScript, even for all-numeric array, is to sort the contents as if they were strings. If this behavior is not expected, the results can be surprising and unpleasant.
numSort
can be passed as a sorting function to the default sort function to solve this problem.
| Code | Result |
|--------------------------------|------------------|
| [10, 2, 5, 20].sort()
| [ 10, 2, 20, 5 ] |
| [10, 2, 5, 20].sort(numSort)
| [ 2, 5, 10, 20 ] |
function nfe<T>(array: T[]): T[] | null
Return the array if the array is not empty, otherwise null
.
function nth<T>(array: ArrayLike<T> | null | undefined, n: number, defaultValue?: T): T | undefined
Return the last element of an array, or defaultValue
(undefined
if not specified) if a last element does not exist.
function nth<T>(array: ArrayLike<T> | null | undefined, n: number, defaultValue?: T): T | undefined
Return n
th element of an array, or defaultValue
(undefined
if not specified) if an n
th element does not exist.
function push<T>(array: T[] | null | undefined, ...items: any[]): T[];
This is a form of push
designed for chained operations, returning the array which has been modified. If array
is null
or undefined
a new array is created and returned, containing the pushed items
.
function pushIf<T>(condition: boolean, array: T[] | null | undefined, ...items: any[]): T[];
The same as push
above, except that items
are pushed conditionally.
type EntrySorter = (a: [string | symbol, any], b: [string | symbol, any]) => number;
function sortObjectEntries<T>(obj: T, inPlace?: boolean): T;
function sortObjectEntries<T>(obj: T, sorter?: EntrySorter, inPlace?: boolean);
JavaScript objects function as ordered maps, with a consistently-maintained ordering of object properties. This function allows you to sort that order.
By default, sorting is done in ascending alphabetical order using JavaScript’s default string collation. You can, however, supply your own sorter
to control how properties will be ordered.
If inPlace
is true
(the default is false
) obj
itself will be returned by the function, modified by the sorting. Otherwise, a new object with sorted properties is returned.
function ufe<T>(array: T[]): T[] | undefined
Return the array if the array is not empty, otherwise undefined
.
String functions
function asLines(s: string, trimFinalBlankLines = false, trimEachLine = false): string[]
Takes a string containing line breaks (LF, CR, or CRLF) and turns it into an array of individual lines. Final blank lines can be optionally omitted, and each line can optionally have leading and trailing white space trimmed.
function checksum53(s: string, seed = 0): string
Returns, in the form of a hexadecimal string, a 53-bit checksum of the value of s
.
function compareCaseInsensitive(a: string, b: string): number;
Compares two strings in a case-insensitive manner, returning a less-than-zero value if a
is less than b
, a greater-than-zero value if a
is greater than b
, or 0 if the strings are (apart from case) identical.
function compareCaseSecondary(a: string, b: string): number;
Compares two strings in the same manner as compareCaseInsensitive
, but if both strings are equal in a case-insensitive manner, case is then taken into consideration, and 0 is only returned if a
and b
are completely identical.
function compareStrings(a: string, b: string): number;
Compares two strings, returning a less-than-zero value if a
is less than b
, a greater-than-zero value if a
is greater than b
, or 0 if the strings are identical.
function extendDelimited(base: string, newItem: string, delimiter = ', '): string;
Appends one string to another string, inserting a delimiter
in between the strings if the first string in not an empty string.
function isAllUppercase(s: string): boolean;
Returns true
if s
contains nothing other than one or more uppercase characters.
function isAllUppercaseWords(s: string): boolean;
Returns true
if s
is non-empty, contains at least one uppercase character, and all letter characters are uppercase letters. Any number of non-letter characters can be present.
function isDigit(ch: string): boolean;
Returns true
if ch
is recognized as a Unicode digit.
function makePlainASCII(s: string, forFileName = false): string;
Converts s
to a string containing only ASCII characters, making substitutions where possible with unaccented ASCII characters, dashes, or underscores.
If forFileName
is true, characters which are disallowed or problematic in file names (such as asterisks, slashes, colons, etc.) are also replaced.
function makePlainASCII_lc(s: string, forFileName = false): string;
Same as makePlainASCII
, but also converted to lowercase.
function makePlainASCII_UC(s: string, forFileName = false): string;
Same as makePlainASCII
, but also converted to uppercase.
function regexEscape(s: string): string;
Returns a representation of s
which can be used by RegExp
, automatically escaped so that all characters are interpreted as literal characters, not as regex syntax.
function replace(str: string, searchStr: string, replaceStr: string, caseInsensitive = false): string;
JavaScript’s own string replace
method only replaces one occurrence of a string with another string unless you use a regex with the g
flag for the search string. This function replaces all occurrences without having to use a regex and without worrying about escaping special characters. Matching can optionally be case-insensitive.
function stripDiacriticals(s: string): string;
Removes diacritical marks from a wide range of alphabetic scripts, as well as removing all combining diacritical marks.
function stripDiacriticals_lc(s: string): string;
Same as stripDiacriticals
, but the results are also converted to lowercase.
function stripDiacriticals_UC(s: string): string;
Same as stripDiacriticals
, but the results are also converted to uppercase.
function stripLatinDiacriticals(s: string): string;
Removes diacritical marks from all Latin 1 and Latin Extended characters, as well as removing all combining diacritical marks (regardless of whether they are combined with a Latin letter or not).
function stripLatinDiacriticals_lc(s: string): string;
Same as stripLatinDiacriticals
, but the results are also converted to lowercase.
function stripLatinDiacriticals_UC(s: string): string;
Same as stripLatinDiacriticals
, but the results are also converted to uppercase.
function toMixedCase(s: string): string;
Capitalizes the first letter in each word in s
, converting all other letters to lowercase.
function toTitleCase(s: string, options?: TitleCaseOptions): string;
This function works much like toMixedCase
, but also makes a simplified attempt to follow English capitalization rules for titles, leaving short words (which are neither the first word nor the last word) in lowercase, such as “and”, “or”, “to”, “the”, etc.
These options are available:
interface TitleCaseOptions {
keepAllCaps?: boolean;
shortSmall?: string[];
special?: string[];
}
If keepAllCaps
is true
, any word that is originally fully capitalized remains fully capitalized, such as “USA”.
shortSmall
is a list of additional words that you wish not to have capitalized, in additions to the built-in list. You can also delete words from the built-in list by including them here with a leading dash, e.g. “-and” to allow the word “and” to be capitalized even when it is not the first or last word of a title.
special
is a list of words that you wish to provide special capitalization rules for, such as “CinemaScope” or “MacDougall”. Some of these are built in, such as “FedEx” and “iOS”.
Date and number formatting
function convertDigits(n: string, baseDigit: string): string;
Converts decimal digits in various scripts (Arabic, Devanagari, Mongolian, etc.) into digits in a different script, where baseDigit
is the desired representation for 0. The default value for baseDigit
is the ASCII digit zero.
function convertDigitsToAscii(n: string, info?: string[]): string;
Converts decimal digits in various scripts (Arabic, Devanagari, Mongolian, etc.) into ASCII digits.
If the optional info
array is passed, info[0]
will be modified to contain the 0-value digit for the last script detected, and info[1]
will be modified to contain the name of that script.
These scripts are supported:
Arabic, ASCII, Balinese, Bengali, Cham, Devanagari, Extended Arabic, Gujarati, Gurmukhi, Javanese, Kannada, Kayah Li, Khmer, Lao, Lepcha, Limbu, Malayalam, Meetei Mayek, Mongolian, Myanmar, Myanmar Shan, Myanmar Tai Laing, N’Ko, New Tai Lue, Ol Chiki, Oriya, Saurashtra, Sinhala Lith, Sundanese, Tai Tham Hora, Tai Tham Tham, Tamil, Telugu, Thai, Tibetan, Vai
function digitScript(ch: string | null | undefined): string | undefined;
Returns the name of the script for the digit contained in first character of ch
, or undefined
.
export function formatDateTime(options?: DateTimeOptions[]): string;
export function formatDateTime(date: Date | number | string, ...options: DateTimeOptions[]): string;
export function formatDateTime(date: Date | number | string, options?: DateTimeOptions[]): string;
enum DateTimeOptions { DATE_ONLY, NO_SECONDS, NO_ZONE, TIME_ONLY, UTC, USE_T, USE_Z, WITH_MILLIS }
This function returns date/time strings in basic ISO 8601 format, for either the default local time zone or for UTC. The default time value is the current time. The default format is date and time at one-second resolution, with UTC offset included, e.g. 2022-08-07 16:12:43 -0400
.
The following options can be applied either as an array of options, or as a variable list of parameters after the date
parameter:
DATE_ONLY
: Date only, e.g.2022-08-07
.NO_SECONDS
: Hide seconds, e.g.2022-08-07 16:12 -0400
.NO_ZONE
: Hide the UTC offset, e.g.2022-08-07 16:12:43
.TIME_ONLY
: Time only, e.g.16:12:43 -0400
.UTC
: Use UTC instead of the default local timezone, e.g.2022-08-07 20:12:43 +0000
.USE_T
: UseT
between date and time, e.g.2022-08-07T16:12:43 -0400
USE_Z
: UseZ
to indicate UTC time and drop timezone offset, e.g.2022-08-07 20:12:43Z
. ImpliesUTC
option.WITH_MILLIS
: Add milliseconds, e.g.2022-08-07 16:12:43.095 -0400
.
For far more flexible, full-featured date/time formatting and other date/time functionality, please see the @tubular/time package.
function padLeft(item: number, length: number, padChar = ' '): string;
Similar to padStart(...)
, but operates on numbers. If item
is negative, and padChar
is a whitespace character, then the first character of the result will remain -
, with padding characters inserted between the sign and the digits.
function toDefaultLocaleFixed(n: number, minFracDigits?: number, maxFracDigits?: number): string;
Converts a number to a formatted string, using localized rules for decimal marks and grouping (such as 1,234,567.89
vs 1 234 567,89
), with optional minimum and maximum numbers of fractional digits.
function toMaxFixed(n: number, maximumFractionDigits: number, locale?: string, useGrouping = false): string;
Using Intl.NumberFormat
, this returns a number as a string with a given maximumFractionDigits
, using an optional locale
(defaults to 'en-US'). Unlike toFixed
, fractional digits are not padded with trailing zeros.
If useGrouping
is true, locale-specific grouping with be performed, such as the commas added to “12,345,678.9012” in the 'en-US' locale.
function toMaxSignificant(n: number, maximumSignificantDigits: number, locale?: string | null, useGrouping = false): string;
Using Intl.NumberFormat
, this returns a number as a string with a given maximumSignificantDigits
, using an optional locale
(defaults to 'en-US'). Unlike toPrecision
, formatting does not switch to scientific notation when more than maximumSignificantDigits
are needed for the integer portion of a value.
If useGrouping
is true, locale-specific grouping with be performed, such as the commas added to “12,345,700” in the 'en-US' locale.
function zeroPad(n: number | string, digits: number): string;
Taking either a number or a string for n
, a string is returned with digits
digits, padded with leading zeros as needed. This should only be used for non-negative integer values.
Browser-oriented functions
function beep(frequency = 440, gainValue = 0.025, duration = 100): void;
Play a simple square-wave tone at the specified frequency
and gainValue
for a duration
in given in milliseconds.
async function beepPromise(frequency = 440, gainValue = 0.025, duration = 100): Promise<void>;
Same as beep
, except that you can await
the completion of the sound.
function eventToKey(event: KeyboardEvent): string;
Turn keyboard events into consistent, browser-independent key codes.
In many circumstances, especially with up-to-date browsers, this function is redundant, returning the same value as event.key
. But for cases where event.key
is not provided and event.charCode
, event.keyCode
, or event.which
need to be examined, or when event.key
contains a non-standard value such as 'UIKeyInputLeftArrow'
instead of 'ArrowLeft'
, eventToKey
helps provide a consistent result.
function getCssValue(element: Element, property: string): string;
Return the value of a CSS property
for the given element
, as either set directly on that element, or as inherited by that element.
function getCssValues(element: Element, properties: string[]): string[];
Same as getCssValue
, except an array of CSS values is returned for the array of properties
. This is more efficient than querying multiple properties one at a time.
function getCssRuleValue(element: Element, property: string): string | undefined;
Same as getCssValue
, except the property value will be returned in the same form as it was defined in the applicable CSS rules. For example, if the rules stated 1em
, this function returns 1em
, rather than converting this value into a px
value as getCssValue
will do.
function getCssRuleValues(element: Element, properties: string[]): string[] | undefined;
Same as getCssRuleValue
, except an array of CSS values is returned for the array of properties
. This is more efficient than querying multiple properties one at a time.
function getFont(element: Element): string;
Returns the font active on the given element
.
interface FontMetrics {
font: string;
lineHeight: number;
ascent: number;
fullAscent: number;
descent: number;
leading: number;
extraAscent?: number;
extraDescent?: number;
extraLineHeight?: number;
}
function getFontMetrics(elementOrFont: Element | string, specificChar?: string): FontMetrics;
Return FontMetrics
to describe the characteristics of a font specified by elementOrFont
.
function doesCharacterGlyphExist(elementOrFont: Element | string, charOrCodePoint: string | number): boolean;
Determine if the font specified by elementOrFont
can render the given charOrCodePoint
.
function encodeForUri(s: string, spaceAsPlus = false): string;
Similar to encodeURIComponent
, except the characters !'()*
are also %-encoded, and spaces can optionally be encoded as +
instead of %20
.
function getTextWidth(items: string | string[], font: string | HTMLElement, fallbackFont?: string): number;
Determine the pixel width of a single string, or of the widest of string in an array of strings, as rendered in the specified font
. If font
is not recognized, the width can be determined according to the optional fallbackFont
.
function htmlEscape(s: string, escapeQuotes = false): string;
Convert s
into a form compatible with HTML text content, replacing the ASCII characters <
, >
, and &
with the HTML entities <
, >
, and &
, respectively. Optionally ASCII apostrophes and double quotes can be converted into '
and "
, respectively.
function htmlUnescape(s: string): string;
Parse HTML entities embedded in s
to return the original unencoded text represented by s
.
function isFullScreen(): boolean;
Return true
if the programmatic full-screen feature is activated. Note that it is possible for a browser to be in full-screen mode by means that are not directly detectable by this function.
function isEffectivelyFullScreen(): boolean;
Return true
if the browser window’s inner width and height match the host computer screen’s width and height.
function restrictPixelWidth(text: string, font: string | HTMLElement, maxWidth: number, clipString = '\u2026'): string;
Return a string derived from text
, truncated if necessary, such that the pixel width of the resulting string, as rendered in the given font
, is equal to or less than maxWidth
.
If text
is truncated, it is done by removing characters from the end of the string, with clipString
(default …
) appended, e.g. 'Long and winding road'
shortened to 'Long and wi…'
.
export function reverseNumSort(a: any, b: any): number
Same as numSort
, but sorts in descending numerical order.
function setFullScreen(full: boolean): void;
Put the web browser in full-screen mode if full
is true, end full-screen mode if full
is false
. Failure is ignored.
function setFullScreenAsync(full: boolean, throwImmediate = false): Promise<void>;
Put the web browser in full-screen mode if full
is true, end full-screen mode if full
is false
. Failure can be detected either immediately or asynchronously using try/catch.
function toggleFullScreen(): void;
Toggle full-screen mode. Failure is ignored.
function toggleFullScreenAsync(throwImmediate = false): Promise<void>;
Toggle full-screen mode. Failure can be detected either immediately or asynchronously using try/catch.
function urlEncodeParams(params: Record<string, string | number | boolean | bigint | null>, spaceAsPlus = false): string;
This function turns the name/value pairs from params
into a URL parameter list, with each value encoded using encodeForUri
.
For example, { name: 'John Doe', points: 250, foo: null }
becomes 'name=John%20Doe&points=250'
.
Browser identification
function iosVersion(): number; // Integer value, not boolean. Major version only.
function isAndroid(): boolean;
function isChrome(): boolean;
function isChromeOS(): boolean;
function isChromium(): boolean;
function isChromiumEdge(): boolean;
function isEdge(): boolean;
function isFirefox(): boolean;
function isIE(): boolean; // @deprecated, always false now since IE is not supported.
function isIOS(): boolean;
function isIOS14OrEarlier(): boolean;
function isLikelyMobile(): boolean;
function isMacOS(): boolean;
function isOpera(): boolean;
function isRaspbian(): boolean;
function isSafari(): boolean;
function isSamsung(): boolean;
function isWindows(): boolean;
The above functions test browser types, platforms, and OS environments.
Developers should depend mainly on feature testing rather than browser detection. Nevertheless, browser detection is sometimes useful, or even necessary, to work around particular browser bugs and quirks.
Note: If you want to give up gracefully on making your code run on old buggy and/or feature-lacking web browsers, @tubular/browser-check might suit your needs.
Browser graphics
function blendColors(color1: string, color2: string, portion1 = 0.5): string;
Blend two CSS-style colors, in equal proportions by default, using a weighted average of their respective RGBA components.
function colorFrom24BitInt(i: number, alpha = 1.0): string;
Turn a numerically-encoded RGB color value i
(in the form 0xRRGGBB) into a CSS color string in the form '#RRGGBB'
, or, if alpha
has a non-1 value, a color string in the form 'rgba(r, g, b, alpha)'
, where r
, g
, and b
are the decimal equivalents of RR
, GG
, and BB
function colorFromByteArray(array: number[], offset = 0): string;
Use values from array
, starting at the optional offset
, to create a CSS color string. Values should be in the integer range 0-255, in the order red, green, blue, optionally followed by an integer 0-255 alpha value.
function colorFromRGB(r: number, g: number, b: number, alpha = 1.0): string;
Return a CSS color string based on integer r
, g
, and b
values from 0-255, and an optional alpha
value from 0-1.
function drawOutlinedText(context: CanvasRenderingContext2D, text: string, x: number, y: number,
outlineStyle?: string, fillStyle?: string, strokeWidth = 4): void;
Draw outlined text
at location x
, y
using the styles (usually simply colors) outlineStyle
and fillStyle
, which default to the current strokeStyle
and fillStyle
, respectively, if not specified.
Note that the strokeWidth
(default value 4) determines the pixel width of the outline stroke, but that only about half of that width will be visible after filled text is drawn on top of the stroked text.
function fillCircle(context: CanvasRenderingContext2D, cx: number, cy: number, r: number): void ;
A method for drawing filled circles which is more convenient than using the standard CanvasRenderingContext2D
arc and path methods.
function fillEllipse(context: CanvasRenderingContext2D, cx: number, cy: number, rx: number, ry: number): void;
A method for drawing filled ellipses which is more convenient than using the standard CanvasRenderingContext2D
arc and path methods.
function getPixel(imageData: ImageData, x: number, y: number): number;
Extract the pixel value at x
, y
from imageData
.
export interface RGBA {
r: number;
g: number;
b: number;
alpha: number;
}
function parseColor(color: string): RGBA;
Parse a CSS color string (including commonly recognized color names such as “orange” and “SteelBlue”) and return the individual color components.
function replaceAlpha(color: string, newAlpha: number): string;
Return a CSS color string equivalent to the originally provided color
, but with its alpha value replaced with newAlpha
.
function setPixel(imageData: ImageData, x: number, y: number, pixel: number): void;
Set the pixel value at x
, y
in imageData
to pixel
.
function strokeCircle(context: CanvasRenderingContext2D, cx: number, cy: number, radius: number): void;
A method for drawing circles which is more convenient than using the standard CanvasRenderingContext2D
arc and path methods.
function strokeEllipse(context: CanvasRenderingContext2D, cx: number, cy: number, rx: number, ry: number): void;
A method for drawing ellipses which is more convenient than using the standard CanvasRenderingContext2D
arc and path methods.
function strokeLine(context: CanvasRenderingContext2D, x0: number, y0: number, x1: number, y1: number): void;
Draw a line from x0
, y0
to x1
, y1
.
Other functions
function forEach<T>(obj: Record<string, T> | null | undefined, callback: (key: string, value: T) => void): void;
Iterate over all string key/value pairs in obj
.
function forEach2<T>(obj: Record<string | symbol, T> | null | undefined, callback: (key: string | symbol, value: T) => void): void;
Iterate over all key/value pairs in obj
, including symbol
keys.
function getOrSet<T, U>(map: Map<T, U>, key: T, callbackOrValue: U | (() => U)): U
This function either returns the value from the map
associated with key
if it exists, or stores a new value under key
and returns that. The value may be either provided explicitly, or provided via a callback function — ideal if you don't want to compute that value unless necessary.
async function getOrSetAsync<T, U>(map: Map<T, U>, key: T, callback: () => Promise<U>): Promise<U>
This function either asynchronously returns the value from the map
associated with key
if it exists, or stores a new value under key
and returns that. The value must be provided via an asynchronous callback
.
function isValidJson(s: string): boolean;
Determines if s
contains valid JSON by attempting to parse the string, returning true
if parsing is successful.
function keyCount(obj: any): number;
A convenience function equivalent to Reflect.ownKeys(obj).length
.
const noop = (..._args: any[]): void => {};
A function that does nothing, useful as a no-operation function parameter.
function processMillis(): number;
This is a platform-neutral method to return the current process running time, returning performance.now()
in a web browser environment, or process.hrtime()
, converted into milliseconds (and derived from the bigint
form if available) in a Node.js environment. The function falls back on Date.now()
if neither of the previous options are available.
function regex(main: TemplateStringsArray, flags?: string): RegExp;
Used as a tag function, regex
provides a way to format complicated regular expressions with line breaks, indentation, and //
-style comments, where the formatting and comments will be filtered out of the regular expression which is returned.
For example, this complex pattern:
/^\s*(\d{5,6})\s+(\d\d-\d\d-\d\d)\s+(\d\d:\d\d:\d\d)\s+(\d\d)\s+(\d)\s+(\d)\s+([\d.]+)\s+UTC\(NIST\)\s+\*(\s*)$/
...can be represented like this:
// Automated Computer Time Service (ACTS) format
regex`^\s*(\d{5,6}) // Modified Julian Date
\s+(\d\d-\d\d-\d\d) // date, YY-MM-DD
\s+(\d\d:\d\d:\d\d) // time, HH:mm:ss
\s+(\d\d) // ST/DST code
\s+(\d) // leap second
\s+(\d) // DUT1
\s+([\d.]+) // msADV
\s+UTC\(NIST\) // label
\s+\*(\s*)$ // On-Time Marker (OTM)
${'i'}`
The final ${'i'}
above is an example of the format for optionally passing regular expression flags, like the i
for case-insensitive. The //
for a comment, if not on a line by itself, must be preceded and followed by at least one space.
const repeat = (n: number, f: (n?: number) => any): void => { while (n-- > 0) f(n); };
A function that calls function f
n
times.
Deprecated functions
function padLeft(item: string, length: number, padChar = ' '): string;
Equivalent to the now-preferred String.prototype.padStart
method.
Note: The form of padLeft
which takes a number
as the first argument is not deprecated.
function padRight(item: string, length: number, padChar?: string): string;
Equivalent to the now-preferred String.prototype.padEnd
method.