mirror of
https://github.com/zhigang1992/DefinitelyTyped.git
synced 2026-04-24 05:06:02 +08:00
# Conflicts: # amcharts/AmCharts.d.ts # angular-gettext/angular-gettext.d.ts # angular-jwt/angular-jwt.d.ts # angular-material/angular-material.d.ts # angularjs/angular.d.ts # auth0-js/auth0-js.d.ts # aws-lambda/aws-lambda.d.ts # aws-sdk/aws-sdk.d.ts # azure-mobile-apps/azure-mobile-apps.d.ts # azure-mobile-services-client/AzureMobileServicesClient.d.ts # blessed/blessed-tests.ts # blessed/blessed.d.ts # bootbox/bootbox.d.ts # bowser/bowser.d.ts # cache-manager/cache-manager.d.ts # chai-things/chai-things.d.ts # colors/colors.d.ts # cordova/cordova-tests.ts # cordova/plugins/Contacts.d.ts # cordova/plugins/FileSystem.d.ts # couchbase/couchbase.d.ts # cucumber/cucumber-tests.ts # cucumber/cucumber.d.ts # d3/d3.d.ts # dojo/dojo.d.ts # dustjs-linkedin/dustjs-linkedin.d.ts # esprima/esprima.d.ts # express-serve-static-core/express-serve-static-core.d.ts # express-session/express-session.d.ts # fetch-mock/fetch-mock.d.ts # fs-extra/fs-extra.d.ts # fullCalendar/fullCalendar.d.ts # github-electron/github-electron.d.ts # gulp-uglify/gulp-uglify.d.ts # gulp/gulp.d.ts # highcharts/highcharts.d.ts # imap/imap.d.ts # incremental-dom/incremental-dom.d.ts # inversify/inversify.d.ts # ionic/ionic.d.ts # ioredis/ioredis.d.ts # isomorphic-fetch/isomorphic-fetch-tests.ts # jake/jake.d.ts # joi/joi.d.ts # jquery-mockjax/jquery-mockjax.d.ts # jquery/jquery.d.ts # js-data-http/js-data-http-tests.ts # js-data-http/js-data-http.d.ts # js-data/js-data.d.ts # jsdom/jsdom.d.ts # jsts/jsts-tests.ts # knex/knex.d.ts # koa-favicon/koa-favicon.d.ts # koa-router/koa-router-tests.ts # koa-router/koa-router.d.ts # lodash/lodash.d.ts # mailparser/mailparser.d.ts # maquette/maquette.d.ts # material-ui/material-ui.d.ts # matter-js/matter-js.d.ts # moment/moment.d.ts # mongoose-promise/mongoose-promise-tests.ts # mongoose/mongoose-tests.ts # mongoose/mongoose.d.ts # multer/multer.d.ts # ncp/ncp.d.ts # nock/nock.d.ts # node/node-tests.ts # node/node.d.ts # nvd3/nvd3.d.ts # object-assign/object-assign.d.ts # openlayers/openlayers.d.ts # parse/parse.d.ts # pdf/pdf.d.ts # pdfkit/pdfkit.d.ts # pg/pg.d.ts # pixi.js/pixi.js.d.ts # progress/progress.d.ts # pusher-js/pusher-js.d.ts # quill/quill-tests.ts # quill/quill.d.ts # radium/radium.d.ts # ravenjs/ravenjs-tests.ts # react-dropzone/react-dropzone.d.ts # react-mdl/react-mdl.d.ts # react-native/react-native.d.ts # react-notification-system/react-notification-system.d.ts # react-router/history-tests.ts # react-router/react-router-tests.tsx # react-router/react-router.d.ts # react-select/react-select-tests.tsx # react-select/react-select.d.ts # react/react.d.ts # redux-form/redux-form.d.ts # request-promise/request-promise.d.ts # resolve-from/resolve-from.d.ts # riot-api-nodejs/riot-api-nodejs.d.ts # sanitize-html/sanitize-html.d.ts # segment-analytics/segment-analytics.d.ts # simple-assign/simple-assign-tests.ts # simple-assign/simple-assign.d.ts # slate-irc/slate-irc.d.ts # soap/soap.d.ts # socket.io/socket.io.d.ts # sql.js/sql.js-tests.ts # sql.js/sql.js.d.ts # steam/steam.d.ts # stylus/stylus.d.ts # swiper/swiper.d.ts # tedious/tedious.d.ts # threejs/three.d.ts # twilio/twilio.d.ts # underscore/underscore.d.ts # ws/ws.d.ts # yeoman-generator/yeoman-generator.d.ts
115 lines
4.2 KiB
TypeScript
115 lines
4.2 KiB
TypeScript
// Type definitions for radium 0.18.1
|
||
// Project: https://github.com/formidablelabs/radium
|
||
// Definitions by: Alex Gorbatchev <https://github.com/alexgorbatchev/>, Philipp Holzer <https://github.com/nupplaphil/>, Alexey Svetliakov <https://github.com/asvetliakov/>, Mikael Hermansson <https://github.com/mihe/>
|
||
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
|
||
|
||
import React = require('react');
|
||
import ReactComponent = React.Component;
|
||
|
||
export = Radium;
|
||
|
||
// @Radium decorator
|
||
declare function Radium<TElement extends Function>(component: TElement): TElement;
|
||
declare function Radium(config: Radium.RadiumConfig): (component?: any) => any;
|
||
declare namespace Radium {
|
||
interface StyleRules {
|
||
[index: string]: React.CSSProperties;
|
||
}
|
||
|
||
/**
|
||
* Style component properties
|
||
*/
|
||
export interface StyleProps {
|
||
/**
|
||
* An object of styles, or an object of CSS rules to render. Each key of the rules object is a CSS
|
||
* selector and the value is an object of styles. If rules is empty, the component will render nothing.
|
||
*/
|
||
rules: React.CSSProperties | StyleRules;
|
||
/**
|
||
* A string that any included selectors in rules will be appended to.
|
||
* Use to scope styles in the component to a particular element. A good use case might be to generate a unique
|
||
* ID for a component to scope any styles to the particular component that owns the <Style> component instance.
|
||
*/
|
||
scopeSelector?: string;
|
||
}
|
||
|
||
/**
|
||
* <Style />
|
||
*/
|
||
export class Style extends React.Component<StyleProps, any> {
|
||
}
|
||
|
||
/**
|
||
* StyleRoot component properties
|
||
*/
|
||
export interface StyleRootProps extends React.HTMLProps<StyleRoot> {
|
||
}
|
||
/**
|
||
* <StyleRoot />
|
||
*/
|
||
export class StyleRoot extends React.Component<StyleRootProps, any> {
|
||
}
|
||
|
||
/**
|
||
* Radium configuration
|
||
*/
|
||
export interface RadiumConfig {
|
||
/**
|
||
* Allow to replace matchMedia function that Radium uses. The default one is window.matchMedia
|
||
* @param mediaQuery
|
||
*/
|
||
matchMedia?: (mediaQuery: string) => MediaQueryList;
|
||
/**
|
||
* Set the user agent passed to inline-style-prefixer to perform prefixing on style objects.
|
||
* Mainly used during server rendering
|
||
*/
|
||
userAgent?: string;
|
||
/**
|
||
* List of plugins
|
||
*/
|
||
plugins?: Array<any>;
|
||
}
|
||
|
||
/**
|
||
* Query Radium's knowledge of the browser state for a given element key.
|
||
* This is particularly useful if you would like to set styles for one element when another element is in a particular state,
|
||
* e.g. show a message when a button is hovered.
|
||
*
|
||
* Note that the target element specified by elementKey must have the state you'd like to check defined in
|
||
* its style object so that Radium knows to add the handlers. It can be empty, e.g. ':hover': {}.
|
||
* @param state you'll usually pass this.state, but sometimes you may want to pass a previous state, like in shouldComponentUpdate, componentWillUpdate, and componentDidUpdate
|
||
* @param elementKey if you used multiple elements, pass the same key="" or ref="". If you only have one element, you can leave it blank ('main' will be inferred)
|
||
* @param value one of the following: :active, :focus, and :hover
|
||
*/
|
||
export function getState(state: any, elementKey: string | void, value: ":active" | ":focus" | ":hover"): boolean;
|
||
|
||
/**
|
||
* Create a keyframes animation for use in an inline style.
|
||
* @param keyframes
|
||
* @param name
|
||
*/
|
||
export function keyframes(keyframes: StyleRules, name?: string): Object;
|
||
|
||
// Radium 0.17 Test mode
|
||
/**
|
||
* Used to control internal Radium state and behavior during tests. It is only available in non-production builds.
|
||
*/
|
||
interface RadiumTestMode {
|
||
/**
|
||
* Clears the global Radium state, currently only the cache of media query listeners.
|
||
*/
|
||
clearState(): void;
|
||
/**
|
||
* Enables "test mode", which doesn’t throw or warn as much. Currently it just doesn’t throw when using addCSS without StyleRoot.
|
||
*/
|
||
enable(): void;
|
||
/**
|
||
* Disables "test mode"
|
||
*/
|
||
disable(): void;
|
||
}
|
||
|
||
var TestMode: RadiumTestMode;
|
||
|
||
}
|