@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.5.0",
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
- const promiseRes = await Promise.all(promises);
84
- setTimeout(() => {
85
- setIsLoading(false);
86
- }, 500);
87
- } catch (e) {}
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
- getReciters();
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
- TrackPlayer.setupPlayer();
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
- <AudioPlayer
158
- ref={audioPlayerRef}
159
- chapterId={selectedVerse?.chapter_id ?? chapterId}
160
- setSelectedVerse={setSelectedVerse}
161
- selectedVerse={selectedVerse}
162
- allReciter={allReciters}
163
- versesBeforeAndAfterCurrentVerse={versesBeforeAndAfterCurrentVerse}
164
- setVersesBeforeAndAfterCurrentVerse={
165
- setVersesBeforeAndAfterCurrentVerse
166
- }
167
- originalVerse={originalVerse}
168
- showSlider={showSlider}
169
- autoCompleteAudioAfterPlayingVerse={
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
  );
@@ -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 {