Added type definitions for react-timeout (#24916)

* Added type definitions for react-timeout

* Fixed export

* Removed rules from tslint.json

* Added types

* Indented

* Fixed types
This commit is contained in:
Kerwyn
2018-04-11 17:15:58 -06:00
committed by Mohamed Hegazy
parent 9db24f13b5
commit d113bbc18a
3 changed files with 58 additions and 0 deletions

32
types/react-timeout/index.d.ts vendored Normal file
View File

@@ -0,0 +1,32 @@
// Type definitions for react-timeout 1.1
// Project: https://github.com/plougsgaard/react-timeout
// Definitions by: Kerwyn Rojas <https://github.com/kerwynrg>
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
// TypeScript Version: 2.6
/// <reference types="node" />
import * as React from 'react';
export = ReactTimeout;
declare function ReactTimeout<T>(
SourceComponent: React.ComponentClass<T> | React.StatelessComponent<T>
): React.ComponentClass<T>;
declare namespace ReactTimeout {
type Timer = NodeJS.Timer | number;
type Id = number;
interface ReactTimeoutProps {
setTimeout?: (callback: (...args: any[]) => void, ms: number, ...args: any[]) => Timer;
clearTimeout?: (timer: Timer) => void;
setInterval?: (callback: (...args: any[]) => void, ms: number, ...args: any[]) => Id;
clearInterval?: (id: Id) => void;
setImmediate?: (callback: (...args: any[]) => void, ...args: any[]) => Id;
clearImmediate?: (id: Id) => void;
requestAnimationFrame?: (callback: (...args: any[]) => void) => Id;
cancelAnimationFrame?: (id: Id) => void;
}
}

View File

@@ -0,0 +1,23 @@
{
"compilerOptions": {
"module": "commonjs",
"lib": [
"es6",
"dom"
],
"noImplicitAny": true,
"noImplicitThis": true,
"strictNullChecks": true,
"strictFunctionTypes": true,
"baseUrl": "../",
"typeRoots": [
"../"
],
"types": [],
"noEmit": true,
"forceConsistentCasingInFileNames": true
},
"files": [
"index.d.ts"
]
}

View File

@@ -0,0 +1,3 @@
{
"extends": "dtslint/dt.json"
}