本文整理匯總了TypeScript中lodash/isPlainObject.default函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript default函數的具體用法?TypeScript default怎麽用?TypeScript default使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了default函數的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: as
/**
* Decorates a component as a dragsource
* @param type The dragsource type
* @param spec The drag source specification
* @param collect The props collector function
* @param options DnD optinos
*/
export default function DragSource<Props, CollectedProps = {}, DragObject = {}>(
type: SourceType | ((props: Props) => SourceType),
spec: DragSourceSpec<Props, DragObject>,
collect: DragSourceCollector<CollectedProps>,
options: DndOptions<Props> = {},
) {
checkDecoratorArguments(
'DragSource',
'type, spec, collect[, options]',
type,
spec,
collect,
options,
)
let getType: ((props: Props) => SourceType) = type as ((
props: Props,
) => SourceType)
if (typeof type !== 'function') {
invariant(
isValidType(type),
'Expected "type" provided as the first argument to DragSource to be ' +
'a string, or a function that returns a string given the current props. ' +
'Instead, received %s. ' +
'Read more: http://react-dnd.github.io/react-dnd/docs-drag-source.html',
type,
)
getType = () => type
}
invariant(
isPlainObject(spec),
'Expected "spec" provided as the second argument to DragSource to be ' +
'a plain object. Instead, received %s. ' +
'Read more: http://react-dnd.github.io/react-dnd/docs-drag-source.html',
spec,
)
const createSource = createSourceFactory(spec)
invariant(
typeof collect === 'function',
'Expected "collect" provided as the third argument to DragSource to be ' +
'a function that returns a plain object of props to inject. ' +
'Instead, received %s. ' +
'Read more: http://react-dnd.github.io/react-dnd/docs-drag-source.html',
collect,
)
invariant(
isPlainObject(options),
'Expected "options" provided as the fourth argument to DragSource to be ' +
'a plain object when specified. ' +
'Instead, received %s. ' +
'Read more: http://react-dnd.github.io/react-dnd/docs-drag-source.html',
collect,
)
return function decorateSource<
TargetClass extends
| React.ComponentClass<Props>
| React.StatelessComponent<Props>
>(DecoratedComponent: TargetClass): TargetClass & DndComponentClass<Props> {
return decorateHandler<Props, TargetClass, SourceType>({
containerDisplayName: 'DragSource',
createHandler: createSource,
registerHandler: registerSource,
createMonitor: createSourceMonitor,
createConnector: createSourceConnector,
DecoratedComponent,
getType,
collect,
options,
})
}
}
示例2: DragSource
export default function DragSource(
type: ItemType,
spec: IDragSourceSpecification<any, any>,
collect: DragSourceCollector<any>,
options: IDragSourceOptions = {},
) {
checkDecoratorArguments(
'DragSource',
'type, spec, collect[, options]',
type,
spec,
collect,
options, // eslint-disable-line prefer-rest-params
)
let getType: any = type
if (typeof type !== 'function') {
invariant(
isValidType(type),
'Expected "type" provided as the first argument to DragSource to be ' +
'a string, or a function that returns a string given the current props. ' +
'Instead, received %s. ' +
'Read more: http://react-dnd.github.io/react-dnd/docs-drag-source.html',
type,
)
getType = () => type
}
invariant(
isPlainObject(spec),
'Expected "spec" provided as the second argument to DragSource to be ' +
'a plain object. Instead, received %s. ' +
'Read more: http://react-dnd.github.io/react-dnd/docs-drag-source.html',
spec,
)
const createSource = createSourceFactory(spec)
invariant(
typeof collect === 'function',
'Expected "collect" provided as the third argument to DragSource to be ' +
'a function that returns a plain object of props to inject. ' +
'Instead, received %s. ' +
'Read more: http://react-dnd.github.io/react-dnd/docs-drag-source.html',
collect,
)
invariant(
isPlainObject(options),
'Expected "options" provided as the fourth argument to DragSource to be ' +
'a plain object when specified. ' +
'Instead, received %s. ' +
'Read more: http://react-dnd.github.io/react-dnd/docs-drag-source.html',
collect,
)
return function decorateSource<
Props,
T extends React.ComponentClass<Props> | React.StatelessComponent<Props>
>(DecoratedComponent: T): T & IDndComponentClass<Props> {
return decorateHandler({
connectBackend: (backend: IBackend, sourceId: string) => {
backend.connectDragSource(sourceId)
},
containerDisplayName: 'DragSource',
createHandler: createSource,
registerHandler: registerSource,
createMonitor: createSourceMonitor,
createConnector: createSourceConnector,
DecoratedComponent,
getType,
collect,
options,
}) as any
}
}
示例3: beginDrag
public beginDrag() {
const item = spec.beginDrag(this.props, this.monitor, this.component)
if (process.env.NODE_ENV !== 'production') {
invariant(
isPlainObject(item),
'beginDrag() must return a plain object that represents the dragged item. ' +
'Instead received %s. ' +
'Read more: http://react-dnd.github.io/react-dnd/docs-drag-source.html',
item,
)
}
return item
}
示例4: drop
public drop() {
if (!spec.drop) {
return undefined
}
const dropResult = spec.drop(this.props, this.monitor, this.component)
if (process.env.NODE_ENV !== 'production') {
invariant(
typeof dropResult === 'undefined' || isPlainObject(dropResult),
'drop() must either return undefined, or an object that represents the drop result. ' +
'Instead received %s. ' +
'Read more: http://react-dnd.github.io/react-dnd/docs-drop-target.html',
dropResult,
)
}
return dropResult
}
示例5: createStore
export const createArkhamStore = (configuration: ArkhamReduxStoreType): Store<any> => {
const {
arkhamMiddleware: middleware = [],
flux,
reducers,
sagas,
statePath = '',
reduxMiddleware = [],
devTools
} = configuration;
// Save initial state tree
const {storage} = Flux.getOptions();
let store: Store;
if(storage) {
const cachedState = Flux.getState(statePath);
if(devTools) {
store = createStore(
devTools(reducers, cachedState),
applyMiddleware(...reduxMiddleware, arkhamMiddleware(statePath, flux)));
} else {
store = createStore(
reducers,
cachedState,
applyMiddleware(...reduxMiddleware, arkhamMiddleware(statePath, flux)));
}
if(cachedState === undefined) {
const stateTree = store.getState();
const updatedState = isPlainObject(stateTree) ? merge(stateTree, cachedState) : stateTree;
Flux.setState(statePath, updatedState);
}
} else {
store = createStore(
reducers,
devTools,
applyMiddleware(...reduxMiddleware, arkhamMiddleware(statePath, flux))
);
Flux.setState(statePath, store.getState());
}
// If saga is being added, run.
reduxMiddleware.every((item: any) => {
if(sagas) {
item.run(sagas);
return false;
}
return true;
});
// Add redux middleware to Arkham to relay dispatches to Redux
middleware.push(new ReduxMiddleware(store, statePath));
// Initialize ArkhamJS
Flux.addMiddleware(middleware);
return store;
};
示例6: setNewState
(newState: any) => setNewState(isPlainObject(initialState) ? merge(state, newState) : newState)