You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
148 lines
6.7 KiB
148 lines
6.7 KiB
{% extends "layout.html" %}
|
|
|
|
{% block head %} <link rel="stylesheet" type="text/css" href="{{ url_for('static', filename='css/ts3_viewer.css') }}"> {% endblock %}
|
|
|
|
{% block title %}Dota Noobs{% endblock %}
|
|
|
|
{% block content %}
|
|
{% set teamspeak_data = get_teamspeak_window() %}
|
|
{% set latest_news = get_latest_news() %}
|
|
<div class="uk-grid">
|
|
|
|
<div id="events_large" class="uk-width-1-2 uk-visible-large uk-panel uk-panel-space">
|
|
{% include "events_widget.html" %}
|
|
</div>
|
|
|
|
<div id="teamspeak" class="uk-width-large-1-2 uk-width-medium-1-1 uk-panel uk-panel-box uk-text-center">
|
|
<a href="#" data-uk-modal="{target: '#tsviewer'}"><div class="uk-badge uk-panel-badge uk-badge-success"><i class="uk-icon-user"></i> Users</div></a>
|
|
<h1 class="uk-panel-title">Teamspeak</h1>
|
|
<div class="uk-grid uk-margin-bottom">
|
|
<div class="uk-width-1-3 uk-panel">
|
|
<h3>Users<br/><span class="ts_num">{{ ts3_current_clients() }}</span></h3>
|
|
</div>
|
|
<div class="uk-width-1-3 uk-panel">
|
|
<h3 class="uk-text-success">Online</h3>
|
|
</div>
|
|
<div class="uk-width-1-3 uk-panel">
|
|
<h3>Countries<br/><span class="ts_num">{{ ts3_countries_active(teamspeak_data) }}</span></h3>
|
|
</div>
|
|
</div>
|
|
|
|
<a class="uk-button uk-button-success uk-width-1-1" href="ts3server://voice.dotanoobs.com"><i class="uk-icon-microphone"></i> Connect</a>
|
|
<a class="uk-button uk-width-1-1 uk-margin" href="{{ url_for('teamspeak') }}"><i class="uk-icon-globe"></i> Stats</a>
|
|
<a class="uk-button uk-width-1-1" href="http://www.teamspeak.com/?page=downloads"><i class="uk-icon-download"></i> Download</a>
|
|
|
|
<div id="tsviewer" class="uk-modal uk-text-left">
|
|
<div class="uk-modal-dialog">
|
|
<a class="uk-modal-close uk-close"></a>
|
|
{{ ts3_viewer() | safe }}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div id="events_small" class="uk-width-1-1 uk-hidden-large uk-panel uk-panel-space">
|
|
{% include "events_widget.html" %}
|
|
</div>
|
|
|
|
<div id="streams" class="uk-width-1-1 uk-text-center uk-panel">
|
|
</div>
|
|
|
|
<div class="uk-width-1-1 uk-panel uk-panel-header uk-panel-space">
|
|
<h1 class="uk-panel-title">News and Announcements</h1>
|
|
{% for news in latest_news %}
|
|
<article class="uk-article dn-news-article">
|
|
<h4 class="uk-article-title" title="{{ news['title'] }}"><a href="{{ news['url'] }}">{{ news['title'] }}</a></h4>
|
|
<p class="uk-article-meta">{{ news['date'] }}</p>
|
|
<p>{{ news['text'] | shorten }}</p>
|
|
</article>
|
|
{% endfor %}
|
|
</div>
|
|
|
|
</div>
|
|
{# ERRORS WHEN CACHING WTF? DISABLE TEMPORARILY #}
|
|
{% cache 60*5 %}
|
|
{% endcache %}
|
|
{% endblock %}
|
|
|
|
{% block pagescripts %}
|
|
<script>
|
|
$(document).ready(function() {
|
|
if ($('#events_large > dl').length < 1) {
|
|
var msg = "<h2>Events</h2><em>No events planned for the near future. Suggest one on the forum!</em>"
|
|
$('#events_small').append(msg);
|
|
$('#events_large').append(msg);
|
|
}
|
|
|
|
// Add the twitch streams
|
|
var stream_url = "https://api.twitch.tv/kraken/streams/";
|
|
// var channels = ["dotanoobs", "bearhugdota", "kreejaffakree", "prettypenguins", "shaneomad"];
|
|
var channels = {{ streamers['twitch']|tojson|safe }};
|
|
for (var idx in channels) {
|
|
$.getJSON(stream_url+channels[idx]+"?callback=?", function(data) {
|
|
if (data.stream) {
|
|
var $a = $("<a href='"+data.stream.channel.url+"'></a>");
|
|
var $strm = $("<div class='dn-streamer uk-text-success uk-panel uk-panel-box' id='"+data.stream.channel.name+"'></div>");
|
|
|
|
$strm.append("<p class='uk-text-bold'>" + data.stream.channel.display_name + "</p>");
|
|
$strm.append("<img src='" + data.stream.preview.small + "' />");
|
|
$strm.append("<p><i class='uk-icon-male'></i> "+data.stream.viewers+"</p>");
|
|
|
|
$a.append($strm);
|
|
$("#streams").prepend($a);
|
|
|
|
} else {
|
|
$.getJSON(data._links.channel+"?callback=?", function(data) {
|
|
var $a = $("<a href='"+data.url+"'></a>");
|
|
var $strm = $("<div class='dn-streamer-offline uk-text-success uk-panel uk-panel-box' id='"+data.name+"'></div>");
|
|
|
|
$strm.append("<p class='uk-text-bold'>" + data.display_name + "</p>");
|
|
$strm.append("<img src='" + data.logo + "' />");
|
|
$strm.append("<p class='dn-offline'>Offline</p>");
|
|
|
|
$a.append($strm);
|
|
$("#streams").append($a);
|
|
});
|
|
}
|
|
});
|
|
}
|
|
|
|
// Add the hitbox streams
|
|
var stream_url = "http://api.hitbox.tv/media/live/";
|
|
//var channels = ["Bandita", "Gibb3d"];
|
|
var channels = {{ streamers['hitbox']|tojson|safe }};
|
|
for (var idx in channels) {
|
|
$.getJSON(stream_url+channels[idx], function(data) {
|
|
var livestream = data.livestream[0];
|
|
var $a = $("<a href='"+livestream.channel.channel_link+"'></a>");
|
|
if (livestream.media_is_live == "1") {
|
|
var $strm = $("<div class='dn-streamer uk-text-success uk-panel uk-panel-box' id='"+livestream.media_name+"'></div>");
|
|
$strm.append("<p class='uk-text-bold'>" + livestream.media_user_name + "</p>");
|
|
$strm.append("<img src='http://edge.sf.hitbox.tv" + livestream.media_thumbnail + "' />");
|
|
$strm.append("<p><i class='uk-icon-male'></i> " + livestream.media_views + "</p>");
|
|
|
|
$a.append($strm);
|
|
$("#streams").prepend($a);
|
|
|
|
} else {
|
|
var $strm = $("<div class='dn-streamer-offline uk-text-success uk-panel uk-panel-box' id='"+livestream.media_name+"'></div>");
|
|
$strm.append("<p class='uk-text-bold'>" + livestream.media_user_name + "</p>");
|
|
$strm.append("<img src='http://edge.sf.hitbox.tv" + livestream.channel.user_logo + "' />");
|
|
$strm.append("<p class='dn-offline'>Offline</p>");
|
|
|
|
$a.append($strm);
|
|
$("#streams").append($a);
|
|
}
|
|
});
|
|
}
|
|
|
|
$("#streams").on({
|
|
mouseover: function() {
|
|
$(this).addClass('dn-streamer-hover');
|
|
},
|
|
mouseleave: function() {
|
|
$(this).removeClass('dn-streamer-hover');
|
|
}
|
|
}, "div");
|
|
});
|
|
</script>
|
|
{% endblock %}
|