95 lines
2.9 KiB
HTML
95 lines
2.9 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
<title>Daily Bonus</title>
|
|
<style>
|
|
body {
|
|
font-family: Arial, sans-serif;
|
|
margin: 0;
|
|
padding: 0;
|
|
background-color: #f4f7fc;
|
|
color: #333;
|
|
text-align: center;
|
|
}
|
|
.calendar {
|
|
display: grid;
|
|
grid-template-columns: repeat(7, 1fr);
|
|
gap: 5px;
|
|
margin: 20px auto;
|
|
width: 90%;
|
|
max-width: 400px;
|
|
}
|
|
.day {
|
|
padding: 15px;
|
|
background-color: #fff;
|
|
border-radius: 5px;
|
|
box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
|
|
cursor: pointer;
|
|
}
|
|
.day.today {
|
|
background-color: #e26f22;
|
|
color: #fff;
|
|
font-weight: bold;
|
|
}
|
|
.day.claimed {
|
|
background-color: #4caf50;
|
|
color: white;
|
|
}
|
|
</style>
|
|
</head>
|
|
<body>
|
|
<h1>Ежедневный бонус</h1>
|
|
<div class="calendar" id="calendar"></div>
|
|
<script>
|
|
const tg = window.Telegram.WebApp;
|
|
const today = new Date().getDate();
|
|
|
|
// Фиктивные данные (замените запросом к вашему серверу)
|
|
const rewards = [
|
|
{ day: 1, reward: '100 монет' },
|
|
{ day: 2, reward: '200 монет' },
|
|
{ day: 3, reward: '50 опыта' },
|
|
// Добавьте остальные дни...
|
|
];
|
|
|
|
const claimedDays = []; // Дни, в которые пользователь уже получил награду (серверные данные)
|
|
|
|
const calendar = document.getElementById('calendar');
|
|
|
|
for (let i = 1; i <= 31; i++) {
|
|
const dayElement = document.createElement('div');
|
|
dayElement.className = 'day';
|
|
dayElement.innerText = i;
|
|
|
|
const reward = rewards.find(r => r.day === i);
|
|
if (reward) {
|
|
dayElement.title = `🎁 ${reward.reward}`;
|
|
}
|
|
|
|
if (i === today) {
|
|
dayElement.classList.add('today');
|
|
}
|
|
|
|
if (claimedDays.includes(i)) {
|
|
dayElement.classList.add('claimed');
|
|
}
|
|
|
|
dayElement.addEventListener('click', () => {
|
|
if (i === today && !claimedDays.includes(i)) {
|
|
claimedDays.push(i);
|
|
dayElement.classList.add('claimed');
|
|
tg.sendData(JSON.stringify({ day: i })); // Отправляем данные на сервер
|
|
alert(`Вы получили награду: ${reward ? reward.reward : 'Награда не найдена'}`);
|
|
}
|
|
});
|
|
|
|
calendar.appendChild(dayElement);
|
|
}
|
|
|
|
tg.ready();
|
|
</script>
|
|
</body>
|
|
</html>
|