I'm working on a project with some folks who want to use TTNavigator rather than Storyboards or old-fashioned UINavigationController pushing. Fine by me, except some view controllers in our app are using the delegate pattern to communicate with each other. I'm not sure how to preserve that pattern while using TTNavigator. Is it possible?
Another way of asking my question is: is it possible to access the destination view controller from within the view controller that is telling TTNavigator to open a new actionURL to that destination view controller?
For example, I have a view controller that wants an image from the user. To get it, it launches a new view controller with a camera UI that allows the user to get the image. Normally, I would set the first view controller as the delegate of the camera view controller. When the user has chosen an image, the camera view controller tells the delegate about the selection, and the delegate grabs the image and pops the camera view controller off the stack.
TTNavigator doesn't seem to give my first view controller a chance to interact with the camera view controller. The one way I see is for the first view controller to set itself as the delegate of the TTNavigator, which will result in the TTNavigator giving me a peek at the view controller it's about to push. Is that the best way to handle this?
It is possible but not recommended
You can pass data in the "query". You could certainly pass your origin viewController and then wire that up in the constructor of the destination viewController. Its loosely coupled and would work just fine. Its not pretty, though.
http://three20.info/article/2010-10-06-URL-Based-Navigation#nativeparams
Alternately, you could retrieve the viewController directly form the TTNavigator using viewControllerForURL: and then push that viewController. Also not pretty
I used TTNavigator on many projects but the last implementation was far more trouble than it was worth. We tried to make it work on an iPad project and constantly fought with the library. The bottom line is that iOS apps are just not web apps and there is no universal strategy for mapping a url to multiple screen navigation within a custom app. It makes perfect sense for web where each page is stateless and lives within a structured semantic architecture (hopefully) but with a rich mobile app, particularly a multi-pane iPad app, these details are not easily encoded in a url. You are better off building a less complicated navigation management sub system and then mapping explicit urls as you need them.