Convert Figma logo to code with AI

fossasia logosusi_android

SUSI.AI Android App https://play.google.com/apps/testing/ai.susi

2,424
1,108
2,424
82

Top Related Projects

6,465

⚠️ Fenix (Firefox for Android) moved to a new repository. It is now developed and maintained as part of: https://github.com/mozilla-mobile/firefox-android

3,796

DuckDuckGo Android App

4,494

The most beautiful SMS messenger for Android

Thunderbird for Android – Open Source Email App for Android (fka K-9 Mail)

A private messenger for Android.

Quick Overview

SUSI.AI Android is an open-source personal assistant application for Android devices. It's part of the larger SUSI.AI project, which aims to create an intelligent personal assistant that can be customized and extended by users. The app allows users to interact with SUSI.AI through voice commands, text input, and provides various features like weather updates, general knowledge queries, and device control.

Pros

  • Open-source and customizable, allowing users to contribute and modify the assistant
  • Supports multiple languages, making it accessible to a global audience
  • Integrates with various third-party services and APIs for extended functionality
  • Privacy-focused, with options for local processing and user data control

Cons

  • May have a steeper learning curve compared to commercial alternatives
  • Potentially less polished user interface than some proprietary assistants
  • Relies on community contributions, which may lead to inconsistent feature development
  • Limited ecosystem compared to assistants from major tech companies

Getting Started

To get started with SUSI.AI Android:

  1. Clone the repository:

    git clone https://github.com/fossasia/susi_android.git
    
  2. Open the project in Android Studio.

  3. Build and run the app on your Android device or emulator.

  4. To contribute, fork the repository, make your changes, and submit a pull request.

For more detailed instructions, refer to the project's README and contribution guidelines on the GitHub repository.

Competitor Comparisons

6,465

⚠️ Fenix (Firefox for Android) moved to a new repository. It is now developed and maintained as part of: https://github.com/mozilla-mobile/firefox-android

Pros of Fenix

  • Larger and more active community with frequent updates and contributions
  • More comprehensive feature set, including advanced privacy and security options
  • Better performance optimization for modern Android devices

Cons of Fenix

  • Larger codebase, potentially more complex for new contributors
  • Heavier resource usage due to more advanced features
  • Steeper learning curve for developers unfamiliar with Mozilla's development practices

Code Comparison

Fenix (Kotlin):

class BrowserFragment : BaseBrowserFragment(), UserInteractionHandler {
    override fun onCreateView(
        inflater: LayoutInflater,
        container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View {
        return inflater.inflate(R.layout.fragment_browser, container, false)
    }
}

Susi Android (Java):

public class ChatActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_chat);
    }
}

The code snippets show that Fenix uses Kotlin and follows a more modern Android development approach with fragments, while Susi Android uses Java and relies on traditional activities. Fenix's codebase appears more modular and potentially easier to maintain in the long run.

3,796

DuckDuckGo Android App

Pros of DuckDuckGo Android

  • More active development with frequent updates and commits
  • Larger community support and user base
  • Comprehensive privacy features and tracking protection

Cons of DuckDuckGo Android

  • Less customizable compared to SUSI.AI Android
  • Focused solely on web browsing, lacking AI assistant capabilities
  • Heavier resource usage due to more complex features

Code Comparison

SUSI.AI Android (Java):

public void sendMessage(String query, String actual_query, boolean isHavingLink) {
    DateTimeZone tz = DateTimeZone.forID(PrefManager.getString(Constant.TIMEZONE, "UTC"));
    long timestamp = System.currentTimeMillis();
    realm.beginTransaction();
    ChatMessage chatMessage = realm.createObject(ChatMessage.class);
    chatMessage.setId(timestamp);
    chatMessage.setContent(query);
    chatMessage.setDate(timestamp);
    chatMessage.setIsMine(true);
    chatMessage.setTimeZone(tz.getOffset(timestamp));
    realm.commitTransaction();
}

DuckDuckGo Android (Kotlin):

private fun launchPlayStore() {
    val intent = Intent(Intent.ACTION_VIEW).apply {
        data = Uri.parse("market://details?id=$packageName")
        setPackage("com.android.vending")
    }
    runCatching {
        startActivity(intent)
    }.onFailure {
        Timber.w(it, "Could not launch Play Store")
    }
}

