Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ListWireframe isn't self contained; knows about AddWireframe and UIWindow #6

Open
fatuhoku opened this issue Sep 15, 2015 · 0 comments

Comments

@fatuhoku
Copy link

Hi, fantastic demo project. I think it really shows the degree to which VIPER helps isolate single responsibilities.

I do have a question over why Wireframes are as they are though.

Imagine that I want to actually build an iPad version of this app and I want to display a List of TODOS inside of a popover, and we don't offer an option to add items at all — but the iPhone version should remain unchanged.

So intuitively I'd think "Easy! We'll just create a new iPad-only target, and we can pick-up-and-use the List module completely unchanged. We just have to install the List view controller into a popover instead, and we make sure that we don't use the Add module and we are done!". This is such that both the iPhone and iPad app share exactly the same conceptual module: List completely unchanged.

Except — this won't work. ListWireframe is considered a 'part' of the List module (judging purely by looking at the file hierarchy). It currently only knows how to present the List into a UIWindow. What if I wanted to present the List from a ViewController? Or a UIView / CGRect from which the popover pops out? Surely ListWireframe cannot know of all possible cases in which its ViewController can be presented. Even if we do put that case in, ListWireframe now has two responsibilities, violating the SRP.

You end up thinking "Hmmm. I need to make an iPad-specific Wireframe class for List".

Another thing is, it also knows about AddWireframe, which means that if you were to lift the whole file hierarchy of List out into a separate project just to run it against some test table of TODOs, the code won't compile: AddWireframe is an inherent collaborator of a list.

This just isn't right to me. What wireframes do (navigation) is actually application-specific. It doesn't belong in modules. I see wireframes not as classes, but rather, protocols that let Presenters 'request' navigation behaviours from some super-module. Only the super module (in our case, probably a RootWireframe knows about both List and Add such that it can get them to work together. i.e. the super-module 'routes' navigation requests to the relevant module, so that e.g. Add can present itself from the List viewController.

Any thoughts? Have I just completely missed the original intention behind Wireframes?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant