ninegate/src/ninegate-1.0/src/Cadoles/PortalBundle/Resources/views/Calendar/view.html.twig

886 lines
41 KiB
Twig

{% extends '@CadolesCore/base.html.twig' %}
{% block pagewrapper %}
{% if access=="config" %}
<div class="pagemenu">
<a href="{{ path('cadoles_portal_config_calendar_view', {id:entity.id})}}">{{ entity.name }}</a>
<a href='{{ path('cadoles_portal_config_calendar_update', {id:entity.id}) }}' title='Modifier le panel'><i class='fa fa-cog fa-fw'></i></a>
<a href='{{ path('cadoles_portal_config_calendar_delete', { id: entity.id }) }}' data-method='delete' data-confirm='Êtes-vous sûr de vouloir supprimer ?' title='Supprimer le panel'><i class='fa fa-trash fa-fw'></i></a>
</div>
{% else %}
<div style="margin:10px 0px 10px 0px; text-align:left;height:34px;">
{% if not idpage is empty %}
<a href="{{path('cadoles_portal_user_page_view',{id:idpage,usage:'group',group:idgroup})}}" class="btn btn-success">Revenir sur le Groupe</a>
{% endif %}
</div>
<ul class="nav navbar-default nav-pills">
<li id="menucalendar-0" class="{% if entity.id is not defined %}active{%endif%}" style="cursor:pointer">
<a href="{{ path("cadoles_portal_user_calendar_view") }}">
Tout
</a>
</li>
{% for calendar in calendars %}
<li id="menucalendar-{{calendar.id}}" data-open="{% if calendar.canupdate %}true{%endif%}" class="{% if entity.id is defined and entity.id==calendar.id%}active{%endif%}" style="cursor:pointer">
<a href="{{ path("cadoles_portal_user_calendar_view",{'id':calendar.id}) }}">
{% if not calendar.groups is empty %}
<i class="fa fa-users fa-fw"></i>
{% elseif app.user==calendar.user %}
<i class="fa fa-user fa-fw"></i>
{%endif%}
{{ calendar.name }}
{% if calendar.canadd %}
<i class="fa fa-pencil"></i>
{% else %}
<i class="fa fa-lock"></i>
{% endif %}
</a>
</li>
{% endfor %}
{% if canupdate %}
<li><a id="menusubmit" style="cursor:pointer" onclick="submitCalendar()" title='Ajouter un calendrier'><i class='fa fa-plus fa-fw'></i></a></li>
{% endif %}
<li><a id="menuupdate" style="cursor:pointer;display:none" onclick="updateCalendar()" title='Modifier un calendrier'><i class='fa fa-file fa-fw'></i></a></li>
<li><a id="menushare" style="cursor:pointer;display:none" onclick="shareCalendar()" title='Partager un calendrier'><i class='fa fa-share-alt fa-fw'></i></a></li>
<li><a id="menudelete" style="cursor:pointer;display:none" onclick="deleteCalendar()" title='Supprimer un calendrier'><i class='fa fa-trash fa-fw'></i></a></li>
</ul>
<br>
{% endif %}
<div id="calendar"></div>
<!-- CREATION EVENEMENT -->
<div id="mymodal-event-add" class="modal fade" tabindex="-1" role="dialog">
<div class="modal-dialog modal-lg">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>
<h4 class="modal-title">Création Evénement</h4>
</div>
<div class="modal-body">
<input id='vladd' name='vladd' class='btn btn-success' type='submit' onClick='submitEvent(false);' value='Valider' />
<input id='vladdpj' name='vladdpj' class='btn btn-success' type='submit' onClick='submitEvent(true);' value='Ajouter des PJ' />
&nbsp;
<input class='btn btn-default' type='submit' value='Annuler' onClick='$("#mymodal-event-add").modal("hide");'>
<input name="calendar_id" id="calendar_id" type="hidden" class="form-control" placeholder="Nom">
<input name="envent_id" id="envent_id" type="hidden" class="form-control" placeholder="Nom">
<fieldset class="fieldset form-horizontal" style="clear:both; margin-top:30px;">
<div class="form-group">
<label for="event_calendar" class="col-sm-3 control-label">Calendrier*</label>
<div class="col-sm-9">
<select name="event_calendar" id="event_calendar" class="form-control">
{% if access=="config" %}
{% for calendar in calendars %}
<option value='{{ calendar.id}}'>{{ calendar.name}}</option>
{% endfor %}
{% else %}
{% for calendar in calendars %}
{% if calendar.canadd %}
<option value='{{ calendar.id}}'>{{ calendar.name}}</option>
{% endif %}
{% endfor %}
{% endif %}
</select>
</div>
</div>
<div class="form-group">
<label for="event_title" class="col-sm-3 control-label">Titre*</label>
<div class="col-sm-9"><input name="event_title" id="event_title" type="titre" class="form-control focus" placeholder="Titre"></div>
</div>
<div class="form-group">
<label for="event_description" class="col-sm-3 control-label">Description</label>
<div class="col-sm-9"><textarea style="height:150px" name="event_description" id="event_description-add" type="titre" class="form-control focus" placeholder="Description"></textarea></div>
</div>
<div class="form-group">
<label for="event_allday" class="col-sm-3 control-label">Evènement sur la journée*</label>
<div class="col-sm-9"><input id="event_allday" name="event_allday" type="checkbox" class="switch" onChange="switchallDay('SUBMIT');"></div>
</div>
<div class="form-group" id="form_event_start_time">
<label for="date" class="col-sm-3 control-label">Date Début*</label>
<div class="col-sm-9"><input name="event_start_time" id="event_start_time" type="titre" class="form-control" placeholder="Date Début" value=""></div>
</div>
<div class="form-group" id="form_event_end_time">
<label for="date" class="col-sm-3 control-label">Date Fin*</label>
<div class="col-sm-9"><input name="event_end_time" id="event_end_time" type="titre" class="form-control" placeholder="Date Fin" value=""></div>
</div>
<div class="form-group" id="form_event_start">
<label for="date" class="col-sm-3 control-label">Date Début*</label>
<div class="col-sm-9"><input name="event_start" id="event_start" type="titre" class="form-control" placeholder="Date Début" value=""></div>
</div>
<div class="form-group" id="form_event_end">
<label for="date" class="col-sm-3 control-label">Date Fin*</label>
<div class="col-sm-9"><input name="event_end" id="event_end" type="titre" class="form-control" placeholder="Date Fin" value=""></div>
</div>
</fieldset>
</div>
</div>
</div>
</div>
<!-- UPDATE / DELETE EVENEMENT -->
<div id="mymodal-event-mod" class="modal fade" tabindex="-1" role="dialog">
<div class="modal-dialog modal-lg">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>
<h4 class="modal-title">Evénement</h4>
</div>
<div class="modal-body">
<input id='vladd' name='vladd' class='btn btn-success' type='submit' onClick='updateEvent();' value='Valider' />
&nbsp;
<input class="btn btn-primary" type='submit' value='Partager' onClick='shareEvent();' />
&nbsp;
<input class="btn btn-primary" type='submit' value='Cloner' onClick='showcloneEvent();' />
&nbsp;
<input class='btn btn-default' type='submit' value='Annuler' onClick='$("#mymodal-event-mod").modal("hide");'>
<input name="calendar_id" id="calendar_id" type="hidden" class="form-control" placeholder="Nom">
<input name="event_id" id="event_id" type="hidden" class="form-control" placeholder="Nom">
<fieldset class="fieldset form-horizontal" style="clear:both; margin-top:30px;">
<div class="form-group">
<label for="event_calendar" class="col-sm-3 control-label">Calendrier*</label>
<div class="col-sm-9">
<select name="event_calendar" id="event_calendar" class="form-control">
{% if access=="config" %}
{% for calendar in calendars %}
<option value='{{ calendar.id}}'>{{ calendar.name}}</option>
{% endfor %}
{% else %}
{% for calendar in calendars %}
{% if calendar.canadd %}
<option value='{{ calendar.id}}'>{{ calendar.name}}</option>
{% endif %}
{% endfor %}
{% endif %}
</select>
</div>
</div>
<div class="form-group">
<label for="event_title" class="col-sm-3 control-label">Titre*</label>
<div class="col-sm-9"><input name="event_title" id="event_title" type="titre" class="form-control focus" placeholder="Titre"></div>
</div>
<div class="form-group">
<label for="event_allday" class="col-sm-3 control-label">Evènement sur la journée*</label>
<div class="col-sm-9"><input id="event_allday" name="event_allday" type="checkbox" class="switch" onChange="switchallDay('UPDATE');"></div>
</div>
<div class="form-group" id="form_event_start_time">
<label for="date" class="col-sm-3 control-label">Date Début*</label>
<div class="col-sm-9"><input name="event_start_time" id="event_start_timem" type="titre" class="form-control" placeholder="Date Début" value=""></div>
</div>
<div class="form-group" id="form_event_end_time">
<label for="date" class="col-sm-3 control-label">Date Fin*</label>
<div class="col-sm-9"><input name="event_end_time" id="event_end_timem" type="titre" class="form-control" placeholder="Date Fin" value=""></div>
</div>
<div class="form-group" id="form_event_start">
<label for="date" class="col-sm-3 control-label">Date Début*</label>
<div class="col-sm-9"><input name="event_start" id="event_startm" type="titre" class="form-control" placeholder="Date Début" value=""></div>
</div>
<div class="form-group" id="form_event_end">
<label for="date" class="col-sm-3 control-label">Date Fin*</label>
<div class="col-sm-9"><input name="event_end" id="event_endm" type="titre" class="form-control" placeholder="Date Fin" value=""></div>
</div>
<div class="form-group">
<div class="col-sm-12"><textarea style="height:150px" name="event_description" id="event_description-mod" type="titre" class="form-control focus" placeholder="Description"></textarea></div>
</div>
<div id="event_PJ"></div>
</fieldset>
</div>
<div class="modal-footer">
<input id='vldel' name='vldel' class='btn btn-danger' type='submit' onClick='deleteEvent();' value='Suppression' />
</div>
</div>
</div>
</div>
<!-- CLONE EVENEMENT -->
<div id="mymodal-event-clone" class="modal fade" tabindex="-1" role="dialog">
<div class="modal-dialog modal-lg">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>
<h4 class="modal-title">Cloner Evénement</h4>
</div>
<div class="modal-body">
<input id='vladd' name='vladd' class='btn btn-success' type='submit' onClick='cloneEvent();' value='Valider' />
&nbsp;
<input class='btn btn-default' type='submit' value='Annuler' onClick='$("#mymodal-event-clone").modal("hide");'>
<input name="event_calendar" id="event_calendar" type="hidden" class="form-control" placeholder="Nom">
<input name="event_id" id="event_id" type="hidden" class="form-control" placeholder="Nom">
<input name="event_title" id="event_title" type="hidden" class="form-control" placeholder="Titre" value="">
<input name="event_description" id="event_description" type="hidden" class="form-control" placeholder="Titre" value="">
<input name="event_start_time" id="event_start_timem" type="hidden" class="form-control" placeholder="Date Début" value="">
<input name="event_end_time" id="event_end_timem" type="hidden" class="form-control" placeholder="Date Fin" value="">
<input name="event_start" id="event_startm" type="hidden" class="form-control" placeholder="Date Début" value="">
<input name="event_end" id="event_endm" type="hidden" class="form-control" placeholder="Date Fin" value="">
<input id="event_allday" name="event_allday" type="hidden" class="switch"">
<fieldset class="fieldset form-horizontal" style="clear:both; margin-top:30px;">
<div id="event_dates"></div>
</fieldset>
</div>
</div>
</div>
</div>
{% endblock %}
{% block localexternalscript %}
<script type="text/javascript" src="/{{alias}}/ckeditor/ckeditor.js"></script>
<script type="text/javascript" src="/{{alias}}/ckeditor/adapters/jquery.js"></script>
<script type="text/javascript" src="/{{alias}}/bundles/cadolescore/js/jquery-ui.multidatespicker.js"></script>
<link href="/{{alias}}/bundles/cadolescore/css/jquery-ui.multidatespicker.css" rel="stylesheet" media="screen" />
{% endblock %}
{% block localjavascript %}
var idcalendar;
var toaddPJ;
var toaddPJevent;
var defautView='month';
{% if app.user %}
{% if app.user.viewcalendar == 2 %}
var defautView='agendaWeek';
{% elseif app.user.viewcalendar == 3 %}
var defautView='agendaDay';
{% endif %}
{% endif %}
$('document').ready(function(){
CKEDITOR.config.toolbar_Basic =
[
{ name: 'document', items : ['Bold','Italic','Underline','-', 'NumberedList','BulletedList','-', 'Link'] },
];
CKEDITOR.config.toolbar = 'Basic';
CKEDITOR.config.height = '100';
CKEDITOR.config.removePlugins = 'elementspath,save,font, resize';
CKEDITOR.replace( 'event_description-add' );
CKEDITOR.replace( 'event_description-mod' );
{% if entity.id is defined %}
{% for calendar in calendars %}
{% if calendar.id==entity.id %}
showCalendar({{ calendar.id }}, {{ calendar.canadd }});
{% endif %}
{% endfor %}
{% else %}
{% set onecalendarcanupdate = false %}
{% for calendar in calendars %}
{% if calendar.canadd %}
{% set onecalendarcanupdate = true %}
{% endif %}
{% endfor %}
showCalendar(0, {{ onecalendarcanupdate }});
{% endif %}
});
function submitCalendar() {
var url="{{ path('cadoles_portal_'~access~'_calendar_submit') }}";
$(location).attr('href',url);
}
function updateCalendar() {
var url="{{ path('cadoles_portal_'~access~'_calendar_update',{id:'xx'}) }}";
url=url.replace('xx',idcalendar);
$(location).attr('href',url);
}
function shareCalendar() {
var url="{{ path('cadoles_portal_'~access~'_calendar_share',{id:'xx'}) }}";
url=url.replace('xx',idcalendar);
$(location).attr('href',url);
}
function deleteCalendar() {
if (confirm('Êtes-vous sûr de vouloir supprimer ?')) {
var url="{{ path('cadoles_portal_'~access~'_calendar_delete',{id:'xx'}) }}";
url=url.replace('xx',idcalendar);
$(location).attr('href',url);
}
}
// Affichages des calendars
function showCalendar(id,canadd) {
idcalendar=id;
urltoload="{{ path('cadoles_portal_'~access~'_calendarevent_load',{'idcalendar':'xx'}) }}";
urltoload=urltoload.replace('xx',idcalendar);
// Rendre actif le page en cours dans le menu
$(".navbar-default li").removeClass("active");
$("#menucalendar-"+id).addClass("active");
// Cacher les actions possibles sur la page
$("#menuupdate").hide();
$("#menushare").hide();
$("#menudelete").hide();
if($("#menucalendar-"+id).data("open")) {
$("#menuupdate").show();
$("#menushare").show();
$("#menudelete").show();
}
$('#calendar').fullCalendar( 'destroy' );
$('#calendar').fullCalendar({
lang: 'fr',
selectable: canadd,
selectHelper: true,
editable: canadd,
eventLimit: true,
defaultView: defautView,
header: {
left: 'prev,next today',
center: 'title',
right: 'month,agendaWeek,agendaDay'
},
// Creation Evenement
select: function(start, end) {
{% if app.user %}
var allDay = !start.hasTime() && !end.hasTime();
$("#mymodal-event-add #event_title").val("");
CKEDITOR.instances["event_description-add"].setData("")
$("#mymodal-event-add #event_start_time").val(moment(start).format("DD/MM/YYYY HH:mm"));
$("#mymodal-event-add #event_end_time").val(moment(end).format("DD/MM/YYYY HH:mm"));
$("#mymodal-event-add #event_start").val(moment(start).format("DD/MM/YYYY"));
$("#mymodal-event-add #event_end").val(moment(end).subtract("1","s").format("DD/MM/YYYY"));
if(allDay) $("#mymodal-event-add #event_end_time").val(moment(end).subtract("1","s").format("DD/MM/YYYY HH:mm"));
$("#mymodal-event-add #event_calendar option[value='"+idcalendar+"']").prop('selected', true);
$("#mymodal-event-add #event_allday").bootstrapSwitch('state', allDay);
switchallDay("SUBMIT");
$('#mymodal-event-add').modal('show');
{% endif %}
},
// Modification Evenement
eventClick: function(event, jsEvent, view) {
if(event.editable) {
end=event.end.clone();
$("#mymodal-event-mod #event_id").val(event.id);
$("#mymodal-event-mod #event_title").val(event.title);
CKEDITOR.instances["event_description-mod"].setData(event.description)
$("#mymodal-event-mod #event_start_timem").val(event.start.format("DD/MM/YYYY HH:mm"));
$("#mymodal-event-mod #event_end_timem").val(event.end.format("DD/MM/YYYY HH:mm"));
$("#mymodal-event-mod #event_startm").val(event.start.format("DD/MM/YYYY"));
$("#mymodal-event-mod #event_endm").val(end.subtract("1","s").format("DD/MM/YYYY"));
$("#mymodal-event-mod #event_allday").bootstrapSwitch('state', event.allDay);
$("#mymodal-event-mod #event_calendar option[value='"+event.calendar+"']").prop('selected', true);
$("#mymodal-event-clone #event_id").val(event.id);
$("#mymodal-event-clone #event_title").val(event.title);
$("#mymodal-event-clone #event_description").val(event.description);
$("#mymodal-event-clone #event_start_timem").val(event.start.format("HH:mm"));
$("#mymodal-event-clone #event_end_timem").val(event.end.format("HH:mm"));
$("#mymodal-event-clone #event_startm").val(event.start.format("DD/MM/YYYY"));
$("#mymodal-event-clone #event_endm").val(event.end.format("DD/MM/YYYY"));
$("#mymodal-event-clone #event_allday").val(event.allDay);
$("#mymodal-event-clone #event_calendar").val(event.calendar);
refreshPJ();
switchallDay("UPDATE");
$('#mymodal-event-mod').modal('show');
}
},
// Deplacement Evenement
eventDrop: function(event, delta, revertFunc) {
$.ajax({
method: "POST",
url: "{{ path('cadoles_portal_'~access~'_calendarevent_update') }}",
data: {
"id": event.id,
"title": event.title,
"description":event.description,
"start": event.start.format("YYYY-MM-DD HH:mm"),
"end": event.end.format("YYYY-MM-DD HH:mm"),
"allday": event.allDay,
"idcalendar": event.calendar
}
});
},
// Resize Evenement
eventResize: function(event, delta, revertFunc) {
$.ajax({
method: "POST",
url: "{{ path('cadoles_portal_'~access~'_calendarevent_update') }}",
data: {
"id": event.id,
"title": event.title,
"description":event.description,
"start": event.start.format("YYYY-MM-DD HH:mm"),
"end": event.end.format("YYYY-MM-DD HH:mm"),
"allday": event.allDay,
"idcalendar": event.calendar
}
});
},
{% if app.user %}
viewRender: function( view, element ) {
if(view.name!=defautView) {
$.ajax({
method: "POST",
url: "{{ path('cadoles_core_user_viewcalendar') }}",
data: {
"view": view.name,
}
});
defautView=view.name;
}
},
{% endif %}
eventRender: function(event, element) {
element.attr('title', event.description);
element.find('.fc-content').attr("id", "event-" + event.id);
},
events:urltoload
});
}
function switchallDay(form) {
if(form=="SUBMIT") {
if($("#mymodal-event-add #event_allday").bootstrapSwitch('state')) {
$("#mymodal-event-add #form_event_start_time").hide();
$("#mymodal-event-add #form_event_end_time").hide();
$("#mymodal-event-add #form_event_start").show();
$("#mymodal-event-add #form_event_end").show();
}
else {
$("#mymodal-event-add #form_event_start_time").show();
$("#mymodal-event-add #form_event_end_time").show();
$("#mymodal-event-add #form_event_start").hide();
$("#mymodal-event-add #form_event_end").hide();
}
}
else if(form=="UPDATE") {
if($("#mymodal-event-mod #event_allday").bootstrapSwitch('state')) {
$("#mymodal-event-mod #form_event_start_time").hide();
$("#mymodal-event-mod #form_event_end_time").hide();
$("#mymodal-event-mod #form_event_start").show();
$("#mymodal-event-mod #form_event_end").show();
}
else {
$("#mymodal-event-mod #form_event_start_time").show();
$("#mymodal-event-mod #form_event_end_time").show();
$("#mymodal-event-mod #form_event_start").hide();
$("#mymodal-event-mod #form_event_end").hide();
}
}
}
function submitEvent(addPJ) {
$("#mymodal-event-add .alert").remove();
if($("#mymodal-event-add #event_title").val()=="") {
$("#mymodal-event-add fieldset").append("<div class='alert alert-danger' style='margin: 5px 0px'>Titre obligatoire</div>");
return;
}
// Allday
if($("#mymodal-event-add #event_allday").bootstrapSwitch('state')) {
var start=moment($("#mymodal-event-add #event_start").val(),"DD/MM/YYYY");
var end=moment($("#mymodal-event-add #event_end").val(),"DD/MM/YYYY").add("1","d");
if( start.isAfter(end) ) {
$("#mymodal-event-add fieldset").append("<div class='alert alert-danger' style='margin: 5px 0px'>Date de début supérieure à date de fin</div>");
return;
}
var dstart=moment($("#mymodal-event-add #event_start").val(),"DD/MM/YYYY").format("YYYY-MM-DD 00:00");
var dend=moment($("#mymodal-event-add #event_end").val(),"DD/MM/YYYY").add("1","d").format("YYYY-MM-DD 00:00");
}
else {
var start=moment($("#mymodal-event-add #event_start_time").val(),"DD/MM/YYYY HH:mm");
var end=moment($("#mymodal-event-add #event_end_time").val(),"DD/MM/YYYY HH:mm");
if( start.isAfter(end) ) {
$("#mymodal-event-add fieldset").append("<div class='alert alert-danger' style='margin: 5px 0px'>Date de début supérieure à date de fin</div>");
return;
}
var dstart=moment($("#mymodal-event-add #event_start_time").val(),"DD/MM/YYYY HH:mm").format("YYYY-MM-DD HH:mm");
var dend=moment($("#mymodal-event-add #event_end_time").val(),"DD/MM/YYYY HH:mm").format("YYYY-MM-DD HH:mm");
}
$.ajax({
method: "POST",
url: "{{ path('cadoles_portal_'~access~'_calendarevent_submit') }}",
data: {
"title":$("#mymodal-event-add #event_title").val(),
"description":CKEDITOR.instances["event_description-add"].getData(),
"start": dstart,
"end": dend,
"allday": $("#mymodal-event-add #event_allday").bootstrapSwitch('state'),
"idcalendar": $("#mymodal-event-add #event_calendar").val()
},
success: function(data) {
// Ajout de l'event dans fullcalendar
event = $('#calendar').fullCalendar('renderEvent',
{
id: data.id,
title: $("#mymodal-event-add #event_title").val(),
description: CKEDITOR.instances["event_description-add"].getData(),
start: start,
end: end,
editable: true,
color: data.color,
allDay: $("#mymodal-event-add #event_allday").bootstrapSwitch('state'),
calendar: $("#mymodal-event-add #event_calendar").val(),
files: []
},
false // make the event "stick"
);
$("#mymodal-event-add").modal("hide");
toaddPJ=addPJ;
toaddPJevent=data.id;
}
});
}
function updateEvent() {
$("#mymodal-event-mod .alert").remove();
if($("#mymodal-event-mod #event_title").val()=="") {
$("#mymodal-event-mod fieldset").append("<div class='alert alert-danger' style='margin: 5px 0px'>Titre obligatoire</div>");
return;
}
// Allday
if($("#mymodal-event-mod #event_allday").bootstrapSwitch('state')) {
var start=moment($("#mymodal-event-mod #event_startm").val(),"DD/MM/YYYY");
var end=moment($("#mymodal-event-mod #event_endm").val(),"DD/MM/YYYY").add("1","d");
if( start.isAfter(end) ) {
$("#mymodal-event-mod fieldset").append("<div class='alert alert-danger' style='margin: 5px 0px'>Date de début supérieure à date de fin</div>");
return;
}
var dstart=moment($("#mymodal-event-mod #event_startm").val(),"DD/MM/YYYY").format("YYYY-MM-DD 00:00");
var dend=moment($("#mymodal-event-mod #event_endm").val(),"DD/MM/YYYY").add("1","d").format("YYYY-MM-DD 00:00");
}
else {
var start=moment($("#mymodal-event-mod #event_start_timem").val(),"DD/MM/YYYY HH:mm");
var end=moment($("#mymodal-event-mod #event_end_timem").val(),"DD/MM/YYYY HH:mm");
if( start.isAfter(end) ) {
$("#mymodal-event-mod fieldset").append("<div class='alert alert-danger' style='margin: 5px 0px'>Date de début supérieure à date de fin</div>");
return;
}
var dstart=moment($("#mymodal-event-mod #event_start_timem").val(),"DD/MM/YYYY HH:mm").format("YYYY-MM-DD HH:mm");
var dend=moment($("#mymodal-event-mod #event_end_timem").val(),"DD/MM/YYYY HH:mm").format("YYYY-MM-DD HH:mm");
}
$.ajax({
method: "POST",
url: "{{ path('cadoles_portal_'~access~'_calendarevent_update') }}",
data: {
"id": $("#mymodal-event-mod #event_id").val(),
"title":$("#mymodal-event-mod #event_title").val(),
"description":CKEDITOR.instances["event_description-mod"].getData(),
"start": dstart,
"end": dend,
"allday": $("#mymodal-event-mod #event_allday").bootstrapSwitch('state'),
"idcalendar": $("#mymodal-event-mod #event_calendar").val()
},
success: function(data) {
var idevent=$("#mymodal-event-mod #event_id").val();
// Modifification de l'event dans fullcalendar
$('#calendar').fullCalendar( 'removeEvents', idevent );
$('#calendar').fullCalendar('renderEvent',
{
id: idevent,
title: $("#mymodal-event-mod #event_title").val(),
description: CKEDITOR.instances["event_description-mod"].getData(),
start: start,
end: end,
editable: true,
color: data.color,
allDay: $("#mymodal-event-mod #event_allday").bootstrapSwitch('state'),
calendar: $("#mymodal-event-mod #event_calendar").val()
},
false // make the event "stick"
);
$("#mymodal-event-mod").modal("hide");
}
});
}
function AddPJ() {
$('#mymodal-event-mod').modal('hide');
url='{{ path('cadoles_core_'~access~'_file_upload',{'id': 'calendarevent-xxxx','type':'all','forcereload':false}) }}';
url=url.replace('xxxx',$("#mymodal-event-mod #event_id").val());
$("#mymodal").modal('show');
ModalLoad('mymodal','Fichiers',url);
}
function shareEvent() {
var id=$("#mymodal-event-mod #event_id").val();
var url="{{ path('cadoles_portal_'~access~'_calendarevent_share',{id:'xx'}) }}";
url=url.replace('xx',id);
$(location).attr('href',url);
}
function showcloneEvent() {
$("#mymodal-event-mod").modal("hide");
$("#mymodal-event-clone").modal("show");
$('#mymodal-event-clone #event_dates').multiDatesPicker({
firstDay: 1,
altField: "#datepicker",
closeText: 'Fermer',
prevText: 'Précédent',
nextText: 'Suivant',
currentText: 'Aujourd\'hui',
monthNames: ['Janvier', 'Février', 'Mars', 'Avril', 'Mai', 'Juin', 'Juillet', 'Août', 'Septembre', 'Octobre', 'Novembre', 'Décembre'],
monthNamesShort: ['Janv.', 'Févr.', 'Mars', 'Avril', 'Mai', 'Juin', 'Juil.', 'Août', 'Sept.', 'Oct.', 'Nov.', 'Déc.'],
dayNames: ['Dimanche', 'Lundi', 'Mardi', 'Mercredi', 'Jeudi', 'Vendredi', 'Samedi'],
dayNamesShort: ['Dim.', 'Lun.', 'Mar.', 'Mer.', 'Jeu.', 'Ven.', 'Sam.'],
dayNamesMin: ['D', 'L', 'M', 'M', 'J', 'V', 'S'],
weekHeader: 'Sem.',
dateFormat: 'yy-mm-dd',
});
$('#mymodal-event-clone #event_dates').multiDatesPicker('resetDates')
}
function cloneEvent() {
var dates = $('#mymodal-event-clone #event_dates').multiDatesPicker('value');
dates=dates.replaceAll(' ','');
tbdates=dates.split(',');
var dstart=moment($("#mymodal-event-clone #event_startm").val(),"DD/MM/YYYY");
var tstart=$("#mymodal-event-clone #event_start_timem").val();
var dend=moment($("#mymodal-event-clone #event_endm").val(),"DD/MM/YYYY");
var tend=$("#mymodal-event-clone #event_end_timem").val();
var nbdays=dend.diff(dstart, 'days');
if($("#mymodal-event-clone #event_allday").val()=="true")
allDay=true;
else
allDay=false;
tbdates.forEach(function(date){
var mdatestart=moment(date +' '+tstart,"YYYY-MM-DD HH:mm");
var mdateend=moment(date +' '+tend,"YYYY-MM-DD HH:mm");
mdateend.add(nbdays,'days');
start=mdatestart.format("YYYY-MM-DD HH:mm");
end=mdateend.format("YYYY-MM-DD HH:mm");
$.ajax({
method: "POST",
url: "{{ path('cadoles_portal_'~access~'_calendarevent_submit') }}",
data: {
"title":$("#mymodal-event-clone #event_title").val(),
"description":$("#mymodal-event-clone #event_description").val(),
"start": start,
"end": end,
"allday": $("#mymodal-event-clone #event_allday").val(),
"idcalendar": $("#mymodal-event-clone #event_calendar").val()
},
success: function(data) {
start=mdatestart.format("YYYY-MM-DD HH:mm");
end=mdateend.format("YYYY-MM-DD HH:mm");
// Ajout de l'event dans fullcalendar
event = $('#calendar').fullCalendar('renderEvent',
{
id: data.id,
title: $("#mymodal-event-clone #event_title").val(),
description:$("#mymodal-event-clone #event_description").val(),
start: mdatestart,
end: mdateend,
editable: true,
color: data.color,
allDay: allDay,
calendar: $("#mymodal-event-clone #event_calendar").val(),
files: []
},
false // make the event "stick"
);
$("#mymodal-event-clone").modal("hide");
}
});
});
}
function deleteEvent() {
$.ajax({
method: "POST",
url: "{{ path('cadoles_portal_'~access~'_calendarevent_delete') }}",
data: {
"id": $("#mymodal-event-mod #event_id").val(),
"idcalendar": $("#mymodal-event-mod #event_calendar").val()
},
success: function(data) {
var idevent=$("#mymodal-event-mod #event_id").val();
// Supression de l'event dans fullcalendar
$('#calendar').fullCalendar( 'removeEvents', idevent );
$("#mymodal-event-mod").modal("hide");
}
});
}
// Supprimer un fichier
function delFile(directory,filename) {
var r = confirm("Confirmez-vous la suppression de ce fichier ?");
if (r == true) {
$.ajax({
method: "POST",
url: "{{ path('cadoles_core_'~access~'_file_delete') }}",
data: {
directory:directory,
filename:filename
},
success: function() {
refreshPJ();
}
});
}
}
$(document).on('mouseenter', '.grid-item-content', function(){
$(this).children(".item-delete").show();
});
$(document).on('mouseleave', '.grid-item-content', function(){
$(this).children(".item-delete").hide();
});
$('#mymodal-event-add').on('hidden.bs.modal', function() {
if(toaddPJ) {
$('#event-'+toaddPJevent+'.fc-content').trigger('click');
AddPJ();
}
toaddPJ=false;
});
$('#mymodal-event-mod').on('shown.bs.modal', function() {
$('body').imagesLoaded(function() {
var optiongrid={columnWidth: '.grid-sizer',itemSelector: '.grid-item', gutter: '.grid-gutter-sizer'};
var grid = $('.grid').masonry(optiongrid);
});
});
function refreshPJ() {
$.ajax({
method: "POST",
url: "{{ path('cadoles_portal_'~access~'_calendarevent_loadpj') }}",
data: {
"id": $("#mymodal-event-mod #event_id").val()
},
success: function(data) {
htmlPJ(data);
}
});
}
$('#mymodal').on('hidden.bs.modal', function() {
$("#mymodal-event-mod").modal("show");
var optiongrid={columnWidth: '.grid-sizer',itemSelector: '.grid-item', gutter: '.grid-gutter-sizer'};
var grid = $('.grid').masonry(optiongrid);
});
function htmlPJ(files) {
html ='<div class="grid clearfix">';
html+='<div class="grid-sizer grid-small"></div>';
html+='<div class="grid-gutter-sizer"></div>';
files.forEach(function(file) {
url="{{ path('cadoles_core_'~access~'_file_download',{'directory':'calendarevent-xxxx','filename':'yyyy' }) }}";
url=url.replace("xxxx",$("#mymodal-event-mod #event_id").val());
url=url.replace("yyyy",file.name);
html+='<div class="grid-item grid-small">';
html+='<div class="grid-item-content" style="background-color: #{{ color["main"]}}">';
html+='<a style="cursor:pointer;color: #{{color['fontcolorhover']}}" onClick="delFile(\'calendarevent-'+$("#mymodal-event-mod #event_id").val()+'\',\''+file.name+'\')" class="item-delete">';
html+='<i class="fa fa-trash" title="Supprimer le fichier"></i>';
html+='</a>';
html+='<a style="cursor:pointer" href="'+url+'">';
html+='<div class="item-link clearfix">';
html+='<div class="grid-item-logo">';
if(file.thumb)
html+='<img class="grid-item-img" height="110" src="'+file.thumb+'">';
else
html+='<img class="grid-item-img" height="110" src="/{{ alias }}/bundles/cadolescore/images/files/_blank.png">';
html+='</div>';
html+='<div class="grid-item-title">';
html+='<h2>'+file.name+'</h2>';
html+='</div>';
html+='</div>';
html+='</a>';
html+='</div>';
html+='</div>';
});
html+='<div class="grid-item grid-small">'
html+='<div onClick="AddPJ();" title="Ajouter des fichiers" class="grid-item-content" style="cursor:pointer;margin-top:20px;">';
html+='<img class="grid-item-img imageshadow" height="60" src="/ninegate/uploads/icon/icon_add.png">';
html+='<br>Ajouter des fichiers';
html+='</div>';
html+='</div>';
html+='</div>';
html+='</div>';
html+='</div>';
// On ajoute les PJ à la modal
$("#mymodal-event-mod #event_PJ").html("");
$("#mymodal-event-mod #event_PJ").append(html);
}
{% endblock %}