Both repositories demonstrate different coding styles and languages, with SUSI.AI using Java and DuckDuckGo using Kotlin. The SUSI.AI example shows message handling, while the DuckDuckGo snippet illustrates app store navigation.

4,494

The most beautiful SMS messenger for Android

Pros of QKSMS

  • More focused and specialized as an SMS app, potentially offering a better user experience for messaging
  • Larger community with more stars (1.8k vs 778) and forks (506 vs 446), indicating higher popularity
  • More recent activity and updates, suggesting active maintenance

Cons of QKSMS

  • Limited to SMS functionality, while SUSI.AI offers a broader range of AI-powered features
  • Less integration with other services compared to SUSI.AI's ecosystem
  • Smaller number of contributors (37 vs 98), which may impact development speed and diversity of ideas

Code Comparison

QKSMS (Kotlin):

override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
    binding = ComposeActivityBinding.inflate(inflater, container, false)
    return binding.root
}

SUSI.AI (Java):

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
    View rootView = inflater.inflate(R.layout.fragment_chat, container, false);
    ButterKnife.bind(this, rootView);
    return rootView;
}

Both projects use similar patterns for creating views, but QKSMS uses Kotlin and view binding, while SUSI.AI uses Java and ButterKnife for view injection.

Thunderbird for Android – Open Source Email App for Android (fka K-9 Mail)

Pros of Thunderbird

  • More active development with frequent updates and commits
  • Larger community support and user base
  • Comprehensive email management features

Cons of Thunderbird

  • Larger codebase, potentially more complex to contribute to
  • Focused solely on email, less versatile than Susi's AI assistant capabilities
  • Steeper learning curve for new contributors due to project size

Code Comparison

Thunderbird (Kotlin):

class MessageListItem(
    val message: Message,
    val isSelected: Boolean = false,
    val isRead: Boolean = false,
    val hasAttachments: Boolean = false
)

Susi Android (Java):

public class ChatMessage {
    private String content, timeStamp, date;
    private boolean isDate, isMine;
    private int id;
}

The code snippets show different approaches to message handling. Thunderbird uses Kotlin and includes more detailed properties for email-specific features, while Susi Android uses Java with a simpler structure for general chat messages.

Thunderbird's codebase is more extensive and email-focused, reflecting its specialized nature. Susi Android's code is more concise and adaptable to various AI assistant tasks.

Both projects use modern mobile development practices, but Thunderbird's use of Kotlin may offer some advantages in terms of conciseness and null safety.

A private messenger for Android.

Pros of Signal-Android

  • More active development with frequent updates and commits
  • Stronger focus on privacy and security features
  • Larger community and user base, leading to better support and documentation

Cons of Signal-Android

  • More complex codebase, potentially harder for new contributors
  • Less flexibility for customization due to strict security requirements
  • Heavier resource usage compared to the lighter Susi Android app

Code Comparison

Signal-Android (Kotlin):

private fun initializeBackgroundService() {
    val intent = Intent(this, ApplicationContext.getInstance(this).jobManager.requiresBackgroundService()::class.java)
    startService(intent)
}

Susi Android (Java):

private void initializeChatbot() {
    chatPresenter = new ChatPresenter(this);
    chatPresenter.retrieveOldMessages(this);
    chatPresenter.getPermissions();
}

Signal-Android focuses on background services and job management, while Susi Android emphasizes chatbot functionality and user interactions. Signal's code tends to be more security-oriented, while Susi's is geared towards AI assistant features.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

SUSI.AI Android App

Dev CircleCI Master CircleCI Codacy Badge Preview the app Gitter Mailing List Twitter Follow

The main feature of the app is to provide a conversational interface to provide intelligent answers using the loklak/AskSusi infrastructure. The app also offers login functionalities to connect to other services and store personal data. Additionally, the application uses data provided by the user's phone to improve Susi answers. Geolocation information, for example, helps to offer better answers related to questions about "things nearby".

Roadmap

Planned features & enhancements are:

  • Hotword Detection training
  • Full-Screen Voice interaction
  • Feedback for skills.
  • Displaying SUSI skills
  • Susi Smart Speaker Configuration and Control

Communication

Please join our mailing list to discuss questions regarding the project: https://groups.google.com/forum/#!forum/susiai

