mirror of
https://github.com/dkmstr/openuds.git
synced 2025-01-08 21:18:00 +03:00
Advancend & sync
This commit is contained in:
parent
7a742c043b
commit
971015d33a
@ -49,7 +49,7 @@ class Images(ModelHandler):
|
||||
'''
|
||||
Handles the gallery REST interface
|
||||
'''
|
||||
needs_admin = True
|
||||
# needs_admin = True
|
||||
|
||||
path = 'gallery'
|
||||
model = Image
|
||||
|
@ -51,7 +51,7 @@ class ServicesPoolGroups(ModelHandler):
|
||||
'''
|
||||
Handles the gallery REST interface
|
||||
'''
|
||||
needs_admin = True
|
||||
# needs_admin = True
|
||||
|
||||
path = 'gallery'
|
||||
model = ServicesPoolGroup
|
||||
|
@ -64,7 +64,7 @@ import logging
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
__updated__ = '2015-09-04'
|
||||
__updated__ = '2016-05-04'
|
||||
|
||||
# several constants as Width height, margins, ..
|
||||
WIDTH, HEIGHT = 1800, 1000
|
||||
@ -98,8 +98,8 @@ class AccessReport(UDSGeraldoReport):
|
||||
height=1 * cm,
|
||||
auto_expand_height=True,
|
||||
elements=(
|
||||
Label(text=_('Users access by date'), top=0.2 * cm, left=0, width=BAND_WIDTH,
|
||||
style={'fontName': 'Helvetica-Bold', 'fontSize': 12, 'alignment': TA_CENTER}),
|
||||
# Label(text=_('Users access by date'), top=0.2 * cm, left=0, width=BAND_WIDTH,
|
||||
# style={'fontName': 'Helvetica-Bold', 'fontSize': 12, 'alignment': TA_CENTER}),
|
||||
|
||||
Label(text=_('Pool'), top=1.0 * cm, left=1.2 * cm,
|
||||
style={'fontName': 'Helvetica-Bold', 'fontSize': 9}),
|
||||
|
@ -4,8 +4,8 @@ gui.servicesPools = new GuiElement(api.servicesPools, "servicespools")
|
||||
# To allow fast admin navigation
|
||||
gui.servicesPools.fastLink = (event, obj) ->
|
||||
gui.doLog 'FastLink clicked', obj
|
||||
event.preventDefault();
|
||||
event.stopPropagation();
|
||||
event.preventDefault()
|
||||
event.stopPropagation()
|
||||
$obj = $(obj);
|
||||
if $obj.hasClass('goServiceLink')
|
||||
vals = $obj.attr('href').substr(1).split(',')
|
||||
|
@ -173,9 +173,12 @@ launchSafari = (el, url, alt) ->
|
||||
), 2800
|
||||
|
||||
|
||||
uds.launch = (el) ->
|
||||
uds.launch = (el, url, alt) ->
|
||||
if url is undefined
|
||||
url = el.attr('data-href')
|
||||
url = if url? then url else el.attr('href')
|
||||
|
||||
if alt is undefined
|
||||
alt = el.attr('data-href-alt')
|
||||
|
||||
blockUI()
|
||||
@ -187,7 +190,6 @@ uds.launch = (el) ->
|
||||
type: "GET"
|
||||
dataType: "json"
|
||||
success: (data) ->
|
||||
|
||||
if data.error? and data.error isnt ''
|
||||
unblockUI()
|
||||
alert data.error
|
||||
|
0
server/src/uds/static/semantic/css/semantic.min.css
vendored
Executable file → Normal file
0
server/src/uds/static/semantic/css/semantic.min.css
vendored
Executable file → Normal file
@ -1,4 +1,4 @@
|
||||
.uds-body {
|
||||
/*.uds-body {
|
||||
display: flex;
|
||||
min-height: 100vh;
|
||||
flex-direction: column;
|
||||
@ -6,7 +6,7 @@
|
||||
|
||||
.uds-content {
|
||||
flex: 1;
|
||||
}
|
||||
}*/
|
||||
|
||||
footer {
|
||||
text-align: right;
|
||||
|
@ -3,6 +3,7 @@
|
||||
{% block title %}{% trans 'Available services list' %}{% endblock %}
|
||||
|
||||
{% block body %}
|
||||
{% if groups|length > 1 %}
|
||||
<ul class="nav nav-tabs nav-justified" id="services-tabs">
|
||||
{% for grp in groups %}
|
||||
<li{% if forloop.first %} class="active"{% endif %} data-name='tab-services-{{ forloop.counter }}'>
|
||||
@ -13,6 +14,7 @@
|
||||
{% comment %}<a href="#tab-services-{{ forloop.counter }}" data-toggle="tab" style="background: url('{% url 'galleryImage' grp.imageUuid %}') no-repeat left; display: block; background-size: 32px; min-width: 128px; padding-left: 32px; height: 40px;">{{ grp.name }}</a>{% endcomment %}
|
||||
</li>
|
||||
{% endfor %}
|
||||
{% endif %}
|
||||
</ul>
|
||||
<div class="tab-content">
|
||||
{% for grp in groups %}
|
||||
|
@ -24,11 +24,7 @@
|
||||
<ul class="nav navbar-nav navbar-right">
|
||||
<li><a href="{% url 'uds.web.views.about' %}">{% trans 'About' %}</a></li>
|
||||
<li class="dropdown">
|
||||
{% for lang in LANGUAGES %}
|
||||
{% if lang.0 == LANGUAGE_CODE %}
|
||||
<a href="#" class="dropdown-toggle" data-toggle="dropdown"><i class="fa fa-comments-o"></i> {% trans lang.1|capfirst %}<b class="caret"></b></a>
|
||||
{% endif %}
|
||||
{% endfor %}
|
||||
<a href="#" class="dropdown-toggle" data-toggle="dropdown"><i class="fa fa-comments-o"></i> {% trans LANGUAGE_INFO.name|capfirst %}<b class="caret"></b></a>
|
||||
<ul class="dropdown-menu">
|
||||
{% for lang in LANGUAGES %}
|
||||
{% if lang.0 != LANGUAGE_CODE %}
|
||||
|
@ -1,6 +1,7 @@
|
||||
{% load l10n i18n static html5 compress %}{% spaceless %}
|
||||
{% get_current_language as LANGUAGE_CODE %}
|
||||
{% get_available_languages as LANGUAGES %}
|
||||
{% get_language_info for LANGUAGE_CODE as LANGUAGE_INFO %}
|
||||
<!DOCTYPE html>{% endspaceless %}
|
||||
<html lang='{{LANGUAGE_CODE}}'>
|
||||
<head>
|
||||
|
@ -4,6 +4,7 @@
|
||||
|
||||
{% block body %}
|
||||
<div class="ui container">
|
||||
{% if groups|length > 1 %}
|
||||
<div class="ui top attached tabular menu">
|
||||
{% for grp in groups %}
|
||||
<a class="tab {% if forloop.first %}active{% endif %} item" data-group="{{ grp.name }}">
|
||||
@ -12,6 +13,7 @@
|
||||
</a>
|
||||
{% endfor %}
|
||||
</div>
|
||||
{% endif %}
|
||||
<div class="ui bottom attached segment">
|
||||
<p></p>
|
||||
</div>
|
||||
@ -21,11 +23,28 @@
|
||||
<i class="tag icon"></i> {% trans "Administrator info" %}
|
||||
</h4>
|
||||
<div class="ui segment">
|
||||
<p>{% trans "Ip" %}: {{ ip }}</p>
|
||||
{% with request.ip_proxy|add:",No Proxy" as proxy %}
|
||||
<p>{% trans "Ip" %}: {{ request.ip }}, {{ request.is_proxy|yesno:proxy }}</p>
|
||||
{% endwith %}
|
||||
<p>{% trans "Networks" %}: {{ nets }}</p>
|
||||
<p>{% trans "Transports" %}: {{ transports }}</p>
|
||||
<p>{% trans "User Agent" %}: {{ request.META.HTTP_USER_AGENT }}</p>
|
||||
<p>{% trans "OS" %}: {{ request.session.OS.OS }}</p>
|
||||
<p>{% trans "Browser Info" %}: {{ request.os }}</p>
|
||||
</div>
|
||||
<div class="trans-placeholder">
|
||||
<p></p>
|
||||
</div>
|
||||
|
||||
<div class="ui basic modal info">
|
||||
<i class="close icon"></i>
|
||||
<div class="header info">
|
||||
<p></p>
|
||||
</div>
|
||||
<div class="image content">
|
||||
<div class="description info">
|
||||
<p></p>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
{% endif %}
|
||||
|
||||
@ -37,14 +56,17 @@
|
||||
<!-- preloading of templates -->
|
||||
{% js_template_path 'uds/semantic/tmpl' %}
|
||||
{% js_template 'items' %}
|
||||
{% js_template 'trans' %}
|
||||
{% endblock %}
|
||||
|
||||
{% block js %}
|
||||
<script>
|
||||
var itemsTemplate = null;
|
||||
var transTemplate = null;
|
||||
|
||||
var groups = {
|
||||
{% for grp in groups %}
|
||||
"{{ grp.name }}": {
|
||||
"{{ grp.name|escape }}": {
|
||||
"items": [
|
||||
{% for ser in services %}
|
||||
{% if ser.group.name == grp.name and ser.transports %}
|
||||
@ -69,16 +91,111 @@ var groups = {
|
||||
{% endfor %}
|
||||
};
|
||||
|
||||
function getUrlVars() {
|
||||
var vars = [], hash;
|
||||
var hashes = window.location.href.slice(window.location.href.indexOf('?') + 1).split('&');
|
||||
for(var i = 0; i < hashes.length; i++)
|
||||
{
|
||||
hash = hashes[i].split('=');
|
||||
vars.push(hash[0]);
|
||||
vars[hash[0]] = hash[1];
|
||||
}
|
||||
return vars;
|
||||
}
|
||||
|
||||
function launch(el, url, alt) {
|
||||
if ( url.substring(0, 7) == 'udsa://' ) {
|
||||
uds.launch(el, url, alt);
|
||||
} else {
|
||||
window.location = url;
|
||||
}
|
||||
}
|
||||
|
||||
function showInfo(title, message) {
|
||||
$('.header.info').html(title);
|
||||
$('.description.info').html(message);
|
||||
$('.modal.info').modal('show');
|
||||
}
|
||||
|
||||
function canLaunch(item) {
|
||||
if( item.not_accesible == true ) {
|
||||
alert("Inaccesible");
|
||||
} else if( item.maintenance == true ) {
|
||||
showInfo('{% trans "In maintenance" %}', '{% trans "The service is currently in maintenance and cannot be accessed." %}');
|
||||
} else {
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
function showSelectedTabItems() {
|
||||
{% if groups|length > 1 %}
|
||||
var gName = $(".tab.active").attr('data-group');
|
||||
{% else %}
|
||||
var gName = "{{ groups.0.name }}";
|
||||
{% endif %}
|
||||
$('.attached.segment').html(itemsTemplate({
|
||||
'data': groups[gName].items
|
||||
}));
|
||||
|
||||
// $(".card").off();
|
||||
$(".card").on('click', function(){
|
||||
var gName = $('.tab.item.active').attr('data-group');
|
||||
var index = $(this).attr('data-item');
|
||||
var item = groups[gName].items[index];
|
||||
if( canLaunch(item) == false ) {
|
||||
return;
|
||||
}
|
||||
launch($(this), item.transports[0].link, "{% url 'uds.web.views.client_downloads' %}");
|
||||
});
|
||||
|
||||
$('.show-transports').on('click', function(event){
|
||||
var card = $(this).parent().parent();
|
||||
event.preventDefault();
|
||||
event.stopPropagation();
|
||||
var gName = $('.tab.item.active').attr('data-group');
|
||||
var index = $(this).closest('.card').attr('data-item');
|
||||
var item = groups[gName].items[index];
|
||||
if( canLaunch(item) == false ) {
|
||||
return;
|
||||
}
|
||||
// alert(groups[gName].items[index].transports[0]);
|
||||
// Remove all previous modals
|
||||
$('.ui.small.basic.modal').remove();
|
||||
$('.trans-placeholder').html(transTemplate({
|
||||
'data': item.transports
|
||||
}));
|
||||
$('.modal.transport')
|
||||
.modal({
|
||||
closable: true,
|
||||
transition: "fly left",
|
||||
offset: "",
|
||||
onVisible: function() {
|
||||
var $modal = $(this);
|
||||
$('.transport-link').on('click', function(ev){
|
||||
ev.preventDefault();
|
||||
ev.stopPropagation();
|
||||
$modal.modal('hide');
|
||||
launch(card, $(this).attr('data-link'), "{% url 'uds.web.views.client_downloads' %}");
|
||||
});
|
||||
}
|
||||
})
|
||||
.modal('show')
|
||||
;
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
// Ready function
|
||||
$(function(){
|
||||
itemsTemplate = Handlebars.compile($("#tmpl_items").html());
|
||||
transTemplate = Handlebars.compile($("#tmpl_trans").html());
|
||||
|
||||
$('.modal.info').modal({
|
||||
closable: true,
|
||||
transition: "horizontal flip",
|
||||
offset: "",
|
||||
});
|
||||
|
||||
showSelectedTabItems();
|
||||
$(".tab.item").on('click', function(){
|
||||
|
@ -9,7 +9,7 @@
|
||||
console.log(val, nonStandard);
|
||||
if( $.inArray(val.toString(), nonStandard) >= 0) {
|
||||
var vv = val;
|
||||
$("#login").hide(300, function() {
|
||||
$("#loginform").hide(300, function() {
|
||||
$.get('{%url "uds.web.views.customAuth" idAuth=''%}' + vv, function(data) {
|
||||
$('#nonStandardLogin').html(data);
|
||||
$('#nonStandard').show(300);
|
||||
@ -62,7 +62,7 @@
|
||||
{% block body %}
|
||||
<div class="ui three column grid">
|
||||
<div class="row">
|
||||
<div class="six wide column centered" id="login">
|
||||
<div class="six wide column centered doubling stackable" id="login">
|
||||
{% if form.errors %}
|
||||
<div class="alert alert-dismissable alert-danger">
|
||||
<button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button>
|
||||
|
@ -1,42 +1,62 @@
|
||||
{% load i18n html5 static %}
|
||||
{% preferences_allowed as show_prefs %}
|
||||
{% root_id as rootid %}
|
||||
<div class="ui menu doubling grid">
|
||||
<form id="form_language" action="{% url "django.views.i18n.set_language" %}" method="post">
|
||||
{% csrf_token %}
|
||||
<input type="hidden" name="language" id="id_language" value=""/>
|
||||
</form>
|
||||
<div class="computer tablet only ui menu grid">
|
||||
<a class="header item" href="/">
|
||||
<img class="ui mini spaced image" src="{% get_static_prefix %}img/udsicon.png">Universal Desktop Services
|
||||
</a>
|
||||
|
||||
<div class="right menu">
|
||||
<div class="item">
|
||||
<form id="form_language" action="{% url "django.views.i18n.set_language" %}" method="post">
|
||||
{% csrf_token %}
|
||||
<select class="ui search selection dropdown" id="id_language" type="hidden" name="language">
|
||||
<div class="ui dropdown item">
|
||||
{{ LANGUAGE_INFO.name }} <i class="dropdown icon"></i>
|
||||
<div class="menu">
|
||||
{% for lang in LANGUAGES %}
|
||||
<option value="{{ lang.0 }}"{% if lang.0 == LANGUAGE_CODE %} selected{%endif %}>{% trans lang.1|capfirst %}</option>
|
||||
<a class="item" onclick='$("#id_language").val("{{ lang.0 }}"); $("#form_language").submit()'>{% trans lang.1|capfirst %}</a>
|
||||
{% endfor %}
|
||||
</select>
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
<a class="item" href="{% url 'uds.web.views.about' %}">
|
||||
{% trans 'About' %}
|
||||
</a>
|
||||
{% if user and user.pk != None %}
|
||||
<div class="item">
|
||||
<div class="ui dropdown selection item">
|
||||
<i class="user icon"></i> {{ user.real_name }}
|
||||
{% include 'uds/semantic/snippets/user-menu.html' %}
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="mobile only ui stackable menu grid">
|
||||
<div class="ui styled fluid accordion">
|
||||
<div class="title">
|
||||
<img class="ui mini spaced image" src="{% get_static_prefix %}img/udsicon.png">
|
||||
Universal Desktop Services
|
||||
</div>
|
||||
<div class="content">
|
||||
<div class="ui styled fluid accordion">
|
||||
<div class="active title">
|
||||
<i class="dropdown icon"></i>
|
||||
<div class="menu">
|
||||
{% if show_prefs and user.id != rootid %}
|
||||
<a class="item" href="{% url "uds.web.views.prefs" %}"><i class="edit icon"></i> {% trans 'Preferences' %}</a>
|
||||
{% endif %}
|
||||
<a class="item" href="{% url "ClientDownload" %}"><i class="disk download icon"></i> {% trans 'UDS Plugin' %}</a>
|
||||
{% if user.staff_member or user.is_admin %}
|
||||
<a class="item" href="{% url "uds.web.views.download" idDownload='' %}"><i class="cloud download icon"></i> {% trans 'Downloads' %}</a>
|
||||
<a class="item" href="{% url "uds.admin.views.index" %}"><i class="dashboard icon"></i> {% trans 'Dashboard' %}</a>
|
||||
{% endif %}
|
||||
<a class="item" href="{% url "uds.web.views.logout" %}"><i class="toggle off icon"></i> {% trans 'Logout' %}</a>
|
||||
What is a dog?
|
||||
</div>
|
||||
<div class="active content">
|
||||
<p>A dog is a type of domesticated animal. Known for its loyalty and faithfulness, it can be found as a welcome guest in many households across the world.</p>
|
||||
</div>
|
||||
<div class="title">
|
||||
<i class="dropdown icon"></i>
|
||||
What kinds of dogs are there?
|
||||
</div>
|
||||
<div class="content">
|
||||
<p>There are many breeds of dogs. Each breed varies in size and temperament. Owners often select a breed of dog that they find to be compatible with their own lifestyle and desires from a companion.</p>
|
||||
</div>
|
||||
<div class="title">
|
||||
<i class="dropdown icon"></i>
|
||||
How do you acquire a dog?
|
||||
</div>
|
||||
<div class="content">
|
||||
<p>Three common ways for a prospective owner to acquire a dog is from pet shops, private owners, or shelters.</p>
|
||||
<p>A pet shop may be the most convenient way to buy a dog. Buying a dog from a private owner allows you to assess the pedigree and upbringing of your dog before choosing to take it home. Lastly, finding your dog from a shelter, helps give a good home to a dog who may not find one so readily.</p>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
{% endif %}
|
||||
</div>
|
||||
</div>
|
||||
|
@ -1,6 +1,7 @@
|
||||
{% load l10n i18n static html5 compress %}{% spaceless %}
|
||||
{% get_current_language as LANGUAGE_CODE %}
|
||||
{% get_available_languages as LANGUAGES %}
|
||||
{% get_language_info for LANGUAGE_CODE as LANGUAGE_INFO %}
|
||||
<!DOCTYPE html>{% endspaceless %}
|
||||
<html class="no-js" lang='{{LANGUAGE_CODE}}'>
|
||||
<head>
|
||||
@ -23,7 +24,7 @@
|
||||
{% endcompress %}
|
||||
</head>
|
||||
|
||||
<body class="uds-body">
|
||||
<body>
|
||||
<!-- Navigation bar -->
|
||||
{% block menu %}{% include 'uds/semantic/snippets/navbar.html' %}{% endblock %}
|
||||
{% ifbrowser ie<10 %}
|
||||
@ -68,9 +69,9 @@
|
||||
$('.ui.dropdown')
|
||||
.dropdown()
|
||||
;
|
||||
$('#id_language').on('change', function() {
|
||||
$('#form_language').submit();
|
||||
});
|
||||
$('.ui.accordion')
|
||||
.accordion()
|
||||
;
|
||||
})
|
||||
</script>
|
||||
<script type="text/coffeescript" charset="utf-8" src="{% get_static_prefix %}js/uds-client.coffee"></script>
|
||||
|
@ -1,8 +1,8 @@
|
||||
{% load i18n %}
|
||||
{% verbatim %}
|
||||
<div class="ui five doubling link cards">
|
||||
<div class="ui four doubling stackable link cards">
|
||||
{{#each data}}
|
||||
<div class="card">
|
||||
<div class="card" data-item="{{ @index }}">
|
||||
<div class="content">
|
||||
<div class="right floated mini ui image">
|
||||
<img src="{{ image }}">
|
||||
@ -19,9 +19,9 @@
|
||||
{{# if show_transports }}
|
||||
{{# compare transports.length 1 operator=">" }}
|
||||
<div class="extra content">
|
||||
<a>
|
||||
<a class="show-transports">
|
||||
<i class="open folder icon"></i>
|
||||
{% endverbatim %}{% trans 'Transports' %}{% verbatim %}{{ transports.length }}
|
||||
{% endverbatim %}{% trans 'Connections' %}{% verbatim %}
|
||||
</a>
|
||||
</div>
|
||||
{{/ compare }}
|
||||
|
@ -226,10 +226,10 @@ def pluginDownloadUrl(os):
|
||||
return tmpl.format(url=static('clients/UDSClientSetup-{version}.exe'.format(version=CLIENT_VERSION)), os='Windows')
|
||||
elif os == 'linux':
|
||||
linux_packages = (
|
||||
('udsclient_{version}_all.deb'.format(version=CLIENT_VERSION), _('Debian based Linux')),
|
||||
('udsclient-{version}-1.noarch.rpm'.format(version=CLIENT_VERSION), _('Red Hat based Linux (RH, Fedora, Centos, ...)')),
|
||||
('udsclient-opensuse-{version}-1.noarch.rpm'.format(version=CLIENT_VERSION), _('Suse based Linux')),
|
||||
('udsclient-{version}.tar.gz'.format(version=CLIENT_VERSION), _('Generic .tar.gz Linux'))
|
||||
('udsclient_{version}_all.deb'.format(version=CLIENT_VERSION), _('Debian based Linux') + ' ' + _('(requires Python-2.7)')),
|
||||
('udsclient-{version}-1.noarch.rpm'.format(version=CLIENT_VERSION), _('Red Hat based Linux (RH, Fedora, Centos, ...)') + ' ' + _('(requires Python-2.7)')),
|
||||
('udsclient-opensuse-{version}-1.noarch.rpm'.format(version=CLIENT_VERSION), _('Suse based Linux') + ' ' + _('(requires Python-2.7)')),
|
||||
('udsclient-{version}.tar.gz'.format(version=CLIENT_VERSION), _('Generic .tar.gz Linux') + ' ' + _('(requires Python-2.7)'))
|
||||
)
|
||||
res = ''
|
||||
for v in linux_packages:
|
||||
|
Loading…
Reference in New Issue
Block a user