// Type definitions for D3JS d3-selection module 3.0 // Project: https://github.com/d3/d3-selection/, https://d3js.org/d3-selection // Definitions by: Tom Wanzek // Alex Ford // Boris Yankov // denisname // Nathan Bierema // Ambar Mutha // Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped // Last module patch version validated against: 3.0.0 // -------------------------------------------------------------------------- // Shared Type Definitions and Interfaces // -------------------------------------------------------------------------- /** * BaseType serves as an alias for the 'minimal' data type which can be selected * without 'd3-selection' trying to use properties internally which would otherwise not * be supported. */ export type BaseType = Element | EnterElement | Document | Window | null; /** * KeyType serves as alias for valid types that d3 supports as key for data binding */ export type KeyType = string | number; /** * A helper interface which covers arguments like NodeListOf or HTMLCollectionOf * argument types */ export interface ArrayLike { length: number; item(index: number): T | null; [index: number]: T; } /** * An interface describing the element type of the Enter Selection group elements * created when invoking selection.enter(). */ export interface EnterElement { ownerDocument: Document; namespaceURI: string; appendChild(newChild: Node): Node; insertBefore(newChild: Node, refChild: Node): Node; querySelector(selectors: string): Element; querySelectorAll(selectors: string): NodeListOf; } /** * Container element type usable for mouse/touch functions */ export type ContainerElement = HTMLElement | SVGSVGElement | SVGGElement; /** * A User interface event (e.g. mouse event, touch or MSGestureEvent) with captured clientX and clientY properties. */ export interface ClientPointEvent { clientX: number; clientY: number; } /** * Interface for optional parameters map, when dispatching custom events * on a selection */ export interface CustomEventParameters { /** * If true, the event is dispatched to ancestors in reverse tree order */ bubbles: boolean; /** * If true, event.preventDefault is allowed */ cancelable: boolean; /** * Any custom data associated with the event */ detail: any; } /** * Callback type for selections and transitions */ export type ValueFn = (this: T, datum: Datum, index: number, groups: T[] | ArrayLike) => Result; /** * TransitionLike is a helper interface to represent a quasi-Transition, without specifying the full Transition interface in this file. * For example, wherever d3-zoom allows a Transition to be passed in as an argument, it internally immediately invokes its `selection()` * method to retrieve the underlying Selection object before proceeding. * d3-brush uses a subset of Transition methods internally. * The use of this interface instead of the full imported Transition interface is [referred] to achieve * two things: * (1) the d3-transition module may not be required by a projects use case, * (2) it avoids possible complications from 'module augmentation' from d3-transition to Selection. */ export interface TransitionLike { selection(): Selection; on(type: string, listener: null): TransitionLike; on(type: string, listener: ValueFn): TransitionLike; tween(name: string, tweenFn: null): TransitionLike; tween(name: string, tweenFn: ValueFn void)>): TransitionLike; } // -------------------------------------------------------------------------- // All Selection related interfaces and function // -------------------------------------------------------------------------- /** * Select the first element that matches the specified selector string. If no elements match the selector, returns an empty selection. * If multiple elements match the selector, only the first matching element (in document order) will be selected. * * The first generic "GElement" refers to the type of element to be selected. The second generic "OldDatum" refers to the type of the * datum, on the selected element. This is useful when re-selecting an element with a previously set, know datum type. * * @param selector CSS selector string */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics export function select(selector: string): Selection; /** * Select the specified node element. * * The first generic "GElement" refers to the type of element to be selected. The second generic "OldDatum" refers to the type of the * datum, on the selected element. This is useful when re-selecting an element with a previously set, know datum type. * * @param node An element to be selected */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics export function select(node: GElement): Selection; /** * Create an empty selection. */ export function selectAll(selector?: null): Selection; /** * Select all elements that match the specified selector string. The elements will be selected in document order (top-to-bottom). * If no elements in the document match the selector, returns an empty selection. * * The first generic "GElement" refers to the type of element to be selected. The second generic "OldDatum" refers to the type of the * datum, of a selected element. This is useful when re-selecting elements with a previously set, know datum type. * * @param selector CSS selector string */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics export function selectAll(selector: string): Selection; /** * Select the specified array, array-like, or iterable of nodes. * This is useful if you already have a reference to nodes, such as `this.childNodes` within an event listener or a global such as `document.links`. * The nodes may instead be an iterable, or a pseudo-array such as a NodeList. * * The first generic "GElement" refers to the type of element to be selected. * The second generic "OldDatum" refers to the type of the datum, of a selected element. * * @param nodes An array, array-like, or iterable of nodes */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics export function selectAll(nodes: GElement[] | ArrayLike | Iterable): Selection; /** * A D3 Selection of elements. * * The first generic "GElement" refers to the type of the selected element(s). * The second generic "Datum" refers to the type of the datum of a selected element(s). * The third generic "PElement" refers to the type of the parent element(s) in the D3 selection. * The fourth generic "PDatum" refers to the type of the datum of the parent element(s). */ export interface Selection { // Sub-selection ------------------------- /** * For each selected element, select the first descendant element that matches the specified selector string. * If no element matches the specified selector for the current element, the element at the current index will * be null in the returned selection. If multiple elements match the selector, only the first matching element * in document order is selected. Selection.select does not affect grouping: it preserves the existing group * structure and indexes, and propagates data (if any) to selected children. * * If the current element has associated data, this data is propagated to the * corresponding selected element. * * The generic represents the type of the descendant element to be selected. * * @param selector CSS selector string */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics select(selector: string): Selection; /** * Create an empty sub-selection. Selection.select does not affect grouping: it preserves the existing group * structure and indexes. */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics select(selector: null): Selection; /** * For each selected element, select the descendant element returned by the selector function. * If no element is returned by the selector function for the current element, the element at the * current index will be null in the returned selection. Selection.select does not affect grouping: * it preserves the existing group structure and indexes, and propagates data (if any) to selected children. * * If the current element has associated data, this data is propagated to the * corresponding selected element. * * The generic represents the type of the descendant element to be selected. * * @param selector A selector function, which is evaluated for each selected element, in order, being passed the current datum (d), * the current index (i), and the current group (nodes), with this as the current DOM element (nodes[i]). * It must return an element, or null if there is no matching element. */ select(selector: ValueFn): Selection; /** * Create an empty sub-selection. Selection.selectAll does affect grouping: The elements in the returned * selection are grouped by their corresponding parent node in this selection, the group at the current index will be empty. */ selectAll(selector?: null): Selection; /** * For each selected element, selects the descendant elements that match the specified selector string. The elements in the returned * selection are grouped by their corresponding parent node in this selection. If no element matches the specified selector * for the current element, the group at the current index will be empty. Selection.selectAll does affect grouping: each selected descendant * is grouped by the parent element in the originating selection. * * The selected elements do not inherit data from this selection; use selection.data to propagate data to children. * * The first generic "DescElement" refers to the type of descendant element to be selected. The second generic "OldDatum" refers to the type of the * datum, of a selected element. This is useful when re-selecting elements with a previously set, know datum type. * * @param selector CSS selector string */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics selectAll(selector: string): Selection; /** * For each selected element, selects the descendant elements returned by the selector function. The elements in the returned * selection are grouped by their corresponding parent node in this selection. If no element matches the specified selector * for the current element, the group at the current index will be empty. Selection.selectAll does affect grouping: each selected descendant * is grouped by the parent element in the originating selection. * * The selected elements do not inherit data from this selection; use selection.data to propagate data to children. * * The first generic "DescElement" refers to the type of descendant element to be selected. The second generic "OldDatum" refers to the type of the * datum, of a selected element. This is useful when re-selecting elements with a previously set, know datum type. * * @param selector A selector function which is evaluated for each selected element, in order, being passed the current datum (d), * the current index (i), and the current group (nodes), with this as the current DOM element (nodes[i]). It must return an array of elements * (or an iterable, or a pseudo-array, such as a NodeList), or the empty array if there are no matching elements. */ selectAll( selector: ValueFn | Iterable> // eslint-disable-next-line @definitelytyped/no-unnecessary-generics ): Selection; /** * Filters the selection, returning a new selection that contains only the elements for * which the specified filter is true. * * The returned filtered selection preserves the parents of this selection, but like array.filter, * it does not preserve indexes as some elements may be removed; use selection.select to preserve the index, if needed. * * @param selector A CSS selector string to match when filtering. */ filter(selector: string): Selection; /** * Filters the selection, returning a new selection that contains only the elements for * which the specified filter is true. * * The returned filtered selection preserves the parents of this selection, but like array.filter, * it does not preserve indexes as some elements may be removed; use selection.select to preserve the index, if needed. * * The generic refers to the type of element which will be selected after applying the filter, i.e. if the element types * contained in a pre-filter selection are narrowed to a subset as part of the filtering. * * @param selector A CSS selector string to match when filtering. */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics filter(selector: string): Selection; /** * Filter the selection, returning a new selection that contains only the elements for * which the specified filter is true. * * The returned filtered selection preserves the parents of this selection, but like array.filter, * it does not preserve indexes as some elements may be removed; use selection.select to preserve the index, if needed. * * @param selector A value function which is evaluated for each selected element, in order, being passed the current datum (d), * the current index (i), and the current group (nodes), with this as the current DOM element (nodes[i]). This function should return true * for an element to be included, and false otherwise. */ filter(selector: ValueFn): Selection; /** * Filter the selection, returning a new selection that contains only the elements for * which the specified filter is true. * * The returned filtered selection preserves the parents of this selection, but like array.filter, * it does not preserve indexes as some elements may be removed; use selection.select to preserve the index, if needed. * * @param selector A value function which is evaluated for each selected element, in order, being passed the current datum (d), * the current index (i), and the current group (nodes), with this as the current DOM element (nodes[i]). This function should return true * for an element to be included, and false otherwise. */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics filter(selector: ValueFn): Selection; /** * Returns a new selection merging this selection with the specified other selection or transition. * The returned selection has the same number of groups and the same parents as this selection. * Any missing (null) elements in this selection are filled with the corresponding element, * if present (not null), from the specified selection. (If the other selection has additional groups or parents, * they are ignored.) * * This method is commonly used to merge the enter and update selections after a data-join. * After modifying the entering and updating elements separately, you can merge the two selections and * perform operations on both without duplicate code. * * This method is not intended for concatenating arbitrary selections, however: if both this selection * and the specified other selection have (non-null) elements at the same index, this selection’s element * is returned in the merge and the other selection’s element is ignored. * * @param other Selection to be merged. */ merge(other: Selection | TransitionLike): Selection; /** * Returns a new selection with the (first) child of each element of the current selection matching the selector. * Selects the first child that matches (if any). * * The generic represents the type of the descendant element to be selected. * * @param selector CSS selector string */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics selectChild(selector?: string): Selection; /** * Returns a new selection with the (first) child of each element of the current selection matching the selector. * * The first generic represents the type of the descendant element to be selected. * The second generic represents the type of any of the child elements. * * @param selector A selector function, which is evaluated for each of the children nodes, in order, being passed the child (child), the child’s index (i), and the list of children (children); * the method selects the first child for which the selector return truthy, if any. */ selectChild( selector: (child: ChildElement, i: number, children: ChildElement[]) => boolean // eslint-disable-next-line @definitelytyped/no-unnecessary-generics ): Selection; /** * Returns a new selection with the children of each element of the current selection matching the selector. * Selects the children that match (if any) * * The first generic represents the type of the descendant element to be selected. * The second generic refers to the type of the datum of the element to be selected. * * @param selector CSS selector string */ selectChildren( selector?: string // eslint-disable-next-line @definitelytyped/no-unnecessary-generics ): Selection; /** * Returns a new selection with the children of each element of the current selection matching the selector. * * The first generic represents the type of the descendant element to be selected. * The second generic refers to the type of the datum of the element to be selected. * The third generic represents the type of any of the child elements. * * @param selector A selector function, which is evaluated for each of the children nodes, in order, being passed the child (child), the child’s index (i), and the list of children (children); * the method selects the first child for which the selector return truthy, if any. */ selectChildren( selector: (child: ChildElement, i: number, children: ChildElement[]) => boolean // eslint-disable-next-line @definitelytyped/no-unnecessary-generics ): Selection; /** * Returns the selection (for symmetry with transition.selection). */ selection(): this; // Modifying ------------------------------- /** * Return the current value of the specified attribute for the first (non-null) element in the selection. * This is generally useful only if you know that the selection contains exactly one element. * * @param name Name of the attribute */ attr(name: string): string; /** * Sets the attribute with the specified name to the specified value on the selected elements and returns this selection. * If the value is a constant, all elements are given the same attribute value; * otherwise, if the value is a function, it is evaluated for each selected element, in order, being passed the current datum (d), * the current index (i), and the current group (nodes), with this as the current DOM element (nodes[i]). * The function’s return value is then used to set each element’s attribute. * A null value will remove the specified attribute. */ attr(name: string, value: null | string | number | boolean | ReadonlyArray | ValueFn>): this; /** * Returns true if and only if the first (non-null) selected element has the specified classes. * This is generally useful only if you know the selection contains exactly one element. * * @param names A string of space-separated class names. */ classed(names: string): boolean; /** * Assigns or unassigns the specified CSS class names on the selected elements by setting * the class attribute or modifying the classList property and returns this selection. * If the constant value is truthy, then all elements are assigned the specified classes; otherwise, the classes are unassigned. * * @param names A string of space-separated class names. * @param value A boolean flag (true = assign / false = unassign) */ classed(names: string, value: boolean): this; /** * Assigns or unassigns the specified CSS class names on the selected elements by setting * the class attribute or modifying the classList property and returns this selection. * The assign/unassign status for the individual selected elements is determined by the boolean return * value of the value function. * * @param names A string of space-separated class names. * @param value A value function which is evaluated for each selected element, in order, * being passed the current datum (d), the current index (i), and the current group (nodes), with this as the current DOM element (nodes[i]). * The function’s return value is then used to assign or unassign classes on each element. */ classed(names: string, value: ValueFn): this; /** * Returns the current value of the specified style property for the first (non-null) element in the selection. * The current value is defined as the element’s inline value, if present, and otherwise its computed value. * Accessing the current style value is generally useful only if you know the selection contains exactly one element. * * @param name Name of the style */ style(name: string): string; /** * Clear the style with the specified name for the selected elements and returns this selection. * * @param name Name of the style * @param value null,to clear the style */ style(name: string, value: null): this; /** * Sets the value of the style with the specified name for the selected elements and returns this selection. * All elements are given the same style value. * * @param name Name of the style * @param value Constant value for the style * @param priority An optional priority flag, either null or the string important (without the exclamation point) */ style(name: string, value: string | number | boolean, priority?: null | 'important'): this; /** * Sets the value of the style with the specified name for the selected elements and returns this selection. * The value for the individual selected elements is determined by the value function. * * @param name Name of the style * @param value A value function which is evaluated for each selected element, in order, being passed the current datum (d), * the current index (i), and the current group (nodes), with this as the current DOM element (nodes[i]). A null value will clear the style. * @param priority An optional priority flag, either null or the string important (without the exclamation point) */ style(name: string, value: ValueFn, priority?: null | 'important'): this; /** * Return the current value of the specified property for the first (non-null) element in the selection. * This is generally useful only if you know that the selection contains exactly one element. * * @param name Name of the property */ property(name: string): any; /** * Look up a local variable on the first node of this selection. Note that this is not equivalent to `local.get(selection.node())` in that it will not look up locals set on the parent node(s). * * @param name The `d3.local` variable to look up. */ property(name: Local): T | undefined; /** * Sets the property with the specified name to the specified value on selected elements. * If the value is a constant, then all elements are given the same property value; * otherwise, if the value is a function, it is evaluated for each selected element, in order, being passed the current datum (d), * the current index (i), and the current group (nodes), with this as the current DOM element (nodes[i]). * The function’s return value is then used to set each element’s property. A null value will delete the specified property. */ property(name: string, value: ValueFn | null): this; /** * Sets the value of the property with the specified name for the selected elements and returns this selection. * All elements are given the same property value. * * @param name Name of the property * @param value Constant value for the property */ property(name: string, value: any): this; /** * Store a value in a `d3.local` variable. * This is equivalent to `selection.each(function (d, i, g) { name.set(this, value.call(this, d, i, g)); })` but more concise. * * @param name A `d3.local` variable * @param value A callback that returns the value to store */ property(name: Local, value: ValueFn): this; /** * Store a value in a `d3.local` variable for each node in the selection. * This is equivalent to `selection.each(function () { name.set(this, value); })` but more concise. * * @param name A `d3.local` variable * @param value A callback that returns the value to store */ property(name: Local, value: T): this; /** * Returns the text content for the first (non-null) element in the selection. * This is generally useful only if you know the selection contains exactly one element. */ text(): string; /** * Sets the text content to the specified value on all selected elements, replacing any existing child elements. * If the value is a constant, then all elements are given the same text content; * otherwise, if the value is a function, it is evaluated for each selected element, in order, being passed the current datum (d), * the current index (i), and the current group (nodes), with this as the current DOM element (nodes[i]). * The function’s return value is then used to set each element’s text content. * A null value will clear the content. */ text(value: null | string | number | boolean | ValueFn): this; /** * Returns a string representation of the inner HTML for the first (non-null) element in the selection. * This is generally useful only if you know the selection contains exactly one element. */ html(): string; /** * Sets the inner HTML to the specified value on all selected elements, replacing any existing child elements. * If the value is a constant, then all elements are given the same inner HTML; * otherwise, if the value is a function, it is evaluated for each selected element, in order, being passed the current datum (d), * the current index (i), and the current group (nodes), with this as the current DOM element (nodes[i]). * The function’s return value is then used to set each element’s inner HTML. * A null value will clear the content. */ html(value: null | string | ValueFn): this; /** * Appends a new element of this type (tag name) as the last child of each selected element, * or before the next following sibling in the update selection if this is an enter selection. * The latter behavior for enter selections allows you to insert elements into the DOM in an order consistent with the new bound data; * however, note that selection.order may still be required if updating elements change order * (i.e., if the order of new data is inconsistent with old data). * * This method returns a new selection containing the appended elements. * Each new element inherits the data of the current elements, if any. * * @param type A string representing the tag name. */ append(type: K): Selection; /** * Appends a new element of this type (tag name) as the last child of each selected element, * or before the next following sibling in the update selection if this is an enter selection. * The latter behavior for enter selections allows you to insert elements into the DOM in an order consistent with the new bound data; * however, note that selection.order may still be required if updating elements change order * (i.e., if the order of new data is inconsistent with old data). * * This method returns a new selection containing the appended elements. * Each new element inherits the data of the current elements, if any. * * The generic refers to the type of the child element to be appended. * * @param type A string representing the tag name. The specified name may have a namespace prefix, such as svg:text * to specify a text attribute in the SVG namespace. If no namespace is specified, the namespace will be inherited * from the parent element; or, if the name is one of the known prefixes, the corresponding namespace will be used * (for example, svg implies svg:svg) */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics append(type: string): Selection; /** * Appends a new element of the type provided by the element creator function as the last child of each selected element, * or before the next following sibling in the update selection if this is an enter selection. * The latter behavior for enter selections allows you to insert elements into the DOM in an order consistent with the new bound data; * however, note that selection.order may still be required if updating elements change order * (i.e., if the order of new data is inconsistent with old data). * * This method returns a new selection containing the appended elements. * Each new element inherits the data of the current elements, if any. * * The generic refers to the type of the child element to be appended. * * @param type A creator function which is evaluated for each selected element, in order, being passed the current datum (d), * the current index (i), and the current group (nodes), with this as the current DOM element (nodes[i]). This function should return * an element to be appended. (The function typically creates a new element, but it may instead return an existing element.) */ append(type: ValueFn): Selection; /** * Inserts a new element of the specified type (tag name) before the first element matching the specified * before selector for each selected element. For example, a before selector :first-child will prepend nodes before the first child. * If before is not specified, it defaults to null. (To append elements in an order consistent with bound data, use selection.append.) * * This method returns a new selection containing the appended elements. * Each new element inherits the data of the current elements, if any. * * The generic refers to the type of the child element to be appended. * * @param type A string representing the tag name for the element type to be inserted. * @param before One of: * * A CSS selector string for the element before which the insertion should occur. * * A child selector function which is evaluated for each selected element, in order, being passed the current datum (d), * the current index (i), and the current group (nodes), with this as the current DOM element (nodes[i]). This function should return the child element * before which the element should be inserted. */ insert( type: K, before?: string | ValueFn ): Selection; /** * Inserts a new element of the specified type (tag name) before the first element matching the specified * before selector for each selected element. For example, a before selector :first-child will prepend nodes before the first child. * If before is not specified, it defaults to null. (To append elements in an order consistent with bound data, use selection.append.) * * This method returns a new selection containing the appended elements. * Each new element inherits the data of the current elements, if any. * * The generic refers to the type of the child element to be appended. * * @param type One of: * * A string representing the tag name for the element type to be inserted. The specified name may have a namespace prefix, * such as svg:text to specify a text attribute in the SVG namespace. If no namespace is specified, the namespace will be inherited * from the parent element; or, if the name is one of the known prefixes, the corresponding namespace will be used * (for example, svg implies svg:svg) * * A creator function which is evaluated for each selected element, in order, being passed the current datum (d), * the current index (i), and the current group (nodes), with this as the current DOM element (nodes[i]). This function should return * an element to be inserted. (The function typically creates a new element, but it may instead return an existing element.) * @param before One of: * * A CSS selector string for the element before which the insertion should occur. * * A child selector function which is evaluated for each selected element, in order, being passed the current datum (d), * the current index (i), and the current group (nodes), with this as the current DOM element (nodes[i]). This function should return the child element * before which the element should be inserted. */ insert( type: string | ValueFn, before?: string | ValueFn ): Selection; /** * Removes the selected elements from the document. * Returns this selection (the removed elements) which are now detached from the DOM. */ remove(): this; /** * Inserts clones of the selected elements immediately following the selected elements and returns a selection of the newly * added clones. If deep is true, the descendant nodes of the selected elements will be cloned as well. Otherwise, only the elements * themselves will be cloned. * * @param deep Perform deep cloning if this flag is set to true. */ clone(deep?: boolean): Selection; /** * Return a new selection that contains a copy of each group in this selection sorted according * to the compare function. After sorting, re-inserts elements to match the resulting order (per selection.order). * * Note that sorting is not guaranteed to be stable; however, it is guaranteed to have the same * behavior as your browser’s built-in sort method on arrays. * * @param comparator An optional comparator function, which defaults to "ascending". The function is passed * two elements’ data a and b to compare. It should return either a negative, positive, or zero value. * If negative, then a should be before b; if positive, then a should be after b; otherwise, a and b are * considered equal and the order is arbitrary. */ sort(comparator?: (a: Datum, b: Datum) => number): this; /** * Re-insert elements into the document such that the document order of each group matches the selection order. * This is equivalent to calling selection.sort if the data is already sorted, but much faster. */ order(): this; /** * Re-insert each selected element, in order, as the last child of its parent. */ raise(): this; /** * Re-insert each selected element, in order, as the first child of its parent. */ lower(): this; // Data Join --------------------------------- /** * Returns the array of data for the selected elements. */ data(): Datum[]; /** * Joins the specified array of data with the selected elements, returning a new selection that represents * the update selection: the elements successfully bound to data. Also defines the enter and exit selections on * the returned selection, which can be used to add or remove elements to correspond to the new data. * * The data is specified for each group in the selection. If the selection has multiple groups * (such as d3.selectAll followed by selection.selectAll), then data should typically be specified as a function. * * If a key function is not specified, then the first datum in data is assigned to the first selected element, * the second datum to the second selected element, and so on. * A key function may be specified to control which datum is assigned to which element, replacing the default join-by-index, * by computing a string identifier for each datum and element. * * The update and enter selections are returned in data order, while the exit selection preserves the selection * order prior to the join. If a key function is specified, the order of elements in the selection may not match * their order in the document; use selection.order or selection.sort as needed. * * This method cannot be used to clear bound data; use selection.datum instead. * * For details see: {@link https://github.com/d3/d3-selection#joining-data } * * The generic refers to the type of the new datum to be used for the selected elements. * * @param data The specified data is an array or iterable of arbitrary values (e.g., numbers or objects) * or a value function which will be evaluated for each group in order, being passed the group’s parent datum * (d, which may be undefined), the group index (i), and the selection’s parent nodes (nodes), * with this as the group’s parent element. The function returns an array or iterable of values for each group. * @param key An optional key function which is evaluated for each selected element, in order, being passed the * current datum (d), the current index (i), and the current group (nodes), with this as the current DOM element (nodes[i]); the returned string is the element’s key. * The key function is then also evaluated for each new datum in data, being passed the current datum (d), * the current index (i), and the group’s new data, with this as the group’s parent DOM element (nodes[i]); the returned string is the datum’s key. * The datum for a given key is assigned to the element with the matching key. If multiple elements have the same key, * the duplicate elements are put into the exit selection; if multiple data have the same key, the duplicate data are put into the enter selection. */ data( data: NewDatum[] | Iterable | ValueFn>, key?: ValueFn ): Selection; /** * Appends, removes and reorders elements as necessary to match the data that was previously bound by `selection.data`, returning the merged enter and update selection. * This method is a convenient alternative to the more explicit `selection.enter`, `selection.exit`, `selection.append` and `selection.remove`. * * The "matching" logic is determined by the key function passed to `selection.data`. */ join( enter: K, update?: (elem: Selection) => Selection | TransitionLike | undefined, // eslint-disable-next-line @definitelytyped/no-unnecessary-generics exit?: (elem: Selection) => void ): Selection; /** * Appends, removes and reorders elements as necessary to match the data that was previously bound by `selection.data`, returning the merged enter and update selection. * This method is a convenient alternative to the more explicit `selection.enter`, `selection.exit`, `selection.append` and `selection.remove`. * * The "matching" logic is determined by the key function passed to `selection.data`. */ join( enter: string | ((elem: Selection) => Selection | TransitionLike), update?: (elem: Selection) => Selection | TransitionLike | undefined, // eslint-disable-next-line @definitelytyped/no-unnecessary-generics exit?: (elem: Selection) => void // eslint-disable-next-line @definitelytyped/no-unnecessary-generics ): Selection; /** * Return the enter selection: placeholder nodes for each datum that had no corresponding DOM element * in the selection. (The enter selection is empty for selections not returned by selection.data.) */ enter(): Selection; /** * Returns the exit selection: existing DOM elements in the selection for which no new datum was found. * (The exit selection is empty for selections not returned by selection.data.) * * IMPORTANT: The generic refers to the type of the old datum associated with the exit selection elements. * Ensure you set the generic to the correct type, if you need to access the data on the exit selection in * follow-up steps, e.g. to set styles as part of an exit transition before removing them. */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics exit(): Selection; /** * Returns the bound datum for the first (non-null) element in the selection. * This is generally useful only if you know the selection contains exactly one element. */ datum(): Datum; /** * Delete the bound data for each element in the selection. */ datum(value: null): Selection; /** * Sets the element’s bound data using the specified value function on all selected elements. * Unlike selection.data, this method does not compute a join and does not affect * indexes or the enter and exit selections. * * The generic refers to the type of the new datum to be used for the selected elements. * * @param value A value function which is evaluated for each selected element, in order, * being passed the current datum (d), the current index (i), and the current group (nodes), * with this as the current DOM element (nodes[i]). The function is then used to set each element’s new data. * A null value will delete the bound data. */ datum(value: ValueFn): Selection; /** * Sets the element’s bound data to the specified value on all selected elements. * Unlike selection.data, this method does not compute a join and does not affect * indexes or the enter and exit selections. * * The generic refers to the type of the new datum to be used for the selected elements. * * @param value A value object to be used as the datum for each element. */ datum(value: NewDatum): Selection; // Event Handling ------------------- /** * Return the currently-assigned listener for the specified event typename on the first (non-null) selected element, * if any, If multiple typenames are specified, the first matching listener is returned. * * @param typenames The typenames is a string event type, such as click, mouseover, or submit; any DOM event type supported by your browser may be used. * The type may be optionally followed by a period (.) and a name; the optional name allows multiple callbacks to be registered * to receive events of the same type, such as click.foo and click.bar. To specify multiple typenames, separate typenames with spaces, * such as "input change"" or "click.foo click.bar". */ on(typenames: string): ((this: GElement, event: any, d: Datum) => void) | undefined; /** * Remove a listener for the specified event type names. To remove all listeners for a given name, * pass null as the listener and ".foo" as the typename, where foo is the name; to remove all listeners with no name, specify "." as the typename. * * @param typenames The typenames is a string event type, such as click, mouseover, or submit; any DOM event type supported by your browser may be used. * The type may be optionally followed by a period (.) and a name; the optional name allows multiple callbacks to be registered * to receive events of the same type, such as click.foo and click.bar. To specify multiple typenames, separate typenames with spaces, * such as "input change"" or "click.foo click.bar". * @param listener null to indicate removal of listener */ on(typenames: string, listener: null): this; /** * Add an event listener for the specified event type names. If an event listener was previously registered for the same typename * on a selected element, the old listener is removed before the new listener is added. * * When a specified event is dispatched on a selected node, the specified listener will be evaluated for each selected element. * * @param typenames The typenames is a string event type, such as click, mouseover, or submit; any DOM event type supported by your browser may be used. * The type may be optionally followed by a period (.) and a name; the optional name allows multiple callbacks to be registered * to receive events of the same type, such as click.foo and click.bar. To specify multiple typenames, separate typenames with spaces, * such as "input change"" or "click.foo click.bar". * @param listener A listener function which will be evaluated for each selected element, * being passed the current event (event) and the current datum (d), with this as the current DOM element (event.currentTarget). * Listeners always see the latest datum for their element. * Note: while you can use event.pageX and event.pageY directly, * it is often convenient to transform the event position to the local coordinate system of that element that received the event using d3.pointer. * @param options An optional options object may specify characteristics about the event listener, such as wehether it is captures or passive; see element.addEventListener. */ on(typenames: string, listener: (this: GElement, event: any, d: Datum) => void, options?: any): this; /** * Dispatches a custom event of the specified type to each selected element, in order. * An optional parameters map may be specified to set additional properties of the event. * * @param type Name of event to dispatch * @param parameters An optional value map with custom event parameters */ dispatch(type: string, parameters?: CustomEventParameters): this; /** * Dispatches a custom event of the specified type to each selected element, in order. * An optional value function returning a parameters map for each element in the selection may be specified to set additional properties of the event. * * @param type Name of event to dispatch * @param parameters A value function which is evaluated for each selected element, in order, * being passed the current datum (d), the current index (i), and the current group (nodes), * with this as the current DOM element (nodes[i]). It must return the parameters map for the current element. */ dispatch(type: string, parameters?: ValueFn): this; // Control Flow ---------------------- /** * Invoke the specified function for each selected element, passing in the current datum (d), * the current index (i), and the current group (nodes), with this of the current DOM element (nodes[i]). * This method can be used to invoke arbitrary code for each selected element, and is useful for creating a context to access parent and child data simultaneously. * * @param func A function which is invoked for each selected element, * being passed the current datum (d), the current index (i), and the current group (nodes), with this of the current DOM element (nodes[i]). */ each(func: ValueFn): this; /** * Invoke the specified function exactly once, passing in this selection along with any optional arguments. * Returns this selection. * * @param func A function which is passed this selection as the first argument along with any optional arguments. * @param args List of optional arguments to be passed to the callback function. */ call(func: (selection: Selection, ...args: Args) => void, ...args: Args): this; /** * Return true if this selection contains no (non-null) elements. */ empty(): boolean; /** * Return an array of all (non-null) elements in this selection. */ nodes(): GElement[]; /** * Return the first (non-null) element in this selection. If the selection is empty, returns null. */ node(): GElement | null; /** * Returns the total number of elements in this selection. */ size(): number; /** * Returns an iterator over the selected (non-null) elements. */ [Symbol.iterator](): Iterator; } /** * Selects the root element, document.documentElement. This function can also be used to test for selections * (instanceof d3.selection) or to extend the selection prototype. */ export type SelectionFn = () => Selection; /** * Selects the root element, document.documentElement. This function can also be used to test for selections * (instanceof d3.selection) or to extend the selection prototype. */ export const selection: SelectionFn; // --------------------------------------------------------------------------- // pointer.js and pointers.js related // --------------------------------------------------------------------------- /** * Returns a two-element array of numbers [x, y] representing the coordinates of the specified event relative to the specified target. * event can be a MouseEvent, a PointerEvent, a Touch, or a custom event holding a UIEvent as event.sourceEvent. * * If target is not specified, it defaults to the source event’s currentTarget property, if available. * If the target is an SVG element, the event’s coordinates are transformed using the inverse of the screen coordinate transformation matrix. * If the target is an HTML element, the event’s coordinates are translated relative to the top-left corner of the target’s bounding client rectangle. * (As such, the coordinate system can only be translated relative to the client coordinates. See also GeometryUtils.) * Otherwise, [event.pageX, event.pageY] is returned. * * @param event The specified event. * @param target The target which the coordinates are relative to. */ export function pointer(event: any, target?: any): [number, number]; /** * Returns an array [[x0, y0], [x1, y1]…] of coordinates of the specified event’s pointer locations relative to the specified target. * For touch events, the returned array of positions corresponds to the event.touches array; for other events, returns a single-element array. * * If target is not specified, it defaults to the source event’s currentTarget property, if any. * * @param event The specified event. * @param target The target which the coordinates are relative to. */ export function pointers(event: any, target?: any): Array<[number, number]>; // --------------------------------------------------------------------------- // style // --------------------------------------------------------------------------- /** * Returns the value of the style property with the specified name for the specified node. * If the node has an inline style with the specified name, its value is returned; otherwise, the computed property value is returned. * See also selection.style. * * @param node A DOM node (e.g. HTMLElement, SVGElement) for which to retrieve the style property. * @param name Style property name. */ export function style(node: Element, name: string): string; // --------------------------------------------------------------------------- // local.js related // --------------------------------------------------------------------------- export interface Local { /** * Retrieves a local variable stored on the node (or one of its parents). * * @param node A node element. */ get(node: Element): T | undefined; /** * Deletes the value associated with the given node. Values stored on ancestors are not affected, meaning that child nodes will still see inherited values. * * This function returns true if there was a value stored directly on the node, and false otherwise. * * @param node A node element. */ remove(node: Element): boolean; /** * Store a value for this local variable. Calling `.get()` on children of this node will also retrieve the variable's value. * * @param node A node element. * @param value Value to store locally */ set(node: Element, value: T): T; /** * Obtain a string with the internally assigned property name for the local * which is used to store the value on a node */ toString(): string; } /** * Obtain a new local variable * * The generic refers to the type of the variable to store locally. */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics export function local(): Local; // --------------------------------------------------------------------------- // namespace.js related // --------------------------------------------------------------------------- /** * Interface for object literal containing local name with related fully qualified namespace */ export interface NamespaceLocalObject { /** * Fully qualified namespace */ space: string; /** * Name of the local to be namespaced. */ local: string; } /** * Obtain an object with properties of fully qualified namespace string and * name of local by parsing a shorthand string "prefix:local". If the prefix * does not exist in the "namespaces" object provided by d3-selection, then * the local name is returned as a simple string. * * @param prefixedLocal A string composed of the namespace prefix and local * name separated by colon, e.g. "svg:text". */ export function namespace(prefixedLocal: string): NamespaceLocalObject | string; // --------------------------------------------------------------------------- // namespaces.js related // --------------------------------------------------------------------------- /** * Interface for maps of namespace prefixes to corresponding fully qualified namespace strings */ export interface NamespaceMap { [prefix: string]: string; } /** * Map of namespace prefixes to corresponding fully qualified namespace strings */ export const namespaces: NamespaceMap; // --------------------------------------------------------------------------- // window.js related // --------------------------------------------------------------------------- /** * Returns the owner window for the specified node. If node is a node, returns the owner document’s default view; * if node is a document, returns its default view; otherwise returns the node. * * @param DOMNode A DOM element */ export function window(DOMNode: Window | Document | Element): Window; // --------------------------------------------------------------------------- // creator.js and matcher.js Complex helper closure generating functions // for explicit bound-context dependent use // --------------------------------------------------------------------------- /** * Given the specified element name, returns a single-element selection containing * a detached element of the given name in the current document. * * @param name tag name of the element to be added. */ export function create(name: K): Selection; /** * Given the specified element name, returns a single-element selection containing * a detached element of the given name in the current document. * * @param name Tag name of the element to be added. See "namespace" for details on supported namespace prefixes, * such as for SVG elements. */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics export function create(name: string): Selection; /** * Given the specified element name, returns a function which creates an element of the given name, * assuming that "this" is the parent element. * * @param name Tag name of the element to be added. */ export function creator(name: K): (this: BaseType) => ElementTagNameMap[K]; /** * Given the specified element name, returns a function which creates an element of the given name, * assuming that "this" is the parent element. * * The generic refers to the type of the new element to be returned by the creator function. * * @param name Tag name of the element to be added. See "namespace" for details on supported namespace prefixes, * such as for SVG elements. */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics export function creator(name: string): (this: BaseType) => NewGElement; /** * Given the specified selector, returns a function which returns true if "this" element matches the specified selector. * * @param selector A CSS selector string. */ export function matcher(selector: string): (this: BaseType) => boolean; // ---------------------------------------------------------------------------- // selector.js and selectorAll.js related functions // ---------------------------------------------------------------------------- /** * Given the specified selector, returns a function which returns the first descendant of "this" element * that matches the specified selector. * * The generic refers to the type of the returned descendant element. * * @param selector A CSS selector string. */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics export function selector(selector: string): (this: BaseType) => DescElement; /** * Given the specified selector, returns a function which returns all descendants of "this" element that match the specified selector. * * The generic refers to the type of the returned descendant element. * * @param selector A CSS selector string. */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics export function selectorAll(selector: string): (this: BaseType) => NodeListOf;