<img src="public/logo.png" alt="Logo" width="80" height="80">
The official source code repository for Quran.com
<br />
<a href="https://discord.gg/SpEeJ5bWEQ"><strong>Join Quran.com community »</strong></a>
<br />
<br />
<a href="https://quran.com">Visit Quran.com</a>
·
<a href="https://github.com/quran/quran.com-frontend-next/issues">Report Bug</a>
·
<a href="https://github.com/quran/quran.com-frontend-next/issues">Request Feature</a>
•
<a href="https://quran.github.io/quran.com-frontend-next/storybook/master">Storybook</a>
This project is the frontend for Quran.com. It is built on top of Next.js, a popular framework that takes the trouble and setup of setting up an isomorphic react app. We deploy it on now.sh automatically with automatic generation of builds for PRs.
We trust that you will not copy this idea/project, this is at the end for the sake of Allah and we all have good intentions while working with this project. But we must stress that copying the code/project is unacceptable.
nodejs
and npm
installed. Prefer 10+yarn
installed. Simply npm i -g yarn
yarn
on the repo to install node_modules
yarn dev
to start the app. If you wish to run on a different port, run yarn dev -p 8000
localhost:3000
in your browserThe app runs on Next.js and will automatically hot reload when you make changes.
If you have access to a Quran.com associated Vercel account, run vercel env pull
. Otherwise, rename the env.example
file to env.local
and you should be good to go.
One mistake we made previously is treated each component as unique. This made our work not scalable. Secondly, when looking at large companies, they often develop a design style language that can be used across the app without the need to create unique components and ensure better consistency across the product. We are trying to take a similar approach. If something can be used elsewhere, please put it inside the dls/
directory and create stories for it.
Our components are built within Storybook.js. See files with name .stories.tsx
. This helps engineers view their work outside of the product, making it super easy to test different configurations of the component.
We also display all our components here.
Check .vscode/extensions.json
for recommended VSCode Extensions
We chose TypeScript as the language of choice of it's ease of type-safety. Please create types where you see fit.
If you are interested to help out, please look at issues on the GitHub repo. This is a good place to start.
Thank you for taking time to file a bug! We'd appreciate your help on fixing it 🙏. Please open an issue.
Join Quran.com Discord community »