UNPKG

quran-meta

Version:

Library with meta data and functionality related to Holy Quran

31 lines (28 loc) 952 B
import type { RiwayaData } from "./lists/types" import type { AyahId, Ruku } from "./types" import { binarySearch } from "./utils" import { checkValidAyahId } from "./validation" /** * Finds the Ruku number for a given Ayah ID using binary search. * * @param ayahId - The unique identifier of an Ayah in format: surah:ayah (e.g., "2:255") * @param data - The Lists object for the riwaya. * @returns The Ruku number corresponding to the given Ayah ID * @throws {@link Error} If the provided Ayah ID is invalid * * @example * ```ts * const ruku = findRukuByAyahId("2:255", HafsLists); * // Returns the Ruku number containing Ayah 255 of Surah 2 * ``` */ export function findRukuByAyahId( ayahId: AyahId, data: RiwayaData ): Ruku { checkValidAyahId(ayahId, data.meta) const RukuList = data.RukuList const jj = binarySearch(RukuList, ayahId) const juz = jj < 0 ? -jj - 2 : jj return juz as Ruku }