A reference implementation of Mifos platform wallet and payment capabilities
Go to file
Sk Niyaj Ali 3782fd0d6f
Merge kmm-impl into dev (#1813)
* Feat: KMP Library Setup (#1766)

* Migrating from hilt to koin (This) (#1764)

* Migrating from hilt to koin

* Fixed Instance creation error

* refactor: Removed Hilt and migrated to Koin

This commit removes Hilt and migrates the project to Koin for dependency injection.

The following
 changes were made:

- Removed the `AndroidHiltConventionPlugin`.
- Added the `AndroidKoinConventionPlugin`.
- Updated dependencies to use Koin.
- Updated KSP configuration for Koin.
- Updated feature modules to use Koin.
- Updated common modules to use Koin
.
- Removed Hilt annotations and replaced them with Koin annotations.
- Updated ViewModels to use Koin for dependency injection.
- Updated modules to use Koin for dependency injection.

* Formatted Dependencies

* migrating from hilt to koin clean up commit

* Revert "migrating from hilt to koin clean up commit"

This reverts commit bb63058e49.

---------

Co-authored-by: Sk Niyaj Ali <niyaj639@gmail.com>

* Feat: KMP Library Setup

---------

Co-authored-by: Nagarjuna <99315689+Nagarjuna0033@users.noreply.github.com>

* Feat: [:core:model] - Migrated to KMM (#1770)

* Feat: [:core:common] KMP Migration (#1768)

* Feat: [:core:common] KMP Migration

* Updated Usage Declaration

* Feat: [:core:datastore] - Migrated to KMP (#1769)

* Feat: [:core:network] - Migrated to KMP (#1772)

* Feat: [:core:network] - Migrated to KMP

* Feat: [:core:data] - Migrated to KMP Library

* Feat: [:core:designsystem] - Migrated to KMP with CMP Library (#1774)

* Feat: [:core:ui] - Migrated to KMP with CMP Library (#1775)

* Feat: [:feature:auth] - Migrated to Kotlin Multiplatform (#1782)

* Feat: [:feature:auth] - Migrated to Kotlin Multiplatform

* Added Support For Web

* Feat: Migrated Passcode Module to KMP (#1783)

* Feat: Migrated Home Module to KMP (#1784)

* Feat: Migrated Edit Password Module to KMP (#1787)

* Feat: Migrated FAQ module to kmp (#1786)

* Feat: Migrated Settings Module to KMP (#1785)

* Feat: Migrated Profile Module to KMP (#1788)

* Feat: Migrated History Module to KMP (#1790)

* Feat: Migrated Payments Module to KMP (#1791)

* Feat: Migrated Finance Module to KMP (#1792)

* Feat: Migrated Accounts Module to KMP (#1793)

* Feat: Migrated Accounts Module to KMP

* Updated README.md

* Update README.md

* Feat: Migrated Invoices Module to KMP (#1794)

* Feat: Migrated KYC Module to KMP (#1798)

* Migrated Notification Module to KMP (#1799)

* Feat: Migrated KYC Module to KMP

* Feat: Migrated Notification Module to KMP

* Feat: Migrated Saved Card Module to KMP (#1800)

* Feat: Migrated Receipt Module to KMP (#1801)

* fix: Ios Build (#1802)

* Feat: Migrated SI Module to KMP (#1803)

* Feat: Migrated Request Money Module to KMP (#1807)

* Feat: Migrated Send Money Module to KMP (#1808)

* Feat: Migrated Make Transfer Module to KMP (#1809)

* Feat: Migrated QR Module to KMP (#1810)

* Feat: Migrated UPI Setup Module to KMP (#1811)

* Feat: Final Clean-up For KMP (#1812)

* Feat: Final Cleanup For KMP

* Update README.md

* Update EditPassword README.md

* Update FAQ README.md

* Update Finance README.md

* Update History README.md

* Update Home README.md

* Update Invoice README.md

* Update KYC README.md

* Update Make Transfer README.md

* Update Notification README.md

* Update Payments README.md

* Update Profile README.md

* Update Saved Card README.md

* Update Send Money README.md

* Update Settings README.md

* Update SI README.md

* Migrating from hilt to koin (This) (#1764)

* Migrating from hilt to koin

* Fixed Instance creation error

* refactor: Removed Hilt and migrated to Koin

This commit removes Hilt and migrates the project to Koin for dependency injection.

The following
 changes were made:

- Removed the `AndroidHiltConventionPlugin`.
- Added the `AndroidKoinConventionPlugin`.
- Updated dependencies to use Koin.
- Updated KSP configuration for Koin.
- Updated feature modules to use Koin.
- Updated common modules to use Koin
.
- Removed Hilt annotations and replaced them with Koin annotations.
- Updated ViewModels to use Koin for dependency injection.
- Updated modules to use Koin for dependency injection.

* Formatted Dependencies

* migrating from hilt to koin clean up commit

* Revert "migrating from hilt to koin clean up commit"

This reverts commit bb63058e49.

---------

Co-authored-by: Sk Niyaj Ali <niyaj639@gmail.com>

* Profile UI redesign  (#1767)

* Refactor Profile UI

* Fixed Build Issue

* Profile UI Bug Fix & Improvement

* added placeholder for  when uri is null

cleanup

fix spotless test failure

* Fix - CI Build Issue

---------

Co-authored-by: Sk Niyaj Ali <niyaj639@gmail.com>

* refactor: Redesign payment screen (#1773)

* refactor: Redesign payment screen

* resolved detekt error

* refactor : changed current theme instead of using NewUi

* resolved spotless errors

* refactor: Redesign finance screen (#1777)

* refactor: Redesign payment screen

* resolved detekt error

* refactor : changed current theme instead of using NewUi

* resolved spotless errors

* refactor: Redesign finance screen UI

* resolved spotless errors

* resolved conflicts

* changed structure of accounts screen

* refactor padding values in finance screen

* fix: dark theme colors (#1789)

* fix: dark theme colors

* fixed edit icon tint

* Fix invoice api (#1797)

* Redesign requeset screen UI

* fix MissingKoinDefinitionException

* removed comments and fixed share qr code bug

* fix: Invoice APIs

* update readme file (#1804)

* update readme file

* update readme file

* update readme file with how to contribute

* Add branch policy (#1805)

* update readme file

* update readme file

* update readme file with how to contribute

* update readme file with how to contribute

* update readme file with branch Policy

---------

Co-authored-by: Rajan Maurya <therajanmaurya@users.noreply.github.com>

* Migrating from hilt to koin (This) (#1764)

* Migrating from hilt to koin

* Fixed Instance creation error

* refactor: Removed Hilt and migrated to Koin

This commit removes Hilt and migrates the project to Koin for dependency injection.

The following
 changes were made:

- Removed the `AndroidHiltConventionPlugin`.
- Added the `AndroidKoinConventionPlugin`.
- Updated dependencies to use Koin.
- Updated KSP configuration for Koin.
- Updated feature modules to use Koin.
- Updated common modules to use Koin
.
- Removed Hilt annotations and replaced them with Koin annotations.
- Updated ViewModels to use Koin for dependency injection.
- Updated modules to use Koin for dependency injection.

* Formatted Dependencies

* migrating from hilt to koin clean up commit

* Revert "migrating from hilt to koin clean up commit"

This reverts commit bb63058e49.

---------

Co-authored-by: Sk Niyaj Ali <niyaj639@gmail.com>

* Merge kmm-impl to dev

---------

Co-authored-by: Nagarjuna <99315689+Nagarjuna0033@users.noreply.github.com>
Co-authored-by: Rajan Maurya <therajanmaurya@users.noreply.github.com>
Co-authored-by: Pronay Sarker <pronaycoding@gmail.com>
Co-authored-by: kapmaurya <152150716+kapmaurya@users.noreply.github.com>
2024-11-06 10:22:46 -05:00
.github Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
.run Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
build-logic Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
config Refactor - [:core:mifospay] Applied Spotless & Detekt Compose Rules (#1748) 2024-08-16 11:11:28 -04:00
core Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
docs/images/graphs fix: generate README and dep graph 2024-05-20 13:30:11 -04:00
fastlane Configured Fastlane & CI Workflow for publishing app to Play Store & GitHub (#1761) 2024-09-06 06:19:46 -04:00
feature Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
gradle Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
kotlin-js-store Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
libs/mifos-passcode Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
mifospay-android Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
mifospay-desktop Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
mifospay-ios Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
mifospay-shared Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
mifospay-web Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
scripts Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
spotless Refactor - [:feature:make-transfer] Applied Spotless & Detekt Compose Rules (#1724) 2024-08-11 13:36:53 -04:00
.editorconfig Refactor - [:feature:make-transfer] Applied Spotless & Detekt Compose Rules (#1724) 2024-08-11 13:36:53 -04:00
.gitignore Configured Fastlane & CI Workflow for publishing app to Play Store & GitHub (#1761) 2024-09-06 06:19:46 -04:00
build.gradle.kts Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
ci-prepush.bat Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
ci-prepush.sh Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
compose_compiler_config.conf fix: implement material theme 2024-03-24 19:14:21 -04:00
Dockerfile fix: update Dockerfile 2024-01-20 17:52:03 -05:00
Gemfile Configured Fastlane & CI Workflow for publishing app to Play Store & GitHub (#1761) 2024-09-06 06:19:46 -04:00
Gemfile.lock Configured Fastlane & CI Workflow for publishing app to Play Store & GitHub (#1761) 2024-09-06 06:19:46 -04:00
generateModuleGraphs.sh fix: generate README and dep graph 2024-05-20 13:30:11 -04:00
gradle.properties Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
gradlew initial mvp-clean project 2017-06-16 22:53:21 +05:30
gradlew.bat initial mvp-clean project 2017-06-16 22:53:21 +05:30
README.md Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00
Screenshot.md fixed screenshot orientation error in mobile phone 2020-06-06 18:26:06 +05:30
settings.gradle.kts Merge kmm-impl into dev (#1813) 2024-11-06 10:22:46 -05:00

Mobile Wallet

Mobile Wallet is an Android-based framework for mobile wallets based on top of Fineract. The app follows clean architecture and contains a core library module that can be used as a dependency in any other wallet based project. It is developed at MIFOS together with a global community.

Run the project

Screenshot 2024-10-19 005524

  • To run the android-app select the mifospay-android run configuration and click run.
  • To run the desktop-app select the mifospay-desktop run configuration and click run.
  • To run the web-app-js select the mifospay-web-js run configuration and click run.

KMP Status for modules

Module Progress Desktop supported Android supported iOS supported Web supported(JS) Web supported(WASM-JS)
mifospay-android Done
mifospay-desktop Done
mifospay-web Done
mifospay-ios NO OP
:core:analytics Done ✔️
:core:common Done
:core:data Done
:core:datastore Done
:core:datastore-proto Done
:core:designsystem Done
:core:domain Done
:core:model Done
:core:network Done
:core:ui Done
:feature:auth Done
:feature:editpassword Done
:feature:faq Done
:feature:history Done
:feature:home Done
:feature:profile Done
:feature:settings Done
:feature:payments Done
:feature:finance Done
:feature:account Done
:feature:invoices Done
:feature:kyc Done
:feature:make-transfer Done
:feature:merchants Done
:feature:notification Done
:feature:qr Done
:feature:receipt Done
:feature:request-money Done
:feature:saved-cards Done
:feature:send-money Done
:feature:standing-instruction Done
:feature:upi-setup Done

: Functioning properly
: Not yet tested, but expected to work
✔️: Successfully compiled
: Not functioning, requires further attention

Notice

⚠️ We are fully committed to implement Jetpack Compose and moving ourself to support kotlin multi-platform. If you are sending any PR regarding XML changes we will not consider at this moment but converting XML to jetpack compose are most welcome. If you sending any PR regarding logical changes in Activity/Fragment you are most welcome.

Development Chat
Mobile-Wallet CI[Master/Dev] Join the chat at https://mifos.slack.com/

Join Us on Slack

Mifos boasts an active and vibrant contributor community, Please join us on slack. Once you've joined the mifos slack community, please join the #mobile-wallet channel to engage with mobile-wallet development. If you encounter any difficulties joining our Slack channel, please don't hesitate to open an issue. This will allow us to assist you promptly or send you an invitation.

How to Contribute

Thank you for your interest in contributing to the Mobile Wallet project by Mifos! We welcome all contributions and encourage you to follow these guidelines to ensure a smooth and efficient collaboration process.

The issues should be raised via the GitHub issue tracker. For Issue tracker guidelines please click here. All fixes should be proposed via pull requests. For pull request guidelines please click here. For commit style guidelines please click here.

Branch Policy

We have the following branches :

  • dev All the contributions should be pushed to this branch. If you're making a contribution, you are supposed to make a pull request to dev. Please make sure it passes a build check on Travis.

    It is advisable to clone only the development branch using the following command:

    git clone -b <branch> <remote_repo>
    

    With Git 1.7.10 and later, add --single-branch to prevent fetching of all branches. Example, with development branch:

    git clone -b dev --single-branch https://github.com/username/mobile-wallet.git`
    
  • master The master branch contains all the stable and bug-free working code. The development branch once complete will be merged with this branch.

Demo credentials

Fineract Instance: demo.mifos.io

Username: venus

Password: Venus2023#

Development Setup

Before you begin, you should have already downloaded the Android Studio SDK and set it up correctly. You can find a guide on how to do this here: Setting up Android Studio.

  1. Fork the Git Repository

    Forking the repository is the first step to start contributing. Click on the "Fork" button in the top right corner of the Mobile Wallet (Mifos Pay) repository to create your own fork.

    image

    Forking creates a copy of the project under your GitHub account. This enables you to work on changes without affecting the original repository directly.

  2. Clone the Forked Repository

    Once you have forked the repository, you need to clone it to your local development environment. Open a terminal or Git Bash and use the following command:

    git clone https://github.com/yourUsername/mobile-wallet.git
    

    Replace yourUsername with your actual GitHub username. Cloning creates a local copy of the repository on your machine, allowing you to make changes and contributions.

  3. Working Locally on Your Cloned Repository

    After cloning, navigate to the project directory using the terminal or Git Bash.

    Before making any changes, create a new branch dedicated to the feature or bug fix you'll be working on:

    git checkout -b "new-branch-name"
    

    Ensure that new-branch-name reflects the purpose of your changes (e.g., add-payment-feature or fix-bug-123).

    Make the necessary changes to the files to address the issue you're working on. Once you're done, you will be ready to proceed with verifying and committing your changes.

  4. Perform a Gradle Check

All your pull requests must pass the CI build only then, it will be allowed to merge. Sometimes, when the build doesn't pass you can use these commands in your local terminal and check for the errors,

We've commited to use Material3 design in our project. And added lint check for not to use any M2 libraries in our project.
And when adding new library, please make sure to follow the naming convention and place in sequential order(A->Z).

In MacOS, Windows or Linux, you should run the following commands before opening a PR, and make sure to pass all the commands:

In order to enhance our development process, we have implemented Git hooks in our project. To install these hooks locally, simply run the command ./gradlew installGitHooks. This will ensure that the Git hooks are installed on your local machine.

  • ./gradlew check -p build-logic this checks build-logic configured properly.
  • ./gradlew spotlessApply --no-configuration-cache an check and apply formatting to any file.
  • ./gradlew dependencyGuardBaseline to generate dependency-guard baseline.
  • ./gradlew detekt to check detekt error.
  • ./gradlew testDemoDebug :lint:test :mifospay:lintProdRelease :lint:lint to check lint and test error.
  • ./gradlew build to build the project.
  • ./gradlew updateProdReleaseBadging to update the badging for the project.

Or Run the ci-prebuild.sh or ci-prebuild.bat script to run all the above commands in one go.

Committing Your Changes

When you've finished making your changes and have tested them locally, it's time to commit your work:

  1. Stage Changes

    Use the following command to stage all changes:

    git add .
    

    This adds all modified and new files to the staging area, preparing them for the commit.

  2. Commit Changes

    Commit your changes with a meaningful commit message that describes the purpose of your changes:

    git commit -m "Your commit message goes here"
    

    A good commit message is concise and provides enough context about the changes made. Mifos follows its own commit style guidelines that you must follow. Learn more about it here.

  3. Push Changes

    Push your changes to your forked repository on GitHub:

    git push origin new-branch-name
    

    Replace new-branch-name with the name of the branch you created earlier.

Making a Pull Request

Once your changes are pushed to your forked repository, you can initiate a pull request to merge your changes into the main project:

  1. Navigate to the Mobile Wallet (Mifos Pay) repository on GitHub.
  2. Click on the "Pull Requests" tab and then click "New Pull Request."

image

  1. Ensure the base repository is set to "openMF/mobile-wallet" and the base branch is the main development branch dev.
  2. Set the compare repository to your forked repository and the compare branch to the branch you just created with your changes (e.g., in my case, the head repository was set to “rchtgpt/mobile-wallet” and the comparison branch was kotlin-migration-common.
  3. Fill out the pull request template, providing a clear description of your changes, why they are necessary, and any relevant information for the reviewers.
  4. Click "Create Pull Request" to submit your changes for review.

Squashing Your Commits

It is common for pull requests to undergo multiple rounds of review before being merged. To keep the Git history clean and organized, you should always squash your commits before finalizing the merge. Here's how you can do it:

  1. Squash your commits:

    git rebase -i HEAD~x
    

    Replace x with the number of commits you want to squash. An interactive rebase will open, allowing you to choose how to combine the commits. Change pick to squash (or simply s) for all but the topmost commit. Save and exit the editor.

  2. Amend the commit message if needed.

    git commit --amend
    
  3. Force push the changes to your forked repository:

    git push --force origin your-branch-name
    

    Please note that force pushing rewrites the Git history, so use it with caution.

Solving Merge Conflicts

In some cases, your pull request might encounter merge conflicts when the changes cannot be automatically merged with the main branch. To resolve merge conflicts:

  1. Update your local branch with the latest changes from the main repository:

    git fetch upstream
    git checkout your-branch-name
    git rebase upstream/master
    
  2. Git will pause when encountering conflicts. Open the affected files, resolve the conflicts manually, and save the changes.

  3. After resolving all conflicts, stage the changes and continue with the rebase:

    git add .
    git rebase --continue
    
  4. Finally, force push the changes to your forked repository:

    git push --force origin your-branch-name
    

Your pull request will be updated with the resolved conflicts, and the reviewers can proceed with the review process. Again, dont forget to squash your commits.

Conclusion

By following these contribution guidelines, you're all set to start contributing to the Mobile Wallet (Mifos Pay) project. We appreciate your efforts and look forward to your valuable contributions. Happy coding!

Instructions to get the latest APK

To get the latest apk fom the Github actions artifacts, follow these steps:

  1. Navigate to the Actions tab of this repository.
  2. Click the latest workflow from the workflows list.
  3. Scroll down to the Artifacts section and click the mobile-wallet hyperlink.
  4. After successful download, extract the zip file to your preferred location.

Wiki

https://github.com/openMF/mobile-wallet/wiki

Screenshots

Click here for more screenshots

Contributors

Special thanks to the incredible code contributors who continue to drive this project forward.