Instantly share code, notes, and snippets.
Last active
July 12, 2016 11:06
-
Star
2
(2)
You must be signed in to star a gist -
Fork
0
(0)
You must be signed in to fork a gist
-
Save callmephilip/8f36e30ede274638ce091749d6e9bc85 to your computer and use it in GitHub Desktop.
Complex navigation with React Native experimental navigation API
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/* | |
* | |
* 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