mirror of
https://github.com/status-im/react-native.git
synced 2025-02-11 00:46:32 +00:00
Summary: A new API to unify internal navigation. Also addresses a highly-rated community 'pain': https://productpains.com/post/react-native/better-navigator-api-and-docs/ Offers the following improvements: - Redux-style navigation logic is easy to reason about - Navigation state can be easily saved and restored through refreshes - Declarative navigation views can be implemented in native or JS - Animations and gestures are isolated and now use the Animated library public Reviewed By: hedgerwang Differential Revision: D2798048 fb-gh-sync-id: 88027ef9ead8a80afa38354252bc377455cc6dbb
39 lines
1.1 KiB
JavaScript
39 lines
1.1 KiB
JavaScript
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under the BSD-style license found in the
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
*
|
|
* @providesModule NavigationFindReducer
|
|
* @flow
|
|
*/
|
|
'use strict';
|
|
|
|
/*
|
|
* NavigationFindReducer takes an array of reducers, and returns a reducer that
|
|
* iterates through all of the reducers and the result of the first reducer
|
|
* that modifies the input
|
|
*/
|
|
|
|
import type {
|
|
NavigationState,
|
|
NavigationReducer
|
|
} from 'NavigationState';
|
|
|
|
function NavigationFindReducer(reducers: Array<NavigationReducer>): ?NavigationReducer {
|
|
return function(lastState: ?NavigationState, action: ?any): ?NavigationState {
|
|
for (let i = 0; i < reducers.length; i++) {
|
|
let reducer = reducers[i];
|
|
let newState = reducer(lastState, action);
|
|
if (newState !== lastState) {
|
|
return newState;
|
|
}
|
|
}
|
|
return lastState;
|
|
};
|
|
}
|
|
|
|
module.exports = NavigationFindReducer;
|