Skip to content

Instantly share code, notes, and snippets.

@callmephilip
Last active July 12, 2016 11:06
Show Gist options
  • Save callmephilip/8f36e30ede274638ce091749d6e9bc85 to your computer and use it in GitHub Desktop.
Save callmephilip/8f36e30ede274638ce091749d6e9bc85 to your computer and use it in GitHub Desktop.
Complex navigation with React Native experimental navigation API
/*
*
* Navigation reducer
* !! Do NOT do this. I am putting this here just for illustraition purposes to demonstrate where i got stuck with
* this approach
*/
import ReactNative from 'react-native';
import Immutable from 'immutable';
const { NavigationExperimental } = ReactNative;
const {
Reducer: NavigationReducer
} = NavigationExperimental;
const simpleIcon = {
uri: '',
scale: 3
};
const tabs = NavigationReducer.TabsReducer({
key: 'ApplicationTabs',
initialIndex: 0,
tabReducers: [
NavigationReducer.StackReducer({
getPushedReducerForAction: (action) => {
if (action.type === 'push' && action.parent === 'notifs') {
return (state) => (state || action.route);
}
return null;
},
initialState: {
key: 'notifs',
icon: simpleIcon,
selectedIcon: simpleIcon,
title: 'Notifications',
index: 0,
children: [
{
key: 'base',
type: 'NotifsPage',
title: 'Feed'
},
],
},
}),
NavigationReducer.StackReducer({
getPushedReducerForAction: (action) => {
return null;
},
initialState: {
key: 'settings',
icon: simpleIcon,
selectedIcon: simpleIcon,
title: 'Settings',
index: 0,
children: [
{key: 'base', type: 'SettingsPage'},
],
},
}),
NavigationReducer.StackReducer({
getPushedReducerForAction: (action) => {
return null;
},
initialState: {
key: 'profile',
icon: simpleIcon,
selectedIcon: simpleIcon,
title: 'Profile',
index: 0,
children: [
{key: 'base', type: 'ProfilePage'},
],
},
}),
]
});
const stackReducerForChildren = (state, action) => {
console.log('checking on stackReducerForChildren', action);
const ts = state.children[state.children.length - 1].children;
const s = Immutable.fromJS(state);
const parent = action.parent;
const targetTab = ts.find(t => t.key === parent);
const targetTabIndex = ts.findIndex(t => t.key === parent);
console.log('gonna update', targetTab);
const newTab = NavigationReducer.StackReducer({
initialState: targetTab
})(targetTab, action);
console.log('reduced to', newTab);
ts[targetTabIndex] = newTab;
return s.merge(state).toJS();
};
const navigation = NavigationReducer.StackReducer({
getPushedReducerForAction: (action) => {
console.log('checking reducer on top');
if (action.type === 'push' && !action.parent) {
return (state) => (state || action.route);
}
return null;
},
getReducerForState: (state) => {
if (state.key === 'ApplicationTabs') {
return tabs;
}
return null;
},
initialState: {
index: 0,
key: 'appNavigation',
children: [
tabs()
],
},
});
const findReducer = NavigationReducer.FindReducer(
[navigation, stackReducerForChildren]
);
module.exports = findReducer;
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment