implementation 'com.github.st235:android-router:0.1.0'
<dependency>
<groupId>com.github.st235</groupId>
<artifactId>android-router</artifactId>
<version>0.1.0</version>
<type>pom</type>
</dependency>
We realized that Android-framework needs its own routing system, but there is no unified solution or any unified concepts.So we came up with our design pattern. Routing in Android is not an easy thing. It was suggested to divide all entities into 2 levels of abstraction: depending on the framework (platform satellites) and independent entities - routers.
Platform-specific entities implement specific functions, such as, system messages handling, showing of dialogs, routing between activities & fragments.
We implemented base router and 2 satellites out of the box. There are activities and fragments satellites and several following commands.
First of all, you need to attach satellite to router.
private Router router = new BaseRouter();
private Satellite satellite;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
satellite = new ActivitySatellite(this);
router.addSatellite(satellite);
}
- start
- startForResult
- forwardIntent
- finish
- with
- and (Sugar 🍬)
router.pushCommand(start(SecondaryActivity.class));
router.pushCommand(finishThis(and(start(SecondaryActivity.class))));
Bundle args = new Bundle();
args.putInt("args", 1);
router.pushCommand(start(SecondaryActivity.class, with(args)));
- addToBackStack
- and (Sugar 🍬)
- replace
- add
- animate
router.pushCommand(replace(new FirstFragment(), null, and(addToBackStack(null))));
- showToast
router.pushCommand(showToast(Toast.LENGTH_SHORT, "Hello world!"));
Note: You can find all usage examples in app folder.
You can extend your own routing system by one of three ways. The first way is to add new command to existing commands group.
To add command you need to inherit new one from command group.
Example:
public final class Start extends ActivityCommand {
...
}
public class Replace extends FragmentCommand {
...
}
If you need more complex functionality to manipulate command stack you can create your own satellite
To add satellite you need to implement satellite interface
public final class ActivitySatellite implements Satellite {
...
}
Satellite interface
public interface Satellite {
/**
* Get current satellite type.
* @return unique id for satellite group (for example, activity group).
*/
int getType();
/**
* Execute passed command by satellite.
* @param command or command chain which contains navigation info.
*/
void execute(@NonNull Command command);
/**
* Checks whether satellite can handle command or not.
* @param command or command chain which contains navigation info.
* @return true if satellite can handle command else otherwise.
*/
boolean isApplicable(@NonNull Command command);
}
And the last one opportunity to add misc functions to router is to write your own custom router.
To add router you need to implement router interface
public class BaseRouter implements Router {
...
}
Router interface
public interface Router {
void pushCommand(@NonNull Command command);
void addSatellite(@NonNull Satellite satellite);
void removeSatellite(@NonNull Satellite satellite);
}
MIT License
Copyright (c) 2017-present Alexander Dadukin
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.