Our chat channel is on gitter here: https://gitter.im/fossasia/susi_android

Screenshots

Development

A native Android app using both Java and Kotlin for writing code. The answers for user queries comes from SUSI Server which further uses skills defined in SUSI Skill Data.

Android App Development Set up

Please find info about the set up of the Android app in your development environment here.

Libraries used and their documentation

  • Realm Docs
  • Retrofit Docs
  • ButterKnife Docs
  • Espresso Docs
  • Tajchert Waiting Dots Docs
  • Picasso Docs
  • LeakCanary Docs
  • LeonardoCardoso/Android-Link-Preview Docs
  • Gericop/Android-Support-Preference-V7-Fix Docs
  • Snowboy Hotword Detection Docs
  • zagum/SpeechRecognitionView Docs
  • MPAndroidChart Docs
  • Timber Docs
  • Play services authentication Docs

Project Conventions

There are certain conventions we follow in the project, we recommend that you become familiar with these so that the development process is uniform for everyone:

MVP

The project follows Model-View-Presenter design pattern and requires schematic interfaces for each component to be written first as contracts and then implemented.
All the interactions are done using interfaces only. This means any model, view or presenter will only be referenced by its interface. We do so it is easy to mock and test them and there is no discrepancy in the callable methods of the concrete class and the interface.
We realize that MVP is opinionated and there is no strict boundary between the responsibility of each component, but we recommend following this style:

  • View is passive and dumb, there is no logic to be exercised in View, only the ability to show data provided by the presenter through contract is present in the View. This makes it easy to unit test and remove the dependence on Android APIs, thus making the need for instrumentation tests scarce.
  • Presenter is responsible for most of the business logic, manipulation of data and organising it for the view to present. All logic for the app is present here and it is devoid of ANY Android related code, making it 100% unit testable. We have created wrapper around common Android APIs in form of models so that they can be mocked and presenter stays clean. The responsibility of presenter includes the fetching of data from external source, observing changes and providing the view with the latest data. It also needs to handle all View interactions that require any logic, such as UI triggers causing complex interactions. Notable exception for this is launching of an Activity on click of a button. There is no logic required in the action and is completely dependent on Android APIs. Lastly, presenter should always clean up after the view is detached to prevent memory leaks.
  • Model has the responsibility to hold the data, load it intelligently from appropriate source, be it disk or network, monitor the changes and notify presenter about those, be self sufficient; meaning to update data accordingly as needed without any external trigger (saving the data in disk after updating from network and providing the saved data from next time on), but be configurable (presenter may be able to ask for fresh data from network). The presenter should not worry about the data loading and syncing conditions (like network connectivity, failed update, scheduling jobs, etc) as it is the job of model itself.

Use of Kotlin

Around 50% of the App is written in Kotlin. Kotlin is a very similar language to Java but with much more advantages than Java. It is easy to adapt and learn. So, you need not worry if you don't have prior experience with it. Follow these docs for syntax reference. The latest Android Canary Version has in built support for Kotlin but if you don't have the Canary version, you can add Kotlin Plugin in your Android Studio. Follow this link to see how to do that.

Project Structure

Generally, projects are created using package by layer approach where packages are names by layers like ui, activity, fragment, etc but it quickly becomes unscalable in large projects where a large number of unrelated classes are crammed in one layer and it becomes difficult to navigate through them.
Instead, we follow package by feature, which at the cost of flatness of our project, provides us packages of isolated functioning related classes which are likely to be a complete self-sufficient component of the application. Each package contains all related classes of view, presenter, their implementations like Activities and Fragments.
A notable exception to this is the helper module and data classes like Models and Repositories as they are used in a cross component way.
Note: The interface contract for Presenter and View is present in contract package in each module

Separation of concerns

Lastly, each class should only perform one task, do it well, and be unit tested for it. For example, if a presenter is doing more than it should, i.e., parsing dates or implementing search logic, better move it in its own class. There can be exceptions to this practice, but if the functionality can be generalised and reused, it should most definitely be transferred in its own class and unit tested.

Contributions Best Practices

For first time Contributor

First time contributors can read CONTRIBUTING.md file for help regarding creating issues and sending pull requests.

Branch Policy

