Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/MahmoudMabrok/QuranyApp

Open Source HolyQuran app that provide Read, Listen, Tafseer, Test all of them and app is very small size.
https://github.com/MahmoudMabrok/QuranyApp

android quran quran-json quran-offline

Last synced: about 2 months ago
JSON representation

Open Source HolyQuran app that provide Read, Listen, Tafseer, Test all of them and app is very small size.

Awesome Lists containing this project

README

        

# QuranyApp

[![Hits-of-Code](https://hitsofcode.com/github/MahmoudMabrok/QuranyApp?branch=master)](https://hitsofcode.com/github/MahmoudMabrok/QuranyApp/view?branch=master)
[![Codacy Badge](https://api.codacy.com/project/badge/Grade/f9f42c68a0764798869e714a215990cf)](https://app.codacy.com/manual/MahmoudMabrok/QuranyApp?utm_source=github.com&utm_medium=referral&utm_content=MahmoudMabrok/QuranyApp&utm_campaign=Badge_Grade_Dashboard)
[![HitCount](http://hits.dwyl.com/mahmoudmabrok/QuranyApp.svg)](http://hits.dwyl.com/mahmoudmabrok/QuranyApp)
[![GitHub Issues](https://img.shields.io/github/issues/MahmoudMabrok/QuranyApp?style=flat-square)](https://github.com/MahmoudMabrok/QuranyApp/issues)
[![GitHub license](https://img.shields.io/github/license/MahmoudMabrok/QuranyApp)](https://github.com/MahmoudMabrok/QuranyApp/blob/master/LICENSE)



Open Source HolyQuran app that provide Read, Listen, Tafseer, Test all of them and app is very small size

- [Google Play Link ](https://play.google.com/store/apps/details?id=education.mahmoud.quranyapp)
- [F-Droid link](https://apt.izzysoft.de/fdroid/index/apk/education.mahmoud.quranyapp)
- App Reviews
- [Youtube Playsit, Journey with App](https://www.youtube.com/watch?v=L4ElhxFyjKA&list=PL7ZA5t6QDessHFv0JplnjqyCb066QCIyc).
- [Versions Demos](https://www.youtube.com/watch?v=BrAeS9-woW0&list=PL7ZA5t6QDesvQGUUa0NxfAog0GwYc0g7T).
- apk
- [latest](https://github.com/MahmoudMabrok/QuranyApp/releases/tag/2.6)
- [My Journey to build App in Arabic](https://www.linkedin.com/pulse/%D8%B1%D8%AD%D9%84%D8%AA%D9%89-%D9%84%D8%A8%D9%86%D8%A7%D8%A1-%D8%AA%D8%B7%D8%A8%D9%8A%D9%82-%D8%A7%D9%84%D9%82%D8%B1%D8%A7%D9%86-%D8%A7%D9%84%D9%83%D8%B1%D9%8A%D9%85-mahmoud-mabrouk-fouad/)
- Last Version with Java [Branch](https://github.com/MahmoudMabrok/QuranyApp/tree/java_last_version)
# Screens







# Note : App is being refactored into Kotlin (Reach now MVP stage from app with Kotlin)

# Features[of full App]
- Go to specific sura by Scrolling and click.
- Go to specific sura by its Num.
- Go to specific sura by its Name.
- Go to Specific Juz
- Go to last Read Position.
- Search for words or complete ayah.
- Download and Listen to ayahs
- Repeat each ayas and repeat whole listening
- Tafseer
- Points for Tasmee3
- can report a bug, chat with app developer powered by InstaBug - explaned in demo video - (Not Available now).
- ReadLog that store pages user read.
- Continue reading when open app.
- App is Full Quran and Tafseer.

# Challenges
- **Data**
first one was data, how to get data, first i found images of quran and build app using it but app size is too larg so i searched for text of quran i have found XML version of quran but i prefere JSON over xml then i got JSON version of quran and built 1.0 version of app.
- **Last Read Feature**
its a good feature to save last position of read automatically I have faced problem with get scroll Position but finally got it using ``` scrollView.getScrollY(); ``` and save it in sharedPreference, and scroll back using ``` scrollView.smoothScrollTo(0, scroll); ```

- **Improve Performance**
last method app load data from JSON and parse it with every open to **sura** so solution was use of db, i have used Room and build entities, Dao, and Database.

- **Search**
Search is fundamental feature of any Qurany App so I wrote Query to search in Ayahs but faced problem that Quran is dialacted(Tashkill - symbols) which make search impossible so I have searched and get a clean Version and add it beside last one (each ayah has two version one for display and other to search), data was XML from [Tanzil](http://tanzil.net/download) and use online converter to convert from XML to JSON but file was not as standard of JSON so I have fixed it.

- **Listening**
Download audio have two ways first download whole sura or download seperate ayahs, i have used seperate ayahs to enable feature of listen to specific ayahs. I download audio in storage then store path into database to be used by medialPlayer.

- **Automatice Scroll down**
was good feature but challegable I found a way for that by using **TimerTask** its job to scroll scrollView down by a constant num, but how to change rate with response to use? I create seekbar and after each change i make new Task but not this way has conflicts so i declare *attribute* that changed by rate from user and used by **timertask**

- **App Not Working with Android 8**
there were a problem with downloading audio on Android 8, I found that we must allow traffic
*solution*
at Manifiest
``` XML

```
- **Unrelated histories Unable to merge**
I have tried to make repo clonable and run without problem but i lost all **63 commit**.
Alhumdllah now developers can **clone & fork & pull** and help us to develop app.

- **Update UI after finish downloading**
after returning from download activity it is good to load data, I have tried play with lifecycle but not work.
I solved it using a tricky solution

``` java
@Override
protected void onResume() {
super.onResume();
// used to update UI
int id = navigation.getSelectedItemId();
navigation.setSelectedItemId(id); // here fragment will be opened with new Data
}
```

- **Display HizbQurater**
I created a function to count and display hizbQuarter info but faced challenge of determine the **first** and **right time** to display it.
so it made a **SQL Query** to get startIndex of pages that contain *first HizbQuarter*.

- **Android Design Library not working**
can not resolve design library so that BottomNavigation and other component not work. After 3 days from solving errors and applying stackoverflow solutions finally solved it by migrating to androidX and solve some third party library configuration.

- **Bad Experience with Toasts**
toasts was shown one after other and conflict user so solution was to check first if toast is shown cancel it then show new one.
``` java
Toast toast ;
private void showMessage(String message) {
if (toast != null){
toast.cancel();
}
toast = Toast.makeText(this , message, Toast.LENGTH_SHORT);
toast.show();

}
```

## Mistakes & Learn

- The app have crashed on real device but app work correctly on emulator so I used a **crashReporter library** and it generates a report after check I found problem was with **primaryColor** that it has a **alpha value** so I removed alpha and app work correctly.

- got error when I built release app after use **retrofit** so I added some rules for **proguard**

```
# Retrofit does reflection on generic parameters. InnerClasses is required to use Signature and
# EnclosingMethod is required to use InnerClasses.
-keepattributes Signature, InnerClasses, EnclosingMethod
# Retain service method parameters when optimizing.
-keepclassmembers,allowshrinking,allowobfuscation interface * {
@retrofit2.http.* ;
}
# Ignore annotation used for build tooling.
-dontwarn org.codehaus.mojo.animal_sniffer.IgnoreJRERequirement
# Ignore JSR 305 annotations for embedding nullability information.
-dontwarn javax.annotation.**
# Guarded by a NoClassDefFoundError try/catch and only used when on the classpath.
-dontwarn kotlin.Unit

```

- *baseUrl* of **retrofit** must end with /

- betwenen has upper bound **included** so if we want from 1 to 10 SQL will be between 1 and 10.

- while creating custome dialog I want to remove title so I use ``dialog.requestWindowFeature`` but
it was called after ``dialoge.setContentView()``, it is error to call it after `setContentView`.

# ChangeLog

- **V2.5.1**
- Add awesome Intro
- Add continue reading feature that Ask user to go to last page to read.
- App start with Quran & Tafseer loaded.
- Improve UI for bottom nav
- add labels and it appear all the time.

- **V2.3.1**
- Add ReadLog that store pages user read.
- Improve UI for page switching.
- fix bugs [#13](https://github.com/MahmoudMabrok/QuranyApp/issues/13),[#24](https://github.com/MahmoudMabrok/QuranyApp/issues/24),[#34](https://github.com/MahmoudMabrok/QuranyApp/issues/34),[#43](https://github.com/MahmoudMabrok/QuranyApp/issues/43),[#44](https://github.com/MahmoudMabrok/QuranyApp/issues/44),[#46](https://github.com/MahmoudMabrok/QuranyApp/issues/46).

- **V2.1.3**
- new UI
- page layout
- setting activity
- new way of switching pages
- fix bugs [#39](https://github.com/MahmoudMabrok/QuranyApp/issues/39),[#38](https://github.com/MahmoudMabrok/QuranyApp/issues/38),[#37](https://github.com/MahmoudMabrok/QuranyApp/issues/37),[#35](https://github.com/MahmoudMabrok/QuranyApp/issues/35).

- **V2.0**
- new UI
- ayahEnd Symbol is fixed.
- UI for Listen & Test.
- add HizbQuarter Info.
- Tafseer is now offline.
- fix Bugs [#31](https://github.com/MahmoudMabrok/QuranyApp/issues/31),[#30](https://github.com/MahmoudMabrok/QuranyApp/issues/30).[#29](https://github.com/MahmoudMabrok/QuranyApp/issues/29),[#28](https://github.com/MahmoudMabrok/QuranyApp/issues/28),[#27](https://github.com/MahmoudMabrok/QuranyApp/issues/27).
- add **InstaBug**(trial) for in-app feedback and crash reporting feature.

## Technologies
Qurany is built using:

Technology | Version
---------- | -------
Java | 8
XML | 1.0
Android Support Library | 28.0.0
retrofit2 | 2.3.0
Room| 1.1.1
ButterKnife | 8.8.1
crashreporter | 1.0.9
gson | 2.8.5
sdp-android | 1.0.5
ssp-android | 1.0.5
AppRate | 1.1
prdownloader | 0.4.0
easypermissions|1.1.1
stetho | 1.5.1
Android-SpinKit | 1.2.0

# statistics

Languages | Line of code (LOC)
---------- | -------
Java | 10494
XML | 3498

- 31/3 / 13/4
![folow](https://user-images.githubusercontent.com/13488900/79120712-d545b000-7d93-11ea-8a3a-1152887d9f28.png)

- 19/3 - 1/4
![folow](https://user-images.githubusercontent.com/13488900/78177161-f76b3400-745d-11ea-9277-d92771cc226c.png)

- 28/2 - 12/3
![git flow](https://user-images.githubusercontent.com/13488900/76508469-17a76480-6457-11ea-9ce3-4e5a76496fc6.png)

------

# Contributors
- Thanks to [zularizal](https://github.com/zularizal) for awesome logo
- Thanks to [izzysoft](https://github.com/IzzySoft) for providing another installion source.

--------

# App Testers
Thanks for your efforts for testing Qurany App, keep moving:
- [crysports](https://github.com/crysports)
- [XAMIR555](https://github.com/XAMIR555)
- [44asad](https://github.com/44asad)
- [facebook-786](https://github.com/facebook-786)
- [sagorahmed](https://github.com/sagorahmed)