Skip to content

This Android project is a simple application that displays a list of postal shipments and their status, reading from a static JSON file

Notifications You must be signed in to change notification settings

hexfa/InpostApp

Repository files navigation

N|Solid hexfa

N|Solid Inpost Android App



Details 📜

This Android project is a simple and lightweight application that allows users to view a list of postal shipments along with their respective status. The application reads the shipment data from a static JSON file and presents it to the users. With this app, users can easily track and monitor the status of their shipments.

The user interface of the app is designed to be simple and efficient, enabling users to effortlessly browse through the list of shipments and check their status. Additionally, users will be able to view the status of multiple shipments simultaneously, staying informed about the progress and latest updates of each shipment. The app aims to provide a user-friendly and cost-effective solution for users to conveniently track their shipments.

Features 🚩

  • Shipment list
  • Parcel more details
  • Archivement
  • Archive list
  • Rotatable
  • Highlight parcels
  • Sorting by: Status, PickupDate, ExpireDate, StoredDate, Number
  • Pull to refresh
  • Local database
  • Simple dark mode style
  • UnitTest
  • Modern strcuture
  • Modern libraries

Lets Start 🕺

Clone this repository and import it into your Android IDE

https://github.com/hexfa/InpostApp.git

Resources ℹ️

  • Documents

    For looking at the last document code version of this project, you can generate it by Dokka section.

    Also, you can see the first document version of the project on this link Documentation

  • Remote API

    This app doesn't have any remote API
  • Structure

    Model-View-ViewModel (MVVM)

Configuration ⚙️

  • Dokka

    • I recommend Html document type

    • I recommend to use the JAVA JDK 18 and set it in your JAVA_HOME environment. after putting it in the system needs a restart

      • Dokka terminal commands
        Type Syntax
        Html ./gradlew.bat dokkaHtml
        Java doc ./gradlew.bat dokkaJavadoc
        Gfm ./gradlew.bat dokkaGfm
      • Output Location

        app -> build -> dokka

Keystore 🗝️

  • Location of the keystore is in root directory(inpost.jks).
  • Alias= inpost
  • Key password= inpost2023
  • Key store password= inpost2023

Preview 📱

Images 🖼️

Inpost App hexfa Inpost App amir

Video 📽️

Inpost App dehdarian fallah

Built With 🛠

  • Kotlin: A modern and concise programming language for Android development.

  • Coroutine: A Kotlin library that simplifies asynchronous programming and enables the writing of asynchronous code in a sequential manner.

  • Hilt: A dependency injection library for Android that simplifies the process of injecting dependencies into Android components.

  • LiveData: A lifecycle-aware data holder class in Android Jetpack that allows data to be observed for changes and provides automatic updates to the UI.

  • Dokka: A documentation generation tool for Kotlin and Java that generates API documentation in various formats, including HTML and Markdown.

  • Junit: A popular unit testing framework for Java and Kotlin that provides a set of annotations and assertions for writing automated tests.

  • Mockito: A mocking framework for unit testing in Java and Kotlin that allows the creation of mock objects to simulate dependencies and behavior during testing.

  • Room: An SQLite database library for Android that provides an abstraction layer over SQLite and enables efficient database operations using annotations and generated code.

  • Moshi: A modern JSON parsing and serialization library for Kotlin and Java that makes it easy to convert JSON data to Kotlin/Java objects and vice versa.

  • Gson: Gson is a powerful JSON library that simplifies JSON parsing and serialization in Android through a flexible reflection-based approach.

    💡 Note 💡

    Using both Moshi and Gson in an Android project offers the benefits of efficient code generation, support for Kotlin-specific features, and flexibility in handling different JSON structures and external dependencies. This ensures compatibility with a wider range of libraries and APIs, enhancing the overall flexibility and functionality of the application. Additionally, having both libraries available allows developers to choose the most appropriate one for each scenario, optimizing performance and convenience during JSON parsing and serialization tasks.

    💡 Advice 💡

    In some cases, it may even be beneficial to use both LiveData and Flow together. You can use Flow for data processing and transformation in the background, and then use LiveData to observe and update UI components based on the transformed data.

About

This Android project is a simple application that displays a list of postal shipments and their status, reading from a static JSON file

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages