
Security News
PolinRider: North Korea-Linked Supply Chain Campaign Expands Across Open Source Ecosystems
PolinRider expands across npm, Packagist, Go modules, and Chrome extensions, using hidden loaders to target developer environments.
quran-madina-html
Advanced tools
A Madina Quran HTML Renderer without images
Theres a pre-processing python script to generate Json databases with quran text with special metadata. The preprocessing is based on text from Tanzil, and the OCR DB downloaded from Murtaza Raja helper project. Every line has a stretch-x factor pre-computed to ensure the best text fitting. Afterwards, the JS library uses those Json objects to render Madina-based Quran pages and lines.
The main purpose of this library is:
Reference Image | HTML: Font=me_quran | HTML: Font=Hafs | HTML: Font=Amiri Quran Colored |
|---|---|---|---|
HTML: Font=Amiri Quran | HTML: Range of Ayas |
In your Html header, add this script:
<script type="text/javascript" src="https://unpkg.com/quran-madina-html"></script>
data-name parameters are: Madina05 (default), others are under development (Shemerly, Qaloon, Newer Madina)data-font parameters are: Hafs (default), Uthman, Amiri Quran, Amiri Quran Coloreddata-font-size which defaults to 16 (px)Then in your body, just add the tag.
<quran-madina-html sura="2" aya="8-10"></quran-madina-html>
If the selected aya(s) fit on a single line, the default is to generate an inline <span> element, otherwise a <div> is generated.
You can also restrict the output to a specific word sequence with the words attribute (1-based, inclusive; start-end, start:end or a single index). Word indices are counted starting from the given sura/aya and may run past it, so the rendered selection can span multiple ayas — and even cross page and sura boundaries (the sura name/basmala are shown for context but not counted as words). The non-selected words are kept in place so the original Madina line layout is preserved — only the chosen words are shown. Aya-number markers are not counted.
<quran-madina-html sura="1" aya="1" words="1:2"></quran-madina-html> <!-- first two words only -->
<quran-madina-html sura="1" aya="1" words="3-10"></quran-madina-html> <!-- words 3..10, spanning ayas 1-3 -->
<quran-madina-html sura="1" aya="7" words="1-10"></quran-madina-html> <!-- spans Al-Fatiha into Al-Baqara -->
The words attribute is ignored when rendering a full page.
Another option exists to render a complete quran page:
<quran-madina-html page="106"></quran-madina-html>
By default a header (sura name + copy/translate icons, on a multiline render) or a copy button (on an inline render) is added. Set headless="true" to drop that chrome and render only the Quran text:
<quran-madina-html sura="2" aya="8-10" headless="true"></quran-madina-html> <!-- no header -->
<quran-madina-html sura="1" aya="1" headless="true"></quran-madina-html> <!-- no copy button -->
The project is published on npm npm install quran-madina-html, with sources, assets and distributables.
Alternatively, you can fork this repo, then clone it.
apt install python3-distutils nodejs npm chromium-driver
npm install // install components and scripts
npm run build-db // build all json Db files
npm run release // build the dist with dependencies
https://tarekeldeeb.github.io/quran-madina-html/demo/index.html
Don't forget to see the page source!
FAQs
A Madina Quran HTML Renderer without images.
The npm package quran-madina-html receives a total of 465 weekly downloads. As such, quran-madina-html popularity was classified as not popular.
We found that quran-madina-html demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
PolinRider expands across npm, Packagist, Go modules, and Chrome extensions, using hidden loaders to target developer environments.

Security News
Open source attacks are accelerating as AI coding agents pull in dependencies faster, with less human review.

Research
/Security News
Malicious Chrome and Firefox extensions posed as free VPNs while stealing clipboard data through later extension updates.