@moustafahelmi/react-native-quran-app 1.5.0 → 1.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@moustafahelmi/react-native-quran-app",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.6.0",
|
|
4
4
|
"description": "React Native library for displaying Quran with Hafs recitation, audio playback, and customizable components",
|
|
5
5
|
"main": "src/index.ts",
|
|
6
6
|
"types": "src/index.ts",
|
|
@@ -80,11 +80,11 @@ const useGetChapterByPage = ({
|
|
|
80
80
|
return downoladThePageFont(Number(item), () => {}, QURAN_FONTS_API);
|
|
81
81
|
});
|
|
82
82
|
try {
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
}
|
|
83
|
+
await Promise.all(promises);
|
|
84
|
+
setIsLoading(false);
|
|
85
|
+
} catch (e) {
|
|
86
|
+
setIsLoading(false);
|
|
87
|
+
}
|
|
88
88
|
};
|
|
89
89
|
|
|
90
90
|
const getTargetChapterPage = async () => {
|
|
@@ -8,15 +8,19 @@ import {I18nManager} from 'react-native';
|
|
|
8
8
|
const useGetReciters = ({
|
|
9
9
|
chapterId,
|
|
10
10
|
type,
|
|
11
|
+
skip = false,
|
|
11
12
|
}: {
|
|
12
13
|
chapterId: number;
|
|
13
14
|
type: QuranTypesEnums;
|
|
15
|
+
skip?: boolean;
|
|
14
16
|
}) => {
|
|
15
17
|
const [allReciters, setAllReciters] = useState<IReciter[]>([]);
|
|
16
18
|
const {getChapterAudionUrl} = useGetChapterAudio();
|
|
17
19
|
useEffect(() => {
|
|
18
|
-
|
|
19
|
-
|
|
20
|
+
if (!skip) {
|
|
21
|
+
getReciters();
|
|
22
|
+
}
|
|
23
|
+
}, [skip]);
|
|
20
24
|
|
|
21
25
|
const getReciters = async () => {
|
|
22
26
|
const queryParams = {
|
|
@@ -27,6 +27,8 @@ const QuranPageLayout = ({
|
|
|
27
27
|
quranPageContainerStyle,
|
|
28
28
|
selectionColor,
|
|
29
29
|
autoCompleteAudioAfterPlayingVerse,
|
|
30
|
+
disableAudio = false,
|
|
31
|
+
showAudioPlayer = true,
|
|
30
32
|
}: IQuranPageLayout) => {
|
|
31
33
|
const flatlistRef = useRef<any>();
|
|
32
34
|
const {chapterLookUp} = useGetChapterLookup({
|
|
@@ -39,7 +41,7 @@ const QuranPageLayout = ({
|
|
|
39
41
|
type,
|
|
40
42
|
QURAN_FONTS_API: QURAN_FONTS_API,
|
|
41
43
|
});
|
|
42
|
-
const {allReciters} = useGetReciters({chapterId, type});
|
|
44
|
+
const {allReciters} = useGetReciters({chapterId, type, skip: disableAudio});
|
|
43
45
|
const audioPlayerRef = useRef<IAudioPlayerRef>();
|
|
44
46
|
const [selectedVerse, setSelectedVerse] = useState<ISurahVerse>(
|
|
45
47
|
{} as ISurahVerse,
|
|
@@ -65,8 +67,10 @@ const QuranPageLayout = ({
|
|
|
65
67
|
);
|
|
66
68
|
|
|
67
69
|
useEffect(() => {
|
|
68
|
-
|
|
69
|
-
|
|
70
|
+
if (!disableAudio) {
|
|
71
|
+
TrackPlayer.setupPlayer();
|
|
72
|
+
}
|
|
73
|
+
}, [disableAudio]);
|
|
70
74
|
useEffect(() => {
|
|
71
75
|
if (!isLoading && selectedBookedMarkedVerse) {
|
|
72
76
|
setSelectedVerse(selectedBookedMarkedVerse);
|
|
@@ -154,22 +158,24 @@ const QuranPageLayout = ({
|
|
|
154
158
|
}}
|
|
155
159
|
/>
|
|
156
160
|
)}
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
setVersesBeforeAndAfterCurrentVerse
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
autoCompleteAudioAfterPlayingVerse
|
|
171
|
-
|
|
172
|
-
|
|
161
|
+
{!disableAudio && showAudioPlayer && (
|
|
162
|
+
<AudioPlayer
|
|
163
|
+
ref={audioPlayerRef}
|
|
164
|
+
chapterId={selectedVerse?.chapter_id ?? chapterId}
|
|
165
|
+
setSelectedVerse={setSelectedVerse}
|
|
166
|
+
selectedVerse={selectedVerse}
|
|
167
|
+
allReciter={allReciters}
|
|
168
|
+
versesBeforeAndAfterCurrentVerse={versesBeforeAndAfterCurrentVerse}
|
|
169
|
+
setVersesBeforeAndAfterCurrentVerse={
|
|
170
|
+
setVersesBeforeAndAfterCurrentVerse
|
|
171
|
+
}
|
|
172
|
+
originalVerse={originalVerse}
|
|
173
|
+
showSlider={showSlider}
|
|
174
|
+
autoCompleteAudioAfterPlayingVerse={
|
|
175
|
+
autoCompleteAudioAfterPlayingVerse
|
|
176
|
+
}
|
|
177
|
+
/>
|
|
178
|
+
)}
|
|
173
179
|
</View>
|
|
174
180
|
</SafeAreaView>
|
|
175
181
|
);
|
package/src/types/index.ts
CHANGED
|
@@ -174,6 +174,8 @@ export interface IQuranPageLayout {
|
|
|
174
174
|
quranPageContainerStyle?: StyleProp<ViewStyle>;
|
|
175
175
|
selectionColor?: ColorValue;
|
|
176
176
|
autoCompleteAudioAfterPlayingVerse?: boolean;
|
|
177
|
+
disableAudio?: boolean;
|
|
178
|
+
showAudioPlayer?: boolean;
|
|
177
179
|
}
|
|
178
180
|
|
|
179
181
|
export enum QuranTypesEnums {
|