forked from MarseyWorld/MarseyWorld
626 lines
35 KiB
HTML
626 lines
35 KiB
HTML
{% extends "default.html" %}
|
|
|
|
|
|
{% block pagetype %}userpage{% endblock %}
|
|
|
|
{% block title %}
|
|
|
|
{% if u and u.profilecss and not request.values.get('nocss') %}
|
|
<link rel="stylesheet" href="/{{u.id}}/profilecss">
|
|
{% endif %}
|
|
|
|
<title>{{u.username}}'s profile - {{SITE_NAME}}</title>
|
|
<meta property="og:article:author" content="@{{u.username}}">
|
|
<meta property="article:section" content="{{u.username}}'s profile - {{SITE_NAME}}">
|
|
<meta property="article:published_time" content="{{u.created_date}}">
|
|
<meta property="og:description" name="description" content="{{u.coins}} coins - Joined {{u.created_date}} - {% if u.stored_subscriber_count >=1 and not u.is_private and not u.is_nofollow %}{{u.stored_subscriber_count}} Followers - {% endif %}{% if not u.is_private %} {{0 if u.shadowbanned else u.post_count}} Posts - {{0 if u.shadowbanned else u.comment_count}} Comments{% endif %}{% if u.bio %} - {{u.bio}}{% endif %}">
|
|
<meta property="og:author" name="author" content="@{{u.username}}">
|
|
<meta property="og:title" content="{{u.username}}">
|
|
<meta property="og:image" content="{{u.banner_url}}">
|
|
<meta property="og:url" content="{{u.url}}">
|
|
<meta property="og:site_name" content="{{SITE}}">
|
|
|
|
<meta name="twitter:card" content="summary_large_image">
|
|
<meta name="twitter:site" content="{{SITE_FULL}}">
|
|
<meta name="twitter:title" content="{{u.username}}'s profile - {{SITE_NAME}}">
|
|
<meta name="twitter:creator" content="@{{u.username}}">
|
|
<meta name="twitter:description" content="{{u.coins}} coins - Joined {{u.created_date}} - {% if u.stored_subscriber_count >=1 and not u.is_private and not u.is_nofollow %}{{u.stored_subscriber_count}} Followers -{% endif %} {% if not u.is_private %} {{0 if u.shadowbanned else u.post_count}} Posts - {{0 if u.shadowbanned else u.comment_count}} Comments{% endif %}{% if u.bio %} - {{u.bio}}{% endif %}">
|
|
<meta name="twitter:image" content="{{u.banner_url}}">
|
|
<meta name="twitter:url" content="{{u.url}}">
|
|
{% endblock %}
|
|
|
|
{% import 'userpage_admintools.html' as userpage_admintools with context %}
|
|
{% set hats_total = u.hats_owned_proportion_display[1] if u else 0 %}
|
|
{% set hats_owned_percent = u.hats_owned_proportion_display[0] if u else '' %}
|
|
|
|
{% block desktopUserBanner %}
|
|
|
|
<div class="row d-mob-none">
|
|
<div class="col px-0">
|
|
<div class="jumbotron jumbotron-fluid jumbotron-guild d-mob-none" {% if FEATURES['USERS_PROFILE_BANNER'] %}style="background-image: url({{u.banner_url}})"{% endif %}>
|
|
<div class="jumbotron-overlay"></div>
|
|
<div class="w-100 my-3">
|
|
<div class="container-fluid nobackground">
|
|
<div class="d-md-flex text-center text-md-left">
|
|
<div id="profile--pfp" {% if u.hat_active %}class="profile--pfp--hat hat"{% endif %}>
|
|
<a rel="nofollow noopener" href="{% if u.highres %}{{u.highres}}{% else %}{{u.profile_url}}{% endif %}" class="profile-pic-100-wrapper">
|
|
<img onclick="expandDesktopImage('{% if u.highres %}{{u.highres}}{% else %}{{u.profile_url}}{% endif %}')" loading="lazy" src="{{u.profile_url}}" class="profile-pic profile-pic-100 mb-5">
|
|
{% if u.hat_active -%}
|
|
<img onclick="expandDesktopImage('{% if u.highres %}{{u.highres}}{% else %}{{u.profile_url}}{% endif %}')" class="profile-pic-100-hat hat" loading="lazy" src="{{u.hat_active}}?h=7" data-bs-toggle="tooltip" data-bs-placement="bottom" title="{{u.hat_tooltip(v)}}">
|
|
{%- endif %}
|
|
</a>
|
|
</div>
|
|
<div id="profilestuff" class="ml-3 w-100">
|
|
{{userpage_admintools.userBanBlock('desktop')}}
|
|
<div class="d-flex align-items-center mt-1 mb-2">
|
|
<h3 class="font-weight-bolder my-0 mr-2" id="profile--name" style="color: #{{u.name_color}}"><span {% if u.patron %}class="patron" style="background-color:#{{u.name_color}}"{% endif %}>{{u.user_name}}</span></h3>
|
|
|
|
{% if u.username != u.original_username %}
|
|
<span id="profile--origname">
|
|
<i class="fas fa-user-tag text-info align-middle ml-2" data-bs-toggle="tooltip" data-bs-placement="bottom" title="Original Username: @{{u.original_username}}"></i>
|
|
</span>
|
|
{% endif %}
|
|
|
|
{% if FEATURES['PATRON_ICONS'] and u.patron %}
|
|
<img loading="lazy" class="ml-3" src="/i/{{SITE_NAME}}/patron_badges/2{{u.patron}}.webp?v=1" height="20" data-bs-toggle="tooltip" data-bs-placement="bottom" title="{{u.patron_tooltip}}" alt="{{u.patron_tooltip}}">
|
|
{% endif %}
|
|
|
|
{% if FEATURES['HOUSES'] and u.house %}
|
|
<img loading="lazy" class="ml-3" id="profile--house" src="/i/{{SITE_NAME}}/houses/{{u.house}}.webp?v=2000" height="20" data-bs-toggle="tooltip" data-bs-placement="bottom" title="House {{u.house}}" alt="House {{u.house}}">
|
|
{% endif %}
|
|
|
|
{% if u.verified %}
|
|
<span id="profile--verified"><i class="fas fa-badge-check align-middle ml-2 {% if u.verified=='Glowiefied' %}glow{% endif %}" style="color:{% if u.verifiedcolor %}#{{u.verifiedcolor}}{% else %}#1DA1F2{% endif %}" data-bs-toggle="tooltip" data-bs-placement="bottom" title="{{u.verified}}"></i></span>
|
|
{% endif %}
|
|
|
|
{% if u.admin_level >= PERMS['ADMIN_MOP_VISIBLE'] %}
|
|
<span id="profile--mop">
|
|
<i class="fas fa-broom text-admin align-middle ml-2" data-bs-toggle="tooltip" data-bs-placement="bottom" title="Admin"></i>
|
|
</span>
|
|
{% endif %}
|
|
{% if v and v.id != u.id and v.has_follower(u) %}
|
|
<span class="followsyou badge badge-secondary text-small align-middle ml-2" id="profile--follows-you">Follows you</span>
|
|
{% endif %}
|
|
</div>
|
|
|
|
{% if FEATURES['PRONOUNS'] %}
|
|
<p class="font-weight-bolder" id="profile--pronouns" style="color: #{{u.titlecolor}}">{{u.pronouns}}</p>
|
|
{% endif %}
|
|
|
|
{% if u.customtitle %}
|
|
<p class="font-weight-bolder" id="profile--flair" style="color: #{{u.titlecolor}}">{{u.customtitle | safe}}</p>
|
|
{% endif %}
|
|
|
|
{% if v and (v.id == u.id or v.admin_level >= PERMS['USER_VOTERS_VISIBLE']) -%}
|
|
<div class="font-weight-bolder mb-2" id="profile--simphate"><a class="mr-1" href="/@{{u.username}}/upvoters">Simps</a> | <a class="mx-1" href="/@{{u.username}}/downvoters">Haters</a> | <a class="mx-1" href="/@{{u.username}}/upvoting">Simps For</a> | <a class="mx-1" href="/@{{u.username}}/downvoting">Hates</a> | <a class="ml-1" href="/@{{u.username}}/upvoted/posts">Upvoted</a></div>
|
|
{%- endif %}
|
|
|
|
<div class="font-weight-bolder">
|
|
<span id="profile-coins-amount">{{u.coins}}</span>
|
|
<img alt="coins" class="ml-1 mb-1 mr-2" data-bs-toggle="tooltip" data-bs-placement="bottom" title="coins" height="20" src="{{'coins.webp' | asset_siteimg}}">
|
|
|
|
{% if FEATURES['PROCOINS'] %}
|
|
<span id="profile-bux-amount">{{u.procoins}}</span>
|
|
<img alt="marseybux" class="ml-1 mb-1 mr-2" data-bs-toggle="tooltip" data-bs-placement="bottom" title="Marseybux" height="20" width="46" src="/i/marseybux.webp?v=2000">
|
|
{% endif %}
|
|
|
|
{% if PERMS['USER_FOLLOWS_VISIBLE'] == 0 or (v and v.admin_level >= PERMS['USER_FOLLOWS_VISIBLE']) -%}
|
|
<a class="mr-2" href="/@{{u.username}}/followers" id="profile--followers">{{u.stored_subscriber_count}} follower{{'s' if u.stored_subscriber_count != 1 else ''}}</a>
|
|
|
|
<a class="mr-2" href="/@{{u.username}}/following" id="profile--following">follows {{u.follow_count}} user{{'s' if u.follow_count != 1 else ''}}</a>
|
|
{%- endif %}
|
|
|
|
<span id="profile--joined">joined <span id="profile--joined--time" data-bs-toggle="tooltip" data-bs-placement="bottom" onmouseover="timestamp('profile--joined--time','{{u.created_utc}}')">{{u.created_date}}</span></span>
|
|
|
|
{% if v and v.admin_level >= PERMS['VIEW_LAST_ACTIVE'] -%}
|
|
<span id="profile--lastactive" class="ml-2">last active <span id="profile--lastactive--time" data-bs-toggle="tooltip" data-bs-placement="bottom" onmouseover="timestamp('profile--lastactive--time','{{u.last_active}}')">{{u.last_active_date}}</span></span>
|
|
{%- endif %}
|
|
</div>
|
|
{% if u.basedcount %}<p class="text-muted" id="profile--based">Based Count: {{u.basedcount}}</p>{% endif %}
|
|
|
|
{% if FEATURES['USERS_PROFILE_BODYTEXT'] -%}
|
|
{% if u.bio_html %}
|
|
<div class="text-muted font-weight-bolder mt-1" id="profile--bio">{{u.bio_html | safe}}</div>
|
|
{% else %}
|
|
<p class="text-muted" id="profile--bio">No bio...</p>
|
|
{% endif %}
|
|
|
|
{% if u.friends_html %}
|
|
<p class="text-muted font-weight-bold">Friends:</p>
|
|
<div id="profile--friends">{{u.friends_html | safe}}</div>
|
|
{% endif %}
|
|
|
|
{% if u.enemies_html %}
|
|
<p class="text-muted font-weight-bold">Enemies:</p>
|
|
<div id="profile--enemies">{{u.enemies_html | safe}}</div>
|
|
{% endif %}
|
|
{%- endif %}
|
|
|
|
{% if u.received_awards and FEATURES['AWARDS'] %}
|
|
<div class="text-white rounded p-2 mb-3" id="profile--awards" style="background-color: rgba(50, 50, 50, 0.6); width: 30%;">
|
|
<p class="text-uppercase my-0" style="font-weight: bold; font-size: 12px;">Awards received</p>
|
|
{% for a in u.received_awards %}
|
|
<span class="d-inline-block mx-1 profile--awards--award">
|
|
<i class="{{a['icon']}} {{a['color']}} fa-fw" data-bs-toggle="tooltip" data-bs-placement="bottom" title="{{a['title']}} Awards received"></i>
|
|
x{{a['count']}}
|
|
</span>
|
|
{% endfor %}
|
|
</div>
|
|
{% endif %}
|
|
|
|
{% if u.moderated_subs %}
|
|
<div class="text-white rounded p-2 mb-3" id="profile--holes" style="background-color: rgba(50, 50, 50, 0.6); width: 30%;">
|
|
<p class="text-uppercase my-0 pb-1" style="font-weight: bold; font-size: 12px;">Moderator of</p>
|
|
{% for a in u.moderated_subs %}
|
|
<span class="d-inline-block mx-1">
|
|
<a href="/h/{{a['sub']}}">/h/{{a['sub']}}</a>
|
|
</span>
|
|
{% endfor %}
|
|
</div>
|
|
{% endif %}
|
|
|
|
<div class="d-flex justify-content-between align-items-center">
|
|
<div>
|
|
{% if v and v.id != u.id %}
|
|
<div id="profile--actionbtns">
|
|
<div class="actionbtns mb-3">
|
|
<button type="button" id="button-unsub" class="btn btn-secondary {% if not is_following %}d-none{% endif %}" onclick="postToastSwitch(this,'/unfollow/{{u.username}}','button-unsub','button-sub','d-none')">Unfollow</button>
|
|
|
|
<button type="button" id="button-sub" class="btn btn-primary {% if is_following or u.is_nofollow or u.is_blocked %}d-none{% endif %}" onclick="postToastSwitch(this,'/follow/{{u.username}}','button-unsub','button-sub','d-none')">Follow</button>
|
|
<button type="button" class="btn btn-primary" onclick="toggleElement('message', 'input-message')">Message</button>
|
|
|
|
{% if FEATURES['USERS_SUICIDE'] -%}
|
|
<button type="button" class="btn btn-primary" onclick="postToastSwitch(this,'/@{{u.username}}/suicide')">Get Them Help</button>
|
|
{%- endif %}
|
|
<button type="button" class="btn btn-primary" onclick="toggleElement('coin-transfer', 'coin-transfer-amount')">Gift Coins</button>
|
|
{% if FEATURES['PROCOINS'] -%}
|
|
<button type="button" class="btn btn-primary" onclick="toggleElement('bux-transfer', 'bux-transfer-amount')">Gift Marseybux</button>
|
|
{%- endif %}
|
|
|
|
<button type="button" class="btn btn-primary" onclick="postToastReload(this,'/settings/block?username={{u.username}}')">Block</button>
|
|
</div>
|
|
</div>
|
|
<form class="d-none toggleable" id="message" action="/@{{u.username}}/message" onsubmit="sendMessage(event)">
|
|
<input type="hidden" name="formkey" value="{{v.formkey}}">
|
|
<textarea autocomplete="off" id="input-message" form="message" name="message" rows="3" minlength="1" maxlength="10000" class="form-control b2 mt-1" data-preview="message-preview" oninput="markdown(this)" required></textarea>
|
|
<pre class="btn btn-secondary format d-inline-block m-0 fas fa-smile-beam" onclick="loadEmojis('input-message')" aria-hidden="true" data-bs-toggle="modal" data-bs-target="#emojiModal" data-bs-toggle="tooltip" data-bs-placement="bottom" title="Add Emoji"></pre>
|
|
|
|
<input type="submit" onclick="disable(this);remove_dialog()" value="Submit" class="btn btn-primary">
|
|
</form>
|
|
|
|
<div id="message-preview" class="preview mt-2"></div>
|
|
|
|
<div class="d-none mt-3 toggleable" id="coin-transfer">
|
|
<input autocomplete="off" id="coin-transfer-amount" class="form-control" name="amount" type="number" oninput="updateTax()">
|
|
<input autocomplete="off" id="coin-transfer-reason" maxlength=200 type="text" class="form-control" name="reason" placeholder="Gift message! (optional)">
|
|
<div>{{u.username}} will receive <span id="coins-transfer-taxed">0</span> coins</div>
|
|
<button type="button" class="btn btn-primary mt-2 mb-3" onclick="transferCoins(this)">Gift</button>
|
|
</div>
|
|
|
|
<div class="d-none mt-3 toggleable" id="bux-transfer">
|
|
<input autocomplete="off" id="bux-transfer-amount" class="form-control" name="amount" type="number" oninput="updateBux()">
|
|
<input autocomplete="off" id="bux-transfer-reason" type="text" class="form-control" name="reason" placeholder="Gift message! (optional)">
|
|
<div>{{u.username}} will receive <span id="bux-transfer-taxed">0</span> marseybux</div>
|
|
<button type="button" class="btn btn-primary mt-2 mb-3" onclick="transferBux(this)">Gift</button>
|
|
</div>
|
|
|
|
{{userpage_admintools.userAdminTools('desktop')}}
|
|
{% endif %}
|
|
|
|
<div class="actionbtns">
|
|
{% if v and v.id == u.id %}
|
|
<a href="/settings/profile" class="btn btn-secondary">Edit profile</a>
|
|
<a href="/views" class="btn btn-secondary">Profile views</a>
|
|
{% endif %}
|
|
|
|
{% if FEATURES['USERS_PROFILE_SONG'] and u.song and v and (v.id == u.id or v.mute and not u.unmutable) %}
|
|
<span>
|
|
<button type="button" class="btn btn-secondary" onclick="toggle()">Toggle anthem</button>
|
|
</span>
|
|
{% endif %}
|
|
</div>
|
|
|
|
<div class="mt-2" id="profile--info">
|
|
<p id="profile--info--id">User ID: {{u.id}}</p>
|
|
<p id="profile--info--spent">Coins spent: {{u.coins_spent}}</p>
|
|
<p id="profile--info--truescore">True score: {{u.truecoins}}</p>
|
|
<p id="profile--info--winnings">Winnings: {{u.winnings}}</p>
|
|
<p id="profile--info--hats-owned" {% if u.num_of_owned_hats >= hats_total %}class="profile-owned-all-hats"{% endif %}>{{u.num_of_owned_hats}} / {{hats_total}} hats owned ({{hats_owned_percent}})</p>
|
|
{% if u.is_private %}
|
|
<p id="profile--info--private">User has private mode enabled</p>
|
|
{% endif %}
|
|
{% if v and (v.admin_level >= PERMS['VIEW_ALTS'] or v.alt) %}
|
|
<span id="profile--alts">Alts:</span>
|
|
<ul id="profile--alts-list">
|
|
{% for account in u.alts_unique %}
|
|
<li><a href="{{account.url}}">@{{account.username}}</a>{% if account._is_manual %} [m]{% endif %}</li>
|
|
{% endfor %}
|
|
</ul>
|
|
{% endif %}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
{% if FEATURES['BADGES'] -%}
|
|
<div id="profile--badges">
|
|
{% for b in u.badges %}
|
|
{% if b.url %}
|
|
<a class="contain" rel="nofollow noopener" href="{{b.url}}">
|
|
<img alt="{{b.name}}" width=55 height=60 loading="lazy" src="{{b.path}}?b=4" data-bs-toggle="tooltip" data-bs-placement="bottom" title="{{b.text}}" {% if b.until %}data-until="{{b.until}}" onmouseover="badge_timestamp(this)"{% endif %}>
|
|
</a>
|
|
{% else %}
|
|
<img class="contain" alt="{{b.name}}" width=55 height=60 loading="lazy" src="{{b.path}}?b=4" data-bs-toggle="tooltip" data-bs-placement="bottom" title="{{b.text}}" {% if b.until %}data-until="{{b.until}}" onmouseover="badge_timestamp(this)"{% endif %}>
|
|
{% endif %}
|
|
{% endfor %}
|
|
</div>
|
|
{%- endif %}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{% endblock %}
|
|
|
|
{% block mobileUserBanner %}
|
|
<div class="container-fluid pb-0 text-center bg-white d-md-none" style="margin-top:-6px;border-radius:0!important;">
|
|
<div class="row">
|
|
<div class="col px-0">
|
|
<a rel="nofollow noopener" href="{{u.banner_url}}">
|
|
<img alt="@{{u.username}}'s banner" onclick="expandDesktopImage()" loading="lazy" src="{{u.banner_url}}" width=100% style="object-fit:cover;max-height:30vh!important">
|
|
</a>
|
|
</div>
|
|
</div>
|
|
<div class="row border-bottom">
|
|
<div class="col">
|
|
<div style="margin-top: -34px;" id="profile-mobile--pfp">
|
|
<a rel="nofollow noopener" href="{% if u.highres %}{{u.highres}}{% else %}{{u.profile_url}}{% endif %}" class="profile-pic-65-wrapper">
|
|
<img onclick="expandDesktopImage('{% if u.highres %}{{u.highres}}{% else %}{{u.profile_url}}{% endif %}')" loading="lazy" src="{{u.profile_url}}" class="profile-pic-65 bg-white mb-2">
|
|
{% if u.hat_active -%}
|
|
<img onclick="expandDesktopImage('{% if u.highres %}{{u.highres}}{% else %}{{u.profile_url}}{% endif %}')" class="profile-pic-65-hat hat" loading="lazy" src="{{u.hat_active}}?h=7">
|
|
{%- endif %}
|
|
</a>
|
|
</div>
|
|
<div class="mt-n3 py-3">
|
|
{{userpage_admintools.userBanBlock('mobile')}}
|
|
<h5 class=" d-inline-block" id="profile-mobile--name" style="color: #{{u.name_color}}"><span {% if u.patron %}class="patron" style="background-color:#{{u.name_color}}"{% endif %}>{{u.user_name}}</span></h5>
|
|
|
|
{% if u.username != u.original_username %}
|
|
<span id="profile-mobile--origname">
|
|
<i class="fas fa-user-tag text-info align-middle ml-2" data-bs-toggle="tooltip" data-bs-placement="bottom" title="Original Username: @{{u.original_username}}"></i>
|
|
</span>
|
|
{% endif %}
|
|
|
|
{% if FEATURES['PATRON_ICONS'] and u.patron %}
|
|
<img loading="lazy" class="ml-2" src="/i/{{SITE_NAME}}/patron_badges/2{{u.patron}}.webp?v=1" height="20" data-bs-toggle="tooltip" data-bs-placement="bottom" title="{{u.patron_tooltip}}" alt="{{u.patron_tooltip}}">
|
|
{% endif %}
|
|
|
|
{% if FEATURES['HOUSES'] and u.house %}
|
|
<img loading="lazy" class="ml-2" id="profile-mobile--house" src="/i/{{SITE_NAME}}/houses/{{u.house}}.webp?v=2000" height="20" data-bs-toggle="tooltip" data-bs-placement="bottom" title="House {{u.house}}" alt="House {{u.house}}">
|
|
{% endif %}
|
|
|
|
{% if u.verified %}
|
|
<span id="profile-mobile--verified"><i class="fas fa-badge-check align-middle ml-2 {% if u.verified=='Glowiefied' %}glow{% endif %}" style="color:{% if u.verifiedcolor %}#{{u.verifiedcolor}}{% else %}#1DA1F2{% endif %}" data-bs-toggle="tooltip" data-bs-placement="bottom" title="{{u.verified}}"></i></span>
|
|
{% endif %}
|
|
|
|
{% if u.admin_level >= PERMS['ADMIN_MOP_VISIBLE'] %}
|
|
<span id="profile-mobile--mop">
|
|
<i class="fas fa-broom text-admin align-middle ml-1" data-bs-toggle="tooltip" data-bs-placement="bottom" title="Admin"></i>
|
|
</span>
|
|
{% endif %}
|
|
{% if v and v.id != u.id and v.has_follower(u) and not v.is_nofollow %}
|
|
<span class="followsyou badge badge-secondary text-small align-middle mx-1" id="profile-mobile--follows-you">Follows you</span>
|
|
{% endif %}
|
|
|
|
{% if FEATURES['PRONOUNS'] %}
|
|
<p style="color: #{{u.titlecolor}}" id="profile-mobile--pronouns">{{u.pronouns}}</p>
|
|
{% endif %}
|
|
|
|
{% if u.customtitle %}
|
|
<p style="color: #{{u.titlecolor}}" id="profile-mobile--flair">{{u.customtitle | safe}}</p>
|
|
{% endif %}
|
|
|
|
{% if v and (v.id == u.id or v.admin_level >= PERMS['USER_VOTERS_VISIBLE']) -%}
|
|
<div class="font-weight-bolder mb-2" id="profile-mobile--simphate"><a class="mr-1" href="/@{{u.username}}/upvoters">Simps</a> | <a class="mx-1" href="/@{{u.username}}/downvoters">Haters</a> | <a class="mx-1" href="/@{{u.username}}/upvoting">Simps For</a> | <a class="mx-1" href="/@{{u.username}}/downvoting">Hates</a> | <a class="ml-1" href="/@{{u.username}}/upvoted/posts">Upvoted</a></div>
|
|
{%- endif %}
|
|
|
|
<div class="font-weight-normal">
|
|
<span id="profile-coins-amount-mobile" class="font-weight-bold">{{u.coins}}</span>
|
|
<img alt="coins" class="ml-1 mb-1 mr-2" data-bs-toggle="tooltip" data-bs-placement="bottom" title="coins" height="15" src="{{'coins.webp' | asset_siteimg}}">
|
|
|
|
{% if FEATURES['PROCOINS'] %}
|
|
<span id="profile-bux-amount-mobile" class="font-weight-bold">{{u.procoins}}</span>
|
|
<img alt="marseybux" class="ml-1 mb-1 mr-2" data-bs-toggle="tooltip" data-bs-placement="bottom" title="Marseybux" height="15" width="35" src="/i/marseybux.webp?v=2000">
|
|
{% endif %}
|
|
|
|
{% if PERMS['USER_FOLLOWS_VISIBLE'] == 0 or (v and v.admin_level >= PERMS['USER_FOLLOWS_VISIBLE']) -%}
|
|
<a href="/@{{u.username}}/followers" class="font-weight-bold mr-2" id="profile-mobile--followers">{{u.stored_subscriber_count}} follower{{'s' if u.stored_subscriber_count != 1 else ''}}</a>
|
|
|
|
<a href="/@{{u.username}}/following" class="font-weight-bold mr-2" id="profile-mobile--following" style="display:block">follows {{u.follow_count}} user{{'s' if u.follow_count != 1 else ''}}</a>
|
|
{%- endif %}
|
|
|
|
{% if u.basedcount %}
|
|
<br><span id="profile-mobile--based">Based count: {{u.basedcount}}</span>
|
|
{% endif %}
|
|
|
|
<br><span id="profile-mobile--joined">joined <span id="profile-mobile--joined--time" data-bs-toggle="tooltip" data-bs-placement="bottom" onmouseover="timestamp('profile-mobile--joined--time','{{u.created_utc}}')" class="font-weight-bold">{{u.created_date}}</span></span>
|
|
|
|
{% if v and v.admin_level >= PERMS['VIEW_LAST_ACTIVE'] -%}
|
|
<br><span id="profile-mobile--lastactive">last active <span id="profile-mobile--lastactive--time" data-bs-toggle="tooltip" data-bs-placement="bottom" onmouseover="timestamp('profile-mobile--lastactive--time','{{u.last_active}}')" class="font-weight-bold">{{u.last_active_date}}</span></span>
|
|
{%- endif %}
|
|
</div>
|
|
|
|
{% if FEATURES['USERS_PROFILE_BODYTEXT'] -%}
|
|
{% if u.bio_html %}
|
|
<div class="text-muted text-break" id="profile-mobile--bio">{{u.bio_html | safe}}</div>
|
|
{% endif %}
|
|
|
|
{% if u.friends_html %}
|
|
<p class="text-muted font-weight-bold mt-3">Friends:</p>
|
|
<div id="profile-mobile--friends">{{u.friends_html | safe}}</div>
|
|
{% endif %}
|
|
|
|
{% if u.enemies_html %}
|
|
<p class="text-muted font-weight-bold mt-3">Enemies:</p>
|
|
<div id="profile-mobile--enemies">{{u.enemies_html | safe}}</div>
|
|
{% endif %}
|
|
{%- endif %}
|
|
|
|
{% if u.received_awards and FEATURES['AWARDS'] %}
|
|
<div class="text-white rounded p-2 my-3 text-center" id="profile-mobile--awards" style="background-color: rgba(50, 50, 50, 0.6);">
|
|
<p class="text-uppercase my-0" style="font-weight: bold; font-size: 12px;">Awards received</p>
|
|
{% for a in u.received_awards %}
|
|
<span class="d-inline-block mx-1 profile-mobile--awards--award">
|
|
<i class="{{a['icon']}} {{a['color']}} fa-fw" data-bs-toggle="tooltip" data-bs-placement="bottom" title="{{a['title']}} Awards received"></i>
|
|
x{{a['count']}}
|
|
</span>
|
|
{% endfor %}
|
|
</div>
|
|
{% endif %}
|
|
|
|
{% if u.moderated_subs %}
|
|
<div class="text-white rounded p-2 mb-3" id="profile-mobile--holes" style="background-color: rgba(50, 50, 50, 0.6);">
|
|
<p class="text-uppercase my-0 pb-1" style="font-weight: bold; font-size: 12px;">Moderator of</p>
|
|
{% for a in u.moderated_subs %}
|
|
<span class="d-inline-block mx-1">
|
|
<a href="/h/{{a['sub']}}">/h/{{a['sub']}}</a>
|
|
</span>
|
|
{% endfor %}
|
|
</div>
|
|
{% endif %}
|
|
|
|
<div class="mb-3" id="profile-mobile--badges">
|
|
{% for b in u.badges %}
|
|
{% if b.url %}
|
|
<a rel="nofollow noopener" href="{{b.url}}">
|
|
<img class="contain" alt="{{b.name}}" width=29.33 height=32 loading="lazy" src="{{b.path}}?b=4" data-bs-toggle="tooltip" data-bs-placement="bottom" title="{{b.text}}" {% if b.until %}data-until="{{b.until}}" onmouseover="badge_timestamp(this)"{% endif %}>
|
|
</a>
|
|
{% else %}
|
|
<img class="contain" alt="{{b.name}}" width=29.33 height=32 loading="lazy" src="{{b.path}}?b=4" data-bs-toggle="tooltip" data-bs-placement="bottom" title="{{b.text}}" {% if b.until %}data-until="{{b.until}}" onmouseover="badge_timestamp(this)"{% endif %}>
|
|
{% endif %}
|
|
{% endfor %}
|
|
</div>
|
|
|
|
<div class="actionbtns">
|
|
{% if v and v.id == u.id %}
|
|
<a href="/settings/profile" class="btn btn-secondary ">Edit profile</a>
|
|
<a href="/views" class="btn btn-secondary">Profile views</a>
|
|
{% endif %}
|
|
|
|
{% if FEATURES['USERS_PROFILE_SONG'] and u.song and v and (v.id == u.id or v.mute and not u.unmutable) %}
|
|
<span>
|
|
<button type="button" class="btn btn-secondary" onclick="toggle()">Toggle anthem</button>
|
|
</span>
|
|
{% endif %}
|
|
|
|
{% if v and v.id != u.id %}
|
|
<button type="button" id="button-unsub2" class="btn btn-secondary {% if not is_following %}d-none{% endif %}" onclick="postToastSwitch(this,'/unfollow/{{u.username}}','button-unsub2','button-sub2','d-none')">Unfollow</button>
|
|
|
|
<button type="button" id="button-sub2" class="btn btn-primary {% if is_following or u.is_nofollow or u.is_blocked %}d-none{% endif %}" onclick="postToastSwitch(this,'/follow/{{u.username}}','button-unsub2','button-sub2','d-none')">Follow</button>
|
|
|
|
<button type="button" class="btn btn-primary" onclick="toggleElement('message-mobile', 'input-message-mobile')">Message</button>
|
|
{% if FEATURES['USERS_SUICIDE'] -%}
|
|
<button type="button" class="btn btn-primary" onclick="postToastSwitch(this,'/@{{u.username}}/suicide')">Get Them Help</button>
|
|
{%- endif %}
|
|
<button type="button" class="btn btn-primary" onclick="toggleElement('coin-transfer-mobile', 'coin-transfer-amount-mobile')">Gift Coins</button>
|
|
{% if FEATURES['PROCOINS'] -%}
|
|
<button type="button" class="btn btn-primary" onclick="toggleElement('bux-transfer-mobile', 'bux-transfer-amount-mobile')">Gift Marseybux</button>
|
|
{%- endif %}
|
|
|
|
<button type="button" class="btn btn-primary" onclick="postToastReload(this,'/settings/block?username={{u.username}}')">Block</button>
|
|
{% endif %}
|
|
</div>
|
|
|
|
{% if v and v.id != u.id %}
|
|
<form class="d-none toggleable" id='message-mobile' action="/@{{u.username}}/message" onsubmit="sendMessage(event)">
|
|
<input class="mt-1" type="hidden" name="formkey" value="{{v.formkey}}">
|
|
<textarea autocomplete="off" id="input-message-mobile" form="message-mobile" name="message" rows="3" minlength="1" maxlength="10000" class="form-control" data-preview="message-preview-mobile" oninput="markdown(this)" required></textarea>
|
|
<pre class="mt-1 btn btn-secondary format d-inline-block m-0 fas fa-smile-beam" onclick="loadEmojis('input-message-mobile')" aria-hidden="true" data-bs-toggle="modal" data-bs-target="#emojiModal" data-bs-toggle="tooltip" data-bs-placement="bottom" title="Add Emoji"></pre>
|
|
|
|
<input type="submit" onclick="disable(this);remove_dialog()" value="Submit" class="btn btn-primary">
|
|
</form>
|
|
|
|
<div id="message-preview-mobile" class="preview my-3"></div>
|
|
|
|
<div class="d-none mt-3 toggleable" id="coin-transfer-mobile">
|
|
<input autocomplete="off" id="coin-transfer-amount-mobile" class="form-control" name="amount" type="number" oninput="updateTax(true)">
|
|
<input autocomplete="off" id="coin-transfer-reason-mobile" maxlength=200 type="text" class="form-control" name="reason" placeholder="Gift message! (optional)">
|
|
<div>{{u.username}} will receive <span id="coins-transfer-taxed-mobile">0</span> coins</div>
|
|
<button type="button" class="btn btn-primary mt-2 mb-3" onclick="transferCoins(this, true)">Gift</button>
|
|
</div>
|
|
|
|
<div class="d-none mt-3 toggleable" id="bux-transfer-mobile">
|
|
<input autocomplete="off" id="bux-transfer-amount-mobile" class="form-control" name="amount" type="number" oninput="updateBux(true)">
|
|
<input autocomplete="off" id="bux-transfer-reason-mobile" type="text" class="form-control" name="reason" placeholder="Gift message! (optional)">
|
|
<div>{{u.username}} will receive <span id="bux-transfer-taxed-mobile">0</span> marseybux</div>
|
|
<button type="button" class="btn btn-primary mt-2 mb-3" onclick="transferBux(this, true)">Gift</button>
|
|
</div>
|
|
{{userpage_admintools.userAdminTools('mobile')}}
|
|
{% endif %}
|
|
|
|
<div class="mt-2" id="profile-mobile--info">
|
|
<p id="profile-mobile--info--id">User ID: {{u.id}}</p>
|
|
<p id="profile-mobile--info--spent">Coins spent: {{u.coins_spent}}</p>
|
|
<p id="profile-mobile--info--truescore">True score: {{u.truecoins}}</p>
|
|
<p id="profile-mobile--info--winnings">Winnings: {{u.winnings}}</p>
|
|
<p id="profile-mobile--info--hats-owned" {% if u.num_of_owned_hats >= hats_total %}class="profile-owned-all-hats"{% endif %}>{{u.num_of_owned_hats}} / {{hats_total}} hats owned ({{hats_owned_percent}})</p>
|
|
{% if u.is_private %}
|
|
<p id="profile-mobile--info--private">User has private mode enabled</p>
|
|
{% endif %}
|
|
{% if v and (v.admin_level >= PERMS['VIEW_ALTS'] or v.alt) %}
|
|
<span id="profile-mobile--alts">Alts:</span>
|
|
<ul id="profile-mobile--alts-list">
|
|
{% for account in u.alts_unique %}
|
|
<li><a href="{{account.url}}">@{{account.username}}</a>{% if account._is_manual %} [m]{% endif %}</li>
|
|
{% endfor %}
|
|
</ul>
|
|
{% endif %}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{% endblock %}
|
|
|
|
{% block content %}
|
|
|
|
<div id="profilecontent" class="row no-gutters">
|
|
<div class="col">
|
|
<div class="flex-row box-shadow-bottom d-flex justify-content-center justify-content-md-between align-items-center">
|
|
<ul class="nav settings-nav" id="profile-content--nav">
|
|
<li class="nav-item">
|
|
<a class="nav-link {% if not 'saved' in request.path %}active{% endif %}" href="/@{{u.username}}">Posts <span class="count">({{u.post_count}})</span></a>
|
|
</li>
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="/@{{u.username}}/comments">Comments <span class="count">({{u.comment_count}})</span></a>
|
|
</li>
|
|
{% if u.id == v.id %}
|
|
<li class="nav-item">
|
|
<a class="nav-link {% if '/saved/' in request.path %}active{% endif %}" href="/@{{u.username}}/saved/posts">Saved Posts <span class="count">({{u.saved_count}})</span></a>
|
|
</li>
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="/@{{u.username}}/saved/comments">Saved Comments <span class="count">({{u.saved_comment_count}})</span></a>
|
|
</li>
|
|
<li class="nav-item">
|
|
<a class="nav-link {% if '/subscribed/' in request.path %}active{% endif %}" href="/@{{u.username}}/subscribed/posts">Subscribed <span class="count">({{u.subscribed_count}})</span></a>
|
|
</li>
|
|
{% endif %}
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
{% if "/saved/" not in request.path and '/subscribed/' not in request.path %}
|
|
<div class="d-flex justify-content-between align-items-center" style="padding-top:10px">
|
|
|
|
<div class="d-flex align-items-center">
|
|
<div class="dropdown dropdown-actions">
|
|
<button type="button" class="btn btn-secondary dropdown-toggle" id="dropdownMenuButton" data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
|
|
{% if t=="hour" %}<i class="fas fa-clock mr-1"></i>
|
|
{% elif t=="day" %}<i class="fas fa-calendar-day mr-1"></i>
|
|
{% elif t=="week" %}<i class="fas fa-calendar-week mr-1"></i>
|
|
{% elif t=="month" %}<i class="fas fa-calendar-alt mr-1"></i>
|
|
{% elif t=="year" %}<i class="fas fa-calendar mr-1"></i>
|
|
{% elif t=="all" %}<i class="fas fa-infinity mr-1"></i>
|
|
{% endif %}
|
|
{{t | capitalize}}
|
|
</button>
|
|
<div class="dropdown-menu" aria-labelledby="dropdownMenuButton" x-placement="bottom-start" style="position: absolute; will-change: transform; top: 0px; left: 0px; transform: translate3d(0px, 31px, 0px);">
|
|
{% if t != "hour" %}<a class="dropdown-item" href="?sort={{sort}}&t=hour"><i class="fas fa-clock mr-2"></i>Hour</a>{% endif %}
|
|
{% if t != "day" %}<a class="dropdown-item" href="?sort={{sort}}&t=day"><i class="fas fa-calendar-day mr-2"></i>Day</a>{% endif %}
|
|
{% if t != "week" %}<a class="dropdown-item" href="?sort={{sort}}&t=week"><i class="fas fa-calendar-week mr-2"></i>Week</a>{% endif %}
|
|
{% if t != "month" %}<a class="dropdown-item" href="?sort={{sort}}&t=month"><i class="fas fa-calendar-alt mr-2"></i>Month</a>{% endif %}
|
|
{% if t != "year" %}<a class="dropdown-item" href="?sort={{sort}}&t=year"><i class="fas fa-calendar mr-2"></i>Year</a>{% endif %}
|
|
{% if t != "all" %}<a class="dropdown-item" href="?sort={{sort}}&t=all"><i class="fas fa-infinity mr-2"></i>All</a>{% endif %}
|
|
</div>
|
|
</div>
|
|
|
|
<div class="dropdown dropdown-actions ml-3">
|
|
<button type="button" class="btn btn-secondary dropdown-toggle" id="dropdownMenuButton2" data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
|
|
{% if sort=="top" %}<i class="fas fa-arrow-alt-circle-up mr-1"></i>{% endif %}
|
|
{% if sort=="bottom" %}<i class="fas fa-arrow-alt-circle-down mr-1"></i>{% endif %}
|
|
{% if sort=="new" %}<i class="fas fa-sparkles mr-1"></i>{% endif %}
|
|
{% if sort=="old" %}<i class="fas fa-book mr-1"></i>{% endif %}
|
|
{% if sort=="controversial" %}<i class="fas fa-bullhorn mr-1"></i>{% endif %}
|
|
{% if sort=="comments" %}<i class="fas fa-comments mr-1"></i>{% endif %}
|
|
{{sort | capitalize}}
|
|
</button>
|
|
<div class="dropdown-menu" aria-labelledby="dropdownMenuButton2" x-placement="bottom-start" style="position: absolute; will-change: transform; top: 0px; left: 0px; transform: translate3d(0px, 31px, 0px);">
|
|
{% if sort != "top" %}<a class="dropdown-item" href="?sort=top&t={{t}}"><i class="fas fa-arrow-alt-circle-up mr-2"></i>Top</a>{% endif %}
|
|
{% if sort != "bottom" %}<a class="dropdown-item" href="?sort=bottom&t={{t}}"><i class="fas fa-arrow-alt-circle-down mr-2"></i>Bottom</a>{% endif %}
|
|
{% if sort != "new" %}<a class="dropdown-item" href="?sort=new&t={{t}}"><i class="fas fa-sparkles mr-2"></i>New</a>{% endif %}
|
|
{% if sort != "old" %}<a class="dropdown-item" href="?sort=old&t={{t}}"><i class="fas fa-book mr-2"></i>Old</a>{% endif %}
|
|
{% if sort != "controversial" %}<a class="dropdown-item" href="?sort=controversial&t={{t}}"><i class="fas fa-bullhorn mr-2"></i>Controversial</a>{% endif %}
|
|
{% if sort != "comments" %}<a class="dropdown-item" href="?sort=comments&t={{t}}"><i class="fas fa-comments mr-2"></i>Comments</a>{% endif %}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{% endif %}
|
|
|
|
<div class="row no-gutters {% if listing %}mt-md-3{% elif not listing %}my-md-3{% endif %}" style="margin-top: 10px;">
|
|
|
|
<div class="col">
|
|
|
|
<div class="posts">
|
|
{% include "submission_listing.html" %}
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
{% if FEATURES['USERS_PROFILE_SONG'] and u.song %}
|
|
{% if v and v.id == u.id %}
|
|
<div id="v_username" class="d-none">{{v.username}}</div>
|
|
{% else %}
|
|
<div id="u_username" class="d-none">{{u.username}}</div>
|
|
{% endif %}
|
|
{% endif %}
|
|
|
|
{% if v %}
|
|
<div id='tax' class="d-none">{% if v.patron or u.patron or v.alts_patron or u.alts_patron %}0{% else %}0.03{% endif %}</div>
|
|
<script defer src="{{'js/userpage_v.js' | asset}}"></script>
|
|
<div id="username" class="d-none">{{u.username}}</div>
|
|
{% endif %}
|
|
|
|
<script defer src="{{'js/userpage.js' | asset}}"></script>
|
|
|
|
{% endblock %}
|
|
|
|
{% block pagenav %}
|
|
{% if listing %}
|
|
<nav aria-label="Page navigation">
|
|
<ul class="pagination pagination-sm mb-0">
|
|
{% if page>1 %}
|
|
<li class="page-item">
|
|
<small><a class="page-link" href="?page={{page-1}}&sort={{sort}}&t={{t}}" tabindex="-1">Prev</a></small>
|
|
</li>
|
|
{% else %}
|
|
<li class="page-item disabled"><span class="page-link">Prev</span></li>
|
|
{% endif %}
|
|
{% if next_exists %}
|
|
<li class="page-item">
|
|
<small><a class="page-link" href="?page={{page+1}}&sort={{sort}}&t={{t}}">Next</a></small>
|
|
</li>
|
|
{% else %}
|
|
<li class="page-item disabled"><span class="page-link">Next</span></li>
|
|
{% endif %}
|
|
</ul>
|
|
</nav>
|
|
{% endif %}
|
|
|
|
{% if not request.path.endswith('/comments') %}
|
|
<script defer src="{{'js/marked.js' | asset}}"></script>
|
|
{% endif %}
|
|
|
|
{% if v and v.id != u.id and '/comments' not in request.path %}
|
|
{% include "emoji_modal.html" %}
|
|
{% endif %}
|
|
|
|
{% endblock %}
|
|
|
|
{% block GIFpicker %}
|
|
{% endblock %}
|