forked from friendica/deprecated-addons
2856 lines
90 KiB
JavaScript
2856 lines
90 KiB
JavaScript
/**
|
|
* @description {Class} wdCalendar
|
|
* This is the main class of wdCalendar.
|
|
*/
|
|
(function ($) {
|
|
"use strict";
|
|
|
|
var __WDAY = $.datepicker._defaults.dayNamesShort;
|
|
//new Array(i18n.xgcalendar.dateformat.sun, i18n.xgcalendar.dateformat.mon, i18n.xgcalendar.dateformat.tue, i18n.xgcalendar.dateformat.wed, i18n.xgcalendar.dateformat.thu, i18n.xgcalendar.dateformat.fri, i18n.xgcalendar.dateformat.sat);
|
|
var __MonthName = $.datepicker._defaults.monthNamesShort;
|
|
//new Array(i18n.xgcalendar.dateformat.jan, i18n.xgcalendar.dateformat.feb, i18n.xgcalendar.dateformat.mar, i18n.xgcalendar.dateformat.apr, i18n.xgcalendar.dateformat.may, i18n.xgcalendar.dateformat.jun, i18n.xgcalendar.dateformat.jul, i18n.xgcalendar.dateformat.aug, i18n.xgcalendar.dateformat.sep, i18n.xgcalendar.dateformat.oct, i18n.xgcalendar.dateformat.nov, i18n.xgcalendar.dateformat.dec);
|
|
|
|
|
|
function dateFormat(format) {
|
|
var o = {
|
|
"M+":this.getMonth() + 1,
|
|
"d+":this.getDate(),
|
|
"h+":this.getHours(),
|
|
"H+":this.getHours(),
|
|
"m+":this.getMinutes(),
|
|
"s+":this.getSeconds(),
|
|
"q+":Math.floor((this.getMonth() + 3) / 3),
|
|
"w":"0123456".indexOf(this.getDay()),
|
|
"W":__WDAY[this.getDay()],
|
|
"L":__MonthName[this.getMonth()] //non-standard
|
|
};
|
|
if (/(y+)/.test(format)) {
|
|
format = format.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
|
|
}
|
|
for (var k in o) {
|
|
if (new RegExp("(" + k + ")").test(format))
|
|
format = format.replace(RegExp.$1, RegExp.$1.length == 1 ? o[k] : ("00" + o[k]).substr(("" + o[k]).length));
|
|
}
|
|
return format;
|
|
}
|
|
|
|
function DateDiff(interval, d1, d2) {
|
|
switch (interval) {
|
|
case "d": //date
|
|
case "w":
|
|
d1 = new Date(d1.getFullYear(), d1.getMonth(), d1.getDate());
|
|
d2 = new Date(d2.getFullYear(), d2.getMonth(), d2.getDate());
|
|
break; //w
|
|
case "h":
|
|
d1 = new Date(d1.getFullYear(), d1.getMonth(), d1.getDate(), d1.getHours());
|
|
d2 = new Date(d2.getFullYear(), d2.getMonth(), d2.getDate(), d2.getHours());
|
|
break; //h
|
|
case "n":
|
|
d1 = new Date(d1.getFullYear(), d1.getMonth(), d1.getDate(), d1.getHours(), d1.getMinutes());
|
|
d2 = new Date(d2.getFullYear(), d2.getMonth(), d2.getDate(), d2.getHours(), d2.getMinutes());
|
|
break;
|
|
case "s":
|
|
d1 = new Date(d1.getFullYear(), d1.getMonth(), d1.getDate(), d1.getHours(), d1.getMinutes(), d1.getSeconds());
|
|
d2 = new Date(d2.getFullYear(), d2.getMonth(), d2.getDate(), d2.getHours(), d2.getMinutes(), d2.getSeconds());
|
|
break;
|
|
}
|
|
var t1 = d1.getTime(), t2 = d2.getTime();
|
|
var diff = NaN;
|
|
switch (interval) {
|
|
case "y":
|
|
diff = d2.getFullYear() - d1.getFullYear();
|
|
break; //y
|
|
case "m":
|
|
diff = (d2.getFullYear() - d1.getFullYear()) * 12 + d2.getMonth() - d1.getMonth();
|
|
break; //m
|
|
case "d":
|
|
diff = Math.floor(t2 / 86400000) - Math.floor(t1 / 86400000);
|
|
break;
|
|
case "w":
|
|
diff = Math.floor((t2 + 345600000) / (604800000)) - Math.floor((t1 + 345600000) / (604800000));
|
|
break; //w
|
|
case "h":
|
|
diff = Math.floor(t2 / 3600000) - Math.floor(t1 / 3600000);
|
|
break; //h
|
|
case "n":
|
|
diff = Math.floor(t2 / 60000) - Math.floor(t1 / 60000);
|
|
break; //
|
|
case "s":
|
|
diff = Math.floor(t2 / 1000) - Math.floor(t1 / 1000);
|
|
break; //s
|
|
case "l":
|
|
diff = t2 - t1;
|
|
break;
|
|
}
|
|
return diff;
|
|
|
|
}
|
|
|
|
function DateAdd(interval, number, idate) {
|
|
number = parseInt(number);
|
|
var date;
|
|
if (typeof (idate) == "string") {
|
|
date = idate.split(/\D/);
|
|
eval("var date = new Date(" + date.join(",") + ")");
|
|
}
|
|
|
|
if (typeof (idate) == "object") {
|
|
date = new Date(idate.toString());
|
|
}
|
|
switch (interval) {
|
|
case "y":
|
|
date.setFullYear(date.getFullYear() + number);
|
|
break;
|
|
case "m":
|
|
date.setMonth(date.getMonth() + number);
|
|
break;
|
|
case "d":
|
|
date.setDate(date.getDate() + number);
|
|
break;
|
|
case "w":
|
|
date.setDate(date.getDate() + 7 * number);
|
|
break;
|
|
case "h":
|
|
date.setHours(date.getHours() + number);
|
|
break;
|
|
case "n":
|
|
date.setMinutes(date.getMinutes() + number);
|
|
break;
|
|
case "s":
|
|
date.setSeconds(date.getSeconds() + number);
|
|
break;
|
|
case "l":
|
|
date.setMilliseconds(date.getMilliseconds() + number);
|
|
break;
|
|
}
|
|
return date;
|
|
}
|
|
|
|
function ColorrCalcBrighten(col, factor) {
|
|
return 255-Math.round((255 - col) * factor);
|
|
}
|
|
function ColorCalcValues(basecol) {
|
|
if (!basecol.match(/^#[0-9a-f]{6}$/i)) return ColorCalcValues("#f8f8ff");
|
|
var r = parseInt(basecol.substring(1, 3), 16);
|
|
var g = parseInt(basecol.substring(3, 5), 16);
|
|
var b = parseInt(basecol.substring(5, 7), 16);
|
|
var col1 = "#" + ColorrCalcBrighten(r, 0.6).toString(16) + ColorrCalcBrighten(g, 0.6).toString(16) + ColorrCalcBrighten(b, 0.6).toString(16);
|
|
var col2 = "#" + ColorrCalcBrighten(r, 0.5).toString(16) + ColorrCalcBrighten(g, 0.5).toString(16) + ColorrCalcBrighten(b, 0.5).toString(16);
|
|
return [basecol, col1, col2];
|
|
}
|
|
|
|
|
|
if ($.fn.noSelect == undefined) {
|
|
$.fn.noSelect = function (p) { //no select addon by me :-)
|
|
var prevent;
|
|
if (p == null)
|
|
prevent = true;
|
|
else
|
|
prevent = p;
|
|
if (prevent) {
|
|
return this.each(function () {
|
|
if ($.browser.msie || $.browser.safari) $(this).bind('selectstart', function () {
|
|
return false;
|
|
});
|
|
else if ($.browser.mozilla) {
|
|
$(this).css('MozUserSelect', 'none');
|
|
$('body').trigger('focus');
|
|
}
|
|
else if ($.browser.opera) $(this).bind('mousedown', function () {
|
|
return false;
|
|
});
|
|
else $(this).data('unselectable', 'on');
|
|
});
|
|
|
|
} else {
|
|
return this.each(function () {
|
|
if ($.browser.msie || $.browser.safari) $(this).unbind('selectstart');
|
|
else if ($.browser.mozilla) $(this).css('MozUserSelect', 'inherit');
|
|
else if ($.browser.opera) $(this).unbind('mousedown');
|
|
else $(this).removeData('unselectable', 'on');
|
|
});
|
|
|
|
}
|
|
}; //end noSelect
|
|
}
|
|
$.fn.bcalendar = function (option) {
|
|
var def = {
|
|
/**
|
|
* @description {Config} view
|
|
* {String} Three calendar view provided, 'day','multi_days','week','month'. 'week' by default.
|
|
*/
|
|
view:"week",
|
|
|
|
date_format_dm1:"W, d.M",
|
|
date_format_dm2:"d. L",
|
|
date_format_dm3:"d L yyyy",
|
|
date_format_full:"yy-mm-dd",
|
|
|
|
/**
|
|
* @description {Config} weekstartday
|
|
* {Number} First day of week 0 for Sun, 1 for Mon, 2 for Tue.
|
|
*/
|
|
weekstartday:1, //start from Monday by default
|
|
std_color: "#5858ff",
|
|
/**
|
|
* @description {Config} height
|
|
* {Number} Calendar height, false for page height by default.
|
|
*/
|
|
height:false,
|
|
baseurl: "",
|
|
/**
|
|
* @description {Config} url
|
|
* {String} Url to request calendar data.
|
|
*/
|
|
url:"",
|
|
|
|
/**
|
|
* @description {Config} eventItems
|
|
* {Array} event items for initialization.
|
|
*/
|
|
eventItems:[],
|
|
method:"POST",
|
|
/**
|
|
* @description {Config} showday
|
|
* {Date} Current date. today by default.
|
|
*/
|
|
showday:new Date(),
|
|
/**
|
|
* @description {Event} onBeforeRequestData:function(stage)
|
|
* Fired before any ajax request is sent.
|
|
* @param {Number} stage. 1 for retrieving events, 2 - adding event, 3 - removiing event, 4 - update event.
|
|
*/
|
|
onBeforeRequestData:false,
|
|
/**
|
|
* @description {Event} onAfterRequestData:function(stage)
|
|
* Fired before any ajax request is finished.
|
|
* @param {Number} stage. 1 for retrieving events, 2 - adding event, 3 - removiing event, 4 - update event.
|
|
*/
|
|
onAfterRequestData:false,
|
|
/**
|
|
* @description {Event} onAfterRequestData:function(stage)
|
|
* Fired when some errors occur while any ajax request is finished.
|
|
* @param {Number} stage. 1 for retrieving events, 2 - adding event, 3 - removiing event, 4 - update event.
|
|
*/
|
|
onRequestDataError:false,
|
|
|
|
onWeekOrMonthToDay:false,
|
|
|
|
/**
|
|
* @description {Event} quickAddHandler:function(calendar, param )
|
|
* Fired when user quick adds an item. If this function is set, ajax request to quickAddUrl will abort.
|
|
* @param {Object} calendar Calendar object.
|
|
* @param {Array} param Format [{name:"name1", value:"value1"}, ...]
|
|
*
|
|
*/
|
|
quickAddHandler:false,
|
|
|
|
quickUpdateHandler:false,
|
|
|
|
quickDeleteHandler: false,
|
|
/**
|
|
* @description {Config} quickAddUrl
|
|
* {String} Url for quick adding.
|
|
*/
|
|
quickAddUrl:"",
|
|
/**
|
|
* @description {Config} quickUpdateUrl
|
|
* {String} Url for time span update.
|
|
*/
|
|
quickUpdateUrl:"",
|
|
/**
|
|
* @description {Config} quickDeleteUrl
|
|
* {String} Url for removing an event.
|
|
*/
|
|
quickDeleteUrl:"",
|
|
/**
|
|
* @description {Config} autoload
|
|
* {Boolean} If event items is empty, and this param is set to true.
|
|
* Event will be retrieved by ajax call right after calendar is initialized.
|
|
*/
|
|
autoload:false,
|
|
/**
|
|
* @description {Config} readonly
|
|
* {Boolean} Indicate calendar is readonly or editable
|
|
*/
|
|
readonly:false,
|
|
/**
|
|
* @description {Config} extParam
|
|
* {Array} Extra params submitted to server.
|
|
* Sample - [{name:"param1", value:"value1"}, {name:"param2", value:"value2"}]
|
|
*/
|
|
extParam:[],
|
|
/**
|
|
* @description {Config} enableDrag
|
|
* {Boolean} Whether end user can drag event item by mouse.
|
|
*/
|
|
enableDrag:true,
|
|
url_add:"",
|
|
num_days:7,
|
|
hour_height:42,
|
|
|
|
calendars_available:[],
|
|
calendars_selected:[]
|
|
};
|
|
var eventDiv = $("#gridEvent");
|
|
if (eventDiv.length == 0) {
|
|
eventDiv = $("<div id='gridEvent' style='display:none;'></div>").appendTo(document.body);
|
|
}
|
|
var $gridcontainer = $(this);
|
|
option = $.extend(def, option);
|
|
|
|
//no quickUpdateUrl, dragging disabled.
|
|
if (option.quickUpdateUrl == null || option.quickUpdateUrl == "") {
|
|
option.enableDrag = false;
|
|
}
|
|
//template for month and date
|
|
var __SCOLLEVENTTEMP = "<DIV style=\"width:{width};top:{top};left:{left};\" title=\"{title}\" class=\"chip chip{i} {drag} {addclasses}\">" +
|
|
"<DIV style=\"border-bottom-color:{bdcolor}\" class=ct> </DIV>" +
|
|
"<DL style=\"border-color:{bdcolor}; background-color:{bgcolor1}; height: {height}px;\"><DT style=\"background-color:{bgcolor2}\">{starttime} - {endtime} {icon}</DT>" +
|
|
"<DD><SPAN>{content}</SPAN></DD><DIV class='resizer' style='display:{redisplay}'><DIV class=rszr_icon> </DIV></DIV></DL>" +
|
|
"<DIV style=\"BORDER-BOTTOM-COLOR:{bdcolor}; background-color:{bgcolor1}; border-color: {bdcolor};\" class=cb1> </DIV>" +
|
|
"<DIV style=\"border-color:{bdcolor};\" class=cb2> </DIV></DIV>";
|
|
var __ALLDAYEVENTTEMP = '<div class="rb-o {eclass}" id="{id}" title="{title}" style="color:{color};">' +
|
|
'<div class="{extendClass} rb-m" style="background-color:{color}">{extendHTML}<div class="rb-i">{content}</div></div></div>';
|
|
var __MonthDays = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
|
|
var __LASSOTEMP = "<div class='drag-lasso' style=\"left:{left}px;top:{top}px;width:{width}px;height:{height}px;\"> </div>";
|
|
//for dragging var
|
|
var _dragdata;
|
|
var _dragevent;
|
|
|
|
//clear DOM
|
|
clearcontainer();
|
|
|
|
//no height specified in options, we get page height.
|
|
if (!option.height) {
|
|
option.height = document.documentElement.clientHeight;
|
|
}
|
|
//
|
|
$gridcontainer.css("overflow-y", "visible").height(option.height - 8);
|
|
|
|
//populate events data for first display.
|
|
if (option.url && option.autoload) {
|
|
populate();
|
|
}
|
|
else {
|
|
//contruct HTML
|
|
render();
|
|
}
|
|
|
|
//clear DOM
|
|
function clearcontainer() {
|
|
$gridcontainer.empty();
|
|
}
|
|
|
|
|
|
//contruct DOM
|
|
function render() {
|
|
//params needed
|
|
//viewType, showday, events, config
|
|
var showday = new Date(option.showday.getFullYear(), option.showday.getMonth(), option.showday.getDate());
|
|
var events = option.eventItems;
|
|
var config = { view:option.view, weekstartday:option.weekstartday, color:option.std_color };
|
|
if (option.view == "day" || option.view == "week" || option.view == "multi_days") {
|
|
var $dvtec = $gridcontainer.find(".scrolltimeevent");
|
|
if ($dvtec.length > 0) {
|
|
option.scroll = $dvtec.scrollTop(); //get scroll bar position
|
|
}
|
|
}
|
|
switch (option.view) {
|
|
case "day":
|
|
BuildDaysAndWeekView(showday, 1, events, config);
|
|
break;
|
|
case "week":
|
|
BuildDaysAndWeekView(showday, 7, events, config);
|
|
break;
|
|
case "multi_days":
|
|
BuildDaysAndWeekView(showday, option.num_days, events, config);
|
|
break;
|
|
case "month":
|
|
BuildMonthView(showday, events, config);
|
|
break;
|
|
default:
|
|
alert(i18n.xgcalendar["no_implement"]);
|
|
break;
|
|
}
|
|
initevents(option.view);
|
|
ResizeView();
|
|
}
|
|
|
|
//build day view
|
|
function BuildDaysAndWeekView(startday, l, events, config) {
|
|
var days = [],
|
|
show;
|
|
if (l == 1) {
|
|
show = dateFormat.call(startday, option.date_format_dm1);
|
|
days.push({ display:show, date:startday, day:startday.getDate(), year:startday.getFullYear(), month:startday.getMonth() + 1 });
|
|
option.datestrshow = CalDateShow(days[0].date);
|
|
option.vstart = days[0].date;
|
|
option.vend = days[0].date;
|
|
}
|
|
else {
|
|
var w = 0;
|
|
if (l == 7) {
|
|
w = config.weekstartday - startday.getDay();
|
|
if (w > 0) w = w - 7;
|
|
}
|
|
var ndate;
|
|
for (var i = w, j = 0; j < l; i = i + 1, j++) {
|
|
ndate = DateAdd("d", i, startday);
|
|
show = dateFormat.call(ndate, option.date_format_dm1);
|
|
days.push({ display:show, date:ndate, day:ndate.getDate(), year:ndate.getFullYear(), month:ndate.getMonth() + 1 });
|
|
}
|
|
option.vstart = days[0].date;
|
|
option.vend = days[l - 1].date;
|
|
option.datestrshow = CalDateShow(days[0].date, days[l - 1].date);
|
|
}
|
|
|
|
var allDayEvents = [];
|
|
var scrollDayEvents = [];
|
|
//get number of all-day events, including more-than-one-day events.
|
|
var dM = PrepareEvents(days, events, allDayEvents, scrollDayEvents);
|
|
|
|
var $html = $("<div class=\"wktopcontainer\"></div>");
|
|
$html.append(BuildWT(days, allDayEvents, dM));
|
|
|
|
$gridcontainer.html("").append($html);
|
|
|
|
$html = $("<div class=\"scrolltimeevent\"></div>");
|
|
$html.append(BuildDayScollEventContainer(days, scrollDayEvents));
|
|
$gridcontainer.append($html);
|
|
|
|
//TODO event handlers
|
|
//$gridcontainer.find(".weekViewAllDaywk").click(RowHandler);
|
|
}
|
|
|
|
//build month view
|
|
function BuildMonthView(showday, events, config) {
|
|
$gridcontainer.find("*").remove();
|
|
$gridcontainer.append("<div class='cal-month-cc cc'><div class='cal-month-cc-header'><div class='cc-close cal-month-closebtn'></div><div class='cal-month-cc-title cc-title'></div></div><div class='cal-month-cc-body cc-body'><div class='cal-month-cc-content st-contents'><table class='st-grid'><tbody></tbody></table></div></div></div>");
|
|
var html = [];
|
|
//build header
|
|
html.push("<div id=\"mvcontainer\" class=\"mv-container\">");
|
|
html.push("<table id=\"mvweek\" class=\"mv-daynames-table\"><tbody><tr>");
|
|
for (var i = config.weekstartday, j = 0; j < 7; i++, j++) {
|
|
if (i > 6) i = 0;
|
|
html.push("<th class=\"mv-dayname\" title=\"", __WDAY[i], "\">", __WDAY[i], "");
|
|
}
|
|
html.push("</tr></tbody></table>");
|
|
html.push("</div>");
|
|
$gridcontainer.append(html.join(""));
|
|
|
|
var bH = GetMonthViewBodyHeight() - GetMonthViewHeaderHeight();
|
|
var $container = $("<div class=\"mvEventContainer mv-event-container\" style=\"height:" + bH + "px;" + "\"></div>");
|
|
var $body = BuilderMonthBody(showday, config.weekstartday, events, bH);
|
|
$container.append($body);
|
|
$gridcontainer.append($container);
|
|
|
|
$gridcontainer.find(".cal-month-closebtn").click(closeCc);
|
|
}
|
|
|
|
function closeCc() {
|
|
$gridcontainer.find(".cal-month-cc").css("visibility", "hidden");
|
|
}
|
|
|
|
//all-day event, including more-than-one-day events
|
|
function PrepareEvents(dayarrs, events, allDayEvents, scrolLDayEvents) {
|
|
var i, j, k, de, x, y, La, H, D, Ia,
|
|
tmp_allday = allDayEvents,
|
|
tmp_scrollevents = scrolLDayEvents,
|
|
l = dayarrs.length,
|
|
el = events.length,
|
|
fE = [];
|
|
for (j = 0; j < el; j++) {
|
|
var sD = events[j]["start"];
|
|
var eD = events[j]["end"];
|
|
var s = {};
|
|
s.event = events[j];
|
|
s.day = sD.getDate();
|
|
s.year = sD.getFullYear();
|
|
s.month = sD.getMonth() + 1;
|
|
s.allday = events[j]["is_allday"] == 1;
|
|
s.crossday = events[j]["is_moredays"] == 1;
|
|
s.reevent = events[j]["is_recurring"] == 1; //Recurring event
|
|
s.daystr = [s.year, s.month, s.day].join("/");
|
|
s.st = {};
|
|
s.st.hour = sD.getHours();
|
|
s.st.minute = sD.getMinutes();
|
|
s.st.p = s.st.hour * 60 + s.st.minute; // start time
|
|
s.et = {};
|
|
s.et.hour = eD.getHours();
|
|
s.et.minute = eD.getMinutes();
|
|
s.et.p = s.et.hour * 60 + s.et.minute; // end time
|
|
fE.push(s);
|
|
}
|
|
var dMax = 0;
|
|
for (i = 0; i < l; i++) {
|
|
var da = dayarrs[i];
|
|
tmp_scrollevents[i] = [];
|
|
tmp_allday[i] = [];
|
|
da.daystr = da.year + "/" + da.month + "/" + da.day;
|
|
for (j = 0; j < fE.length; j++) {
|
|
if (!fE[j].crossday && !fE[j].allday) {
|
|
if (da.daystr == fE[j].daystr)
|
|
tmp_scrollevents[i].push(fE[j]);
|
|
}
|
|
else {
|
|
if (da.daystr == fE[j].daystr) {
|
|
tmp_allday[i].push(fE[j]);
|
|
dMax++;
|
|
}
|
|
else {
|
|
if (i == 0 && da.date >= fE[j].event["start"] && da.date <= fE[j].event["end"])//first more-than-one-day event
|
|
{
|
|
tmp_allday[i].push(fE[j]);
|
|
dMax++;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
var lrdate = dayarrs[l - 1].date;
|
|
for (i = 0; i < l; i++) { //to deal with more-than-one-day event
|
|
de = tmp_allday[i];
|
|
if (de.length > 0) { //
|
|
for (j = 0; j < de.length; j++) {
|
|
var end = DateDiff("d", lrdate, de[j].event["end"]) > 0 ? lrdate : de[j].event["end"];
|
|
de[j].colSpan = DateDiff("d", dayarrs[i].date, end) + 1
|
|
}
|
|
}
|
|
de = null;
|
|
}
|
|
//for all-day events
|
|
for (i = 0; i < l; i++) {
|
|
de = tmp_scrollevents[i];
|
|
if (de.length > 0) {
|
|
x = [];
|
|
y = [];
|
|
D = [];
|
|
var dl = de.length;
|
|
for (j = 0; j < dl; ++j) {
|
|
var ge = de[j];
|
|
for (La = ge.st.p, Ia = 0; y[Ia] > La;) Ia++;
|
|
ge.PO = Ia;
|
|
ge.ne = []; //PO is how many events before this one
|
|
y[Ia] = ge.et.p || 1440;
|
|
x[Ia] = ge;
|
|
if (!D[Ia]) {
|
|
D[Ia] = [];
|
|
}
|
|
D[Ia].push(ge);
|
|
if (Ia != 0) {
|
|
ge.pe = [x[Ia - 1]]; //previous event
|
|
x[Ia - 1].ne.push(ge); //next event
|
|
}
|
|
for (Ia = Ia + 1; y[Ia] <= La;) Ia++;
|
|
if (x[Ia]) {
|
|
k = x[Ia];
|
|
ge.ne.push(k);
|
|
k.pe.push(ge);
|
|
}
|
|
ge.width = 1 / (ge.PO + 1);
|
|
ge.left = 1 - ge.width;
|
|
}
|
|
k = Array.prototype.concat.apply([], D);
|
|
x = y = D = null;
|
|
var t = k.length;
|
|
for (y = t; y--;) {
|
|
H = 1;
|
|
La = 0;
|
|
x = k[y];
|
|
for (D = x.ne.length; D--;) {
|
|
Ia = x.ne[D];
|
|
La = Math.max(La, Ia.VL);
|
|
H = Math.min(H, Ia.left)
|
|
}
|
|
x.VL = La + 1;
|
|
x.width = H / (x.PO + 1);
|
|
x.left = H - x.width;
|
|
}
|
|
for (y = 0; y < t; y++) {
|
|
x = k[y];
|
|
x.left = 0;
|
|
if (x.pe) for (D = x.pe.length; D--;) {
|
|
H = x.pe[D];
|
|
x.left = Math.max(x.left, H.left + H.width);
|
|
}
|
|
var p = (1 - x.left) / x.VL;
|
|
x.width = Math.max(x.width, p);
|
|
x.aQ = Math.min(1 - x.left, x.width + 0.7 * p); //width offset
|
|
}
|
|
de = null;
|
|
tmp_scrollevents[i] = k;
|
|
}
|
|
}
|
|
return dMax;
|
|
}
|
|
|
|
|
|
// Week view: top row (full-day events)
|
|
function BuildWT(dayarrs, events, dMax) {
|
|
//1:
|
|
var i, j, h, e, el, x, l;
|
|
var html = "<table class=\"wk-top\">";
|
|
html += "<tr><th style='width: 60px;' rowspan=\"3\"> </th>";
|
|
for (i = 0; i < dayarrs.length; i++) {
|
|
var ev, title, cl;
|
|
if (dayarrs.length == 1) {
|
|
ev = "";
|
|
title = "";
|
|
cl = "";
|
|
}
|
|
else {
|
|
ev = ""; // "onclick=\"javascript:FunProxy('week2day',event,this);\"";
|
|
title = i18n.xgcalendar.to_date_view;
|
|
cl = "wk-daylink";
|
|
}
|
|
html += "<th data-abbr='" + dayarrs[i].date.getTime() + "' class='gcweekname' scope=\"col\">";
|
|
html += "<div title='" + title + "' " + ev + " class='wk-dayname'><span class='" + cl + "'>" + dayarrs[i].display + "</span></div></th>";
|
|
|
|
}
|
|
html += "<th style='width: 16px;' rowspan=\"3\"> </th>";
|
|
html += "</tr>"; //end tr1;
|
|
//2:
|
|
html += "<tr>";
|
|
html += "<td class=\"wk-allday\"";
|
|
|
|
if (dayarrs.length > 1) {
|
|
html += " colSpan='" + dayarrs.length + "'";
|
|
}
|
|
//onclick=\"javascript:FunProxy('rowhandler',event,this);\"
|
|
html += "><div class=\"weekViewAllDaywk\" ><table class=\"st-grid\"><tbody>";
|
|
|
|
if (dMax == 0) {
|
|
html += "<tr>";
|
|
for (i = 0; i < dayarrs.length; i++) {
|
|
html += "<td class=\"st-c st-s\" data-ch='qkadd' data-abbr='" + dayarrs[i].date.getTime() + "' data-axis='00:00'> </td>";
|
|
}
|
|
html += "</tr>";
|
|
}
|
|
else {
|
|
l = events.length;
|
|
el = 0;
|
|
x = [];
|
|
for (j = 0; j < l; j++) {
|
|
x.push(0);
|
|
}
|
|
//var c = tc();
|
|
for (j = 0; el < dMax; j++) {
|
|
html += "<tr class='row" + j + "'>";
|
|
for (h = 0; h < l;) {
|
|
e = events[h][x[h]];
|
|
html += "<td class='st-c col" + h;
|
|
if (e) { //if exists
|
|
x[h] = x[h] + 1;
|
|
html += "'";
|
|
if (e.colSpan > 1) {
|
|
html += " colSpan='" + e.colSpan + "'";
|
|
h += e.colSpan;
|
|
}
|
|
else {
|
|
h++;
|
|
}
|
|
html += " ch='show'>";
|
|
el++;
|
|
}
|
|
else {
|
|
html += " st-s' data-ch='qkadd' data-abbr='" + dayarrs[h].date.getTime() + "' data-axis='00:00'> ";
|
|
h++;
|
|
}
|
|
html += "</td>";
|
|
}
|
|
html += "</tr>";
|
|
}
|
|
html += "<tr>";
|
|
for (h = 0; h < l; h++) {
|
|
html += "<td class='st-c st-s' data-ch='qkadd' data-abbr='" + dayarrs[h].date.getTime() + "' data-axis='00:00'> </td>";
|
|
}
|
|
html += "</tr>";
|
|
}
|
|
html += "</tbody></table></div></td></tr>"; // stgrid end //wvAd end //td2 end //tr2 end
|
|
//3:
|
|
html += "<tr>";
|
|
|
|
html += "<td style=\"height: 5px;\"";
|
|
if (dayarrs.length > 1) {
|
|
html += " colSpan='" + dayarrs.length + "'";
|
|
}
|
|
html += "></td>";
|
|
html += "</tr>";
|
|
html += "</table>";
|
|
var $el = $(html);
|
|
|
|
if (dMax > 0) {
|
|
l = events.length;
|
|
el = 0;
|
|
x = [];
|
|
for (j = 0; j < l; j++) {
|
|
x.push(0);
|
|
}
|
|
for (j = 0; el < dMax; j++) {
|
|
for (h = 0; h < l;) {
|
|
e = events[h][x[h]];
|
|
if (e) { //if exists
|
|
x[h] = x[h] + 1;
|
|
var $t = BuildMonthDayEvent(e, dayarrs[h].date, l - h);
|
|
$el.find(".row" + j + " .col" + h).append($t);
|
|
if (e.colSpan > 1) {
|
|
h += e.colSpan;
|
|
}
|
|
else {
|
|
h++;
|
|
}
|
|
el++;
|
|
}
|
|
else {
|
|
h++;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return $el;
|
|
}
|
|
|
|
function BuildDayScollEventContainer(dayarrs, events) {
|
|
//1:
|
|
var i, c;
|
|
|
|
var html = "<table style=\"table-layout: fixed;";
|
|
html += ($.browser.msie ? "" : "width:100%");
|
|
html += "\"><tbody><tr><td><table style=\"height: " + (option.hour_height * 24) + "px\" class=\"tg-timedevents\"><tbody>";
|
|
html += "<tr><td style='width:60px;'></td><td";
|
|
if (dayarrs.length > 1) {
|
|
html += " colSpan='" + dayarrs.length + "'";
|
|
}
|
|
html += "><div class=\"tg-spanningwrapper\"><div style=\"font-size: " + (Math.round(option.hour_height / 2) - 1) + "px\" class=\"tg-hourmarkers\">";
|
|
for (i = 0; i < 24; i++) {
|
|
html += "<div class=\"tg-dualmarker\"></div>";
|
|
}
|
|
html += "</div></div></td></tr>";
|
|
|
|
//2:
|
|
html += "<tr>";
|
|
html += "<td style=\"width: 60px; \" class=\"tg-times\">";
|
|
|
|
//get current time
|
|
var now = new Date();
|
|
var h = now.getHours();
|
|
var m = now.getMinutes();
|
|
var mHg = gP(h, m) - 4; //make middle alignment vertically
|
|
html += "<div id=\"tgnowptr\" class=\"tg-nowptr\" style=\"left:0;top:" + mHg + "px\"></div>";
|
|
for (i = 0; i < 24; i++) html += "<div style=\"height: " + (option.hour_height - 1) + "px\" class=\"tg-time\">" + fomartTimeShow(i) + "</div>";
|
|
html += "</td>";
|
|
|
|
var l = dayarrs.length;
|
|
var hh24 = option.hour_height * 24;
|
|
for (i = 0; i < l; i++) {
|
|
html += "<td class='tg-col' data-ch='qkadd' data-abbr='" + dayarrs[i].date.getTime() + "'>";
|
|
var istoday = formatDate(dayarrs[i].date) == formatDate(new Date());
|
|
// Today
|
|
if (istoday) {
|
|
html += "<div style=\"margin-bottom: -" + hh24 + "px; height:" + hh24 + "px\" class=\"tg-today\"> </div>";
|
|
}
|
|
//var eventC = $(eventWrap);
|
|
//onclick=\"javascript:FunProxy('rowhandler',event,this);\"
|
|
html += "<div style=\"margin-bottom: -" + hh24 + "px; height: " + hh24 + "px\" data-col='" + i + "' class='tgCol" + i + " tg-col-eventwrapper'></div>";
|
|
|
|
html += "<div class='tg-col-overlaywrapper tgOver" + i + "' data-col='" + i + "'>";
|
|
if (istoday) {
|
|
var mhh = mHg + 4;
|
|
html += "<div class=\"tg-hourmarker tg-nowmarker\" style=\"left:0;top:" + mhh + "px\"></div>";
|
|
}
|
|
html += "</div>";
|
|
html += "</td>";
|
|
}
|
|
html += "</tr>";
|
|
|
|
html += "</tbody></table></td></tr></tbody></table>";
|
|
var $container = $(html);
|
|
|
|
for (i = 0; i < l; i++) {
|
|
var $col = $container.find(".tgCol" + i);
|
|
for (var j = 0; j < events[i].length; j++) {
|
|
if (events[i][j].event["color"] && events[i][j].event["color"].match(/^[0-9a-f]{6}$/i)) {
|
|
c = "#" + events[i][j].event["color"];
|
|
}
|
|
else {
|
|
c = option.std_color;
|
|
}
|
|
var $tt = BuildDayEvent(c, events[i][j], j);
|
|
$col.append($tt);
|
|
}
|
|
}
|
|
|
|
return $container;
|
|
}
|
|
|
|
|
|
function getTitle(event) {
|
|
var timeshow, eventshow;
|
|
var showtime = event["is_allday"] != 1;
|
|
eventshow = event["summary"];
|
|
var startformat = getymformat(event["start"], null, showtime, true);
|
|
var endformat = getymformat(event["end"], event["start"], showtime, true);
|
|
timeshow = dateFormat.call(event["start"], startformat) + " - " + dateFormat.call(event["end"], endformat);
|
|
//var linebreak = ($.browser.mozilla?"":"\r\n");
|
|
var linebreak = "\r\n";
|
|
var ret = [];
|
|
if (event["is_allday"] == 1) {
|
|
//ret.push("[" + i18n.xgcalendar.allday_event + "]", linebreak );
|
|
}
|
|
else {
|
|
if (event["is_recurring"] == 1) {
|
|
ret.push("[" + i18n.xgcalendar.repeat_event + "]", linebreak);
|
|
}
|
|
}
|
|
ret.push(i18n.xgcalendar.time + ": ", timeshow, linebreak, i18n.xgcalendar.event + ": ", eventshow);
|
|
|
|
if (event["location"] != undefined && event["location"] != "") {
|
|
ret.push(linebreak, i18n.xgcalendar.location + ": ", event["location"]);
|
|
}
|
|
|
|
if (event["attendees"] != undefined && event["attendees"] != "") {
|
|
ret.push(linebreak, i18n.xgcalendar.participant + ": ", event["attendees"]);
|
|
}
|
|
return ret.join("");
|
|
}
|
|
|
|
function BuildDayEvent(color, e, index) {
|
|
var theme = ColorCalcValues(color);
|
|
var p = { bdcolor:theme[0], bgcolor2:theme[0], bgcolor1:theme[2], width:"70%", icon:"", title:"", data:"" };
|
|
p.starttime = pZero(e.st.hour) + ":" + pZero(e.st.minute);
|
|
p.endtime = pZero(e.et.hour) + ":" + pZero(e.et.minute);
|
|
p.content = e.event["summary"];
|
|
p.title = getTitle(e.event);
|
|
var icons = [];
|
|
if (e.event["has_notification"] == 1) icons.push("<I class=\"cic cic-tmr\"> </I>");
|
|
if (e.reevent) {
|
|
icons.push("<I class=\"cic cic-spcl\"> </I>");
|
|
}
|
|
p.icon = icons.join("");
|
|
var sP = gP(e.st.hour, e.st.minute);
|
|
var eP = gP(e.et.hour, e.et.minute);
|
|
p.top = sP + "px";
|
|
p.left = (e.left * 100) + "%";
|
|
p.width = (e.aQ * 100) + "%";
|
|
p.height = (eP - sP - 4);
|
|
p.i = index;
|
|
if (option.enableDrag && e.event["is_editable_quick"] == 1) {
|
|
p.drag = "drag";
|
|
p.redisplay = "block";
|
|
}
|
|
else {
|
|
p.drag = "";
|
|
p.redisplay = "none";
|
|
}
|
|
|
|
p.addclasses = (e.event["is_editable_quick"] ? "editable" : "not_editable");
|
|
|
|
var $newtemp = $(Tp(__SCOLLEVENTTEMP, p));
|
|
$newtemp.data("eventdata", $.extend(true, {}, e.event));
|
|
|
|
return $newtemp;
|
|
}
|
|
|
|
//get body height in month view
|
|
function GetMonthViewBodyHeight() {
|
|
return option.height;
|
|
}
|
|
|
|
function GetMonthViewHeaderHeight() {
|
|
return 21;
|
|
}
|
|
|
|
function BuilderMonthBody(showday, startday, events, bodyHeight) {
|
|
var i, j, k, b, day;
|
|
|
|
var htb = [];
|
|
var firstdate = new Date(showday.getFullYear(), showday.getMonth(), 1);
|
|
var diffday = startday - firstdate.getDay();
|
|
var showmonth = showday.getMonth();
|
|
if (diffday > 0) {
|
|
diffday -= 7;
|
|
}
|
|
var startdate = DateAdd("d", diffday, firstdate);
|
|
var enddate = DateAdd("d", 34, startdate);
|
|
var rc = 5;
|
|
|
|
if (enddate.getFullYear() == showday.getFullYear() && enddate.getMonth() == showday.getMonth() && enddate.getDate() < __MonthDays[showmonth]) {
|
|
enddate = DateAdd("d", 7, enddate);
|
|
rc = 6;
|
|
}
|
|
option.vstart = startdate;
|
|
option.vend = enddate;
|
|
option.datestrshow = CalDateShow(startdate, enddate);
|
|
bodyHeight = bodyHeight - 18 * rc;
|
|
var rowheight = bodyHeight / rc;
|
|
var roweventcount = parseInt(rowheight / 21);
|
|
if (rowheight % 21 > 15) {
|
|
roweventcount++;
|
|
}
|
|
var p = 100 / rc;
|
|
var formatevents = [];
|
|
var hastdata = formartEventsInHashtable(events, startday, 7, startdate, enddate);
|
|
var B = [];
|
|
var C = [];
|
|
for (j = 0; j < rc; j++) {
|
|
k = 0;
|
|
formatevents[j] = b = [];
|
|
for (i = 0; i < 7; i++) {
|
|
var newkeyDate = DateAdd("d", j * 7 + i, startdate);
|
|
C[j * 7 + i] = newkeyDate;
|
|
var newkey = dateFormat.call(newkeyDate, i18n.xgcalendar.dateformat.fulldaykey);
|
|
b[i] = hastdata[newkey];
|
|
if (b[i] && b[i].length > 0) {
|
|
k += b[i].length;
|
|
}
|
|
}
|
|
B[j] = k;
|
|
}
|
|
eventDiv.data("mvdata", formatevents);
|
|
for (j = 0; j < rc; j++) {
|
|
//onclick=\"javascript:FunProxy('rowhandler',event,this);\"
|
|
htb.push("<div style=\"HEIGHT:", p, "%; TOP:", p * j, "%\" data-row=\"" + j + "\" class=\"month-row mvrow_" + j + "\">");
|
|
htb.push("<table class=\"st-bg-table\"><tbody><tr>");
|
|
|
|
for (i = 0; i < 7; i++) {
|
|
day = C[j * 7 + i];
|
|
htb.push("<td data-abbr='", day.getTime(), "' data-ch='qkadd' data-axis='00:00' title=''");
|
|
|
|
if (formatDate(day) == formatDate(new Date())) {
|
|
htb.push(" class=\"st-bg st-bg-today\">");
|
|
} else if (day.getMonth() != showmonth) {
|
|
htb.push(" class=\"st-bg st-bg-nonmonth\">");
|
|
} else {
|
|
htb.push(" class=\"st-bg\">");
|
|
}
|
|
htb.push(" </td>");
|
|
}
|
|
//bgtable
|
|
htb.push("</tr></tbody></table>");
|
|
|
|
//stgrid
|
|
htb.push("<table class=\"st-grid row" + j + "\"><tbody>");
|
|
|
|
//title tr
|
|
htb.push("<tr>");
|
|
var titletemp = "<td class=\"st-dtitle{titleClass}\" data-ch='qkadd' data-abbr='{abbr}' data-axis='00:00' title=\"{title}\"><span class='monthdayshow'>{dayshow}</span></a></td>";
|
|
|
|
for (i = 0; i < 7; i++) {
|
|
var o = { titleClass:"", dayshow:"" };
|
|
day = C[j * 7 + i];
|
|
if (formatDate(day) == formatDate(new Date())) {
|
|
o.titleClass = " st-dtitle-today";
|
|
}
|
|
if (day.getMonth() != showmonth) {
|
|
o.titleClass = " st-dtitle-nonmonth";
|
|
}
|
|
o.title = formatDate(day);
|
|
if (day.getDate() == 1) {
|
|
if (day.getMonth == 0) {
|
|
o.dayshow = formatDate(day);
|
|
}
|
|
else {
|
|
o.dayshow = dateFormat.call(day, option.date_format_dm2).toString();
|
|
}
|
|
}
|
|
else {
|
|
o.dayshow = day.getDate();
|
|
}
|
|
o.abbr = day.getTime();
|
|
htb.push(Tp(titletemp, o));
|
|
}
|
|
htb.push("</tr>");
|
|
htb.push("</tbody></table>");
|
|
//month-row
|
|
htb.push("</div>");
|
|
}
|
|
var $ret = $(htb.join(""));
|
|
|
|
for (j = 0; j < rc; j++) {
|
|
var sfirstday = C[j * 7];
|
|
var dMax = B[j];
|
|
var obs = BuildMonthRow(formatevents[j], dMax, roweventcount, sfirstday);
|
|
for (i = 0; i < obs.length; i++) $ret.find(".row" + j).append(obs[i]);
|
|
//htb=htb.concat(rowHtml); rowHtml = null;
|
|
|
|
}
|
|
return $ret;
|
|
}
|
|
|
|
//formate datetime
|
|
function formartEventsInHashtable(events, startday, daylength, rbdate, redate) {
|
|
var key;
|
|
var hast = new Object();
|
|
var l = events.length;
|
|
for (var i = 0; i < l; i++) {
|
|
var sD = events[i]["start"];
|
|
var eD = events[i]["end"];
|
|
var diff = DateDiff("d", sD, eD);
|
|
var s = {};
|
|
s.event = events[i];
|
|
s.day = sD.getDate();
|
|
s.year = sD.getFullYear();
|
|
s.month = sD.getMonth() + 1;
|
|
s.allday = events[i]["is_allday"] == 1;
|
|
s.crossday = events[i]["is_moredays"] == 1;
|
|
s.reevent = events[i]["is_recurring"] == 1; //Recurring event
|
|
s.daystr = s.year + "/" + s.month + "/" + s.day;
|
|
s.st = {};
|
|
s.st.hour = sD.getHours();
|
|
s.st.minute = sD.getMinutes();
|
|
s.st.p = s.st.hour * 60 + s.st.minute; // start time position
|
|
s.et = {};
|
|
s.et.hour = eD.getHours();
|
|
s.et.minute = eD.getMinutes();
|
|
s.et.p = s.et.hour * 60 + s.et.minute; // end time postition
|
|
|
|
if (diff > 0) {
|
|
if (sD < rbdate) { //start date out of range
|
|
sD = rbdate;
|
|
}
|
|
if (eD > redate) { //end date out of range
|
|
eD = redate;
|
|
}
|
|
var f = startday - sD.getDay();
|
|
if (f > 0) {
|
|
f -= daylength;
|
|
}
|
|
var sdtemp = DateAdd("d", f, sD);
|
|
for (; sdtemp <= eD; sD = sdtemp = DateAdd("d", daylength, sdtemp)) {
|
|
var d = $.extend(s, {});
|
|
key = dateFormat.call(sD, i18n.xgcalendar.dateformat.fulldaykey);
|
|
var x = DateDiff("d", sdtemp, eD);
|
|
if (hast[key] == null) {
|
|
hast[key] = [];
|
|
}
|
|
d.colSpan = (x >= daylength) ? daylength - DateDiff("d", sdtemp, sD) : DateDiff("d", sD, eD) + 1;
|
|
hast[key].push(d);
|
|
d = null;
|
|
}
|
|
}
|
|
else {
|
|
key = dateFormat.call(events[i]["start"], i18n.xgcalendar.dateformat.fulldaykey);
|
|
if (hast[key] == null) {
|
|
hast[key] = [];
|
|
}
|
|
s.colSpan = 1;
|
|
hast[key].push(s);
|
|
}
|
|
s = null;
|
|
}
|
|
return hast;
|
|
}
|
|
|
|
function BuildMonthRow(events, dMax, sc, day) {
|
|
var j, e, m,
|
|
x = [],
|
|
y = [],
|
|
z = [],
|
|
cday = [];
|
|
var l = events.length;
|
|
var el = 0;
|
|
var ret = [];
|
|
for (j = 0; j < l; j++) {
|
|
x.push(0);
|
|
y.push(0);
|
|
z.push(0);
|
|
cday.push(DateAdd("d", j, day));
|
|
}
|
|
for (j = 0; j < l; j++) {
|
|
var ec = events[j] ? events[j].length : 0;
|
|
y[j] += ec;
|
|
for (var k = 0; k < ec; k++) {
|
|
e = events[j][k];
|
|
if (e && e.colSpan > 1) {
|
|
for (m = 1; m < e.colSpan; m++) {
|
|
y[j + m]++;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
var tdtemp = "<td class='{cssclass}' data-axis='{axis}' data-ch='{ch}' data-abbr='{abbr}' title='{title}' {otherAttr}>{html}</td>";
|
|
for (j = 0; j < sc && el < dMax; j++) {
|
|
var $row = $("<tr></tr>");
|
|
//var gridtr = $(__TRTEMP);
|
|
for (var h = 0; h < l;) {
|
|
e = events[h] ? events[h][x[h]] : undefined;
|
|
var $ev = null;
|
|
var tempdata = { "class":"", axis:"", ch:"", title:"", abbr:"", html:"", otherAttr:"", click:"javascript:void(0);" };
|
|
var tempCss = ["st-c"];
|
|
|
|
if (e) {
|
|
x[h] = x[h] + 1;
|
|
//last event of the day
|
|
var bs = false;
|
|
if (z[h] + 1 == y[h] && e.colSpan == 1) {
|
|
bs = true;
|
|
}
|
|
if (!bs && j == (sc - 1) && z[h] < y[h]) {
|
|
el++;
|
|
$.extend(tempdata, { "axis":h, ch:"more", "abbr":cday[h].getTime(), html:i18n.xgcalendar.others + (y[h] - z[h]) + i18n.xgcalendar.item, click:"javascript:alert('more event');" });
|
|
tempCss.push("st-more st-moreul");
|
|
h++;
|
|
}
|
|
else {
|
|
tempdata.html = "";
|
|
$ev = BuildMonthDayEvent(e, cday[h], l - h);
|
|
tempdata.ch = "show";
|
|
if (e.colSpan > 1) {
|
|
tempdata.otherAttr = " colSpan='" + e.colSpan + "'";
|
|
for (m = 0; m < e.colSpan; m++) {
|
|
z[h + m] = z[h + m] + 1;
|
|
}
|
|
h += e.colSpan;
|
|
|
|
}
|
|
else {
|
|
z[h] = z[h] + 1;
|
|
h++;
|
|
}
|
|
el++;
|
|
}
|
|
}
|
|
else {
|
|
if (j == (sc - 1) && z[h] < y[h] && y[h] > 0) {
|
|
$.extend(tempdata, { "axis":h, ch:"more", "abbr":cday[h].getTime(), html:i18n.xgcalendar.others + (y[h] - z[h]) + i18n.xgcalendar.item, click:"javascript:alert('more event');" });
|
|
tempCss.push("st-more st-moreul");
|
|
h++;
|
|
}
|
|
else {
|
|
$.extend(tempdata, { html:" ", ch:"qkadd", "axis":"00:00", "abbr":cday[h].getTime(), title:"" });
|
|
tempCss.push("st-s");
|
|
h++;
|
|
}
|
|
}
|
|
tempdata.cssclass = tempCss.join(" ");
|
|
tempCss = null;
|
|
var $z = $(Tp(tdtemp, tempdata));
|
|
if ($ev != null) $z.append($ev);
|
|
$row.append($z);
|
|
tempdata = null;
|
|
}
|
|
ret.push($row);
|
|
}
|
|
return ret;
|
|
}
|
|
|
|
function BuildMonthDayEvent(e, cday, length) {
|
|
var theme;
|
|
if (e.event["color"] && e.event["color"].match(/^#[0-9a-f]{6}$/i)) {
|
|
theme = ColorCalcValues(e.event["color"]);
|
|
}
|
|
else {
|
|
theme = ColorCalcValues(option.std_color);
|
|
}
|
|
var p = { color:theme[2], title:"", extendClass:"", extendHTML:"", data:"" };
|
|
|
|
p.title = getTitle(e.event);
|
|
p.id = "bbit_cal_event_" + e.event["jq_id"];
|
|
if (option.enableDrag && e.event["is_editable_quick"] == 1) {
|
|
p.eclass = "drag";
|
|
}
|
|
else {
|
|
p.eclass = "cal_" + e.event["jq_id"];
|
|
}
|
|
p.eclass += " " + (e.event["is_editable"] ? "editable" : "not_editable");
|
|
var sp = "<span style=\"cursor: pointer\">{content}</span>";
|
|
var i = "<I class=\"cic cic-tmr\"> </I>";
|
|
var i2 = "<I class=\"cic cic-rcr\"> </I>";
|
|
var ml = "<div class=\"st-ad-ml\"></div>";
|
|
var mr = "<div class=\"st-ad-mr\"></div>";
|
|
var arrm = [];
|
|
var sf = e.event["start"] < cday;
|
|
var ef = DateDiff("d", cday, e.event["end"]) >= length; //e.event["end"] >= DateAdd("d", 1, cday);
|
|
if (sf || ef) {
|
|
if (sf) {
|
|
arrm.push(ml);
|
|
p.extendClass = "st-ad-mpad ";
|
|
}
|
|
if (ef) {
|
|
arrm.push(mr);
|
|
}
|
|
p.extendHTML = arrm.join("");
|
|
|
|
}
|
|
var cen;
|
|
if (!e.allday && !sf) {
|
|
cen = pZero(e.st.hour) + ":" + pZero(e.st.minute) + " " + e.event["summary"];
|
|
}
|
|
else {
|
|
cen = e.event["summary"];
|
|
}
|
|
var content = [];
|
|
if (cen.indexOf("Geburtstag:") == 0) {
|
|
content.push("<img src='/pics/silk/cake.png' alt='Geburtstag: ' title='Geburtstag' style='height: 12px; margin-right: 3px;'>");
|
|
cen = cen.replace(/Geburtstag: /, "");
|
|
}
|
|
content.push(Tp(sp, { content:cen }));
|
|
if (e.event["has_notification"] == 1) content.push(i);
|
|
if (e.reevent) {
|
|
content.push(i2);
|
|
}
|
|
p.content = content.join("");
|
|
var $newel = $(Tp(__ALLDAYEVENTTEMP, p));
|
|
$newel.data("eventdata", e.event);
|
|
return $newel;
|
|
}
|
|
|
|
//to populate the data
|
|
function populate() {
|
|
if (option.isloading) {
|
|
return true;
|
|
}
|
|
if (option.url && option.url != "") {
|
|
option.isloading = true;
|
|
//clearcontainer();
|
|
if (option.onBeforeRequestData && $.isFunction(option.onBeforeRequestData)) {
|
|
option.onBeforeRequestData(1);
|
|
}
|
|
var param = [
|
|
{ name:"showdate", value: Math.floor(option.showday.getTime() / 1000) },
|
|
{ name:"viewtype", value:option.view },
|
|
{ name:"weekstartday", value:option.weekstartday }
|
|
];
|
|
if (option.view == "multi_days") {
|
|
param.push({ name:"num_days", value:option.num_days });
|
|
}
|
|
if (option.extParam) {
|
|
for (var pi = 0; pi < option.extParam.length; pi++) {
|
|
param[param.length] = option.extParam[pi];
|
|
}
|
|
}
|
|
|
|
$.ajax({
|
|
type:option.method, //
|
|
url:option.url + option.url_add,
|
|
data:param,
|
|
dataType:"json",
|
|
dataFilter:function (data) {
|
|
//return data.replace(/"\\\/(Date\([0-9-]+\))\\\/"/gi, "new $1");
|
|
|
|
return data;
|
|
},
|
|
success:function (data) {//function(datastr) {
|
|
//datastr =datastr.replace(/"\\\/(Date\([0-9-]+\))\\\/"/gi, 'new $1');
|
|
//var data = (new Function("return " + datastr))();
|
|
if (data != null && data.error != null) {
|
|
if (option.onRequestDataError) {
|
|
option.onRequestDataError(1, data);
|
|
}
|
|
}
|
|
else {
|
|
data["start"] = parseDate(data["start"]);
|
|
data["end"] = parseDate(data["end"]);
|
|
$.each(data.events, function (index, value) {
|
|
value["start"] = new Date(value["start"] * 1000);
|
|
value["end"] = new Date(value["end"] * 1000);
|
|
});
|
|
responseData(data, data.start, data.end);
|
|
}
|
|
if (option.onAfterRequestData && $.isFunction(option.onAfterRequestData)) {
|
|
option.onAfterRequestData(1);
|
|
}
|
|
option.isloading = false;
|
|
},
|
|
error:function (data) {
|
|
try {
|
|
if (option.onRequestDataError) {
|
|
option.onRequestDataError(1, data);
|
|
} else {
|
|
alert(i18n.xgcalendar.get_data_exception);
|
|
}
|
|
if (option.onAfterRequestData && $.isFunction(option.onAfterRequestData)) {
|
|
option.onAfterRequestData(1);
|
|
}
|
|
option.isloading = false;
|
|
} catch (e) {
|
|
}
|
|
}
|
|
});
|
|
}
|
|
else {
|
|
alert("url" + i18n.xgcalendar.i_undefined);
|
|
}
|
|
return true;
|
|
}
|
|
|
|
function responseData(data, start, end) {
|
|
var events = data.events;
|
|
ConcatEvents(events, start, end);
|
|
render();
|
|
|
|
}
|
|
|
|
function clearrepeat(events, start) {
|
|
var jl = events.length;
|
|
if (jl > 0) {
|
|
var es = events[0]["start"];
|
|
var el = events[jl - 1]["start"];
|
|
for (var i = 0, l = option.eventItems.length; i < l; i++) {
|
|
|
|
if (option.eventItems[i]["sart"] > el || jl == 0) {
|
|
break;
|
|
}
|
|
if (option.eventItems[i]["start"] >= es) {
|
|
for (var j = 0; j < jl; j++) {
|
|
if (option.eventItems[i]["jq_id"] == events[j]["jq_id"] && option.eventItems[i]["start"] < start) {
|
|
events.splice(j, 1); //for duplicated event
|
|
jl--;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
function ConcatEvents(events, start, end) {
|
|
var e, s;
|
|
if (!events) {
|
|
events = [];
|
|
}
|
|
if (events) {
|
|
if (option.eventItems.length == 0) {
|
|
option.eventItems = events;
|
|
}
|
|
else {
|
|
//remove duplicated one
|
|
clearrepeat(events, start);
|
|
var sl = option.eventItems.length;
|
|
var sI = -1;
|
|
var eI = sl;
|
|
s = start;
|
|
e = end;
|
|
if (option.eventItems[0]["start"] > e) {
|
|
option.eventItems = events.concat(option.eventItems);
|
|
return;
|
|
}
|
|
if (option.eventItems[sl - 1]["start"] < s) {
|
|
option.eventItems = option.eventItems.concat(events);
|
|
return;
|
|
}
|
|
for (var i = 0; i < sl; i++) {
|
|
if (option.eventItems[i]["start"] >= s && sI < 0) {
|
|
sI = i;
|
|
continue;
|
|
}
|
|
if (option.eventItems[i]["start"] > e) {
|
|
eI = i;
|
|
break;
|
|
}
|
|
}
|
|
|
|
var e1 = sI <= 0 ? [] : option.eventItems.slice(0, sI);
|
|
var e2 = eI == sl ? [] : option.eventItems.slice(eI);
|
|
option.eventItems = [].concat(e1, events, e2);
|
|
}
|
|
}
|
|
}
|
|
|
|
//utils goes here
|
|
function weekormonthtoday(e) {
|
|
var th = $(this);
|
|
option.showday = new Date(parseInt(th.data("abbr")));
|
|
option.view = "day";
|
|
render();
|
|
if (option.onWeekOrMonthToDay) {
|
|
option.onWeekOrMonthToDay(option);
|
|
}
|
|
e.stopPropagation();
|
|
e.preventDefault();
|
|
}
|
|
|
|
function parseDate(str) {
|
|
return new Date(Date.parse(str));
|
|
}
|
|
|
|
function gP(h, m) {
|
|
return h * option.hour_height + parseInt(m / 60 * option.hour_height);
|
|
}
|
|
|
|
function gW(ts1, ts2) {
|
|
var t1 = ts1 / option.hour_height;
|
|
var t2 = parseInt(t1);
|
|
var t3 = t1 - t2 >= 0.5 ? 30 : 0;
|
|
var t4 = ts2 / option.hour_height;
|
|
var t5 = parseInt(t4);
|
|
var t6 = t4 - t5 >= 0.5 ? 30 : 0;
|
|
return { sh:t2, sm:t3, eh:t5, em:t6, h:ts2 - ts1 };
|
|
}
|
|
|
|
function gH(y1, y2, pt) {
|
|
var sy1 = Math.min(y1, y2);
|
|
var sy2 = Math.max(y1, y2);
|
|
var t1 = (sy1 - pt) / option.hour_height;
|
|
var t2 = parseInt(t1);
|
|
var t3 = t1 - t2 >= 0.5 ? 30 : 0;
|
|
var t4 = (sy2 - pt) / option.hour_height;
|
|
var t5 = parseInt(t4);
|
|
var t6 = t4 - t5 >= 0.5 ? 30 : 0;
|
|
return { sh:t2, sm:t3, eh:t5, em:t6, h:sy2 - sy1 };
|
|
}
|
|
|
|
function pZero(n) {
|
|
return n < 10 ? "0" + n : "" + n;
|
|
}
|
|
|
|
function Tp(temp, dataarry) {
|
|
return temp.replace(/\{([\w]+)\}/g, function (s1, s2) {
|
|
var s = dataarry[s2];
|
|
if (typeof (s) != "undefined") {
|
|
return s;
|
|
} else {
|
|
return s1;
|
|
}
|
|
});
|
|
}
|
|
|
|
function fomartTimeShow(h) {
|
|
return h < 10 ? "0" + h + ":00" : h + ":00";
|
|
}
|
|
|
|
function getymformat(date, comparedate, isshowtime, isshowweek) {
|
|
var showyear = isshowtime != undefined ? (date.getFullYear() != new Date().getFullYear()) : true;
|
|
var showmonth = true;
|
|
var showday = true;
|
|
var showtime = isshowtime || false;
|
|
var showweek = isshowweek || false;
|
|
if (comparedate) {
|
|
showyear = comparedate.getFullYear() != date.getFullYear();
|
|
//showmonth = comparedate.getFullYear() != date.getFullYear() || date.getMonth() != comparedate.getMonth();
|
|
if (comparedate.getFullYear() == date.getFullYear() &&
|
|
date.getMonth() == comparedate.getMonth() &&
|
|
date.getDate() == comparedate.getDate()
|
|
) {
|
|
showyear = showmonth = showday = showweek = false;
|
|
}
|
|
}
|
|
|
|
var a = [];
|
|
if (showyear) {
|
|
a.push(option.date_format_dm3)
|
|
} else if (showmonth) {
|
|
a.push(option.date_format_dm2)
|
|
} else if (showday) {
|
|
a.push(i18n.xgcalendar.dateformat.day);
|
|
}
|
|
a.push(showweek ? " (W)" : "", showtime ? " HH:mm" : "");
|
|
return a.join("");
|
|
}
|
|
|
|
function CalDateShow(startday, endday, isshowtime, isshowweek) {
|
|
if (!endday) {
|
|
return dateFormat.call(startday, getymformat(startday, null, isshowtime));
|
|
} else {
|
|
var strstart = dateFormat.call(startday, getymformat(startday, null, isshowtime, isshowweek));
|
|
var strend = dateFormat.call(endday, getymformat(endday, startday, isshowtime, isshowweek));
|
|
var join = (strend != "" ? " - " : "");
|
|
return [strstart, strend].join(join);
|
|
}
|
|
}
|
|
|
|
function buildtempdayevent(sh, sm, eh, em, h, title, w, resize, color) {
|
|
if (!color.match(/^#[0-9a-f]{6}$/i)) color = option.std_color;
|
|
var t = ColorCalcValues(color);
|
|
return Tp(__SCOLLEVENTTEMP, {
|
|
bdcolor:t[0],
|
|
bgcolor2:t[1],
|
|
bgcolor1:t[2],
|
|
data:"",
|
|
starttime:[pZero(sh), pZero(sm)].join(":"),
|
|
endtime:[pZero(eh), pZero(em)].join(":"),
|
|
content:title ? title : i18n.xgcalendar.new_event,
|
|
title:title ? title : i18n.xgcalendar.new_event,
|
|
icon:"<I class=\"cic cic-tmr\"> </I>",
|
|
top:"0px",
|
|
left:"",
|
|
width:w ? w : "100%",
|
|
height:h - 4,
|
|
i:"-1",
|
|
drag:"drag-chip",
|
|
redisplay:resize ? "block" : "none"
|
|
});
|
|
}
|
|
|
|
function quickd(type) {
|
|
$("#bbit-cs-buddle").css("visibility", "hidden");
|
|
var calid = $("#bbit-cs-id").val();
|
|
var param = [
|
|
{ "name":"jq_id", value:calid },
|
|
{ "name":"type", value:type}
|
|
];
|
|
var de = rebyKey(calid, true);
|
|
option.onBeforeRequestData && option.onBeforeRequestData(3);
|
|
$.post(option.quickDeleteUrl, param, function (data) {
|
|
if (data) {
|
|
$(document).trigger("wdcal:updated");
|
|
if (data["IsSuccess"]) {
|
|
de = null;
|
|
populate();
|
|
option.onAfterRequestData && option.onAfterRequestData(3);
|
|
}
|
|
else {
|
|
option.onRequestDataError && option.onRequestDataError(3, data);
|
|
Ind(de);
|
|
render();
|
|
option.onAfterRequestData && option.onAfterRequestData(3);
|
|
}
|
|
}
|
|
}, "json");
|
|
}
|
|
|
|
function getbuddlepos(x, y) {
|
|
var tleft = x - 110;
|
|
var ttop = y - 217;
|
|
var maxLeft = document.documentElement.clientWidth;
|
|
var maxTop = document.documentElement.clientHeight;
|
|
var ishide = false;
|
|
if (tleft <= 0 || ttop <= 0 || tleft + 400 > maxLeft) {
|
|
tleft = x - 200 <= 0 ? 10 : x - 200;
|
|
ttop = y - 159 <= 0 ? 10 : y - 159;
|
|
if (tleft + 400 >= maxLeft) {
|
|
tleft = maxLeft - 410;
|
|
}
|
|
if (ttop + 164 >= maxTop) {
|
|
ttop = maxTop - 165;
|
|
}
|
|
ishide = true;
|
|
}
|
|
return { left:tleft, top:ttop, hide:ishide };
|
|
}
|
|
|
|
function dayshow(e, data) {
|
|
var $t = $(e.target);
|
|
if ($t.hasClass("axx_username") || $t.parents(".axx_username").length > 0 || $t.hasClass("cal_nojs") || $t.parents(".cal_nojs").length > 0) return false;
|
|
|
|
if (data == undefined) {
|
|
if ($t.hasClass("chip") || $t.hasClass("rb-o")) data = $t.data("eventdata");
|
|
else data = $t.parents(".chip, .rb-o").data("eventdata");
|
|
}
|
|
|
|
if (data != null) {
|
|
var editable = false;
|
|
if (option.quickDeleteUrl != "" && data["is_editable"] == 1 && option.readonly != true) editable = true;
|
|
var csbuddle = '<div id="bbit-cs-buddle" style="z-index: 180; width: 400px;visibility:hidden;" class="bubble"><table class="bubble-table"><tbody' +
|
|
'><tr><td class="bubble-cell-side"><div id="tl1" class="bubble-corner"><div class="bubble-sprite bubble-tl"></div></div>' +
|
|
'<td class="bubble-cell-main"><div class="bubble-top"></div><td class="bubble-cell-side"><div id="tr1" class="bubble-corner"><div class="bubble-sprite bubble-tr"></div></div>' +
|
|
'<tr><td class="bubble-mid" colSpan="3"><div style="overflow: hidden" id="bubbleContent1"><div><div></div><div class="cb-root">' +
|
|
'<table class="cb-table"><tbody><tr><td class="cb-value"><div class="textbox-fill-wrapper"><div class="textbox-fill-mid">' +
|
|
'<a href="" title="' + i18n.xgcalendar.click_to_detail + '" class="bbit-cs-what textbox-fill-div lk"></a></div></div></td></tr>' +
|
|
'<tr><td class=cb-value><div id="bbit-cs-buddle-timeshow"></div></td></tr>' +
|
|
'</tbody></table><div class="bbit-cs-split"><input id="bbit-cs-id" type="hidden" value=""/>[ <span id="bbit-cs-delete" class="lk">'
|
|
+ i18n.xgcalendar.i_delete + '</span> ] ' +
|
|
'<a href="" class="bbit-cs-editLink lk">' + i18n.xgcalendar.update_detail + ' <strong>>></strong></a>' +
|
|
'</div></div></div></div><tr><td><div id="bl1" class="bubble-corner"><div class="bubble-sprite bubble-bl"></div></div>' +
|
|
'<td><div class="bubble-bottom"></div><td><div id="br1" class="bubble-corner"><div class="bubble-sprite bubble-br"></div></div></tr></tbody>' +
|
|
'</table><div id="bubbleClose2" class="bubble-closebutton"></div><div id="prong1" class="prong"><div class=bubble-sprite></div></div></div>';
|
|
var $bud = $("#bbit-cs-buddle");
|
|
if ($bud.length == 0) {
|
|
$bud = $(csbuddle).appendTo(document.body);
|
|
var calbutton = $("#bbit-cs-delete");
|
|
$("#bubbleClose2").on("click", function () {
|
|
$("#bbit-cs-buddle").css("visibility", "hidden");
|
|
});
|
|
calbutton.on("click", function () {
|
|
var data = $("#bbit-cs-buddle").data("cdata");
|
|
if (option.quickDeleteHandler && $.isFunction(option.quickDeleteHandler)) {
|
|
option.quickDeleteHandler.call(this, data, quickd);
|
|
}
|
|
else {
|
|
if (confirm(i18n.xgcalendar.confirm_delete_event)) {
|
|
var s = 0; //0 single event , 1 for Recurring event
|
|
if (data["is_recurring"] == 1) {
|
|
if (confirm(i18n.xgcalendar.confrim_delete_event_or_all)) {
|
|
s = 0;
|
|
}
|
|
else {
|
|
s = 1;
|
|
}
|
|
}
|
|
else {
|
|
s = 0;
|
|
}
|
|
quickd(s);
|
|
}
|
|
}
|
|
});
|
|
}
|
|
|
|
if (editable) {
|
|
$("#bbit-cs-delete").parents(".bbit-cs-split").show();
|
|
$bud.find(".bbit-cs-editLink").attr("href", data["url_edit"]).show();
|
|
}
|
|
else {
|
|
$("#bbit-cs-delete").parents(".bbit-cs-split").hide();
|
|
$bud.find(".bbit-cs-editLink").hide();
|
|
}
|
|
|
|
var pos = getbuddlepos(e.pageX, e.pageY);
|
|
if (pos.hide) {
|
|
$("#prong1").hide()
|
|
}
|
|
else {
|
|
$("#prong1").show()
|
|
}
|
|
var ss = [];
|
|
var iscos = DateDiff("d", data["start"], data["end"]) != 0;
|
|
ss.push(dateFormat.call(data["start"], option.date_format_dm2), " (", __WDAY[data["start"].getDay()], ")");
|
|
if (data["is_allday"] != 1) {
|
|
ss.push(",", dateFormat.call(data["start"], "HH:mm"));
|
|
}
|
|
|
|
if (iscos) {
|
|
ss.push(" - ", dateFormat.call(data["end"], option.date_format_dm2), " (", __WDAY[data["end"].getDay()], ")");
|
|
if (data["is_allday"] != 1) {
|
|
ss.push(",", dateFormat.call(data["end"], "HH:mm"));
|
|
}
|
|
}
|
|
var location = "";
|
|
if (data["location"] != "") location = data["location"] + ", ";
|
|
$("#bbit-cs-buddle-timeshow").html(location + ss.join(""));
|
|
$bud.find(".bbit-cs-what").html(data["summary"]).attr("href", data["url_detail"]);
|
|
$("#bbit-cs-id").val(data["jq_id"]);
|
|
$bud.data("cdata", data);
|
|
$bud.css({ "visibility":"visible", left:pos.left, top:pos.top });
|
|
|
|
$(document).one("click", function () {
|
|
$("#bbit-cs-buddle").css("visibility", "hidden");
|
|
});
|
|
}
|
|
else {
|
|
alert(i18n.xgcalendar.data_format_error);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
function moreshow(mv) {
|
|
var $me = $(this);
|
|
var $pdiv = $(mv);
|
|
var divIndex = parseInt($pdiv.data("row"));
|
|
var offsetMe = $me.position();
|
|
var offsetP = $pdiv.position();
|
|
var width = ($me.width() + 2) * 1.5;
|
|
var top = offsetP.top + 15;
|
|
var left = offsetMe.left;
|
|
|
|
var day = new Date(parseInt($me.data("abbr")));
|
|
var cc = $gridcontainer.find(".cal-month-cc");
|
|
var ccontent = $gridcontainer.find(".cal-month-cc-content table tbody");
|
|
var ctitle = $gridcontainer.find(".cal-month-cc-title");
|
|
ctitle.html(formatDate(day));
|
|
ccontent.empty();
|
|
var edata = $("#gridEvent").data("mvdata");
|
|
var events = edata[divIndex];
|
|
var index = parseInt($me.data("axis"));
|
|
ccontent.find("*").remove();
|
|
for (var i = 0; i <= index; i++) {
|
|
var ec = events[i] ? events[i].length : 0;
|
|
for (var j = 0; j < ec; j++) {
|
|
var e = events[i][j];
|
|
if (e) {
|
|
if ((e.colSpan + i - 1) >= index) {
|
|
var $x = $("<tr><td class='st-c'></td></tr>");
|
|
var $y = BuildMonthDayEvent(e, day, 1);
|
|
$x.find(".st-c").append($y);
|
|
ccontent.append($x);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
//click
|
|
ccontent.find("div.rb-o").each(function () {
|
|
$(this).click(dayshow);
|
|
});
|
|
|
|
var height = cc.height();
|
|
var maxleft = document.documentElement.clientWidth;
|
|
var maxtop = document.documentElement.clientHeight;
|
|
if (left + width >= maxleft) {
|
|
left = offsetMe.left - ($me.width() + 2) * 0.5;
|
|
}
|
|
if (top + height >= maxtop) {
|
|
top = maxtop - height - 2;
|
|
}
|
|
var newOff = { left:left, top:top, "z-index":180, width:width, "visibility":"visible" };
|
|
cc.css(newOff);
|
|
$(document).on("click", closeCc);
|
|
return false;
|
|
}
|
|
|
|
function dayupdate(data, start, end) {
|
|
if (option.quickUpdateUrl != "" && data["is_editable_quick"] == 1 && option.readonly != true) {
|
|
if (option.isloading) {
|
|
return false;
|
|
}
|
|
option.isloading = true;
|
|
var id = data["jq_id"];
|
|
var os = data["start"];
|
|
var od = data["end"];
|
|
var param = [
|
|
{ "name":"jq_id", value:id },
|
|
{ "name":"CalendarStartTime", value:Math.floor(start.getTime() / 1000) },
|
|
{ "name":"CalendarEndTime", value:Math.floor(end.getTime() / 1000) }
|
|
];
|
|
var d;
|
|
if (option.quickUpdateHandler && $.isFunction(option.quickUpdateHandler)) {
|
|
option.quickUpdateHandler.call(this, param);
|
|
}
|
|
else {
|
|
option.onBeforeRequestData && option.onBeforeRequestData(4);
|
|
$.post(option.quickUpdateUrl, param, function (data) {
|
|
if (data) {
|
|
$(document).trigger("wdcal:updated");
|
|
if (data["IsSuccess"] == true) {
|
|
option.isloading = false;
|
|
option.onAfterRequestData && option.onAfterRequestData(4);
|
|
}
|
|
else {
|
|
option.onRequestDataError && option.onRequestDataError(4, data);
|
|
option.isloading = false;
|
|
d = rebyKey(id, true);
|
|
d["start"] = os;
|
|
d["end"] = od;
|
|
Ind(d);
|
|
render();
|
|
d = null;
|
|
option.onAfterRequestData && option.onAfterRequestData(4);
|
|
}
|
|
}
|
|
}, "json");
|
|
d = rebyKey(id, true);
|
|
if (d) {
|
|
d["start"] = start;
|
|
d["end"] = end;
|
|
}
|
|
Ind(d);
|
|
render();
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
function quickadd(start, end, isallday, pos) {
|
|
if ((!option.quickAddHandler && option.quickAddUrl == "") || option.readonly) {
|
|
return false;
|
|
}
|
|
var buddle = $("#bbit-cal-buddle");
|
|
if (buddle.length == 0) {
|
|
var temparr = [];
|
|
temparr.push('<form id="bbit-cal-submitFORM">');
|
|
temparr.push('<div id="bbit-cal-buddle" style="z-index: 180; width: 400px;visibility:hidden;" class="bubble">');
|
|
temparr.push('<table class="bubble-table"><tbody><tr><td class="bubble-cell-side"><div id="tl1" class="bubble-corner"><div class="bubble-sprite bubble-tl"></div></div>');
|
|
temparr.push('<td class="bubble-cell-main"><div class="bubble-top"></div><td class="bubble-cell-side"><div id="tr1" class="bubble-corner"><div class="bubble-sprite bubble-tr"></div></div> <tr><td class="bubble-mid" colSpan="3"><div style="overflow: hidden" id="bubbleContent1"><div><div></div><div class="cb-root">');
|
|
temparr.push('<table class="cb-table"><tbody><tr><th class="cb-key">');
|
|
temparr.push(i18n.xgcalendar.time, ':</th><td class=cb-value><div id="bbit-cal-buddle-timeshow"></div></td></tr><tr><th class="cb-key">');
|
|
temparr.push(i18n.xgcalendar.content, ':</th><td class="cb-value"><div class="textbox-fill-wrapper"><div class="textbox-fill-mid"><input id="bbit-cal-what" class="textbox-fill-input"/></div></div><div class="cb-example">');
|
|
temparr.push(i18n.xgcalendar.example, '</div></td></tr></tbody></table><input id="bbit-cal-start" type="hidden"/><input id="bbit-cal-end" type="hidden"/><input id="bbit-cal-allday" type="hidden"/><input value="');
|
|
temparr.push(i18n.xgcalendar.create_event, '" type="submit"/> <a href="" class="lk bbit-cal-editLink">');
|
|
temparr.push(i18n.xgcalendar.update_detail, ' <StrONG>>></StrONG></SPAN></div></div></div><tr><td><div id="bl1" class="bubble-corner"><div class="bubble-sprite bubble-bl"></div></div><td><div class="bubble-bottom"></div><td><div id="br1" class="bubble-corner"><div class="bubble-sprite bubble-br"></div></div></tr></tbody></table><div id="bubbleClose1" class="bubble-closebutton"></div><div id="prong2" class="prong"><div class=bubble-sprite></div></div></div>');
|
|
temparr.push('</form>');
|
|
var tempquickAddHandler = temparr.join("");
|
|
temparr = null;
|
|
$(document.body).append(tempquickAddHandler);
|
|
buddle = $("#bbit-cal-buddle");
|
|
$("#bubbleClose1").on("click", function () {
|
|
$("#bbit-cal-buddle").css("visibility", "hidden");
|
|
releasedragevent();
|
|
});
|
|
$("#bbit-cal-submitFORM").on("keyup", function (e) {
|
|
if (e.which == 27) $("#bubbleClose1").click();
|
|
});
|
|
$("#bbit-cal-submitFORM").on("submit", function (e) {
|
|
e.stopPropagation();
|
|
e.preventDefault();
|
|
if (option.isloading) {
|
|
return false;
|
|
}
|
|
option.isloading = true;
|
|
var what = $("#bbit-cal-what").val();
|
|
var datestart = $("#bbit-cal-start").val();
|
|
var dateend = $("#bbit-cal-end").val();
|
|
var allday = $("#bbit-cal-allday").val();
|
|
var f = /^[^\$<>]+$/.test(what);
|
|
if (!f) {
|
|
alert(i18n.xgcalendar.invalid_title);
|
|
$("#bbit-cal-what").focus();
|
|
option.isloading = false;
|
|
return false;
|
|
}
|
|
var param = [
|
|
{ "name":"CalendarTitle", value:what },
|
|
{ "name":"CalendarStartTime", value: Math.floor(datestart / 1000)},
|
|
{ "name":"CalendarEndTime", value: Math.floor(dateend / 1000)},
|
|
{ "name":"IsAllDayEvent", value:allday }
|
|
];
|
|
|
|
if (option.extParam) {
|
|
for (var pi = 0; pi < option.extParam.length; pi++) {
|
|
param[param.length] = option.extParam[pi];
|
|
}
|
|
}
|
|
if (option.quickAddHandler && $.isFunction(option.quickAddHandler)) {
|
|
option.quickAddHandler.call(this, param);
|
|
$("#bbit-cal-buddle").css("visibility", "hidden");
|
|
releasedragevent();
|
|
}
|
|
else {
|
|
$("#bbit-cal-buddle").css("visibility", "hidden");
|
|
var tId = -1;
|
|
option.onBeforeRequestData && option.onBeforeRequestData(2);
|
|
|
|
var sd = new Date(datestart),
|
|
ed = new Date(dateend),
|
|
diff = DateDiff("d", sd, ed);
|
|
var newdata = {
|
|
"jq_id":"",
|
|
"ev_id":"",
|
|
"summary":what,
|
|
"start":sd,
|
|
"end":ed,
|
|
"is_allday":(allday == "1" ? 1 : 0),
|
|
"is_moredays":(diff > 0 ? 1 : 0),
|
|
"is_recurring":0,
|
|
"color":option.std_color,
|
|
"is_editable":0,
|
|
"is_editable_quick":0,
|
|
"location":"",
|
|
"attendees":""
|
|
};
|
|
tId = Ind(newdata);
|
|
releasedragevent();
|
|
render();
|
|
|
|
$.post(option.quickAddUrl, param, function (data) {
|
|
option.isloading = false;
|
|
if (data) {
|
|
if (data["IsSuccess"] == true) {
|
|
populate();
|
|
option.onAfterRequestData && option.onAfterRequestData(2);
|
|
}
|
|
else {
|
|
option.onRequestDataError && option.onRequestDataError(2, data);
|
|
option.onAfterRequestData && option.onAfterRequestData(2);
|
|
}
|
|
$(document).trigger("wdcal:updated");
|
|
}
|
|
|
|
}, "json");
|
|
}
|
|
return false;
|
|
});
|
|
buddle.on("mousedown", function (e) {
|
|
e.stopPropagation();
|
|
e.preventDefault();
|
|
});
|
|
}
|
|
|
|
var dateshow = CalDateShow(start, end, !isallday, true);
|
|
var off = getbuddlepos(pos.left, pos.top);
|
|
if (off.hide) {
|
|
$("#prong2").hide()
|
|
}
|
|
else {
|
|
$("#prong2").show()
|
|
}
|
|
$("#bbit-cal-buddle-timeshow").html(dateshow);
|
|
var calwhat = $("#bbit-cal-what").val("");
|
|
$("#bbit-cal-allday").val(isallday ? "1" : "0");
|
|
$("#bbit-cal-start").val(start.getTime());
|
|
$("#bbit-cal-end").val(end.getTime());
|
|
|
|
var addurl = option.baseurl + "new/?start=" + Math.floor($("#bbit-cal-start").val() / 1000) + "&end=" + Math.floor($("#bbit-cal-end").val() / 1000) +
|
|
"&isallday=" + (isallday ? "1" : "0") + "&title=";
|
|
buddle.find(".bbit-cal-editLink").attr("href", addurl);
|
|
|
|
buddle.css({ "visibility":"visible", left:off.left, top:off.top });
|
|
calwhat.blur().focus(); //add 2010-01-26 blur() fixed chrome
|
|
$(document).on("mousedown", function () {
|
|
$("#bbit-cal-buddle").css("visibility", "hidden");
|
|
releasedragevent();
|
|
});
|
|
$(document).on("keyup", "#bbit-cal-what", function() {
|
|
buddle.find(".bbit-cal-editLink").attr("href", addurl + encodeURIComponent($("#bbit-cal-what").val()));
|
|
});
|
|
return false;
|
|
}
|
|
|
|
function formatDate(time, format) {
|
|
if (typeof(format) == "undefined") return $.datepicker.formatDate(option.date_format_full,time);
|
|
var time2 = $.datepicker.formatDate(format, time);
|
|
var h = time.getHours();
|
|
var i = time.getMinutes();
|
|
time2 = time2.replace("HH", (h > 10 ? "" : "0") + h);
|
|
time2 = time2.replace("ii", (i > 10 ? "" : "0") + i);
|
|
return time2;
|
|
}
|
|
|
|
function rebyKey(key, remove) {
|
|
if (option.eventItems && option.eventItems.length > 0) {
|
|
var sl = option.eventItems.length;
|
|
var i = -1;
|
|
for (var j = 0; j < sl; j++) {
|
|
if (option.eventItems[j]["jq_id"] == key) {
|
|
i = j;
|
|
break;
|
|
}
|
|
}
|
|
if (i >= 0) {
|
|
var t = option.eventItems[i];
|
|
if (remove) {
|
|
option.eventItems.splice(i, 1);
|
|
}
|
|
return t;
|
|
}
|
|
}
|
|
return null;
|
|
}
|
|
|
|
function Ind(event, i) {
|
|
var d = 0;
|
|
var j;
|
|
if (!i) {
|
|
if (option.eventItems && option.eventItems.length > 0) {
|
|
var sl = option.eventItems.length;
|
|
var s = event["start"];
|
|
var d1 = s.getTime() - option.eventItems[0]["start"].getTime();
|
|
var d2 = option.eventItems[sl - 1]["start"].getTime() - s.getTime();
|
|
var diff = d1 - d2;
|
|
if (d1 < 0 || diff < 0) {
|
|
for (j = 0; j < sl; j++) {
|
|
if (option.eventItems[j]["start"] >= s) {
|
|
i = j;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
else if (d2 < 0) {
|
|
i = sl;
|
|
}
|
|
else {
|
|
for (j = sl - 1; j >= 0; j--) {
|
|
if (option.eventItems[j]["start"] < s) {
|
|
i = j + 1;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else {
|
|
i = 0;
|
|
}
|
|
}
|
|
else {
|
|
d = 1;
|
|
}
|
|
if (option.eventItems && option.eventItems.length > 0) {
|
|
if (i == option.eventItems.length) {
|
|
option.eventItems.push(event);
|
|
}
|
|
else {
|
|
option.eventItems.splice(i, d, event);
|
|
}
|
|
}
|
|
else {
|
|
option.eventItems = [event];
|
|
}
|
|
return i;
|
|
}
|
|
|
|
|
|
function ResizeView() {
|
|
var _viewType = option.view;
|
|
if (_viewType == "day" || _viewType == "week" || _viewType == "multi_days") {
|
|
var $dvwkcontaienr = $gridcontainer.find(".wktopcontainer");
|
|
var $dvtec = $gridcontainer.find(".scrolltimeevent");
|
|
if ($dvwkcontaienr.length == 0 || $dvtec.length == 0) {
|
|
alert(i18n.xgcalendar.view_no_ready);
|
|
return;
|
|
}
|
|
var dvwkH = $dvwkcontaienr.height() + 2;
|
|
var calH = option.height - 8 - dvwkH;
|
|
$dvtec.height(calH);
|
|
if (typeof (option.scroll) == "undefined") {
|
|
var currentday = new Date();
|
|
var h = currentday.getHours();
|
|
var m = currentday.getMinutes();
|
|
var th = gP(h, m);
|
|
//var ch = $dvtec.attr("clientHeight");
|
|
var ch = $dvtec.height();
|
|
var sh = th - 0.5 * ch;
|
|
//var ph = $dvtec.attr("scrollHeight");
|
|
var ph = $dvtec.children().height();
|
|
if (sh < 0) sh = 0;
|
|
if (sh > ph - ch) sh = ph - ch - 10 * (23 - h);
|
|
//$dvtec.attr("scrollTop", sh);
|
|
$dvtec.scrollTop(sh);
|
|
}
|
|
else {
|
|
$dvtec.scrollTop(option.scroll);
|
|
}
|
|
}
|
|
else if (_viewType == "month") {
|
|
//Resize GridContainer
|
|
}
|
|
}
|
|
|
|
function returnfalse() {
|
|
return false;
|
|
}
|
|
|
|
function initevents(viewtype) {
|
|
if (viewtype == "week" || viewtype == "day" || viewtype == "multi_days") {
|
|
$("div.chip", $gridcontainer).each(function () {
|
|
var chip = $(this);
|
|
chip.click(dayshow);
|
|
if (chip.hasClass("drag")) {
|
|
chip.mousedown(function (e) {
|
|
dragStart.call(this, "std_item_move", e);
|
|
e.stopPropagation();
|
|
e.preventDefault();
|
|
});
|
|
//resize
|
|
chip.find("div.resizer").mousedown(function (e) {
|
|
dragStart.call($(this).parent().parent(), "std_item_resize", e);
|
|
e.stopPropagation();
|
|
e.preventDefault();
|
|
});
|
|
}
|
|
else {
|
|
chip.mousedown(returnfalse)
|
|
}
|
|
});
|
|
$("div.rb-o", $gridcontainer).each(function () {
|
|
var chip = $(this);
|
|
chip.click(dayshow);
|
|
if (chip.hasClass("drag") && (viewtype == "week" || viewtype == "multi_days")) {
|
|
//drag;
|
|
chip.mousedown(function (e) {
|
|
dragStart.call(this, "fullday_item_move", e);
|
|
e.stopPropagation();
|
|
e.preventDefault();
|
|
});
|
|
}
|
|
else {
|
|
chip.mousedown(returnfalse)
|
|
}
|
|
});
|
|
if (option.readonly == false) {
|
|
$("td.tg-col", $gridcontainer).each(function () {
|
|
$(this).mousedown(function (e) {
|
|
dragStart.call(this, "std_empty_drag", e);
|
|
e.stopPropagation();
|
|
e.preventDefault();
|
|
});
|
|
});
|
|
$gridcontainer.find(".weekViewAllDaywk").mousedown(function (e) {
|
|
dragStart.call(this, "fullday_empty_drag", e);
|
|
e.stopPropagation();
|
|
e.preventDefault();
|
|
});
|
|
}
|
|
|
|
if (viewtype == "week" || viewtype == "multi_days") {
|
|
$gridcontainer.find(".wktopcontainer th.gcweekname").each(function () {
|
|
$(this).click(weekormonthtoday);
|
|
});
|
|
}
|
|
|
|
|
|
}
|
|
else if (viewtype = "month") {
|
|
$("div.rb-o", $gridcontainer).each(function () {
|
|
var chip = $(this);
|
|
chip.click(dayshow);
|
|
if (chip.hasClass("drag")) {
|
|
//drag;
|
|
chip.mousedown(function (e) {
|
|
dragStart.call(this, "std_item_month_drag", e);
|
|
e.stopPropagation();
|
|
e.preventDefault();
|
|
});
|
|
}
|
|
else {
|
|
chip.mousedown(returnfalse)
|
|
}
|
|
});
|
|
$("td.st-more", $gridcontainer).each(function () {
|
|
|
|
$(this).on("click", function (e) {
|
|
moreshow.call(this, $(this).parent().parent().parent().parent()[0]);
|
|
e.stopPropagation();
|
|
e.preventDefault();
|
|
}).on("mousedown", function (e) {
|
|
e.stopPropagation();
|
|
e.preventDefault();
|
|
});
|
|
});
|
|
if (option.readonly == false) {
|
|
$gridcontainer.find(".mvEventContainer").mousedown(function (e) {
|
|
dragStart.call(this, "empty_month_drag", e);
|
|
e.stopPropagation();
|
|
e.preventDefault();
|
|
});
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
function releasedragevent() {
|
|
if (_dragevent) {
|
|
_dragevent();
|
|
_dragevent = null;
|
|
}
|
|
}
|
|
|
|
function dragStart(type, e) {
|
|
var w, h, offset, moffset, left, top, l, py, pw, xa, ya, i, data, fdi, dp, yl;
|
|
var $obj = $(this);
|
|
releasedragevent();
|
|
switch (type) {
|
|
case "std_empty_drag":
|
|
_dragdata = { type:"std_empty_drag", target:$obj, sx:e.pageX, sy:e.pageY };
|
|
break;
|
|
case "fullday_empty_drag":
|
|
w = $obj.width();
|
|
h = $obj.height();
|
|
offset = $obj.offset();
|
|
left = offset.left;
|
|
top = offset.top;
|
|
l = option.view == "day" ? 1 : 7;
|
|
py = w % l;
|
|
pw = parseInt(w / l);
|
|
if (py > l / 2 + 1) {
|
|
pw++;
|
|
}
|
|
xa = [];
|
|
ya = [];
|
|
for (i = 0; i < l; i++) {
|
|
xa.push({ s:i * pw + left, e:(i + 1) * pw + left });
|
|
}
|
|
ya.push({ s:top, e:top + h });
|
|
_dragdata = { type:"fullday_empty_drag", target:$obj, sx:e.pageX, sy:e.pageY, pw:pw, xa:xa, ya:ya, h:h };
|
|
w = left = l = py = pw = xa = null;
|
|
break;
|
|
case "std_item_move":
|
|
var evid = $obj.parent().data("col");
|
|
var p = $obj.parent();
|
|
var pos = p.offset();
|
|
w = p.width() + 10;
|
|
h = $obj.height();
|
|
data = $obj.data("eventdata");
|
|
_dragdata = { type:"std_item_move", target:$obj, sx:e.pageX, sy:e.pageY,
|
|
pXMin:pos.left, pXMax:pos.left + w, pw:w, h:h,
|
|
cdi:parseInt(evid), fdi:parseInt(evid), data:data
|
|
};
|
|
break;
|
|
case "std_item_resize":
|
|
h = $obj.height();
|
|
data = $obj.data("eventdata");
|
|
_dragdata = { type:"std_item_resize", target:$obj, sx:e.pageX, sy:e.pageY, h:h, data:data };
|
|
break;
|
|
case "fullday_item_move":
|
|
var con = $gridcontainer.find(".weekViewAllDaywk");
|
|
w = con.width();
|
|
h = con.height();
|
|
offset = con.offset();
|
|
moffset = $obj.offset();
|
|
left = offset.left;
|
|
top = offset.top;
|
|
l = 7;
|
|
py = w % l;
|
|
pw = parseInt(w / l);
|
|
if (py > l / 2 + 1) {
|
|
pw++;
|
|
}
|
|
xa = [];
|
|
ya = [];
|
|
var di = 0;
|
|
for (i = 0; i < l; i++) {
|
|
xa.push({ s:i * pw + left, e:(i + 1) * pw + left });
|
|
if (moffset.left >= xa[i].s && moffset.left < xa[i].e) {
|
|
di = i;
|
|
}
|
|
}
|
|
fdi = { x:di, y:0, di:di };
|
|
ya.push({ s:top, e:top + h });
|
|
data = $obj.data("eventdata");
|
|
dp = DateDiff("d", data["start"], data["end"]) + 1;
|
|
_dragdata = { type:"fullday_item_move", target:$obj, sx:e.pageX, sy:e.pageY, data:data, xa:xa, ya:ya, fdi:fdi, h:h, dp:dp, pw:pw };
|
|
break;
|
|
case "empty_month_drag":
|
|
w = $obj.width();
|
|
offset = $obj.offset();
|
|
left = offset.left;
|
|
top = offset.top;
|
|
l = 7;
|
|
yl = $obj.children().length;
|
|
py = w % l;
|
|
pw = parseInt(w / l);
|
|
if (py > l / 2 + 1) {
|
|
pw++;
|
|
}
|
|
h = $gridcontainer.find(".mvrow_0").height();
|
|
xa = [];
|
|
ya = [];
|
|
for (i = 0; i < l; i++) {
|
|
xa.push({ s:i * pw + left, e:(i + 1) * pw + left });
|
|
}
|
|
xa = [];
|
|
ya = [];
|
|
for (i = 0; i < l; i++) {
|
|
xa.push({ s:i * pw + left, e:(i + 1) * pw + left });
|
|
}
|
|
for (i = 0; i < yl; i++) {
|
|
ya.push({ s:i * h + top, e:(i + 1) * h + top });
|
|
}
|
|
_dragdata = { type:"empty_month_drag", target:$obj, sx:e.pageX, sy:e.pageY, pw:pw, xa:xa, ya:ya, h:h };
|
|
break;
|
|
case "std_item_month_drag":
|
|
var row0 = $gridcontainer.find(".mvrow_0");
|
|
var row1 = $gridcontainer.find(".mvrow_1");
|
|
w = row0.width();
|
|
offset = row0.offset();
|
|
var diffset = row1.offset();
|
|
moffset = $obj.offset();
|
|
h = diffset.top - offset.top;
|
|
left = offset.left;
|
|
top = offset.top;
|
|
l = 7;
|
|
yl = row0.parent().children().length;
|
|
py = w % l;
|
|
pw = parseInt(w / l);
|
|
if (py > l / 2 + 1) {
|
|
pw++;
|
|
}
|
|
xa = [];
|
|
ya = [];
|
|
var xi = 0;
|
|
var yi = 0;
|
|
for (i = 0; i < l; i++) {
|
|
xa.push({ s:i * pw + left, e:(i + 1) * pw + left });
|
|
if (moffset.left >= xa[i].s && moffset.left < xa[i].e) {
|
|
xi = i;
|
|
}
|
|
}
|
|
for (i = 0; i < yl; i++) {
|
|
ya.push({ s:i * h + top, e:(i + 1) * h + top });
|
|
if (moffset.top >= ya[i].s && moffset.top < ya[i].e) {
|
|
yi = i;
|
|
}
|
|
}
|
|
fdi = { x:xi, y:yi, di:yi * 7 + xi };
|
|
data = $obj.data("eventdata");
|
|
dp = DateDiff("d", data["start"], data["end"]) + 1;
|
|
_dragdata = { type:"std_item_month_drag", target:$obj, sx:e.pageX, sy:e.pageY, data:data, xa:xa, ya:ya, fdi:fdi, h:h, dp:dp, pw:pw };
|
|
break;
|
|
}
|
|
$('body').noSelect();
|
|
}
|
|
|
|
function dragMove(e) {
|
|
var d, sy, sx, x, y, diffy, gh, ny, tempdata, cpwrap, ndi, evid, nh, cp, w1;
|
|
if (_dragdata) {
|
|
if (e.pageX < 0 || e.pageY < 0
|
|
|| e.pageX > document.documentElement.clientWidth
|
|
|| e.pageY >= document.documentElement.clientHeight) {
|
|
dragEnd(e);
|
|
return false;
|
|
}
|
|
d = _dragdata;
|
|
switch (d.type) {
|
|
case "std_empty_drag":
|
|
sy = d.sy;
|
|
y = e.pageY;
|
|
diffy = y - sy;
|
|
if (diffy > (option.hour_height / 4) || diffy < (-1 * (option.hour_height / 4)) || d.cpwrap) {
|
|
if (diffy == 0) {
|
|
diffy = Math.ceil(option.hour_height / 2);
|
|
}
|
|
var dy = diffy % Math.ceil(option.hour_height / 2);
|
|
if (dy != 0) {
|
|
diffy = dy > 0 ? diffy + Math.ceil(option.hour_height / 2) - dy : diffy - Math.ceil(option.hour_height / 2) - dy;
|
|
y = d.sy + diffy;
|
|
if (diffy < 0) {
|
|
sy = sy + Math.ceil(option.hour_height / 2);
|
|
}
|
|
}
|
|
if (!d.tp) {
|
|
d.tp = $(d.target).offset().top;
|
|
}
|
|
gh = gH(sy, y, d.tp);
|
|
ny = gP(gh.sh, gh.sm);
|
|
if (!d.cpwrap) {
|
|
tempdata = buildtempdayevent(gh.sh, gh.sm, gh.eh, gh.em, gh.h, "", "", "", option.std_color);
|
|
cpwrap = $("<div class='ca-evpi drag-chip-wrapper' style='top:" + ny + "px'/>").html(tempdata);
|
|
$(d.target).find("div.tg-col-overlaywrapper").append(cpwrap);
|
|
d.cpwrap = cpwrap;
|
|
}
|
|
else {
|
|
if (d.cgh.sh != gh.sh || d.cgh.eh != gh.eh || d.cgh.sm != gh.sm || d.cgh.em != gh.em) {
|
|
tempdata = buildtempdayevent(gh.sh, gh.sm, gh.eh, gh.em, gh.h, "", "", "", option.std_color);
|
|
d.cpwrap.css("top", ny + "px").html(tempdata);
|
|
}
|
|
}
|
|
d.cgh = gh;
|
|
}
|
|
break;
|
|
case "fullday_empty_drag":
|
|
sx = d.sx;
|
|
x = e.pageX;
|
|
diffx = x - sx;
|
|
if (diffx > 5 || diffx < -5 || d.lasso) {
|
|
if (!d.lasso) {
|
|
d.lasso = $("<div style='z-index: 10; display: block' class='drag-lasso-container'/>");
|
|
$(document.body).append(d.lasso);
|
|
}
|
|
if (!d.sdi) {
|
|
d.sdi = getdi(d.xa, d.ya, sx, d.sy);
|
|
}
|
|
ndi = getdi(d.xa, d.ya, x, e.pageY);
|
|
if (!d.fdi || d.fdi.di != ndi.di) {
|
|
addlasso(d.lasso, d.sdi, ndi, d.xa, d.ya, d.h);
|
|
}
|
|
d.fdi = ndi;
|
|
}
|
|
break;
|
|
case "empty_month_drag":
|
|
sx = d.sx;
|
|
x = e.pageX;
|
|
sy = d.sy;
|
|
y = e.pageY;
|
|
diffx = x - sx;
|
|
diffy = y - sy;
|
|
if (diffx > 5 || diffx < -5 || diffy < -5 || diffy > 5 || d.lasso) {
|
|
if (!d.lasso) {
|
|
d.lasso = $("<div style='z-index: 10; display: block' class='drag-lasso-container'/>");
|
|
$(document.body).append(d.lasso);
|
|
}
|
|
if (!d.sdi) {
|
|
d.sdi = getdi(d.xa, d.ya, sx, sy);
|
|
}
|
|
ndi = getdi(d.xa, d.ya, x, y);
|
|
if (!d.fdi || d.fdi.di != ndi.di) {
|
|
addlasso(d.lasso, d.sdi, ndi, d.xa, d.ya, d.h);
|
|
}
|
|
d.fdi = ndi;
|
|
}
|
|
break;
|
|
case "std_item_move":
|
|
data = d.data;
|
|
if (data != null && data["is_editable_quick"] == 1) {
|
|
sx = d.sx;
|
|
x = e.pageX;
|
|
sy = d.sy;
|
|
y = e.pageY;
|
|
diffx = x - sx;
|
|
diffy = y - sy;
|
|
if (diffx > 5 || diffx < -5 || diffy > 5 || diffy < -5 || d.cpwrap) {
|
|
if (!d.cpwrap) {
|
|
gh = { sh:data["start"].getHours(),
|
|
sm:data["start"].getMinutes(),
|
|
eh:data["end"].getHours(),
|
|
em:data["end"].getMinutes(),
|
|
h:d.h
|
|
};
|
|
d.target.hide();
|
|
ny = gP(gh.sh, gh.sm);
|
|
d.top = ny;
|
|
tempdata = buildtempdayevent(gh.sh, gh.sm, gh.eh, gh.em, gh.h, data["summary"], false, false, data["color"]);
|
|
cpwrap = $("<div class='ca-evpi drag-chip-wrapper' style='top:" + ny + "px'/>").html(tempdata);
|
|
evid = ".tgOver" + d.target.parent().data("col");
|
|
$gridcontainer.find(evid).append(cpwrap);
|
|
d.cpwrap = cpwrap;
|
|
d.ny = ny;
|
|
}
|
|
else {
|
|
var pd = 0;
|
|
if (x < d.pXMin) {
|
|
pd = -1;
|
|
}
|
|
else if (x > d.pXMax) {
|
|
pd = 1;
|
|
}
|
|
if (pd != 0) {
|
|
|
|
d.cdi = d.cdi + pd;
|
|
var ov = $gridcontainer.find(".tgOver" + d.cdi);
|
|
if (ov.length == 1) {
|
|
d.pXMin = d.pXMin + d.pw * pd;
|
|
d.pXMax = d.pXMax + d.pw * pd;
|
|
ov.append(d.cpwrap);
|
|
}
|
|
else {
|
|
d.cdi = d.cdi - pd;
|
|
}
|
|
}
|
|
ny = d.top + diffy;
|
|
var pny = ny % Math.ceil(option.hour_height / 2);
|
|
if (pny != 0) {
|
|
ny = ny - pny;
|
|
}
|
|
if (d.ny != ny) {
|
|
//log.info("ny=" + ny);
|
|
gh = gW(ny, ny + d.h);
|
|
//log.info("sh=" + gh.sh + ",sm=" + gh.sm);
|
|
tempdata = buildtempdayevent(gh.sh, gh.sm, gh.eh, gh.em, gh.h, data["summary"], false, false, data["color"]);
|
|
d.cpwrap.css("top", ny + "px").html(tempdata);
|
|
}
|
|
d.ny = ny;
|
|
}
|
|
}
|
|
}
|
|
|
|
break;
|
|
case "std_item_resize":
|
|
var data = d.data;
|
|
if (data != null && data["is_editable_quick"] == 1) {
|
|
sy = d.sy;
|
|
y = e.pageY;
|
|
diffy = y - sy;
|
|
if (diffy != 0 || d.cpwrap) {
|
|
if (!d.cpwrap) {
|
|
gh = { sh:data["start"].getHours(),
|
|
sm:data["start"].getMinutes(),
|
|
eh:data["end"].getHours(),
|
|
em:data["end"].getMinutes(),
|
|
h:d.h
|
|
};
|
|
d.target.hide();
|
|
ny = gP(gh.sh, gh.sm);
|
|
d.top = ny;
|
|
tempdata = buildtempdayevent(gh.sh, gh.sm, gh.eh, gh.em, gh.h, data["summary"], "100%", true, data["color"]);
|
|
cpwrap = $("<div class='ca-evpi drag-chip-wrapper' style='top:" + ny + "px'/>").html(tempdata);
|
|
evid = ".tgOver" + d.target.parent().data("col");
|
|
$gridcontainer.find(evid).append(cpwrap);
|
|
d.cpwrap = cpwrap;
|
|
}
|
|
else {
|
|
nh = d.h + diffy;
|
|
var pnh = nh % Math.ceil(option.hour_height / 2);
|
|
nh = pnh > 1 ? nh - pnh + Math.ceil(option.hour_height / 2) : nh - pnh;
|
|
if (d.nh != nh) {
|
|
gh = gW(d.top, d.top + nh);
|
|
tempdata = buildtempdayevent(gh.sh, gh.sm, gh.eh, gh.em, gh.h, data["summary"], "100%", true, data["color"]);
|
|
d.cpwrap.html(tempdata);
|
|
}
|
|
d.nh = nh;
|
|
}
|
|
}
|
|
}
|
|
break;
|
|
case "fullday_item_move":
|
|
sx = d.sx;
|
|
x = e.pageX;
|
|
y = e.pageY;
|
|
diffx = x - sx;
|
|
if (diffx > 5 || diffx < -5 || d.lasso) {
|
|
if (!d.lasso) {
|
|
w1 = d.dp > 1 ? (d.pw - 4) * 1.5 : (d.pw - 4);
|
|
cp = d.target.clone();
|
|
if (d.dp > 1) {
|
|
cp.find("div.rb-i>span").prepend("(" + d.dp + " " + i18n.xgcalendar.day_plural + ") ");
|
|
}
|
|
cpwrap = $("<div class='drag-event st-contents' style='width:" + w1 + "px'/>").append(cp).appendTo(document.body);
|
|
d.cpwrap = cpwrap;
|
|
d.lasso = $("<div style='z-index: 10; display: block' class='drag-lasso-container'/>");
|
|
$(document.body).append(d.lasso);
|
|
cp = cpwrap = null;
|
|
}
|
|
fixcppostion(d.cpwrap, e, d.xa, d.ya);
|
|
ndi = getdi(d.xa, d.ya, x, e.pageY);
|
|
if (!d.cdi || d.cdi.di != ndi.di) {
|
|
addlasso(d.lasso, ndi, { x:ndi.x, y:ndi.y, di:ndi.di + d.dp - 1 }, d.xa, d.ya, d.h);
|
|
}
|
|
d.cdi = ndi;
|
|
}
|
|
break;
|
|
case "std_item_month_drag":
|
|
sx = d.sx;
|
|
sy = d.sy;
|
|
x = e.pageX;
|
|
y = e.pageY;
|
|
var diffx = x - sx;
|
|
diffy = y - sy;
|
|
if (diffx > 5 || diffx < -5 || diffy > 5 || diffy < -5 || d.lasso) {
|
|
if (!d.lasso) {
|
|
w1 = d.dp > 1 ? (d.pw - 4) * 1.5 : (d.pw - 4);
|
|
cp = d.target.clone();
|
|
if (d.dp > 1) {
|
|
cp.find("div.rb-i>span").prepend("(" + d.dp + " " + i18n.xgcalendar.day_plural + ") ");
|
|
}
|
|
cpwrap = $("<div class='drag-event st-contents' style='width:" + w1 + "px'/>").append(cp).appendTo(document.body);
|
|
d.cpwrap = cpwrap;
|
|
d.lasso = $("<div style='z-index: 10; display: block' class='drag-lasso-container'/>");
|
|
$(document.body).append(d.lasso);
|
|
cp = cpwrap = null;
|
|
}
|
|
fixcppostion(d.cpwrap, e, d.xa, d.ya);
|
|
ndi = getdi(d.xa, d.ya, x, e.pageY);
|
|
if (!d.cdi || d.cdi.di != ndi.di) {
|
|
addlasso(d.lasso, ndi, { x:ndi.x, y:ndi.y, di:ndi.di + d.dp - 1 }, d.xa, d.ya, d.h);
|
|
}
|
|
d.cdi = ndi;
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
function dragEnd(e) {
|
|
if (_dragdata) {
|
|
var d = _dragdata;
|
|
var tp, start, end, gh;
|
|
switch (d.type) {
|
|
case "std_empty_drag": //day view
|
|
var wrapid = new Date().getTime();
|
|
tp = d.target.offset().top;
|
|
if (!d.cpwrap) {
|
|
gh = gH(d.sy, d.sy + option.hour_height, tp);
|
|
var ny = gP(gh.sh, gh.sm);
|
|
var tempdata = buildtempdayevent(gh.sh, gh.sm, gh.eh, gh.em, gh.h, "", "", "", option.std_color);
|
|
d.cpwrap = $("<div class='ca-evpi drag-chip-wrapper' style='top:" + ny + "px'/>").html(tempdata);
|
|
$(d.target).find("div.tg-col-overlaywrapper").append(d.cpwrap);
|
|
d.cgh = gh;
|
|
}
|
|
var pos = d.cpwrap.offset();
|
|
pos.left = pos.left + 30;
|
|
d.cpwrap.attr("id", wrapid);
|
|
start = new Date(parseInt(d.target.data("abbr")) + (d.cgh.sh * 3600 + d.cgh.sm * 60) * 1000);
|
|
end = new Date(parseInt(d.target.data("abbr")) + (d.cgh.eh * 3600 + d.cgh.em * 60) * 1000);
|
|
_dragevent = function () {
|
|
$("#" + wrapid).remove();
|
|
$("#bbit-cal-buddle").css("visibility", "hidden");
|
|
};
|
|
quickadd(start, end, false, pos);
|
|
break;
|
|
case "fullday_empty_drag": //week view
|
|
case "empty_month_drag": //month view
|
|
var source = e.srcElement || e.target;
|
|
var lassoid = new Date().getTime();
|
|
if (!d.lasso) {
|
|
if ($(source).hasClass("monthdayshow")) {
|
|
weekormonthtoday.call($(source).parent()[0], e);
|
|
break;
|
|
}
|
|
d.fdi = d.sdi = getdi(d.xa, d.ya, d.sx, d.sy);
|
|
d.lasso = $("<div style='z-index: 10; display: block' class='drag-lasso-container'/>");
|
|
$(document.body).append(d.lasso);
|
|
addlasso(d.lasso, d.sdi, d.fdi, d.xa, d.ya, d.h);
|
|
}
|
|
d.lasso.attr("id", lassoid);
|
|
var si = Math.min(d.fdi.di, d.sdi.di);
|
|
var ei = Math.max(d.fdi.di, d.sdi.di);
|
|
var firstday = option.vstart;
|
|
start = DateAdd("d", si, firstday);
|
|
end = DateAdd("d", ei, firstday);
|
|
_dragevent = function () {
|
|
$("#" + lassoid).remove();
|
|
};
|
|
quickadd(start, end, true, { left:e.pageX, top:e.pageY });
|
|
break;
|
|
case "std_item_move": // event moving
|
|
if (d.cpwrap) {
|
|
start = DateAdd("d", d.cdi, option.vstart);
|
|
end = DateAdd("d", d.cdi, option.vstart);
|
|
gh = gW(d.ny, d.ny + d.h);
|
|
start.setHours(gh.sh, gh.sm);
|
|
end.setHours(gh.eh, gh.em);
|
|
if (start.getTime() == d.data["start"].getTime() && end.getTime() == d.data["end"].getTime()) {
|
|
d.cpwrap.remove();
|
|
d.target.show();
|
|
}
|
|
else {
|
|
dayupdate(d.data, start, end);
|
|
}
|
|
}
|
|
break;
|
|
case "std_item_resize": //Resize
|
|
if (d.cpwrap) {
|
|
start = new Date(d.data["start"].toString());
|
|
end = new Date(d.data["end"].toString());
|
|
gh = gW(d.top, d.top + d.nh);
|
|
start.setHours(gh.sh, gh.sm);
|
|
end.setHours(gh.eh, gh.em);
|
|
if (start.getTime() == d.data["start"].getTime() && end.getTime() == d.data["end"].getTime()) {
|
|
d.cpwrap.remove();
|
|
d.target.show();
|
|
}
|
|
else {
|
|
dayupdate(d.data, start, end);
|
|
}
|
|
}
|
|
break;
|
|
case "fullday_item_move":
|
|
case "std_item_month_drag":
|
|
if (d.lasso) {
|
|
d.cpwrap.remove();
|
|
d.lasso.remove();
|
|
start = new Date(d.data["start"].toString());
|
|
end = new Date(d.data["end"].toString());
|
|
var currrentdate = DateAdd("d", d.cdi.di, option.vstart);
|
|
var diff = DateDiff("d", start, currrentdate);
|
|
start = DateAdd("d", diff, start);
|
|
end = DateAdd("d", diff, end);
|
|
if (start.getTime() != d.data["start"].getTime() || end.getTime() != d.data["end"].getTime()) {
|
|
dayupdate(d.data, start, end);
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
d = _dragdata = null;
|
|
$('body').noSelect(false);
|
|
return false;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
function getdi(xa, ya, x, y) {
|
|
var ty = 0;
|
|
var tx = 0;
|
|
var lx = 0;
|
|
var ly = 0;
|
|
if (xa && xa.length != 0) {
|
|
lx = xa.length;
|
|
if (x >= xa[lx - 1].e) {
|
|
tx = lx - 1;
|
|
}
|
|
else {
|
|
for (var i = 0; i < lx; i++) {
|
|
if (x > xa[i].s && x <= xa[i].e) {
|
|
tx = i;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
if (ya && ya.length != 0) {
|
|
ly = ya.length;
|
|
if (y >= ya[ly - 1].e) {
|
|
ty = ly - 1;
|
|
}
|
|
else {
|
|
for (var j = 0; j < ly; j++) {
|
|
if (y > ya[j].s && y <= ya[j].e) {
|
|
ty = j;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return { x:tx, y:ty, di:ty * lx + tx };
|
|
}
|
|
|
|
function addlasso(lasso, sdi, edi, xa, ya, height) {
|
|
var diff = sdi.di > edi.di ? sdi.di - edi.di : edi.di - sdi.di;
|
|
diff++;
|
|
var sp = sdi.di > edi.di ? edi : sdi;
|
|
var l = xa.length > 0 ? xa.length : 1;
|
|
var h = ya.length > 0 ? ya.length : 1;
|
|
var play = [];
|
|
var width = xa[0].e - xa[0].s;
|
|
var i = sp.x;
|
|
var j = sp.y;
|
|
var max = Math.min(document.documentElement.clientWidth, xa[l - 1].e) - 2;
|
|
|
|
while (j < h && diff > 0) {
|
|
var left = xa[i].s;
|
|
var d = i + diff > l ? l - i : diff;
|
|
var wid = width * d;
|
|
while (left + wid >= max) {
|
|
wid--;
|
|
}
|
|
play.push(Tp(__LASSOTEMP, { left:left, top:ya[j].s, height:height, width:wid }));
|
|
i = 0;
|
|
diff = diff - d;
|
|
j++;
|
|
}
|
|
lasso.html(play.join(""));
|
|
}
|
|
|
|
function fixcppostion(cpwrap, e, xa, ya) {
|
|
var x = e.pageX - 6;
|
|
var y = e.pageY - 4;
|
|
var w = cpwrap.width();
|
|
var h = 21;
|
|
var lmin = xa[0].s + 6;
|
|
var tmin = ya[0].s + 4;
|
|
var lmax = xa[xa.length - 1].e - w - 2;
|
|
var tmax = ya[ya.length - 1].e - h - 2;
|
|
if (x > lmax) {
|
|
x = lmax;
|
|
}
|
|
if (x <= lmin) {
|
|
x = lmin + 1;
|
|
}
|
|
if (y <= tmin) {
|
|
y = tmin + 1;
|
|
}
|
|
if (y > tmax) {
|
|
y = tmax;
|
|
}
|
|
cpwrap.css({ left:x, top:y });
|
|
}
|
|
|
|
$(document)
|
|
.mousemove(dragMove)
|
|
.mouseup(dragEnd);
|
|
//.mouseout(dragEnd);
|
|
|
|
this[0].bcal = {
|
|
sv:function (view) { //switch view
|
|
if (view == option.view) {
|
|
return;
|
|
}
|
|
clearcontainer();
|
|
option.view = view;
|
|
render();
|
|
populate();
|
|
},
|
|
rf:function () {
|
|
populate();
|
|
},
|
|
gt:function (d) {
|
|
if (!d) {
|
|
d = new Date();
|
|
}
|
|
option.showday = d;
|
|
render();
|
|
populate();
|
|
},
|
|
|
|
pv:function () {
|
|
switch (option.view) {
|
|
case "day":
|
|
option.showday = DateAdd("d", -1, option.showday);
|
|
break;
|
|
case "week":
|
|
option.showday = DateAdd("w", -1, option.showday);
|
|
break;
|
|
case "multi_days":
|
|
option.showday = DateAdd("w", -1, option.showday);
|
|
break;
|
|
case "month":
|
|
option.showday = DateAdd("m", -1, option.showday);
|
|
break;
|
|
}
|
|
render();
|
|
populate();
|
|
},
|
|
nt:function () {
|
|
switch (option.view) {
|
|
case "day":
|
|
option.showday = DateAdd("d", 1, option.showday);
|
|
break;
|
|
case "week":
|
|
option.showday = DateAdd("w", 1, option.showday);
|
|
break;
|
|
case "multi_days":
|
|
option.showday = DateAdd("w", 1, option.showday);
|
|
break;
|
|
case "month":
|
|
var od = option.showday.getDate();
|
|
option.showday = DateAdd("m", 1, option.showday);
|
|
var nd = option.showday.getDate();
|
|
if (od != nd) //we go to the next month
|
|
{
|
|
option.showday = DateAdd("d", 0 - nd, option.showday); //last day of last month
|
|
}
|
|
break;
|
|
}
|
|
render();
|
|
populate();
|
|
},
|
|
go:function () {
|
|
return option;
|
|
},
|
|
so:function (p) {
|
|
option = $.extend(option, p);
|
|
}
|
|
};
|
|
|
|
return this;
|
|
};
|
|
|
|
/**
|
|
* @description {Method} switchView To switch to another view.
|
|
* @param {String} view View name, one of 'day', 'week', 'multi_days', 'month'.
|
|
*/
|
|
$.fn.switchView = function (view) {
|
|
return this.each(function () {
|
|
if (this.bcal) {
|
|
this.bcal.sv(view);
|
|
}
|
|
})
|
|
};
|
|
|
|
/**
|
|
* @description {Method} reload To reload event of current time range.
|
|
*/
|
|
$.fn.reload = function () {
|
|
return this.each(function () {
|
|
if (this.bcal) {
|
|
this.bcal.rf();
|
|
}
|
|
})
|
|
};
|
|
|
|
/**
|
|
* @description {Method} gotoDate To go to a range containing date.
|
|
* If view is week, it will go to a week containing date.
|
|
* If view is month, it will got to a month containing date.
|
|
* @param {Date} d. Date to go.
|
|
*/
|
|
$.fn.gotoDate = function (d) {
|
|
return this.each(function () {
|
|
if (this.bcal) {
|
|
this.bcal.gt(d);
|
|
}
|
|
})
|
|
};
|
|
|
|
/**
|
|
* @description {Method} previousRange To go to previous date range.
|
|
* If view is week, it will go to previous week.
|
|
* If view is month, it will got to previous month.
|
|
*/
|
|
$.fn.previousRange = function () {
|
|
return this.each(function () {
|
|
if (this.bcal) {
|
|
this.bcal.pv();
|
|
}
|
|
})
|
|
};
|
|
|
|
/**
|
|
* @description {Method} nextRange To go to next date range.
|
|
* If view is week, it will go to next week.
|
|
* If view is month, it will got to next month.
|
|
*/
|
|
$.fn.nextRange = function () {
|
|
return this.each(function () {
|
|
if (this.bcal) {
|
|
this.bcal.nt();
|
|
}
|
|
})
|
|
};
|
|
|
|
|
|
$.fn.BcalGetOp = function () {
|
|
if (this[0].bcal) {
|
|
return this[0].bcal.go();
|
|
}
|
|
return null;
|
|
};
|
|
|
|
|
|
$.fn.BcalSetOp = function (p) {
|
|
if (this[0].bcal) {
|
|
return this[0].bcal.so(p);
|
|
}
|
|
};
|
|
|
|
})(jQuery); |