mirror of
https://github.com/gosticks/DefinitelyTyped.git
synced 2025-10-16 12:05:41 +00: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
223 lines
6.7 KiB
TypeScript
223 lines
6.7 KiB
TypeScript
import * as React from "react";
|
|
import * as ReactDOM from "react-dom";
|
|
|
|
import Select = require("react-select");
|
|
import { Option, ReactSelectProps, ReactCreatableSelectProps, ReactAsyncSelectProps, MenuRendererProps } from "react-select";
|
|
|
|
const CustomOption = React.createClass({
|
|
propTypes: {
|
|
children: React.PropTypes.node,
|
|
className: React.PropTypes.string,
|
|
isDisabled: React.PropTypes.bool,
|
|
isFocused: React.PropTypes.bool,
|
|
isSelected: React.PropTypes.bool,
|
|
onFocus: React.PropTypes.func,
|
|
onSelect: React.PropTypes.func,
|
|
option: React.PropTypes.object.isRequired,
|
|
},
|
|
handleMouseDown (event: Event) {
|
|
event.preventDefault();
|
|
event.stopPropagation();
|
|
this.props.onSelect(this.props.option, event);
|
|
},
|
|
handleMouseEnter (event: Event) {
|
|
this.props.onFocus(this.props.option, event);
|
|
},
|
|
handleMouseMove (event: Event) {
|
|
if (this.props.isFocused) return;
|
|
this.props.onFocus(this.props.option, event);
|
|
},
|
|
render () {
|
|
return (
|
|
<div className="Select-option"
|
|
onMouseDown={this.handleMouseDown}
|
|
onMouseEnter={this.handleMouseEnter}
|
|
onMouseMove={this.handleMouseMove}
|
|
title={this.props.option.title}>
|
|
{this.props.children}
|
|
</div>
|
|
);
|
|
}
|
|
});
|
|
|
|
const CustomValue = React.createClass({
|
|
propTypes: {
|
|
children: React.PropTypes.node,
|
|
placeholder: React.PropTypes.string,
|
|
value: React.PropTypes.object
|
|
},
|
|
render () {
|
|
return (
|
|
<div className="Select-value" title={this.props.value.title}>
|
|
<span className="Select-value-label">
|
|
{this.props.children}
|
|
</span>
|
|
</div>
|
|
);
|
|
}
|
|
});
|
|
|
|
const filterOptions = (options: Array<Option>, filter: string, values: Array<Option>) => {
|
|
// Filter already selected values
|
|
let filteredOptions = options.filter(option => values.indexOf(option) < 0);
|
|
|
|
// Filter by label
|
|
if (filter != null && filter.length > 0) {
|
|
filteredOptions = filteredOptions.filter(option => RegExp(filter, 'ig').test(option.label));
|
|
}
|
|
|
|
// Append Addition option
|
|
if (filteredOptions.length === 0) {
|
|
filteredOptions.push({
|
|
label: `Create: ${filter}`,
|
|
value: filter
|
|
});
|
|
}
|
|
|
|
return filteredOptions;
|
|
};
|
|
|
|
class SelectTest extends React.Component<React.Props<{}>, {}> {
|
|
|
|
render() {
|
|
const options: Option[] = [{ label: "Foo", value: "bar" }];
|
|
const onChange = (value: any) => console.log(value);
|
|
const renderMenu = ({
|
|
focusedOption,
|
|
focusOption,
|
|
labelKey,
|
|
options,
|
|
selectValue,
|
|
valueArray
|
|
}: MenuRendererProps) => { return <div></div> };
|
|
const onOpen = () => { return; };
|
|
const onClose = () => { return; };
|
|
const optionRenderer = (option: Option) => <span>{option.label}</span>
|
|
|
|
const selectProps: ReactSelectProps = {
|
|
name: "test-select",
|
|
className: "test-select",
|
|
key: "1",
|
|
options: options,
|
|
optionRenderer: optionRenderer,
|
|
autofocus: true,
|
|
autosize: true,
|
|
clearable: true,
|
|
escapeClearsValue: true,
|
|
filterOptions: filterOptions,
|
|
ignoreAccents: true,
|
|
joinValues: false,
|
|
matchPos: "any",
|
|
matchProp: "any",
|
|
menuContainerStyle: {},
|
|
menuRenderer: renderMenu,
|
|
menuStyle: {},
|
|
multi: true,
|
|
onMenuScrollToBottom: () => {},
|
|
onValueClick: onChange,
|
|
onOpen: onOpen,
|
|
onClose: onClose,
|
|
openAfterFocus: false,
|
|
optionComponent: CustomOption,
|
|
required: false,
|
|
resetValue: "resetValue",
|
|
scrollMenuIntoView: false,
|
|
valueKey: "github",
|
|
labelKey: "name",
|
|
onChange: onChange,
|
|
value: options,
|
|
valueComponent: CustomValue,
|
|
valueRenderer: optionRenderer
|
|
};
|
|
|
|
return <div>
|
|
<Select {...selectProps} />
|
|
</div>;
|
|
}
|
|
}
|
|
|
|
class SelectWithStringValueTest extends React.Component<React.Props<{}>, {}> {
|
|
|
|
render() {
|
|
const options: Option[] = [{ label: "Foo", value: "bar" }];
|
|
const onChange = (value: any) => console.log(value);
|
|
|
|
const selectProps: ReactSelectProps = {
|
|
name: "test-select-with-string-value",
|
|
value: "bar",
|
|
options: options,
|
|
onChange: onChange
|
|
};
|
|
|
|
return <div>
|
|
<Select {...selectProps} />
|
|
</div>;
|
|
}
|
|
}
|
|
|
|
class SelectAsyncTest extends React.Component<React.Props<{}>, {}> {
|
|
|
|
render() {
|
|
const getOptions = (input: string, callback: Function) => {
|
|
setTimeout(function() {
|
|
callback(null, options);
|
|
}, 500);
|
|
};
|
|
const options: Option[] = [{ label: "Foo", value: "bar" }];
|
|
const onChange = (value: any) => console.log(value);
|
|
|
|
const asyncSelectProps: ReactAsyncSelectProps = {
|
|
name: "test-select",
|
|
className: "test-select",
|
|
key: "1",
|
|
matchPos: "any",
|
|
matchProp: "any",
|
|
multi: true,
|
|
onValueClick: onChange,
|
|
valueKey: "github",
|
|
labelKey: "name",
|
|
onChange: onChange,
|
|
simpleValue: undefined,
|
|
value: options,
|
|
loadOptions: getOptions,
|
|
cache: {},
|
|
ignoreAccents: false,
|
|
ignoreCase: true,
|
|
isLoading: false,
|
|
minimumInput: 5,
|
|
searchPromptText: "search...",
|
|
searchingText: "searching...",
|
|
};
|
|
|
|
return <div>
|
|
<Select.Async {...asyncSelectProps} />
|
|
</div>;
|
|
}
|
|
|
|
}
|
|
|
|
class SelectCreatableTest extends React.Component<React.Props<{}>, {}> {
|
|
|
|
render() {
|
|
const options: Option[] = [{ label: "Foo", value: "bar" }];
|
|
const onChange = (value: any) => console.log(value);
|
|
|
|
const creatableSelectProps: ReactCreatableSelectProps = {
|
|
name: "test-creatable-select",
|
|
value: "bar",
|
|
options: options,
|
|
onChange: onChange,
|
|
isOptionUnique: () => { return true; },
|
|
isValidNewOption: () => { return true; },
|
|
newOptionCreator: () => { return { label: "NewFoo", value: "newBar" }; },
|
|
promptTextCreator: () => { return ""; },
|
|
shouldKeyDownEventCreateNewOption: () => { return true; }
|
|
};
|
|
|
|
return <div>
|
|
<Select.Creatable {...creatableSelectProps} />
|
|
</div>
|
|
}
|
|
|
|
}
|