-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathscript.js
227 lines (196 loc) · 13.2 KB
/
script.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
document.addEventListener("DOMContentLoaded", () => {
const notableVerses = [
{ surah: 'The Prophets', ayah: 30, highlightColor: 'gold', explanation: "Refers to the creation of the universe, supporting the Big Bang theory." },
{ surah: 'The Prophets', ayah: 33, highlightColor: 'gold', explanation: "Mentions the orbits of celestial bodies, aligning with astronomy." },
{ surah: 'The Prophets', ayah: 104, highlightColor: 'gold', explanation: "Describes the universe's end in a 'Big Crunch' scenario." },
{ surah: 'The Believers', ayah: 12, highlightColor: 'gold', explanation: "Details embryonic development stages in humans." },
{ surah: 'The Light', ayah: 40, highlightColor: 'gold', explanation: "Discusses darkness in the deep sea, relating to oceanography." },
{ surah: 'Ya-Sin', ayah: 36, highlightColor: 'gold', explanation: "Mentions creation in pairs across life forms." },
{ surah: 'The Winnowing Winds', ayah: 47, highlightColor: 'gold', explanation: "Refers to the expansion of the universe." },
{ surah: 'The Iron', ayah: 25, highlightColor: 'gold', explanation: "Describes iron as 'sent down,' indicating its extraterrestrial origin." },
{ surah: 'The Cow', ayah: 164, highlightColor: 'gold', explanation: "Refers to the water cycle and nature’s balance." },
{ surah: 'The Bee', ayah: 66, highlightColor: 'gold', explanation: "Discusses milk production in cattle." },
{ surah: 'The Bee', ayah: 68, highlightColor: 'gold', explanation: "References bees and honey’s healing properties." },
{ surah: 'The Cattle', ayah: 125, highlightColor: 'gold', explanation: "Describes decreased oxygen at high altitudes." },
{ surah: 'The Moon', ayah: 1, highlightColor: 'gold', explanation: "Mentions the splitting of the moon." },
{ surah: 'The Cave', ayah: 86, highlightColor: 'gold', explanation: "Describes the sun setting in a muddy spring." },
{ surah: 'The Thunder', ayah: 3, highlightColor: 'gold', explanation: "Discusses the layers of the Earth and sky." },
{ surah: 'The Criterion', ayah: 61, highlightColor: 'gold', explanation: "Mentions creation in balance." },
{ surah: 'The Family of Imran', ayah: 191, highlightColor: 'gold', explanation: "Reflects on the order in the creation of heavens and earth." },
{ surah: 'The Moon', ayah: 19, highlightColor: 'gold', explanation: "Describes the moon’s phases." },
{ surah: 'The Dominion', ayah: 5, highlightColor: 'gold', explanation: "Mentions the atmosphere’s protection." },
{ surah: 'The Cow', ayah: 22, highlightColor: 'gold', explanation: "Refers to Earth’s stability." },
{ surah: 'The Smoke', ayah: 10, highlightColor: 'gold', explanation: "Describes the universe’s origin as smoke." },
{ surah: 'The Divorce', ayah: 12, highlightColor: 'gold', explanation: "Mentions the seven heavens." },
{ surah: 'The Forgiver', ayah: 57, highlightColor: 'gold', explanation: "Describes creation from dust." },
{ surah: 'Noah', ayah: 14, highlightColor: 'gold', explanation: "References human creation in stages." },
{ surah: 'The Reality', ayah: 19, highlightColor: 'gold', explanation: "Mentions wind as a destructive force." },
{ surah: 'The Kneeling', ayah: 28, highlightColor: 'gold', explanation: "Refers to the hydrological cycle." },
{ surah: 'The Cave', ayah: 29, highlightColor: 'gold', explanation: "Discusses free will." },
{ surah: 'The Pilgrimage', ayah: 5, highlightColor: 'gold', explanation: "Describes biological stages." },
{ surah: 'The Star', ayah: 45, highlightColor: 'gold', explanation: "Mentions pairing in creation." },
{ surah: 'The Bees', ayah: 69, highlightColor: 'gold', explanation: "Highlights the benefits of honey." },
{ surah: 'The Thunder', ayah: 12, highlightColor: 'gold', explanation: "Describes thunder’s formation." },
{ surah: 'The Cave', ayah: 11, highlightColor: 'gold', explanation: "Discusses sleep as a protection mechanism." },
{ surah: 'The Criterion', ayah: 25, highlightColor: 'gold', explanation: "Touches on the concept of time and relativity." },
{ surah: 'Ta-Ha', ayah: 53, highlightColor: 'gold', explanation: "Here is the translation of the translation of zauj (plural azwaj) whose original meaning is: ‘that which, in the company of another, forms a pair’; the word is used just as readily for a married couple as for a pair of shoes. This is describing how plants come in pairs, implying sexual plant reproduction, which was not something that was known at the time of the Quran." },
{ surah: 'The Romans', ayah: 1, highlightColor: 'gold', explanation: "This miracle is depicted in Verses 1-5 of Surah Ar-Rum (Romans). Predicted the Romans defeating the Persians (more details shown below)." },
{ surah: 'The Romans', ayah: 2, highlightColor: 'gold', explanation: "This miracle is depicted in Verses 1-5 of Surah Ar-Rum (Romans). Predicted the Romans defeating the Persians (more details shown below)." },
{ surah: 'The Romans', ayah: 3, highlightColor: 'gold', explanation: "This miracle is depicted in Verses 1-5 of Surah Ar-Rum (Romans). Predicted the Romans defeating the Persians (more details shown below)." },
{ surah: 'The Romans', ayah: 4, highlightColor: 'gold', explanation: "This miracle is depicted in Verses 1-5 of Surah Ar-Rum (Romans). Predicted the Romans defeating the Persians (more details shown below)." },
{ surah: 'The Romans', ayah: 5, highlightColor: 'gold', explanation: "This miracle is depicted in Verses 1-5 of Surah Ar-Rum (Romans). Predicted the Romans defeating the Persians (more details shown below)." },
{ surah: 'The Heights', ayah: 57, highlightColor: 'gold', explanation: "This miracle is depicted in Verse 57 of Surah Al-Araf (The Heights). This verse mentions clouds being heavy, something that scientists did not know about until much later. Scroll below for more information." },
];
let scientificOnly = false;
d3.json("https://raw.githubusercontent.com/ymorsi7/Quran-Interactive-Visualization/main/TheQuranDataset.json")
.then(data => {
const nestedData = d3.groups(data.children, d => d.surah_name_en);
const hierarchyData = {
name: "Quran",
children: nestedData.map(([surah, verses]) => ({
name: surah,
children: verses.map(verse => ({
...verse,
value: +verse.no_of_word_ayah || 1
}))
}))
};
const width = 800;
const height = 600;
const root = d3.hierarchy(hierarchyData)
.sum(d => d.value)
.sort((a, b) => b.value - a.value);
d3.treemap().size([width, height]).padding(1)(root);
const svg = d3.select("#treemap").append("svg")
.attr("width", width)
.attr("height", height)
.call(d3.zoom()
.scaleExtent([1, 8]) // [min zoom, max zoom] where 1 is the default view
.on("zoom", (event) => {
svg.attr("transform", event.transform);
}))
.append("g");
const color = d3.scaleOrdinal()
.domain(root.children.map(d => d.data.name))
.range(d3.schemeCategory10);
function renderTreemap() {
svg.selectAll("*").remove();
const filteredData = scientificOnly
? root.leaves().filter(d => notableVerses.some(v => v.surah === d.data.surah_name_en && v.ayah === d.data.ayah_no_surah))
: root.leaves();
svg.selectAll("rect")
.data(filteredData)
.enter()
.append("rect")
.attr("x", d => d.x0)
.attr("y", d => d.y0)
.attr("width", d => d.x1 - d.x0)
.attr("height", d => d.y1 - d.y0)
.style("fill", d => {
const notableVerse = notableVerses.find(v => v.surah === d.data.surah_name_en && v.ayah === d.data.ayah_no_surah);
return notableVerse ? notableVerse.highlightColor : color(d.parent.data.name);
})
.style("stroke", "#333")
.on("click", function (event, d) { displayDetails(d); });
}
function displayDetails(d) {
const details = d3.select("#verse-details");
details.html("");
if (d && d.data) {
const surahName = d.data.surah_name_en || "Unknown Surah";
const ayahText = d.data.ayah_en || "No translation available";
const ayahNo = d.data.ayah_no_surah || "No Ayah Number";
details.append("h3").text(`${surahName} - Ayah ${ayahNo}`);
details.append("p").text(ayahText);
const notableVerse = notableVerses.find(v =>
v.surah === d.data.surah_name_en && v.ayah === d.data.ayah_no_surah
);
if (notableVerse && notableVerse.explanation) {
const explanationDiv = details.append("div").attr("id", "explanation");
explanationDiv.append("h4").text("Scientific Explanation:");
explanationDiv.append("p").text(notableVerse.explanation);
}
} else {
details.append("p").text("No data found for this specific verse in the dataset.");
}
}
function toggleScientificMiracles() {
scientificOnly = !scientificOnly;
document.getElementById("filter-button").textContent = scientificOnly
? "Show All Verses"
: "Show Scientific Miracles Only";
renderTreemap();
}
function searchVerses() {
const keyword = document.getElementById("search-bar").value.toLowerCase();
const searchData = root.leaves().filter(d =>
d.data.ayah_en && d.data.ayah_en.toLowerCase().includes(keyword)
);
svg.selectAll("*").remove();
svg.selectAll("rect")
.data(searchData)
.enter()
.append("rect")
.attr("x", d => d.x0)
.attr("y", d => d.y0)
.attr("width", d => d.x1 - d.x0)
.attr("height", d => d.y1 - d.y0)
.style("fill", d => {
const notableVerse = notableVerses.find(v => v.surah === d.data.surah_name_en && v.ayah === d.data.ayah_no_surah);
return notableVerse ? notableVerse.highlightColor : color(d.parent.data.name);
})
.style("stroke", "#333")
.on("click", function (event, d) { displayDetails(d); });
}
document.getElementById("filter-button").onclick = toggleScientificMiracles;
document.getElementById("search-bar").addEventListener("input", searchVerses);
renderTreemap();
})
.catch(error => console.error("Error loading JSON:", error));
function initHadithViz() {
const width = 800;
const height = 600;
const svg = d3.select("#hadith-treemap")
.append("svg")
.attr("width", width)
.attr("height", height);
d3.json("data/hadith.json").then(data => {
const root = d3.hierarchy(data)
.sum(d => d.value)
.sort((a, b) => b.value - a.value);
const treemapLayout = d3.treemap()
.size([width, height])
.padding(1);
treemapLayout(root);
const nodes = svg.selectAll('g')
.data(root.leaves())
.enter()
.append('g')
.attr('transform', d => `translate(${d.x0},${d.y0})`);
nodes.append('rect')
.attr('width', d => d.x1 - d.x0)
.attr('height', d => d.y1 - d.y0)
.style('fill', '#33cccc')
.style('opacity', 0.7)
.on('mouseover', function (event, d) {
d3.select(this).style('opacity', 1);
const details = document.querySelector('.hadith-section .details-content');
details.innerHTML = `
<h3>${d.data.collection}</h3>
<p>${d.data.text}</p>
<p><em>Book: ${d.data.book}</em></p>
`;
})
.on('mouseout', function () {
d3.select(this).style('opacity', 0.7);
});
nodes.append('text')
.attr('x', 5)
.attr('y', 20)
.text(d => d.data.collection)
.style('font-size', '12px')
.style('fill', 'white');
});
}
initHadithViz();
});