-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.php
152 lines (130 loc) · 6.71 KB
/
index.php
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
<?php
header('X-Frame-Options: DENY');
header('X-XSS-Protection: 1; mode=block');
header('X-Content-Type-Options: nosniff');
header('Strict-Transport-Security: max-age=63072000');
header('X-Robots-Tag: noindex, nofollow', true);
if(isset($_GET['username']) && $_GET['username'] !== '') {
$username = htmlspecialchars(trim($_GET['username']));
} else {
$username = "tamilsms";
}
?>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="HandheldFriendly" content="True" />
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="theme-color" content="#c7ecee">
<link rel="shortcut icon" href="" />
<?php $current_page = "https://$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]"; echo '<link rel="canonical" href="'.$current_page.'" />'; ?>
<title><?php echo $username; ?>'s Quotes and Kavithai</title>
<meta name="description" content="kavithai and Quotes Public Index - Our database collects kavithai and quotes from users - Users can submit their kavithai and quotes to the database."/>
<link rel="preconnect" href="https://cdnjs.cloudflare.com">
<link rel="preconnect" href="https://cdn.jsdelivr.net">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/bulma/0.9.3/css/bulma.min.css" integrity="sha512-IgmDkwzs96t4SrChW29No3NXBIBv8baW490zk5aXvhCD8vuZM3yUSkbyTBcXohkySecyzIrUwiF/qV0cuPcL3Q==" crossorigin="anonymous" referrerpolicy="no-referrer" />
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Catamaran:wght@100..900&display=swap" rel="stylesheet">
<link rel="stylesheet" href="/css/styles.css">
</head>
<body>
<section class="section">
<div class="container">
<div id="user"></div>
<div id="quote-container"></div>
<div class="content has-text-centered">
<div id="pagination" class="pagination is-centered is-rounded" role="navigation" aria-label="pagination"></div>
</div>
</div>
</section>
<script>
document.addEventListener("DOMContentLoaded", function () {
const quoteContainer = document.getElementById("quote-container");
const pagination = document.getElementById("pagination");
const user = document.getElementById("user");
let currentPage = 1;
function fetchQuotes(username, page) {
fetch(`/api/posts.php?username=${username}&page=${page}`)
.then(response => response.json())
.then(data => {
if (data && data.quotes && data.quotes.length > 0 && data.user) {
user.innerHTML = `<div class="content has-text-centered"><h1 class="title is-size-5 has-text-warning">Posts by ✍ ${data.user}</h1></div>`
displayQuotes(data.quotes);
renderPagination(data.page, data.perPage, data.totalQuotes);
} else {
quoteContainer.innerHTML = `<div class="notification is-warning"><p class="content has-text-centered">${data.message}</p></div>`;
pagination.innerHTML = "";
}
})
.catch(error => { quoteContainer.innerHTML = `<div class="notidication is-danger">Data Error</p><br>`;});
}
function displayQuotes(quotes) {
quoteContainer.innerHTML = "";
quotes.forEach(quote => {
const quoteCard = `
<div class="chat-box">
<div class="quote-card">
<div class="quote-text">
${quote.quote_text}
</div>
<br>
<div class="quote-author">📝 ${quote.author_name}</div>
<div class="quote-date">📅 ${quote.date}</div>
<div class="quote-tags">🔖 #${quote.tags}</div>
</div>
</div>
</div>`;
quoteContainer.innerHTML += quoteCard;
});
}
function renderPagination(page, perPage, totalQuotes) {
const totalPages = Math.ceil(totalQuotes / perPage);
const maxPagesToShow = 3; // Maximum number of page links to show
const currentPageGroup = Math.ceil(page / maxPagesToShow);
const startPage = (currentPageGroup - 1) * maxPagesToShow + 1;
const endPage = Math.min(startPage + maxPagesToShow - 1, totalPages);
let paginationHTML = `<ul class="pagination-list">`;
const prevPage = Math.max(startPage - 1, 1);
if (page > 1) {
paginationHTML += `
<li>
<a class="pagination-previous button is-warning is-rounded" aria-label="Previous" data-page="${prevPage}">⬅</a>
</li>
`;
}
for (let i = startPage; i <= endPage; i++) {
paginationHTML += `
<li>
<a class="pagination-link ${i === page ? 'is-current' : ''}" aria-label="Goto page ${i}" data-page="${i}">${i}</a>
</li>`;
}
const nextPage = Math.min(endPage + 1, totalPages);
if (page < totalPages) {
paginationHTML += `
<li>
<a class="pagination-next button is-warning is-rounded" aria-label="Next" data-page="${nextPage}">➡</a>
</li>
`;
}
paginationHTML += `</ul>`;
pagination.innerHTML = paginationHTML;
pagination.querySelectorAll(".pagination-link, .pagination-previous, .pagination-next").forEach(link => {
link.addEventListener("click", () => {
currentPage = parseInt(link.dataset.page);
// const urlParams = new URLSearchParams(window.location.search);
const username = "<?php echo $username; ?>";
fetchQuotes(username, currentPage);
});
});
}
// Initial fetch
//const urlParams = new URLSearchParams(window.location.search);
const username = "<?php echo $username; ?>";
fetchQuotes(username, currentPage);
});
</script>
</body>
</html>