We have the following branches

  • development All development goes on in this branch. If you're making a contribution, you are supposed to make a pull request to development. PRs to development branch must pass a build check and a unit-test check on Circle CI.
  • master This contains shipped code. After significant features/bugfixes are accumulated on development, we make a version update and make a release.
    • Please Note that :-

      Each push to master branch automatically publishes the application to Play Store as an Alpha Release. Thus, on each merge into master, the versionCode and versionName MUST be changed accordingly in app/build.gradle

    • versionCode : Integer : To be monotonically incremented with each merge. Failure to do so will lead to publishing error, and thus is a crucial step before any merge

    • versionName : String : User visible version of the app. To be changed following semantic versioning

  • apk This branch contains many apk files, that are automatically generated on the merged pull request a) debug apk for Fdroid and Playstore b) release apk for Fdroid and Playstore
    • There are multiple files in the apk branch of the project, this branch consists of all the APK files and other files that are relevant when an APK is generated.
    • Once a pull request is merged, the previous APK branch is deleted and a new APK branch is created.
    • If a PR is merged in development branch then the new APKs for the development branch are generated whereas the APKs corresponding to the master branch are not regenerated and simply the previously generated files are added.

Code practices

Please help us follow the best practice to make it easy for the reviewer as well as the contributor. We want to focus on the code quality more than on managing pull request ethics.

  • Single commit per pull request

  • For writing commit messages please read the COMMITSTYLE carefully. Kindly adhere to the guidelines.

  • Follow uniform design practices. The design language must be consistent throughout the app.

  • The pull request will not get merged until and unless the commits are squashed. In case there are multiple commits on the PR, the commit author needs to squash them and not the maintainers cherrypicking and merging squashes.

  • If the PR is related to any front end change, please attach relevant screenshots in the pull request description.

  • Before you join development, please set up the project on your local machine, run it and go through the application completely. Press on any button you can find and see where it leads to. Explore. (Don't worry ... Nothing will happen to the app or to you due to the exploring :wink: Only thing that will happen is, you'll be more familiar with what is where and might even get some cool ideas on how to improve various aspects of the app.)

  • If you would like to work on an issue, drop in a comment at the issue. If it is already assigned to someone, but there is no sign of any work being done, please free to drop in a comment so that the issue can be assigned to you if the previous assignee has dropped it entirely.

For Developers: Adding Fabric API KEY

  1. Go to AndroidManifest.xml Replace the fabric_api_key with the Real Fabric API Key by adding :

    <meta-data android:name="io.fabric.ApiKey" android:value="fabric_api_key" />
    
  2. Open the app/fabric.properties: Replace the fabric_api_key with your actual Fabric API Secret.

  3. Open MainApplication.java, a) After adding the API KEYS and API Secret uncomment the line : Fabric.with(this, new Crashlytics())

    b) Add imports : import com.crashlytics.android.Crashlytics; import io.fabric.sdk.android.Fabric;

  4. Uncomment the line in the app/gradle:

    apply plugin: 'io.fabric'
    

For Developers: Updating the URL of the smart speaker

  1. Go to build.gradle file and the URL of the smart speaker local server under the name of SPEAKER_BASE_URL as a buildConfigField can be updated there under the buildtypes section in both the release and debug blocks :
    buildConfigField "String", "SPEAKER_BASE_URL", '"http://10.0.0.1:5000"'	
    
    

For Developers: Adding the YouTube API key

Go to AndroidManifest.xml and replace the ${YOUTUBE_API_KEY} with the real youtube API Key by adding :

<meta-data
android:name="com.google.android.youtube.API_KEY"
android:value="${YOUTUBE_API_KEY}" />

For Testers: Testing the App

If you are a tester and want to test the app, you have two ways to do that:

  1. Installing APK on your device: You can get debug APK as well as Release APK in apk branch of the repository. After each PR merge, both the APKs are automatically updated. So, just download the APK you want and install it on your device. The APKs will always be the latest one.
  2. Testing on appetize.io: If you don't want to download the APKs, you can simply go on this link and use the App on an online simulator. You will always find the latest version of App on that link because it is updated after each PR merge.

License

This project is currently licensed under the Apache License Version 2.0. A copy of LICENSE.md should be present along with the source code. To obtain the software under a different license, please contact FOSSASIA.