143 lines
5.6 KiB
HTML
143 lines
5.6 KiB
HTML
{% extends "default.html" %}
|
|
{% block pagetitle %}Hats{% endblock %}
|
|
{% block pagetype %}message{% endblock %}
|
|
|
|
{% block banner %}
|
|
<style>
|
|
.shop-tabs {
|
|
padding-top: 50px;
|
|
}
|
|
|
|
@media (max-width: 768px) {
|
|
#hats-banner {
|
|
width: 80%;
|
|
}
|
|
.shop-tabs {
|
|
padding-top: 30px;
|
|
}
|
|
}
|
|
|
|
.shop-tab {
|
|
display: inline-flex;
|
|
max-width: 46.6%;
|
|
letter-spacing: 3px;
|
|
border-radius: 0;
|
|
}
|
|
|
|
.shop-tab.active {
|
|
background-color: var(--primary) !important;
|
|
pointer-events: none !important;
|
|
cursor: default !important;
|
|
}
|
|
</style>
|
|
|
|
<div class="container-fluid bg-white sticky shop-tabs" style="padding-bottom: 0 !important;">
|
|
<div class="row box-shadow-bottom">
|
|
<div class="col p-0">
|
|
<div class="container" style="padding-bottom: 0;">
|
|
<div class="row box-shadow-bottom bg-white" style="justify-content: center;">
|
|
<a class="btn btn-primary btn-block m-0 shop-tab" href="/shop">
|
|
<span class="mr-auto ml-auto"><i class="fas fa-gift mr-2"></i>AWARDS</span>
|
|
</a>
|
|
<a class="btn btn-primary btn-block m-0 shop-tab active" href="/hats">
|
|
<span class="mr-auto ml-auto"><i class="fas fa-hat-cowboy mr-2"></i>HATS</span>
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<header class="container pb-1 text-center">
|
|
<img id="hats-banner" class="mt-5" alt="hats banner" src="/i/hats.webp?v=1" width="50%">
|
|
<h5 class="mt-4">Number of hats you bought: {{v.num_of_owned_hats}}</h5>
|
|
<h5 class="mt-4">Number of hats you designed: {{v.num_of_designed_hats}}</h5>
|
|
<h5 class="mt-4">Coins you spent on hats: {{"{:,}".format(v.coins_spent_on_hats)}}</h5>
|
|
<h5 class="mt-4">Total hat sales: {{"{:,}".format(sales)}}</h5>
|
|
<h5 class="mt-4">Number of hats: {{num_of_hats}}</h5>
|
|
</header>
|
|
{% endblock %}
|
|
|
|
{% block content %}
|
|
<script>
|
|
function equip_hat(t, hat_id, hat_name) {
|
|
const profile_pic_hat = document.getElementById("profile-pic-35-hat");
|
|
function extra_actions(xhr) {
|
|
if(xhr.status == 200) {
|
|
profile_pic_hat.src = `/i/hats/${hat_name}.webp?h=7`
|
|
profile_pic_hat.classList.remove('d-none')
|
|
}
|
|
}
|
|
|
|
postToastSwitch(t, `/equip_hat/${hat_id}`, `equip-${hat_id}`, `unequip-${hat_id}`, `d-none`, extra_actions)
|
|
}
|
|
</script>
|
|
|
|
<div class="overflow-x-auto mt-1 mb-5">
|
|
<table class="table table-striped shop">
|
|
<thead class="bg-primary text-white">
|
|
<tr>
|
|
<th scope="col">Hat</th>
|
|
<th scope="col">Name</th>
|
|
<th scope="col">Description</th>
|
|
{% if SITE == 'rdrama.net' %}
|
|
{% if request.values.get("sort") == 'author_asc' %}
|
|
<th scope="col"><a href="?sort=author_desc">Author</a></th>
|
|
{% else %}
|
|
<th scope="col"><a href="?sort=author_asc">Author</a></th>
|
|
{% endif %}
|
|
<th scope="col" onclick="sort_table(4)">Owners</th>
|
|
<th scope="col" onclick="sort_table(5)">Price</th>
|
|
<th scope="col">Actions</th>
|
|
<th scope="col" onclick="sort_table(7)">Added on</th>
|
|
{% else %}
|
|
<th scope="col" onclick="sort_table(3)">Owners</th>
|
|
<th scope="col" onclick="sort_table(4)">Price</th>
|
|
<th scope="col">Actions</th>
|
|
<th scope="col" onclick="sort_table(6)">Added on</th>
|
|
{% endif %}
|
|
</tr>
|
|
</thead>
|
|
|
|
<tbody>
|
|
{% for hat, user in hats %}
|
|
<tr>
|
|
<td>
|
|
<div class="profile-pic-75-wrapper mt-4">
|
|
<img loading="lazy" alt="avatar" src="{{v.profile_url}}" class="profile-pic-75">
|
|
<img loading="lazy" alt="{{hat.name}}" class="profile-pic-75-hat" src="/i/hats/{{hat.name}}.webp?h=7">
|
|
</div>
|
|
</td>
|
|
<td>{{hat.name}}</td>
|
|
<td style="word-break:break-word">{{hat.censored_description(v)}}</td>
|
|
{% if SITE == 'rdrama.net' %}
|
|
<td>{% include "user_in_table.html" %}</td>
|
|
{% endif %}
|
|
<td><a href="/hat_owners/{{hat.id}}">{{hat.number_sold(g.db)}}</a></td>
|
|
<td>{{hat.price}}</td>
|
|
<td class="shop-table-actions" style="width:unset">
|
|
{% if hat.id not in owned_hat_ids and hat.is_purchasable %}
|
|
<div id="if-not-owned-{{hat.id}}">
|
|
<button type="button" id="buy1-{{hat.id}}" class="btn btn-success {% if v.coins < hat.price %}disabled{% endif %}" data-click2="postToastSwitch(this, '/buy_hat/{{hat.id}}', 'if-not-owned-{{hat.id}}', 'if-owned-{{hat.id}}', 'd-none', (xhr)=>{if(xhr.status == 200)document.getElementById('user-coins-amount').innerHTML-={{hat.price}}})" onclick="areyousure(this)"><span class="m-auto">Buy</span></button>
|
|
|
|
{% if FEATURES['MARSEYBUX'] %}
|
|
<button type="button" id="buy2-{{hat.id}}" class="marseybux btn btn-success {% if v.marseybux < hat.price %}disabled{% endif %}" data-click2="postToastSwitch(this, '/buy_hat/{{hat.id}}?mb=true', 'if-not-owned-{{hat.id}}', 'if-owned-{{hat.id}}', 'd-none', (xhr)=>{if(xhr.status == 200)document.getElementById('user-bux-amount').innerHTML-={{hat.price}}})" onclick="areyousure(this)"><span class="m-auto">MBux</span></button>
|
|
{% endif %}
|
|
</div>
|
|
{% endif %}
|
|
|
|
<div id="if-owned-{{hat.id}}" {% if hat.id not in owned_hat_ids %}class="d-none"{% endif %}>
|
|
<button type="button" id="unequip-{{hat.id}}" class="unequip {% if hat.id not in v.equipped_hat_ids %}d-none{% endif %} btn btn-success" onclick="postToastSwitch(this, '/unequip_hat/{{hat.id}}', 'equip-{{hat.id}}', 'unequip-{{hat.id}}', 'd-none')"><span class="m-auto">Unequip</span></button>
|
|
|
|
<button type="button" id="equip-{{hat.id}}" class="equip {% if hat.id in v.equipped_hat_ids %}d-none{% endif %} btn btn-success" onclick="equip_hat(this, '{{hat.id}}', '{{hat.name}}')"><span class="m-auto">Equip</span></button>
|
|
</div>
|
|
</td>
|
|
|
|
<td data-time="{{hat.created_utc}}"></td>
|
|
</tr>
|
|
{% endfor %}
|
|
</tbody>
|
|
</table>
|
|
<script defer src="{{'js/sort_table.js' | asset}}"></script>
|
|
{% endblock %}
|