Merge pull request #259 from orbitroom/master

Added ability to edit structure timers
This commit is contained in:
Mr McClain 2016-02-11 21:16:43 -06:00
commit 3b3c4cbb00
4 changed files with 115 additions and 3 deletions

View File

@ -143,6 +143,7 @@ urlpatterns = patterns('',
url(r'^timers/$', 'timerboard.views.timer_view', name='auth_timer_view'), url(r'^timers/$', 'timerboard.views.timer_view', name='auth_timer_view'),
url(r'^add_timer/$', 'timerboard.views.add_timer_view', name='auth_add_timer_view'), url(r'^add_timer/$', 'timerboard.views.add_timer_view', name='auth_add_timer_view'),
url(r'^remove_timer/(\w+)', 'timerboard.views.remove_timer', name='auth_remove_timer'), url(r'^remove_timer/(\w+)', 'timerboard.views.remove_timer', name='auth_remove_timer'),
url(r'^edit_timer/(\w+)$', 'timerboard.views.edit_timer', name='auth_edit_timer'),
# SRP URLS # SRP URLS
url(r'^srp/$', 'srp.views.srp_management', name='auth_srp_management_view'), url(r'^srp/$', 'srp.views.srp_management', name='auth_srp_management_view'),

View File

@ -114,6 +114,10 @@
<a href="/remove_timer/{{ closest_timer.id }}"> <a href="/remove_timer/{{ closest_timer.id }}">
<button type="button" class="btn btn-danger"><span <button type="button" class="btn btn-danger"><span
class="glyphicon glyphicon-remove"></span></button> class="glyphicon glyphicon-remove"></span></button>
</a>
<a href="/edit_timer/{{ closest_timer.id }}">
<button type="button" class="btn btn-info"><span
class="glyphicon glyphicon-pencil"></span></button>
</a> </a>
</td> </td>
{% endif %} {% endif %}
@ -213,6 +217,9 @@
<button type="button" class="btn btn-danger"><span <button type="button" class="btn btn-danger"><span
class="glyphicon glyphicon-remove"></span></button> class="glyphicon glyphicon-remove"></span></button>
</a> </a>
<a href="/edit_timer/{{ timer.id }}">
<button type="button" class="btn btn-info"><span
class="glyphicon glyphicon-pencil"></span></button>
</td> </td>
{% endif %} {% endif %}
</tr> </tr>
@ -312,6 +319,9 @@
<button type="button" class="btn btn-danger"><span <button type="button" class="btn btn-danger"><span
class="glyphicon glyphicon-remove"></span></button> class="glyphicon glyphicon-remove"></span></button>
</a> </a>
<a href="/edit_timer/{{ timer.id }}">
<button type="button" class="btn btn-info"><span
class="glyphicon glyphicon-pencil"></span></button>
</td> </td>
{% endif %} {% endif %}
</tr> </tr>

View File

@ -0,0 +1,45 @@
{% extends "public/base.html" %}
{% load bootstrap %}
{% load staticfiles %}
{% block title %}Alliance Auth - Update Structure Timer {% endblock %}
{% block page_title %}Update AAR Link{% endblock page_title %}
{% block extra_css %}
<link href="{% static 'css/jquery.datetimepicker.css' %}" rel="stylesheet" type="text/css">{% endblock extra_css %}
{% block content %}
<div class="col-lg-12">
<h1 class="page-header text-center">Update Structure Timer</h1>
<div class="container-fluid">
<div class="col-md-4 col-md-offset-4">
<div class="row">
{% if no_fleet_id %}
<div class="alert alert-danger" role="alert">Structure Timer Does Not Exist</div>
{% else %}
<form class="form-signin" role="form" action="" method="POST">
{% csrf_token %}
{{ form|bootstrap }}
<br/>
<button class="btn btn-lg btn-primary btn-block" type="submit">Update Structure Timer
</button>
</form>
{% endif %}
</div>
</div>
</div>
</div>
{% endblock content %}
{% block extra_script %}
$('#id_fleet_time').datetimepicker({
maskInput: true,
format: 'Y-m-d H:i',minDate:0
});
{% endblock extra_script %}

View File

@ -5,7 +5,9 @@ from django.template import RequestContext
from django.shortcuts import render_to_response from django.shortcuts import render_to_response
from django.contrib.auth.decorators import login_required from django.contrib.auth.decorators import login_required
from django.contrib.auth.decorators import permission_required from django.contrib.auth.decorators import permission_required
from django.shortcuts import get_object_or_404
from django.contrib.auth.decorators import user_passes_test from django.contrib.auth.decorators import user_passes_test
from django.utils import timezone
from util import check_if_user_has_permission from util import check_if_user_has_permission
from authentication.managers import AuthServicesInfoManager from authentication.managers import AuthServicesInfoManager
@ -13,6 +15,7 @@ from eveonline.managers import EveManager
from form import TimerForm from form import TimerForm
from models import Timer from models import Timer
import logging import logging
logger = logging.getLogger(__name__) logger = logging.getLogger(__name__)
@ -40,8 +43,7 @@ def timer_view(request):
closest_timer = None closest_timer = None
if timer_list: if timer_list:
closest_timer = \ closest_timer = \
sorted(list(Timer.objects.all().filter(corp_timer=False)), key=lambda d: abs(datetime.datetime.now() - d.eve_time.replace(tzinfo=None)))[ sorted(list(Timer.objects.all().filter(corp_timer=False)), key=lambda d: (timezone.now()))[0]
0]
logger.debug("Determined closest timer is %s" % closest_timer) logger.debug("Determined closest timer is %s" % closest_timer)
render_items = {'timers': Timer.objects.all().filter(corp_timer=False), render_items = {'timers': Timer.objects.all().filter(corp_timer=False),
'corp_timers': corp_timers, 'corp_timers': corp_timers,
@ -65,7 +67,7 @@ def add_timer_view(request):
logger.debug("Determined timer add request on behalf of character %s corporation %s" % (character, corporation)) logger.debug("Determined timer add request on behalf of character %s corporation %s" % (character, corporation))
# calculate future time # calculate future time
future_time = datetime.timedelta(days=form.cleaned_data['days_left'], hours=form.cleaned_data['hours_left'], minutes=form.cleaned_data['minutes_left']) future_time = datetime.timedelta(days=form.cleaned_data['days_left'], hours=form.cleaned_data['hours_left'], minutes=form.cleaned_data['minutes_left'])
current_time = datetime.datetime.utcnow() current_time = timezone.now()
eve_time = current_time + future_time eve_time = current_time + future_time
logger.debug("Determined timer eve time is %s - current time %s, adding %s" % (eve_time, current_time, future_time)) logger.debug("Determined timer eve time is %s - current time %s, adding %s" % (eve_time, current_time, future_time))
# handle valid form # handle valid form
@ -104,3 +106,57 @@ def remove_timer(request, timer_id):
else: else:
logger.error("Unable to delete timer id %s for user %s - timer matching id not found." % (timer_id, request.user)) logger.error("Unable to delete timer id %s for user %s - timer matching id not found." % (timer_id, request.user))
return HttpResponseRedirect("/timers/") return HttpResponseRedirect("/timers/")
@login_required
@permission_required('auth.timer_management')
def edit_timer(request, timer_id):
logger.debug("edit_timer called by user %s for timer id %s" % (request.user, timer_id))
timer = get_object_or_404(Timer, id=timer_id)
if request.method == 'POST':
form = TimerForm(request.POST)
logger.debug("Received POST request containing updated timer form, is valid: %s" % form.is_valid())
if form.is_valid():
auth_info = AuthServicesInfoManager.get_auth_service_info(request.user)
character = EveManager.get_character_by_id(auth_info.main_char_id)
corporation = EveManager.get_corporation_info_by_id(character.corporation_id)
logger.debug("Determined timer edit request on behalf of character %s corporation %s" % (character, corporation))
# calculate future time
future_time = datetime.timedelta(days=form.cleaned_data['days_left'], hours=form.cleaned_data['hours_left'], minutes=form.cleaned_data['minutes_left'])
current_time = datetime.datetime.utcnow()
eve_time = current_time + future_time
logger.debug("Determined timer eve time is %s - current time %s, adding %s" % (eve_time, current_time, future_time))
timer.details = form.cleaned_data['details']
timer.system = form.cleaned_data['system']
timer.planet_moon = form.cleaned_data['planet_moon']
timer.structure = form.cleaned_data['structure']
timer.objective = form.cleaned_data['objective']
timer.eve_time = eve_time
timer.important = form.cleaned_data['important']
timer.corp_timer = form.cleaned_data['corp_timer']
timer.eve_character = character
timer.eve_corp = corporation
logger.info("User %s updating timer id %s " % (request.user, timer_id))
timer.save()
logger.debug("Detected no changes between timer id %s and supplied form." % timer_id)
return HttpResponseRedirect("/timers/")
else:
current_time = timezone.now()
td = timer.eve_time - current_time
tddays, tdhours, tdminutes = td.days, td.seconds // 3600, td.seconds // 60 % 60
data = {
'details': timer.details,
'system': timer.system,
'planet_moon': timer.planet_moon,
'structure': timer.structure,
'objective': timer.objective,
'important': timer.important,
'corp_timer': timer.corp_timer,
'days_left': tddays,
'hours_left': tdhours,
'minutes_left': tdminutes,
}
form = TimerForm(initial= data)
return render_to_response('registered/timerupdate.html', {'form':form}, context_instance=RequestContext(request))