clonage d'evenement (ref #244)
This commit is contained in:
parent
5aefa64fce
commit
dd46b9ba01
12
src/ninegate-1.0/src/Cadoles/CoreBundle/Resources/public/css/jquery-ui.multidatespicker.css
vendored
Normal file
12
src/ninegate-1.0/src/Cadoles/CoreBundle/Resources/public/css/jquery-ui.multidatespicker.css
vendored
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
/* jQuery UI Datepicker moving pixels fix */
|
||||||
|
table.ui-datepicker-calendar {border-collapse: separate;}
|
||||||
|
.ui-datepicker-calendar td {border: 1px solid transparent;}
|
||||||
|
|
||||||
|
/* jQuery UI Datepicker hide datepicker helper */
|
||||||
|
#ui-datepicker-div {display:none;}
|
||||||
|
|
||||||
|
/* jQuery UI Datepicker emphasis on selected dates */
|
||||||
|
.ui-datepicker .ui-datepicker-calendar .ui-state-highlight a {
|
||||||
|
background: #743620 none;
|
||||||
|
color: white;
|
||||||
|
}
|
498
src/ninegate-1.0/src/Cadoles/CoreBundle/Resources/public/js/jquery-ui.multidatespicker.js
vendored
Normal file
498
src/ninegate-1.0/src/Cadoles/CoreBundle/Resources/public/js/jquery-ui.multidatespicker.js
vendored
Normal file
|
@ -0,0 +1,498 @@
|
||||||
|
/*
|
||||||
|
* MultiDatesPicker v1.6.4
|
||||||
|
* http://multidatespickr.sourceforge.net/
|
||||||
|
*
|
||||||
|
* Copyright 2014, Luca Lauretta
|
||||||
|
* Dual licensed under the MIT or GPL version 2 licenses.
|
||||||
|
*/
|
||||||
|
(function( $ ){
|
||||||
|
$.extend($.ui, { multiDatesPicker: { version: "1.6.4" } });
|
||||||
|
|
||||||
|
$.fn.multiDatesPicker = function(method) {
|
||||||
|
var mdp_arguments = arguments;
|
||||||
|
var ret = this;
|
||||||
|
var today_date = new Date();
|
||||||
|
var day_zero = new Date(0);
|
||||||
|
var mdp_events = {};
|
||||||
|
|
||||||
|
function removeDate(date, type) {
|
||||||
|
if(!type) type = 'picked';
|
||||||
|
date = dateConvert.call(this, date);
|
||||||
|
for(var i = 0; i < this.multiDatesPicker.dates[type].length; i++)
|
||||||
|
if(!methods.compareDates(this.multiDatesPicker.dates[type][i], date))
|
||||||
|
return this.multiDatesPicker.dates[type].splice(i, 1).pop();
|
||||||
|
}
|
||||||
|
function removeIndex(index, type) {
|
||||||
|
if(!type) type = 'picked';
|
||||||
|
return this.multiDatesPicker.dates[type].splice(index, 1).pop();
|
||||||
|
}
|
||||||
|
function addDate(date, type, no_sort) {
|
||||||
|
if(!type) type = 'picked';
|
||||||
|
date = dateConvert.call(this, date);
|
||||||
|
|
||||||
|
// @todo: use jQuery UI datepicker method instead
|
||||||
|
date.setHours(0);
|
||||||
|
date.setMinutes(0);
|
||||||
|
date.setSeconds(0);
|
||||||
|
date.setMilliseconds(0);
|
||||||
|
|
||||||
|
if (methods.gotDate.call(this, date, type) === false) {
|
||||||
|
this.multiDatesPicker.dates[type].push(date);
|
||||||
|
if(!no_sort) this.multiDatesPicker.dates[type].sort(methods.compareDates);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function sortDates(type) {
|
||||||
|
if(!type) type = 'picked';
|
||||||
|
this.multiDatesPicker.dates[type].sort(methods.compareDates);
|
||||||
|
}
|
||||||
|
function dateConvert(date, desired_type, date_format) {
|
||||||
|
if(!desired_type) desired_type = 'object';/*
|
||||||
|
if(!date_format && (typeof date == 'string')) {
|
||||||
|
date_format = $(this).datepicker('option', 'dateFormat');
|
||||||
|
if(!date_format) date_format = $.datepicker._defaults.dateFormat;
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
return methods.dateConvert.call(this, date, desired_type, date_format);
|
||||||
|
}
|
||||||
|
|
||||||
|
var methods = {
|
||||||
|
init : function( options ) {
|
||||||
|
var $this = $(this);
|
||||||
|
this.multiDatesPicker.changed = false;
|
||||||
|
|
||||||
|
var mdp_events = {
|
||||||
|
beforeShow: function(input, inst) {
|
||||||
|
this.multiDatesPicker.changed = false;
|
||||||
|
if(this.multiDatesPicker.originalBeforeShow)
|
||||||
|
this.multiDatesPicker.originalBeforeShow.call(this, input, inst);
|
||||||
|
},
|
||||||
|
onSelect : function(dateText, inst) {
|
||||||
|
var $this = $(this);
|
||||||
|
this.multiDatesPicker.changed = true;
|
||||||
|
|
||||||
|
if (dateText) {
|
||||||
|
$this.multiDatesPicker('toggleDate', dateText);
|
||||||
|
this.multiDatesPicker.changed = true;
|
||||||
|
// @todo: this will be optimized when I'll move methods to the singleton.
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.multiDatesPicker.mode == 'normal' && this.multiDatesPicker.pickableRange) {
|
||||||
|
if(this.multiDatesPicker.dates.picked.length > 0) {
|
||||||
|
var min_date = this.multiDatesPicker.dates.picked[0],
|
||||||
|
max_date = new Date(min_date.getTime());
|
||||||
|
|
||||||
|
methods.sumDays(max_date, this.multiDatesPicker.pickableRange-1);
|
||||||
|
|
||||||
|
// counts the number of disabled dates in the range
|
||||||
|
if(this.multiDatesPicker.adjustRangeToDisabled) {
|
||||||
|
var c_disabled,
|
||||||
|
disabled = this.multiDatesPicker.dates.disabled.slice(0);
|
||||||
|
do {
|
||||||
|
c_disabled = 0;
|
||||||
|
for(var i = 0; i < disabled.length; i++) {
|
||||||
|
if(disabled[i].getTime() <= max_date.getTime()) {
|
||||||
|
if((min_date.getTime() <= disabled[i].getTime()) && (disabled[i].getTime() <= max_date.getTime()) ) {
|
||||||
|
c_disabled++;
|
||||||
|
}
|
||||||
|
disabled.splice(i, 1);
|
||||||
|
i--;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
max_date.setDate(max_date.getDate() + c_disabled);
|
||||||
|
} while(c_disabled != 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(this.multiDatesPicker.maxDate && (max_date > this.multiDatesPicker.maxDate))
|
||||||
|
max_date = this.multiDatesPicker.maxDate;
|
||||||
|
|
||||||
|
$this
|
||||||
|
.datepicker("option", "minDate", min_date)
|
||||||
|
.datepicker("option", "maxDate", max_date);
|
||||||
|
} else {
|
||||||
|
$this
|
||||||
|
.datepicker("option", "minDate", this.multiDatesPicker.minDate)
|
||||||
|
.datepicker("option", "maxDate", this.multiDatesPicker.maxDate);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(this.multiDatesPicker.originalOnSelect && dateText)
|
||||||
|
this.multiDatesPicker.originalOnSelect.call(this, dateText, inst);
|
||||||
|
|
||||||
|
},
|
||||||
|
beforeShowDay : function(date) {
|
||||||
|
var $this = $(this),
|
||||||
|
gotThisDate = $this.multiDatesPicker('gotDate', date) !== false,
|
||||||
|
isDisabledCalendar = $this.datepicker('option', 'disabled'),
|
||||||
|
isDisabledDate = $this.multiDatesPicker('gotDate', date, 'disabled') !== false,
|
||||||
|
areAllSelected = this.multiDatesPicker.maxPicks <= this.multiDatesPicker.dates.picked.length;
|
||||||
|
|
||||||
|
var bsdReturn = [true, '', null];
|
||||||
|
if(this.multiDatesPicker.originalBeforeShowDay)
|
||||||
|
bsdReturn = this.multiDatesPicker.originalBeforeShowDay.call(this, date);
|
||||||
|
|
||||||
|
bsdReturn[1] = gotThisDate ? 'ui-state-highlight '+bsdReturn[1] : bsdReturn[1];
|
||||||
|
bsdReturn[0] = bsdReturn[0] && !(isDisabledCalendar || isDisabledDate || (areAllSelected && !bsdReturn[1]));
|
||||||
|
return bsdReturn;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// value have to be extracted before datepicker is initiated
|
||||||
|
if($this.val()) var inputDates = $this.val()
|
||||||
|
|
||||||
|
if(options) {
|
||||||
|
// value have to be extracted before datepicker is initiated
|
||||||
|
//if(options.altField) var inputDates = $(options.altField).val();
|
||||||
|
if(options.separator) this.multiDatesPicker.separator = options.separator;
|
||||||
|
if(!this.multiDatesPicker.separator) this.multiDatesPicker.separator = ', ';
|
||||||
|
|
||||||
|
this.multiDatesPicker.originalBeforeShow = options.beforeShow;
|
||||||
|
this.multiDatesPicker.originalOnSelect = options.onSelect;
|
||||||
|
this.multiDatesPicker.originalBeforeShowDay = options.beforeShowDay;
|
||||||
|
this.multiDatesPicker.originalOnClose = options.onClose;
|
||||||
|
|
||||||
|
// datepicker init
|
||||||
|
$this.datepicker(options);
|
||||||
|
|
||||||
|
this.multiDatesPicker.minDate = $.datepicker._determineDate(this, options.minDate, null);
|
||||||
|
this.multiDatesPicker.maxDate = $.datepicker._determineDate(this, options.maxDate, null);
|
||||||
|
if(options.addDates) methods.addDates.call(this, options.addDates);
|
||||||
|
|
||||||
|
if(options.addDisabledDates)
|
||||||
|
methods.addDates.call(this, options.addDisabledDates, 'disabled');
|
||||||
|
|
||||||
|
methods.setMode.call(this, options);
|
||||||
|
} else {
|
||||||
|
$this.datepicker();
|
||||||
|
}
|
||||||
|
$this.datepicker('option', mdp_events);
|
||||||
|
|
||||||
|
// adds any dates found in the input or alt field
|
||||||
|
if(inputDates) $this.multiDatesPicker('value', inputDates);
|
||||||
|
|
||||||
|
// generates the new string of added dates
|
||||||
|
var inputs_values = $this.multiDatesPicker('value');
|
||||||
|
|
||||||
|
// fills the input field back with all the dates in the calendar
|
||||||
|
$this.val(inputs_values);
|
||||||
|
|
||||||
|
// Fixes the altField filled with defaultDate by default
|
||||||
|
var altFieldOption = $this.datepicker('option', 'altField');
|
||||||
|
if (altFieldOption) $(altFieldOption).val(inputs_values);
|
||||||
|
|
||||||
|
// Updates the calendar view
|
||||||
|
$this.datepicker('refresh');
|
||||||
|
},
|
||||||
|
compareDates : function(date1, date2) {
|
||||||
|
date1 = dateConvert.call(this, date1);
|
||||||
|
date2 = dateConvert.call(this, date2);
|
||||||
|
// return > 0 means date1 is later than date2
|
||||||
|
// return == 0 means date1 is the same day as date2
|
||||||
|
// return < 0 means date1 is earlier than date2
|
||||||
|
var diff = date1.getFullYear() - date2.getFullYear();
|
||||||
|
if(!diff) {
|
||||||
|
diff = date1.getMonth() - date2.getMonth();
|
||||||
|
if(!diff)
|
||||||
|
diff = date1.getDate() - date2.getDate();
|
||||||
|
}
|
||||||
|
return diff;
|
||||||
|
},
|
||||||
|
sumDays : function( date, n_days ) {
|
||||||
|
var origDateType = typeof date;
|
||||||
|
obj_date = dateConvert.call(this, date);
|
||||||
|
obj_date.setDate(obj_date.getDate() + n_days);
|
||||||
|
return dateConvert.call(this, obj_date, origDateType);
|
||||||
|
},
|
||||||
|
dateConvert : function( date, desired_format, dateFormat ) {
|
||||||
|
var from_format = typeof date;
|
||||||
|
var $this = $(this);
|
||||||
|
|
||||||
|
if(from_format == desired_format) {
|
||||||
|
if(from_format == 'object') {
|
||||||
|
try {
|
||||||
|
date.getTime();
|
||||||
|
} catch (e) {
|
||||||
|
$.error('Received date is in a non supported format!');
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return date;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(typeof date == 'undefined') date = new Date(0);
|
||||||
|
|
||||||
|
if(desired_format != 'string' && desired_format != 'object' && desired_format != 'number')
|
||||||
|
$.error('Date format "'+ desired_format +'" not supported!');
|
||||||
|
|
||||||
|
if(!dateFormat) {
|
||||||
|
// thanks to bibendus83 -> http://sourceforge.net/tracker/index.php?func=detail&aid=3213174&group_id=358205&atid=1495382
|
||||||
|
var dp_dateFormat = $this.datepicker('option', 'dateFormat');
|
||||||
|
if (dp_dateFormat) {
|
||||||
|
dateFormat = dp_dateFormat;
|
||||||
|
} else {
|
||||||
|
dateFormat = $.datepicker._defaults.dateFormat;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// converts to object as a neutral format
|
||||||
|
switch(from_format) {
|
||||||
|
case 'object': break;
|
||||||
|
case 'string': date = $.datepicker.parseDate(dateFormat, date); break;
|
||||||
|
case 'number': date = new Date(date); break;
|
||||||
|
default: $.error('Conversion from "'+ desired_format +'" format not allowed on jQuery.multiDatesPicker');
|
||||||
|
}
|
||||||
|
// then converts to the desired format
|
||||||
|
switch(desired_format) {
|
||||||
|
case 'object': return date;
|
||||||
|
case 'string': return $.datepicker.formatDate(dateFormat, date);
|
||||||
|
case 'number': return date.getTime();
|
||||||
|
default: $.error('Conversion to "'+ desired_format +'" format not allowed on jQuery.multiDatesPicker');
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
},
|
||||||
|
gotDate : function( date, type ) {
|
||||||
|
if(!type) type = 'picked';
|
||||||
|
for(var i = 0; i < this.multiDatesPicker.dates[type].length; i++) {
|
||||||
|
if(methods.compareDates.call(this, this.multiDatesPicker.dates[type][i], date) === 0) {
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
},
|
||||||
|
value : function( value ) {
|
||||||
|
if(value && typeof value == 'string') {
|
||||||
|
methods.addDates.call(this, value.split(this.multiDatesPicker.separator));
|
||||||
|
} else {
|
||||||
|
var dates = methods.getDates.call(this, 'string');
|
||||||
|
return dates.length
|
||||||
|
? dates.join(this.multiDatesPicker.separator)
|
||||||
|
: "";
|
||||||
|
}
|
||||||
|
},
|
||||||
|
getDates : function( format, type ) {
|
||||||
|
if(!format) format = 'string';
|
||||||
|
if(!type) type = 'picked';
|
||||||
|
switch (format) {
|
||||||
|
case 'object':
|
||||||
|
return this.multiDatesPicker.dates[type];
|
||||||
|
case 'string':
|
||||||
|
case 'number':
|
||||||
|
var o_dates = new Array();
|
||||||
|
for(var i in this.multiDatesPicker.dates[type])
|
||||||
|
o_dates.push(
|
||||||
|
dateConvert.call(
|
||||||
|
this,
|
||||||
|
this.multiDatesPicker.dates[type][i],
|
||||||
|
format
|
||||||
|
)
|
||||||
|
);
|
||||||
|
return o_dates;
|
||||||
|
|
||||||
|
default: $.error('Format "'+format+'" not supported!');
|
||||||
|
}
|
||||||
|
},
|
||||||
|
addDates : function( dates, type ) {
|
||||||
|
if(dates.length > 0) {
|
||||||
|
if(!type) type = 'picked';
|
||||||
|
switch(typeof dates) {
|
||||||
|
case 'object':
|
||||||
|
case 'array':
|
||||||
|
if(dates.length) {
|
||||||
|
for(var i = 0; i < dates.length; i++)
|
||||||
|
addDate.call(this, dates[i], type, true);
|
||||||
|
sortDates.call(this, type);
|
||||||
|
break;
|
||||||
|
} // else does the same as 'string'
|
||||||
|
case 'string':
|
||||||
|
case 'number':
|
||||||
|
addDate.call(this, dates, type);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
$.error('Date format "'+ typeof dates +'" not allowed on jQuery.multiDatesPicker');
|
||||||
|
}
|
||||||
|
//$(this).datepicker('refresh');
|
||||||
|
} else {
|
||||||
|
$.error('Empty array of dates received.');
|
||||||
|
}
|
||||||
|
},
|
||||||
|
removeDates : function( dates, type ) {
|
||||||
|
if(!type) type = 'picked';
|
||||||
|
var removed = [];
|
||||||
|
if (Object.prototype.toString.call(dates) === '[object Array]') {
|
||||||
|
for(var i in dates.sort(function(a,b){return b-a})) {
|
||||||
|
removed.push(removeDate.call(this, dates[i], type));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
removed.push(removeDate.call(this, dates, type));
|
||||||
|
}
|
||||||
|
return removed;
|
||||||
|
},
|
||||||
|
removeIndexes : function( indexes, type ) {
|
||||||
|
if(!type) type = 'picked';
|
||||||
|
var removed = [];
|
||||||
|
if (Object.prototype.toString.call(indexes) === '[object Array]') {
|
||||||
|
for(var i in indexes.sort(function(a,b){return b-a})) {
|
||||||
|
removed.push(removeIndex.call(this, indexes[i], type));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
removed.push(removeIndex.call(this, indexes, type));
|
||||||
|
}
|
||||||
|
return removed;
|
||||||
|
},
|
||||||
|
resetDates : function ( type ) {
|
||||||
|
if(!type) type = 'picked';
|
||||||
|
this.multiDatesPicker.dates[type] = [];
|
||||||
|
},
|
||||||
|
toggleDate : function( date, type ) {
|
||||||
|
if(!type) type = 'picked';
|
||||||
|
|
||||||
|
switch(this.multiDatesPicker.mode) {
|
||||||
|
case 'daysRange':
|
||||||
|
this.multiDatesPicker.dates[type] = []; // deletes all picked/disabled dates
|
||||||
|
var end = this.multiDatesPicker.autoselectRange[1];
|
||||||
|
var begin = this.multiDatesPicker.autoselectRange[0];
|
||||||
|
if(end < begin) { // switch
|
||||||
|
end = this.multiDatesPicker.autoselectRange[0];
|
||||||
|
begin = this.multiDatesPicker.autoselectRange[1];
|
||||||
|
}
|
||||||
|
for(var i = begin; i < end; i++)
|
||||||
|
methods.addDates.call(this, methods.sumDays.call(this,date, i), type);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
if(methods.gotDate.call(this, date) === false) // adds dates
|
||||||
|
methods.addDates.call(this, date, type);
|
||||||
|
else // removes dates
|
||||||
|
methods.removeDates.call(this, date, type);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
setMode : function( options ) {
|
||||||
|
var $this = $(this);
|
||||||
|
if(options.mode) this.multiDatesPicker.mode = options.mode;
|
||||||
|
|
||||||
|
switch(this.multiDatesPicker.mode) {
|
||||||
|
case 'normal':
|
||||||
|
for(option in options)
|
||||||
|
switch(option) {
|
||||||
|
case 'maxPicks':
|
||||||
|
case 'minPicks':
|
||||||
|
case 'pickableRange':
|
||||||
|
case 'adjustRangeToDisabled':
|
||||||
|
this.multiDatesPicker[option] = options[option];
|
||||||
|
break;
|
||||||
|
//default: $.error('Option ' + option + ' ignored for mode "'.options.mode.'".');
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'daysRange':
|
||||||
|
case 'weeksRange':
|
||||||
|
var mandatory = 1;
|
||||||
|
for(option in options)
|
||||||
|
switch(option) {
|
||||||
|
case 'autoselectRange':
|
||||||
|
mandatory--;
|
||||||
|
case 'pickableRange':
|
||||||
|
case 'adjustRangeToDisabled':
|
||||||
|
this.multiDatesPicker[option] = options[option];
|
||||||
|
break;
|
||||||
|
//default: $.error('Option ' + option + ' does not exist for setMode on jQuery.multiDatesPicker');
|
||||||
|
}
|
||||||
|
if(mandatory > 0) $.error('Some mandatory options not specified!');
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
if(options.pickableRange) {
|
||||||
|
$this.datepicker("option", "maxDate", options.pickableRange);
|
||||||
|
$this.datepicker("option", "minDate", this.multiDatesPicker.minDate);
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
if(mdp_events.onSelect)
|
||||||
|
mdp_events.onSelect();
|
||||||
|
},
|
||||||
|
destroy: function(){
|
||||||
|
this.multiDatesPicker = null;
|
||||||
|
$(this).datepicker('destroy');
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
this.each(function() {
|
||||||
|
var $this = $(this);
|
||||||
|
if (!this.multiDatesPicker) {
|
||||||
|
this.multiDatesPicker = {
|
||||||
|
dates: {
|
||||||
|
picked: [],
|
||||||
|
disabled: []
|
||||||
|
},
|
||||||
|
mode: 'normal',
|
||||||
|
adjustRangeToDisabled: true
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
if(methods[method]) {
|
||||||
|
var exec_result = methods[method].apply(this, Array.prototype.slice.call(mdp_arguments, 1));
|
||||||
|
switch(method) {
|
||||||
|
case 'removeDates':
|
||||||
|
case 'removeIndexes':
|
||||||
|
case 'resetDates':
|
||||||
|
case 'toggleDate':
|
||||||
|
case 'addDates':
|
||||||
|
var altField = $this.datepicker('option', 'altField');
|
||||||
|
// @todo: should use altFormat for altField
|
||||||
|
var dates_string = methods.value.call(this);
|
||||||
|
if (altField !== undefined && altField != "") {
|
||||||
|
$(altField).val(dates_string);
|
||||||
|
}
|
||||||
|
$this.val(dates_string);
|
||||||
|
|
||||||
|
$.datepicker._refreshDatepicker(this);
|
||||||
|
}
|
||||||
|
switch(method) {
|
||||||
|
case 'removeDates':
|
||||||
|
case 'getDates':
|
||||||
|
case 'gotDate':
|
||||||
|
case 'sumDays':
|
||||||
|
case 'compareDates':
|
||||||
|
case 'dateConvert':
|
||||||
|
case 'value':
|
||||||
|
ret = exec_result;
|
||||||
|
}
|
||||||
|
return exec_result;
|
||||||
|
} else if( typeof method === 'object' || ! method ) {
|
||||||
|
return methods.init.apply(this, mdp_arguments);
|
||||||
|
} else {
|
||||||
|
$.error('Method ' + method + ' does not exist on jQuery.multiDatesPicker');
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
};
|
||||||
|
|
||||||
|
var PROP_NAME = 'multiDatesPicker';
|
||||||
|
var dpuuid = new Date().getTime();
|
||||||
|
var instActive;
|
||||||
|
|
||||||
|
$.multiDatesPicker = {version: false};
|
||||||
|
//$.multiDatesPicker = new MultiDatesPicker(); // singleton instance
|
||||||
|
$.multiDatesPicker.initialized = false;
|
||||||
|
$.multiDatesPicker.uuid = new Date().getTime();
|
||||||
|
$.multiDatesPicker.version = $.ui.multiDatesPicker.version;
|
||||||
|
|
||||||
|
// allows MDP not to hide everytime a date is picked
|
||||||
|
$.multiDatesPicker._hideDatepicker = $.datepicker._hideDatepicker;
|
||||||
|
$.datepicker._hideDatepicker = function(){
|
||||||
|
var target = this._curInst.input[0];
|
||||||
|
var mdp = target.multiDatesPicker;
|
||||||
|
if(!mdp || (this._curInst.inline === false && !mdp.changed)) {
|
||||||
|
return $.multiDatesPicker._hideDatepicker.apply(this, arguments);
|
||||||
|
} else {
|
||||||
|
mdp.changed = false;
|
||||||
|
$.datepicker._refreshDatepicker(target);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Workaround for #4055
|
||||||
|
// Add another global to avoid noConflict issues with inline event handlers
|
||||||
|
window['DP_jQuery_' + dpuuid] = $;
|
||||||
|
})( jQuery );
|
|
@ -144,6 +144,8 @@
|
||||||
|
|
||||||
<input class="btn btn-primary" type='submit' value='Partager' onClick='shareEvent();' />
|
<input class="btn btn-primary" type='submit' value='Partager' onClick='shareEvent();' />
|
||||||
|
|
||||||
|
<input class="btn btn-primary" type='submit' value='Cloner' onClick='showcloneEvent();' />
|
||||||
|
|
||||||
<input class='btn btn-default' type='submit' value='Annuler' onClick='$("#mymodal-event-mod").modal("hide");'>
|
<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="calendar_id" id="calendar_id" type="hidden" class="form-control" placeholder="Nom">
|
||||||
|
@ -217,11 +219,46 @@
|
||||||
</div>
|
</div>
|
||||||
</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">×</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' />
|
||||||
|
|
||||||
|
<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 %}
|
{% endblock %}
|
||||||
|
|
||||||
{% block localexternalscript %}
|
{% block localexternalscript %}
|
||||||
<script type="text/javascript" src="/{{alias}}/ckeditor/ckeditor.js"></script>
|
<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}}/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 %}
|
{% endblock %}
|
||||||
|
|
||||||
{% block localjavascript %}
|
{% block localjavascript %}
|
||||||
|
@ -357,17 +394,29 @@
|
||||||
// Modification Evenement
|
// Modification Evenement
|
||||||
eventClick: function(event, jsEvent, view) {
|
eventClick: function(event, jsEvent, view) {
|
||||||
if(event.editable) {
|
if(event.editable) {
|
||||||
|
end=event.end.clone();
|
||||||
|
|
||||||
$("#mymodal-event-mod #event_id").val(event.id);
|
$("#mymodal-event-mod #event_id").val(event.id);
|
||||||
$("#mymodal-event-mod #event_title").val(event.title);
|
$("#mymodal-event-mod #event_title").val(event.title);
|
||||||
CKEDITOR.instances["event_description-mod"].setData(event.description)
|
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_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_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_startm").val(event.start.format("DD/MM/YYYY"));
|
||||||
$("#mymodal-event-mod #event_endm").val(event.end.subtract("1","s").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_allday").bootstrapSwitch('state', event.allDay);
|
||||||
$("#mymodal-event-mod #event_calendar option[value='"+event.calendar+"']").prop('selected', true);
|
$("#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();
|
refreshPJ();
|
||||||
|
|
||||||
switchallDay("UPDATE");
|
switchallDay("UPDATE");
|
||||||
|
@ -526,7 +575,6 @@
|
||||||
},
|
},
|
||||||
false // make the event "stick"
|
false // make the event "stick"
|
||||||
);
|
);
|
||||||
console.log(event);
|
|
||||||
|
|
||||||
$("#mymodal-event-add").modal("hide");
|
$("#mymodal-event-add").modal("hide");
|
||||||
|
|
||||||
|
@ -625,6 +673,92 @@
|
||||||
$(location).attr('href',url);
|
$(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() {
|
function deleteEvent() {
|
||||||
|
|
||||||
$.ajax({
|
$.ajax({
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 6.8 KiB |
Binary file not shown.
After Width: | Height: | Size: 6.9 KiB |
Binary file not shown.
After Width: | Height: | Size: 4.6 KiB |
Binary file not shown.
After Width: | Height: | Size: 6.8 KiB |
Binary file not shown.
After Width: | Height: | Size: 4.5 KiB |
Binary file not shown.
After Width: | Height: | Size: 6.2 KiB |
Loading…
Reference in New Issue