MoxyX

General

Category
Free
Tag
System
License
MIT License
Registered
Mar 3, 2019
Favorites
1
Link
https://github.com/jordan1997/Moxy
See also
android-hidden-api
ReactiveAirplaneMode
Contacts
android-metadata
Hermes

Additional

Language
Java
Version
v1.6.0-beta (Mar 6, 2019)
Created
Mar 23, 2018
Updated
Mar 6, 2019
Owner
Volodymyr (jordan1997)
Contributors
Konstantin (terrakok)
seven332
SavinMike
senneco
fl1pflops
Andrey Zaiats (A-Zaiats)
xanderblinov
Dmitriy Gorbunov (dmdevgo)
CherryPerry
lion4ik
AlexeyKorshun
ekursakov
v-grishechko
mohaxspb
Volodymyr (jordan1997)
AcoustickSan
rsajob
sbogolepov
Show all (19)19
Activity
Badge
Generate
Download
Source code

Advertisement

MoxyX

We added X to the Moxy for make this library coolest.

Moxy is a library that helps to use MVP pattern when you do the Android Application. _Without problems of lifecycle and boilerplate code!

The main idea of using Moxy:

See what's happening here in the wiki.

Diff between us and root project

  1. We support androidX
  2. We will remove GLOBAL and WEAK preseter type from the library
  3. Starategy which work by tag, will be added to main package.
  4. We will change the template for android studio (and intelij), the templates will create a view interface and activity or fragment into one file, and this file and presenter keep into one package. We will remove template for Java.

Capabilities

Moxy has a few killer features in other ways:

  • Presenter stay alive when Activity recreated(it simplify work with multithreading)
  • Automatically restore all that user see when Activity recreated(including dynamic content is added)
  • Capability to changes of many Views from one Presenter

Sample

View interface

public interface HelloWorldView extends MvpView {
 void showMessage(int message);
}

Presenter

@InjectViewState
public class HelloWorldPresenter extends MvpPresenter<HelloWorldView> {
 public HelloWorldPresenter() {
  getViewState().showMessage(R.string.hello_world);
 }
}

View implementation

public class HelloWorldActivity extends MvpAppCompatActivity implements HelloWorldView {

 @InjectPresenter
 HelloWorldPresenter helloWorldPresenter;

 private TextView helloWorldTextView;

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_hello_world);

  helloWorldTextView = ((TextView) findViewById(R.id.activity_hello_world_text_view_message));
 }

 @Override
 public void showMessage(int message) {
  helloWorldTextView.setText(message);
 }
}

Here you can see "Github" sample application.

Wiki

For all information check Moxy Wiki

Android studio templates

In order to avoid boilerplate code creating for binding activity, fragments and its presentation part, we propose to use Android Studio templates for Moxy.

Templates located in /moxy-templates

Links (Telegram channels from original moxy community)

Telegram channel (en)Telegram channel (ru)ReferencesFAQ



Twitter

For connection with author of this repository use twitter Twitter

Integration

Base modules integration:

dependencies {
  ...
  implementation 'tech.schoolhelper:moxy-x:1.5.7'
  annotationProcessor 'tech.schoolhelper:moxy-x-compiler:1.5.7'
}

For additional base view classes MvpActivity and MvpFragment add this:

dependencies {
  ...
  implementation 'tech.schoolhelper:moxy-x-android:1.5.7'
}

If you are planning to use AppCompat, then you can use MvpAppCompatActivity and MvpAppCompatFragment. Then add this:

dependencies {
  ...
  implementation 'tech.schoolhelper:moxy-x-app-compat:1.5.7'
  implementation 'com.android.support:appcompat-v7:$support_version'
}

If you are planning to use AndroidX, then you can use MvpAppCompatActivity and MvpAppCompatFragment. Then add this:

   ...
   implementation 'tech.schoolhelper:moxy-x-androidx:1.5.7'

Kotlin

If you are using kotlin, use kapt instead of provided/apt dependency type:

apply plugin: 'kotlin-kapt'

dependencies {
  ...
  kapt 'tech.schoolhelper:moxy-x-compiler:1.5.7'
}

ProGuard

MoxyX is completely without reflection! No special ProGuard rules required.

License

The MIT License (MIT)

Copyright (c) 2016 Arello Mobile

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.