Skip to content

Commit

Permalink
Use React.ComponentType to provide forwards compatibility with React 18
Browse files Browse the repository at this point in the history
In older versions of @types/react `ComponentType` is an alias for `ComponentClass` and `SFC`. In @types/react 18+ `SFC` no longer exists and `ComponentType` is an alias for `ComponentClass` and `FunctionComponent`.
  • Loading branch information
jorrit committed Jul 18, 2022
1 parent 13b5c35 commit 2d54783
Showing 1 changed file with 6 additions and 6 deletions.
12 changes: 6 additions & 6 deletions types/react-datasheet.d.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Component, ReactNode, KeyboardEventHandler, MouseEventHandler } from "react";
import { Component, ReactNode, KeyboardEventHandler, MouseEventHandler, ComponentType } from 'react';

declare namespace ReactDataSheet {
/** The cell object is what gets passed to the callbacks and events, and contains the basic information about what to show in each cell. You should extend this interface to build a place to store your data.
Expand Down Expand Up @@ -110,7 +110,7 @@ declare namespace ReactDataSheet {
}

/** Optional function or React Component to render the main sheet element. The default renders a table element. To wire it up, pass your function to the sheetRenderer property of the ReactDataSheet component. */
export type SheetRenderer<T extends Cell<T, V>, V = string> = React.ComponentClass<SheetRendererProps<T, V>> | React.SFC<SheetRendererProps<T, V>>;
export type SheetRenderer<T extends Cell<T, V>, V = string> = React.ComponentType<SheetRendererProps<T, V>>;

/** The properties that will be passed to the RowRenderer component or function. */
export interface RowRendererProps<T extends Cell<T, V>, V = string> {
Expand All @@ -123,7 +123,7 @@ declare namespace ReactDataSheet {
}

/** Optional function or React Component to render each row element. The default renders a tr element. To wire it up, pass your function to the rowRenderer property of the ReactDataSheet component. */
export type RowRenderer<T extends Cell<T, V>, V = string> = React.ComponentClass<RowRendererProps<T, V>> | React.SFC<RowRendererProps<T, V>>;
export type RowRenderer<T extends Cell<T, V>, V = string> = React.ComponentType<RowRendererProps<T, V>>;

/** The arguments that will be passed to the first parameter of the onCellsChanged handler function. These represent all the changes _inside_ the bounds of the existing grid. The first generic parameter (required) indicates the type of the cell property, and the second generic parameter (default: string) indicates the type of the value property. */
export type CellsChangedArgs<T extends Cell<T, V>, V = string> = {
Expand Down Expand Up @@ -198,7 +198,7 @@ declare namespace ReactDataSheet {
}

/** A function or React Component to render each cell element. The default renders a td element. To wire it up, pass it to the cellRenderer property of the ReactDataSheet component. */
export type CellRenderer<T extends Cell<T, V>, V = string> = React.ComponentClass<CellRendererProps<T, V>> | React.SFC<CellRendererProps<T, V>>;
export type CellRenderer<T extends Cell<T, V>, V = string> = React.ComponentType<CellRendererProps<T, V>>;

/** The properties that will be passed to the CellRenderer component or function. */
export interface ValueViewerProps<T extends Cell<T, V>, V = string> {
Expand All @@ -213,7 +213,7 @@ declare namespace ReactDataSheet {
}

/** Optional function or React Component to customize the way the value for each cell in the sheet is displayed. If it is passed to the valueViewer property of the ReactDataSheet component, it affects every cell in the sheet. Different editors can also be passed to the valueViewer property of each Cell to control each cell separately. */
export type ValueViewer<T extends Cell<T, V>, V = string> = React.ComponentClass<ValueViewerProps<T, V>> | React.SFC<ValueViewerProps<T, V>>;
export type ValueViewer<T extends Cell<T, V>, V = string> = React.ComponentType<ValueViewerProps<T, V>>;

/** The properties that will be passed to the DataEditor component or function. */
export interface DataEditorProps<T, V = string> {
Expand All @@ -236,7 +236,7 @@ declare namespace ReactDataSheet {
}

/** A function or React Component to render a custom editor. If it is passed to the dataEditor property of the ReactDataSheet component, it affects every cell in the sheet. Different editors can also be passed to the dataEditor property of each Cell to control each cell separately. */
export type DataEditor<T extends Cell<T, V>, V = string> = React.ComponentClass<DataEditorProps<T, V>> | React.SFC<DataEditorProps<T, V>>;
export type DataEditor<T extends Cell<T, V>, V = string> = React.ComponentType<DataEditorProps<T, V>>;

export interface CellReference {
row: number;
Expand Down

0 comments on commit 2d54783

Please sign in to comment.