From 10eef51a0f086ad148928ba965c330599b4765cb Mon Sep 17 00:00:00 2001 From: Unrud Date: Sun, 4 Jun 2017 17:16:11 +0200 Subject: Update package for new web plugin interface --- radicale_web/web/infcloud/lib/fullcalendar.js | 7196 ----------------- radicale_web/web/infcloud/lib/ie_base64.js | 176 - radicale_web/web/infcloud/lib/jquery-2.1.4.min.js | 4 - .../web/infcloud/lib/jquery-ui-1.11.4.custom.js | 8226 -------------------- radicale_web/web/infcloud/lib/jquery.autosize.js | 258 - radicale_web/web/infcloud/lib/jquery.browser.js | 43 - .../web/infcloud/lib/jquery.placeholder-1.1.9.js | 195 - .../web/infcloud/lib/jquery.quicksearch.js | 205 - radicale_web/web/infcloud/lib/jquery.tagsinput.js | 436 -- radicale_web/web/infcloud/lib/rrule.js | 1910 ----- radicale_web/web/infcloud/lib/sha256.js | 16 - radicale_web/web/infcloud/lib/spectrum.js | 2027 ----- 12 files changed, 20692 deletions(-) delete mode 100644 radicale_web/web/infcloud/lib/fullcalendar.js delete mode 100644 radicale_web/web/infcloud/lib/ie_base64.js delete mode 100644 radicale_web/web/infcloud/lib/jquery-2.1.4.min.js delete mode 100644 radicale_web/web/infcloud/lib/jquery-ui-1.11.4.custom.js delete mode 100644 radicale_web/web/infcloud/lib/jquery.autosize.js delete mode 100644 radicale_web/web/infcloud/lib/jquery.browser.js delete mode 100644 radicale_web/web/infcloud/lib/jquery.placeholder-1.1.9.js delete mode 100644 radicale_web/web/infcloud/lib/jquery.quicksearch.js delete mode 100644 radicale_web/web/infcloud/lib/jquery.tagsinput.js delete mode 100644 radicale_web/web/infcloud/lib/rrule.js delete mode 100644 radicale_web/web/infcloud/lib/sha256.js delete mode 100644 radicale_web/web/infcloud/lib/spectrum.js (limited to 'radicale_web/web/infcloud/lib') diff --git a/radicale_web/web/infcloud/lib/fullcalendar.js b/radicale_web/web/infcloud/lib/fullcalendar.js deleted file mode 100644 index 8effe83..0000000 --- a/radicale_web/web/infcloud/lib/fullcalendar.js +++ /dev/null @@ -1,7196 +0,0 @@ -/** - * @preserve - * FullCalendar v1.5.4 - * http://arshaw.com/fullcalendar/ - * - * Use fullcalendar.css for basic styling. - * For event drag & drop, requires jQuery UI draggable. - * For event resizing, requires jQuery UI resizable. - * - * Copyright (c) 2011 Adam Shaw - * Dual licensed under the MIT and GPL licenses, located in - * MIT-LICENSE.txt and GPL-LICENSE.txt respectively. - * - * Date: Tue Sep 4 23:38:33 2012 -0700 - * - */ - -(function($, undefined) { - -var defaults = { - - // display - defaultView: 'month', - aspectRatio: 1.35, - header: { - left: 'title', - center: '', - right: 'today prev,next' - }, - weekends: true, - currentTimeIndicator: false, - - // editing - //editable: false, - //disableDragging: false, - //disableResizing: false, - - allDayDefault: true, - ignoreTimezone: true, - - // event ajax - lazyFetching: true, - startParam: 'start', - endParam: 'end', - - // time formats - titleFormat: { - month: 'MMMM yyyy', - multiWeek: "MMM d[ yyyy]{ '–'[ MMM] d yyyy}", - week: "MMM d[ yyyy]{ '–'[ MMM] d yyyy}", - day: 'dddd, MMM d, yyyy', - list: 'MMM d, yyyy', - table: "MMM d[ yyyy]{ '–'[ MMM] d yyyy}", - todo: "MMM d[ yyyy]{ '–'[ MMM] d yyyy}", - }, - columnFormat: { - month: 'ddd', - multiWeek: 'ddd', - week: 'ddd M/d', - day: 'dddd M/d', - list: 'dddd, MMM d, yyyy', - table: 'MMM d, yyyy', - todo: 'MMM d, yyyy', - }, - timeFormat: { // for event elements - '': 'h(:mm)t', // default - agenda: 'h:mm{ – h:mm}', //agenda views - list: 'hh:mm{ – hh:mm}', //list and table views - listFull: 'hh:mm M d yyyy{ – hh:mm M d yyyy}', //list and table views for events that span multiple days - listFullAllDay: 'M d yyyy{ – M d yyyy}', //list and table views for allday events that span multiple days - }, - - // locale - isRTL: false, - firstDay: 0, - weekendDays: [0, 6], - monthNames: ['January','February','March','April','May','June','July','August','September','October','November','December'], - monthNamesShort: ['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec'], - dayNames: ['Sunday','Monday','Tuesday','Wednesday','Thursday','Friday','Saturday'], - dayNamesShort: ['Sun','Mon','Tue','Wed','Thu','Fri','Sat'], - buttonText: { - prev: ' ❮ ', - next: ' ❯ ', - prevYear: ' << ', - nextYear: ' >> ', - today: 'today', - month: 'month', - multiWeek: 'mweek', - week: 'week', - day: 'day', - list: 'list', - table: 'table', - todo: 'todo', - prevMonth: 'Load previous month', - nextMonth: 'Load next month', - filtersHeader: 'Filters', - filtersFooter: '* completed at or after %date%', - filterAction: 'Needs action', - filterProgress: 'In progress', - filterCompleted: 'Completed', - filterCanceled: 'Canceled' - }, - - listTexts: { - until: 'until', - past: 'Past events', - today: 'Today', - tomorrow: 'Tomorrow', - thisWeek: 'This week', - nextWeek: 'Next week', - thisMonth: 'This month', - nextMonth: 'Next month', - future: 'Future events', - week: 'W' - }, - - // list/table options - listSections: 'smart', // false|'day'|'week'|'month'|'smart' - listRange: 30, // number of days to be displayed - listPage: 7, // number of days to jump when paging - tableCols: ['handle', 'date', 'time', 'title'], - todoCols: ['handle', 'check', 'priority', 'time', 'title', 'location', 'status', 'percent'], - todoColThresholds: [], - todoOptionalCols: [], - //defaultFilters: ['filterAction', 'filterProgress', 'filterCompleted', 'filterCanceled'], - defaultFilters: [], - - // jquery-ui theming - theme: false, - buttonIcons: { - prev: 'circle-triangle-w', - next: 'circle-triangle-e' - }, - - //selectable: false, - unselectAuto: true, - - dropAccept: '*', - - headerContainer: false, - bindingMode: 'single', - dayEventSizeStrict: false, - startOfBusiness: 0, - endOfBusiness: 0, - showWeekNumbers: true, - multiWeekSize: 3, - showDatepicker: false, - eventMode: true, - showUnstartedEvents: false, - simpleFilters: false, -}; - -// right-to-left defaults -var rtlDefaults = { - header: { - left: 'next,prev today', - center: '', - right: 'title' - }, - headerContainer: '', - buttonText: { - prev: ' ► ', - next: ' ◄ ', - prevYear: ' >> ', - nextYear: ' << ' - }, - buttonIcons: { - prev: 'circle-triangle-e', - next: 'circle-triangle-w' - } -}; - -var fc = $.fullCalendar = { version: "1.5.4" }; -var fcViews = fc.views = {}; - -$.fn.fullCalendar = function(options) { - // method calling - if (typeof options == 'string') { - var args = Array.prototype.slice.call(arguments, 1); - var res; - this.each(function() { - var calendar = $.data(this, 'fullCalendar'); - if (calendar && $.isFunction(calendar[options])) { - var r = calendar[options].apply(calendar, args); - if (res === undefined) { - res = r; - } - if (options == 'destroy') { - $.removeData(this, 'fullCalendar'); - } - } - }); - if (res !== undefined) { - return res; - } - return this; - } - - // would like to have this logic in EventManager, but needs to happen before options are recursively extended - var eventSources = options.eventSources || []; - delete options.eventSources; - if (options.events) { - eventSources.push(options.events); - delete options.events; - } - - options = $.extend(true, {}, - defaults, - (options.isRTL || options.isRTL===undefined && defaults.isRTL) ? rtlDefaults : {}, - options - ); - - this.each(function(i, _element) { - var element = $(_element); - var calendar = new Calendar(element, options, eventSources); - element.data('fullCalendar', calendar); // TODO: look into memory leak implications - calendar.render(); - }); - - return this; -}; - -// function for adding/overriding defaults -function setDefaults(d) { - $.extend(true, defaults, d); -} - -function Calendar(element, options, eventSources) { - var t = this; - - // exports - t.options = options; - t.render = render; - t.destroy = destroy; - t.refetchEvents = refetchEvents; - t.reportEvents = reportEvents; - t.reportEventChange = reportEventChange; - t.rerenderEvents = rerenderEvents; - t.changeView = changeView; - t.select = select; - t.unselect = unselect; - t.prev = prev; - t.next = next; - t.prevYear = prevYear; - t.nextYear = nextYear; - t.today = today; - t.findToday = findToday; - t.gotoDate = gotoDate; - t.incrementDate = incrementDate; - t.formatDate = function(format, date) { return formatDate(format, date, options) }; - t.formatDates = function(format, date1, date2) { return formatDates(format, date1, date2, options) }; - t.getDate = getDate; - t.getView = getView; - t.option = option; - t.trigger = trigger; - t.selectEvent = selectEvent; - t.allowSelectEvent = allowSelectEvent; - t.updateToday = updateToday; - t.updateGrid = updateGrid; - t.renderViews = renderViews; - t.setOptions = setOptions; - t.getOption = getOption; - t.viewInstances = {}; - - // imports - EventManager.call(t, options, eventSources); - var isFetchNeeded = t.isFetchNeeded; - var fetchEvents = t.fetchEvents; - - // locals - var _element = element[0]; - var header; - var headerElement; - var content; - var tm; // for making theme classes - var currentView; - var elementOuterWidth; - var suggestedViewHeight; - var absoluteViewElement; - var resizeUID = 0; - var ignoreWindowResize = 0; - var date = new Date(); - var events = []; - var _dragElement; - - /* Main Rendering - -----------------------------------------------------------------------------*/ - - setYMD(date, options.year, options.month, options.date); - - function render(inc) { - if (!content) { - initialRender(); - }else{ - calcSize(); - markSizesDirty(); - markEventsDirty(); - renderView(inc); - } - } - - function initialRender() { - tm = options.theme ? 'ui' : 'fc'; - element.addClass('fc'); - if (options.isRTL) { - element.addClass('fc-rtl'); - } - if (options.theme) { - element.addClass('ui-widget'); - } - content = $("
") - .prependTo(element); - header = new Header(t, options); - headerElement = header.render(); - if (headerElement) { - options.headerContainer ? options.headerContainer.prepend(headerElement) : element.prepend(headerElement); - } - changeView(options.defaultView); - $(window).resize(windowResize); - // needed for IE in a 0x0 iframe, b/c when it is resized, never triggers a windowResize - if (!bodyVisible()) { - lateRender(); - } - } - - // called when we know the calendar couldn't be rendered when it was initialized, - // but we think it's ready now - function lateRender() { - setTimeout(function() { // IE7 needs this so dimensions are calculated correctly - if (!currentView.start && bodyVisible()) { // !currentView.start makes sure this never happens more than once - renderView(); - } - },0); - } - - function updateToday() - { - for(var view in t.viewInstances) - t.viewInstances[view].updateToday(); - } - - function updateGrid() - { - for(var view in t.viewInstances) - t.viewInstances[view].updateGrid(); - } - - function renderViews() - { - //Force rerender of all views - for(var view in t.viewInstances) - t.viewInstances[view].start=null; - renderView(); - } - - function setOptions(newOptions) - { - var rerender=false; - - $.each(newOptions, function(key,value){ - if($.isPlainObject(value)) - $.extend(options[key],value); - else - options[key]=value; - - if(key=='firstDay' || key=='timeFormat') - rerender=true; - else - { - for(var view in t.viewInstances) - t.viewInstances[view]['set'+key.charAt(0).toUpperCase()+key.slice(1)](); - } - }); - - if(rerender) - renderViews(); - } - - function getOption(option) - { - return options[option]; - } - - function destroy() { - $(window).unbind('resize', windowResize); - header.destroy(); - content.remove(); - element.removeClass('fc fc-rtl ui-widget'); - } - - function elementVisible() { - return _element.offsetWidth !== 0; - } - - function bodyVisible() { - return $('body')[0].offsetWidth !== 0; - } - - /* View Rendering - -----------------------------------------------------------------------------*/ - - // TODO: improve view switching (still weird transition in IE, and FF has whiteout problem) - - function changeView(newViewName) { - if (!currentView || newViewName != currentView.name) { - ignoreWindowResize++; // because setMinHeight might change the height before render (and subsequently setSize) is reached - - unselect(); - - var oldView = currentView; - var newViewElement; - - if (oldView) { - (oldView.beforeHide || noop)(); // called before changing min-height. if called after, scroll state is reset (in Opera) - //setMinHeight(content, content.height()); why is this necessary? - oldView.element.hide(); - if(oldView.addedView) { - oldView.addedView.element.hide(); - } - }else{ - setMinHeight(content, 1); // needs to be 1 (not 0) for IE7, or else view dimensions miscalculated - } - content.css('overflow', 'hidden'); - - currentView = t.viewInstances[newViewName]; - if (currentView) { - currentView.element.show(); - }else{ - currentView = t.viewInstances[newViewName] = new fcViews[newViewName]( - newViewElement = absoluteViewElement = - $("
") - .appendTo(content), - t // the calendar object - ); - } - - if(newViewName == 'agendaDay') { - addedView = t.viewInstances['table']; - if (addedView) { - addedView.element.show(); - }else{ - addedView = t.viewInstances['table'] = new fcViews['table']( - addedNewViewElement = addedAbsoluteViewElement = - $("
") - .appendTo(content), - t // the calendar object - ); - currentView.addedView = addedView; - } - } - - if (oldView) { - header.deactivateButton(oldView.name); - } - header.activateButton(newViewName); - - renderView(); // after height has been set, will make absoluteViewElement's position=relative, then set to null - - content.css('overflow', ''); - if (oldView) { - setMinHeight(content, 1); - } - - if (!newViewElement) { - (currentView.afterShow || noop)(); // called after setting min-height/overflow, so in final scroll state (for Opera) - } - - ignoreWindowResize--; - currentView.trigger('viewChanged', _element); - } - } - - function renderView(inc) { - if (elementVisible()) { - currentView.trigger('beforeViewDisplay', _element); - ignoreWindowResize++; // because renderEvents might temporarily change the height before setSize is reached - - unselect(); - - if (suggestedViewHeight === undefined) { - calcSize(); - } - - if(currentView.addedView && currentView.start && cloneDate(date, true).getTime() == currentView.start.getTime()) { - currentView.addedView.scrollToDate(date); - } - - var forceEventRender = false; - if (!currentView.start || inc || date < currentView.start || date >= currentView.end) { - // view must render an entire new date range (and refetch/render events) - currentView.render(date, inc || 0); // responsible for clearing events - setSize(true); - forceEventRender = true; - } - else if (currentView.sizeDirty) { - // view must resize (and rerender events) - currentView.clearEvents(); - setSize(); - forceEventRender = true; - } - else if (currentView.eventsDirty) { - currentView.clearEvents(); - forceEventRender = true; - } - - currentView.sizeDirty = false; - currentView.eventsDirty = false; - updateEvents(forceEventRender); - - elementOuterWidth = element.outerWidth(); - - header.updateTitle(currentView.title); - var today = new Date(); - if (today >= currentView.start && today < currentView.end) { - //header.disableButton('today'); - header.setTodayScroll(element); - findToday(); - }else{ - //header.enableButton('today'); - header.setTodayDefault(); - } - - ignoreWindowResize--; - currentView.trigger('viewDisplay', _element); - } - } - - /* Resizing - -----------------------------------------------------------------------------*/ - - function updateSize() { - markSizesDirty(); - if (elementVisible()) { - calcSize(); - setSize(); - if(currentView.name!='todo') - { - unselect(); - currentView.clearEvents(); - currentView.renderEvents(events); - } - currentView.sizeDirty = false; - } - } - - function markSizesDirty() { - $.each(t.viewInstances, function(i, inst) { - inst.sizeDirty = true; - }); - } - - function calcSize() { - if (options.contentHeight) { - suggestedViewHeight = options.contentHeight; - } - else if (options.height) { - suggestedViewHeight = options.height - (headerElement ? headerElement.height() : 0) - vsides(content); - } - else { - suggestedViewHeight = Math.round(content.width() / Math.max(options.aspectRatio, .5)); - } - } - - function setSize(dateChanged) { // todo: dateChanged? - ignoreWindowResize++; - currentView.setWidth(content.width(), dateChanged); - currentView.setHeight(suggestedViewHeight, dateChanged); - if (absoluteViewElement) { - absoluteViewElement.css('position', 'relative'); - absoluteViewElement = null; - } - /*if(currentView.addedView) { - currentView.addedView.setWidth(content.width(), dateChanged); - var tmpContentWidth = Math.floor(content.width() / 2); - currentView.element.width(tmpContentWidth); - currentView.addedView.element.css({'left' : tmpContentWidth, - 'width' : tmpContentWidth - 2}); - }*/ - ignoreWindowResize--; - } - - function windowResize() { - if (!ignoreWindowResize) { - if (currentView.start) { // view has already been rendered - var uid = ++resizeUID; - //setTimeout(function() { // add a delay - if (uid == resizeUID && !ignoreWindowResize && elementVisible()) { - if (elementOuterWidth != (elementOuterWidth = element.outerWidth())) { - ignoreWindowResize++; // in case the windowResize callback changes the height - updateSize(); - currentView.trigger('windowResize', _element); - ignoreWindowResize--; - } - } - //}, 200); - }else{ - // calendar must have been initialized in a 0x0 iframe that has just been resized - lateRender(); - } - } - } - - /* Event Fetching/Rendering - -----------------------------------------------------------------------------*/ - - // fetches events if necessary, rerenders events if necessary (or if forced) - function updateEvents(forceRender) { - if (!options.lazyFetching || isFetchNeeded(currentView.visStart, currentView.visEnd)) { - refetchEvents(); - } - else if (forceRender) { - rerenderEvents(); - } - } - - function refetchEvents() { - fetchEvents(currentView.visStart, currentView.visEnd); // will call reportEvents - } - - // called when event data arrives - function reportEvents(_events) { - events = _events; - rerenderEvents(); - } - - // called when a single event's data has been changed - function reportEventChange(eventID) { - rerenderEvents(eventID); - } - - // attempts to rerenderEvents - function rerenderEvents(modifiedEventID) { - markEventsDirty(); - if (elementVisible()) { - currentView.clearEvents(); - currentView.renderEvents(events, modifiedEventID); - currentView.eventsDirty = false; - } - } - - function markEventsDirty() { - $.each(t.viewInstances, function(i, inst) { - inst.eventsDirty = true; - }); - } - - /* Selection - -----------------------------------------------------------------------------*/ - - function select(start, end, allDay) { - currentView.select(start, end, allDay===undefined ? true : allDay); - } - - function unselect() { // safe to be called before renderView - if(currentView) - currentView.unselect(); - } - - /* Date - -----------------------------------------------------------------------------*/ - - function prev() { - renderView(-1); - trigger('prevClick'); - } - - function next() { - renderView(1); - trigger('nextClick'); - } - - function prevYear() { - addYears(date, -1); - renderView(); - } - - function nextYear() { - addYears(date, 1); - renderView(); - } - - function today() { - date = new Date(); - renderView(); - findToday(); - trigger('todayClick'); - } - - function findToday() { - if(currentView.addedView) { - if(currentView.addedView.getDaySegmentContainer().find('.fc-today').length>0) { - if(new Date().getDate()==1) { - currentView.addedView.getDaySegmentContainer().parent().scrollTop(0); - } - else { - offset = currentView.addedView.getDaySegmentContainer().find('.fc-today').position().top; - var top = currentView.addedView.getDaySegmentContainer().parent().scrollTop(); - currentView.addedView.getDaySegmentContainer().parent().scrollTop(top + offset); - } - } - } - else if(currentView.name == 'todo') { - if(currentView.getDaySegmentContainer().find('.fc-today').length>0) { - offset = currentView.getDaySegmentContainer().find('.fc-today').position().top; - var top = currentView.getDaySegmentContainer().parent().scrollTop(); - currentView.getDaySegmentContainer().parent().scrollTop(top + offset); - } - } - else { - var todayElem = currentView.element.find('.fc-today'); - if(todayElem.length>0) { - var offset = 0; - if(!todayElem.parent().hasClass('fc-week0')) { - offset = todayElem.position().top; - } - element.parent().scrollTop(offset); - } - } - } - - function gotoDate(year, month, dateOfMonth) { - if (year instanceof Date) - date = cloneDate(year); // provided 1 argument, a Date - else - setYMD(date, year, month, dateOfMonth); - renderView(); - } - - function incrementDate(years, months, days) { - if(years !== undefined) - addYears(date, years); - if(months !== undefined) - addMonths(date, months); - if(days !== undefined) - addDays(date, days); - renderView(); - } - - function getDate() { - return cloneDate(date); - } - - /* Misc - -----------------------------------------------------------------------------*/ - - function getView() { - return currentView; - } - - function option(name, value) { - if (value === undefined) { - return options[name]; - } - if (name == 'height' || name == 'contentHeight' || name == 'aspectRatio') { - options[name] = value; - updateSize(); - } else if (name.indexOf('list') == 0 || name == 'tableCols') { - options[name] = value; - currentView.start = null; // force re-render - } - } - - function trigger(name, thisObj) { - if (options[name]) { - return options[name].apply( - thisObj || _element, - Array.prototype.slice.call(arguments, 2) - ); - } - } - - function selectEvent(eventElement, noClick) { - currentView.selectEvent(eventElement, noClick); - } - - function allowSelectEvent(value) { - currentView.allowSelectEvent(value); - } - - /* External Dragging - ------------------------------------------------------------------------*/ - - if (options.droppable) { - $(document) - .bind('dragstart', function(ev, ui) { - var _e = ev.target; - var e = $(_e); - if (!e.parents('.fc').length) { // not already inside a calendar - var accept = options.dropAccept; - if ($.isFunction(accept) ? accept.call(_e, e) : e.is(accept)) { - _dragElement = _e; - currentView.dragStart(_dragElement, ev, ui); - } - } - }) - .bind('dragstop', function(ev, ui) { - if (_dragElement) { - currentView.dragStop(_dragElement, ev, ui); - _dragElement = null; - } - }); - } -} - -function Header(calendar, options) { - var t = this; - - // exports - t.render = render; - t.destroy = destroy; - t.updateTitle = updateTitle; - t.activateButton = activateButton; - t.deactivateButton = deactivateButton; - t.disableButton = disableButton; - t.enableButton = enableButton; - t.setTodayDefault = setTodayDefault; - t.setTodayScroll = setTodayScroll; - - // locals - var element = $([]); - var tm; - - function render() { - tm = options.theme ? 'ui' : 'fc'; - var sections = options.header; - if (sections) { - element = $("") - .append( - $("") - .append(renderSection('left')) - .append(renderSection('center')) - .append(renderSection('right')) - ); - return element; - } - } - - function destroy() { - element.remove(); - } - - function renderSection(position) { - var e = $("" + - "" + - ""; - for (i=0; i"; // fc- needed for setDayID - } - s += - "" + - "" + - "" + - "" + - "" + - ""; - for (i=0; i" + // fc- needed for setDayID - "
" + - "
" + - "
 
" + - "
" + - "
" + - ""; - } - s += - "
" + - "" + - "" + - "
"); - var buttonStr = options.header[position]; - if (buttonStr) { - $.each(buttonStr.split(' '), function(i) { - if (i > 0) { - e.append(""); - } - var prevButton; - $.each(this.split(','), function(j, buttonName) { - if (buttonName == 'title') { - e.append("

 

"); - if (prevButton) { - prevButton.addClass(tm + '-corner-right'); - } - prevButton = null; - }else{ - var buttonClick; - if (calendar[buttonName]) { - buttonClick = calendar[buttonName]; // calendar method - } - else if (fcViews[buttonName]) { - buttonClick = function() { - button.removeClass(tm + '-state-hover'); // forget why - calendar.changeView(buttonName); - }; - } - if (buttonClick) { -// var icon = options.theme ? smartProperty(options.buttonIcons, buttonName) : null; // why are we using smartProperty here? - var icon = (buttonName=='prev' || buttonName=='next') ? buttonName : null; - var text = smartProperty(options.buttonText, buttonName); // why are we using smartProperty here? - var button = $( - "" + - "" + - "" + - (icon ? - "" : - text - ) + - "" + - "" + - "" + - "" - ); - if (button) { - button - .click(function() { - if (!button.hasClass(tm + '-state-disabled')) { - buttonClick(); - } - }) - .mousedown(function() { - button - .not('.' + tm + '-state-active') - .not('.' + tm + '-state-disabled') - .addClass(tm + '-state-down'); - }) - .mouseup(function() { - button.removeClass(tm + '-state-down'); - }) - .hover( - function() { - button - .not('.' + tm + '-state-active') - .not('.' + tm + '-state-disabled') - .addClass(tm + '-state-hover'); - }, - function() { - button - .removeClass(tm + '-state-hover') - .removeClass(tm + '-state-down'); - } - ) - .appendTo(e); - if (!prevButton) { - button.addClass(tm + '-corner-left'); - } - prevButton = button; - } - } - } - }); - if (prevButton) { - prevButton.addClass(tm + '-corner-right'); - } - }); - } - return e; - } - - function updateTitle(html) { - element.find('h2') - .html(html) - .attr('title', $("
").html(html).text()); - } - - function activateButton(buttonName) { - element.find('span.fc-button-' + buttonName) - .addClass(tm + '-state-active'); - } - - function deactivateButton(buttonName) { - element.find('span.fc-button-' + buttonName) - .removeClass(tm + '-state-active'); - } - - function disableButton(buttonName) { - element.find('span.fc-button-' + buttonName) - .addClass(tm + '-state-disabled'); - } - - function enableButton(buttonName) { - element.find('span.fc-button-' + buttonName) - .removeClass(tm + '-state-disabled'); - } - - function setTodayDefault() { - var todayBt = element.find('span.fc-button-' + 'today'); - var todayBtClc = calendar['today']; - - todayBt.unbind('click'); - todayBt.click(function(){ - if(!todayBt.hasClass(tm + '-state-disabled')) { - todayBtClc(); - } - }); - } - - function setTodayScroll(body) { - var todayBt = element.find('span.fc-button-' + 'today'); - var todayBtClc = calendar['findToday']; - - todayBt.unbind('click'); - todayBt.click(function(){ - if(!todayBt.hasClass(tm + '-state-disabled')) - todayBtClc(); - }); - } - -} - -fc.sourceNormalizers = []; -fc.sourceFetchers = []; - -var ajaxDefaults = { - dataType: 'json', - cache: false -}; - -var eventGUID = 1; - -function EventManager(options, _sources) { - var t = this; - - // exports - t.isFetchNeeded = isFetchNeeded; - t.fetchEvents = fetchEvents; - t.addEventSource = addEventSource; - t.removeEventSource = removeEventSource; - t.removeEventSources = removeEventSources; - t.updateEvent = updateEvent; - t.renderEvent = renderEvent; - t.removeEvents = removeEvents; - t.clientEvents = clientEvents; - t.normalizeEvent = normalizeEvent; - - // imports - var trigger = t.trigger; - var getView = t.getView; - var reportEvents = t.reportEvents; - - // locals - var stickySource = { events: [] }; - var sources = [ stickySource ]; - var rangeStart, rangeEnd; - var currentFetchID = 0; - var pendingSourceCnt = 0; - var loadingLevel = 0; - var cache = []; - - for (var i=0; i<_sources.length; i++) { - _addEventSource(_sources[i]); - } - - /* Fetching - -----------------------------------------------------------------------------*/ - - function isFetchNeeded(start, end) { - return !rangeStart || start < rangeStart || end > rangeEnd; - } - - function fetchEvents(start, end) { - rangeStart = start; - rangeEnd = end; - cache = []; - var fetchID = ++currentFetchID; - var len = sources.length; - pendingSourceCnt = len; - for (var i=0; i)), return null instead - return null; -} - -function parseISO8601(s, ignoreTimezone) { // ignoreTimezone defaults to false - // derived from http://delete.me.uk/2005/03/iso8601.html - // TODO: for a know glitch/feature, read tests/issue_206_parseDate_dst.html - var m = s.match(/^([0-9]{4})(-([0-9]{2})(-([0-9]{2})([T ]([0-9]{2}):([0-9]{2})(:([0-9]{2})(\.([0-9]+))?)?(Z|(([-+])([0-9]{2})(:?([0-9]{2}))?))?)?)?)?$/); - if (!m) { - return null; - } - var date = new Date(m[1], 0, 1); - if (ignoreTimezone || !m[13]) { - var check = new Date(m[1], 0, 1, 12, 0); - fixDate(date, check); - if (m[3]) { - date.setMonth(m[3] - 1); - check.setMonth(m[3] - 1); - } - if (m[5]) { - date.setDate(m[5]); - check.setDate(m[5]); - } - fixDate(date, check); - if (m[7]) { - date.setHours(m[7]); - } - if (m[8]) { - date.setMinutes(m[8]); - } - if (m[10]) { - date.setSeconds(m[10]); - } - if (m[12]) { - date.setMilliseconds(Number("0." + m[12]) * 1000); - } - fixDate(date, check); - }else{ - date.setUTCFullYear( - m[1], - m[3] ? m[3] - 1 : 0, - m[5] || 1 - ); - date.setUTCHours( - m[7] || 0, - m[8] || 0, - m[10] || 0, - m[12] ? Number("0." + m[12]) * 1000 : 0 - ); - if (m[14]) { - var offset = Number(m[16]) * 60 + (m[18] ? Number(m[18]) : 0); - offset *= m[15] == '-' ? 1 : -1; - date = new Date(+date + (offset * 60 * 1000)); - } - } - return date; -} - -function parseTime(s) { // returns minutes since start of day - if (typeof s == 'number') { // an hour - return s * 60; - } - if (typeof s == 'object') { // a Date object - return s.getHours() * 60 + s.getMinutes(); - } - var m = s.match(/(\d+)(?::(\d+))?\s*(\w+)?/); - if (m) { - var h = parseInt(m[1], 10); - if (m[3]) { - h %= 12; - if (m[3].toLowerCase().charAt(0) == 'p') { - h += 12; - } - } - return h * 60 + (m[2] ? parseInt(m[2], 10) : 0); - } -} - -/* Date Formatting ------------------------------------------------------------------------------*/ -// TODO: use same function formatDate(date, [date2], format, [options]) - -function formatDate(date, format, options) { - return formatDates(date, null, format, options); -} - -function formatDates(date1, date2, format, options) { - options = options || defaults; - var date = date1, - otherDate = date2, - i, len = format.length, c, - i2, formatter, - res = ''; - for (i=0; ii; i2--) { - if (formatter = dateFormatters[format.substring(i, i2)]) { - if (date) { - res += formatter(date, options); - } - i = i2 - 1; - break; - } - } - if (i2 == i) { - if (date) { - res += c; - } - } - } - } - return res; -}; - -var dateFormatters = { - s : function(d) {return d.getSeconds() }, - ss : function(d) {return zeroPad(d.getSeconds())}, - m : function(d) {return d.getMinutes()}, - mm : function(d) {return zeroPad(d.getMinutes())}, - h : function(d) {return d.getHours() % 12 || 12}, - hh : function(d) {return zeroPad(d.getHours() % 12 || 12)}, - H : function(d) {return d.getHours()}, - HH : function(d) {return zeroPad(d.getHours())}, - d : function(d) {return d.getDate()}, - dd : function(d) {return zeroPad(d.getDate())}, - ddd : function(d,o) {return o.dayNamesShort[d.getDay()]}, - dddd: function(d,o) {return o.dayNames[d.getDay()]}, - W : function(d) {return getWeekNumber(d)}, - M : function(d) {return d.getMonth() + 1}, - MM : function(d) {return zeroPad(d.getMonth() + 1)}, - MMM : function(d,o) {return o.monthNamesShort[d.getMonth()]}, - MMMM: function(d,o) {return o.monthNames[d.getMonth()]}, - yy : function(d) {return (d.getFullYear()+'').substring(2)}, - yyyy: function(d) {return d.getFullYear()}, - t : function(d) {return d.getHours() < 12 ? 'a' : 'p'}, - tt : function(d) {return d.getHours() < 12 ? 'am' : 'pm'}, - T : function(d) {return d.getHours() < 12 ? 'A' : 'P'}, - TT : function(d) {return d.getHours() < 12 ? 'AM' : 'PM'}, - u : function(d) {return formatDate(d, "yyyy-MM-dd'T'HH:mm:ss'Z'")}, - S : function(d) { - var date = d.getDate(); - if (date > 10 && date < 20) { - return 'th'; - } - return ['st', 'nd', 'rd'][date%10-1] || 'th'; - } -}; - -fc.applyAll = applyAll; - -/* Event Date Math ------------------------------------------------------------------------------*/ - -function exclEndDay(event) { - if (event.end) { - return _exclEndDay(event.end, event.allDay); - }else{ - return addDays(cloneDate(event.start), 1); - } -} - -function _exclEndDay(end, allDay) { - end = cloneDate(end); - return allDay || end.getHours() || end.getMinutes() ? addDays(end, 1) : clearTime(end); -} - -function segCmp(a, b) { - return (b.msLength - a.msLength) * 100 + (a.event.start - b.event.start); -} - -function segsCollide(seg1, seg2) { - return seg1.end > seg2.start && seg1.start < seg2.end; -} - -/* Event Sorting ------------------------------------------------------------------------------*/ - -// event rendering utilities -function sliceSegs(events, visEventEnds, start, end) { - var segs = [], - i, len=events.length, event, - eventStart, eventEnd, - segStart, segEnd, - isStart, isEnd; - for (i=0; i start && eventStart < end) { - if (eventStart < start) { - segStart = cloneDate(start); - isStart = false; - }else{ - segStart = eventStart; - isStart = true; - } - if (eventEnd > end) { - segEnd = cloneDate(end); - isEnd = false; - }else{ - segEnd = eventEnd; - isEnd = true; - } - segs.push({ - event: event, - start: segStart, - end: segEnd, - isStart: isStart, - isEnd: isEnd, - msLength: segEnd - segStart - }); - } - } - return segs.sort(segCmp); -} - -// event rendering calculation utilities -function stackSegs(segs) { - var levels = [], - i, len = segs.length, seg, - j, collide, k; - for (i=0; i=0; i--) { - res = obj[parts[i].toLowerCase()]; - if (res !== undefined) { - return res; - } - } - return obj['']; -} - -function htmlEscape(s) { - return s.replace(/&/g, '&') - .replace(//g, '>') - .replace(/'/g, ''') - .replace(/"/g, '"') - .replace(/\n/g, '
'); -} - -function cssKey(_element) { - return _element.id + '/' + _element.className + '/' + _element.style.cssText.replace(/(^|;)\s*(top|left|width|height)\s*:[^;]*/ig, ''); -} - -function disableTextSelection(element) { - element - .attr('unselectable', 'on') - .css('MozUserSelect', 'none') - .bind('selectstart.ui', function() { return false; }); -} - -/* -function enableTextSelection(element) { - element - .attr('unselectable', 'off') - .css('MozUserSelect', '') - .unbind('selectstart.ui'); -} -*/ - -function markFirstLast(e) { - e.children() - .removeClass('fc-first fc-last') - .filter(':first-child') - .addClass('fc-first') - .end() - .filter(':last-child') - .addClass('fc-last'); -} - -function setDayID(cell, date, opt) { - cell.each(function(i, _cell) { - _cell.className = _cell.className.replace(/^fc-\w*( fc-weekend-day)?/, 'fc-' + dayIDs[date.getDay()] + (opt('weekendDays').length>0 && opt('weekendDays').indexOf(date.getDay())!=-1 ? ' fc-weekend-day' : '')); - // TODO: make a way that doesn't rely on order of classes - }); -} - -function getSkinCss(event, opt) { - var source = event.source || {}; - var eventColor = event.color; - var sourceColor = source.color; - var optionColor = opt('eventColor'); - var backgroundColor = - event.backgroundColor || - eventColor || - source.backgroundColor || - sourceColor || - opt('eventBackgroundColor') || - optionColor; - var borderColor = - event.borderColor || - eventColor || - source.borderColor || - sourceColor || - opt('eventBorderColor') || - optionColor; - var textColor = - event.textColor || - source.textColor || - opt('eventTextColor'); - var statements = []; - if (backgroundColor) { - statements.push('background-color:' + backgroundColor); - } - if (borderColor) { - statements.push('border-color:' + borderColor); - } - if (textColor) { - statements.push('color:' + textColor); - } - return statements.join(';'); -} - -function applyAll(functions, thisObj, args) { - if ($.isFunction(functions)) { - functions = [ functions ]; - } - if (functions) { - var i; - var ret; - for (i=0; i0) - addDays(date, -(( - (Math.abs(Math.ceil(dayDiff(dateWeekStart, currentWeekStart) / 7)) % opt('multiWeekSize'))) % opt('multiWeekSize')) * 7); - - //var start = addDays(cloneDate(date), -((date.getDay() - opt('firstDay') + 7) % 7)); - var start = cloneDate(date); - //var end = addDays(cloneDate(start), opt('multiWeekSize') * 7); - //var visStart = cloneDate(start); - var visStart = addDays(cloneDate(date), -((date.getDay() - opt('firstDay') + 7) % 7)); - var end = addDays(cloneDate(visStart), opt('multiWeekSize') * 7); - var visEnd = cloneDate(end); - - var firstDay = opt('firstDay'); - var nwe = opt('weekends') ? 0 : 1; - if (nwe) { - skipWeekend(visStart); - skipWeekend(visEnd, -1, true); - } - - addDays(visStart, -((visStart.getDay() - Math.max(firstDay, nwe) + 7) % 7)); - addDays(visEnd, (7 - visEnd.getDay() + Math.max(firstDay, nwe)) % 7); - - t.title = formatDates( - visStart, - addDays(cloneDate(visEnd), -1), - opt('titleFormat') - ); - t.start = start; - t.end = end; - t.visStart = visStart; - t.visEnd = visEnd; - renderBasic(opt('multiWeekSize'), opt('multiWeekSize'), nwe ? 5 : 7, true); - } -} - -fcViews.basicWeek = BasicWeekView; - -function BasicWeekView(element, calendar) { - var t = this; - - // exports - t.render = render; - - // imports - BasicView.call(t, element, calendar, 'basicWeek'); - var opt = t.opt; - var renderBasic = t.renderBasic; - var formatDates = calendar.formatDates; - - function render(date, delta) { - if (delta) { - addDays(date, delta * 7); - } - var start = addDays(cloneDate(date), -((date.getDay() - opt('firstDay') + 7) % 7)); - var end = addDays(cloneDate(start), 7); - var visStart = cloneDate(start); - var visEnd = cloneDate(end); - var weekends = opt('weekends'); - if (!weekends) { - skipWeekend(visStart); - skipWeekend(visEnd, -1, true); - } - t.title = formatDates( - visStart, - addDays(cloneDate(visEnd), -1), - opt('titleFormat') - ); - t.start = start; - t.end = end; - t.visStart = visStart; - t.visEnd = visEnd; - renderBasic(1, 1, weekends ? 7 : 5, false); - } -} - -fcViews.basicDay = BasicDayView; - -//TODO: when calendar's date starts out on a weekend, shouldn't happen - -function BasicDayView(element, calendar) { - var t = this; - - // exports - t.render = render; - - // imports - BasicView.call(t, element, calendar, 'basicDay'); - var opt = t.opt; - var renderBasic = t.renderBasic; - var formatDate = calendar.formatDate; - - function render(date, delta) { - if (delta) { - addDays(date, delta); - if (!opt('weekends')) { - skipWeekend(date, delta < 0 ? -1 : 1); - } - } - t.title = formatDate(date, opt('titleFormat')); - t.start = t.visStart = cloneDate(date, true); - t.end = t.visEnd = addDays(cloneDate(t.start), 1); - renderBasic(1, 1, 1, false); - } -} - -setDefaults({ - weekMode: 'fixed' -}); - -function BasicView(element, calendar, viewName) { - var t = this; - - // exports - t.renderBasic = renderBasic; - t.setHeight = setHeight; - t.setWidth = setWidth; - t.renderDayOverlay = renderDayOverlay; - t.defaultSelectionEnd = defaultSelectionEnd; - t.renderSelection = renderSelection; - t.clearSelection = clearSelection; - t.reportDayClick = reportDayClick; // for selection (kinda hacky) - t.dragStart = dragStart; - t.dragStop = dragStop; - t.defaultEventEnd = defaultEventEnd; - t.getHoverListener = function() { return hoverListener }; - t.colContentLeft = colContentLeft; - t.colContentRight = colContentRight; - t.dayOfWeekCol = dayOfWeekCol; - t.dateCell = dateCell; - t.cellDate = cellDate; - t.cellIsAllDay = function() { return true }; - t.allDayRow = allDayRow; - t.allDayBounds = allDayBounds; - t.getRowCnt = function() { return rowCnt }; - t.getColCnt = function() { return colCnt }; - t.getColWidth = function() { return colWidth }; - t.getDaySegmentContainer = function() { return daySegmentContainer }; - t.updateGrid = updateGrid; - t.updateToday = updateToday; - t.setAxisFormat = setAxisFormat; - t.setStartOfBusiness = setStartOfBusiness; - t.setEndOfBusiness = setEndOfBusiness; - t.setWeekendDays = setWeekendDays; - t.setBindingMode = setBindingMode; - t.setSelectable = setSelectable; - - // imports - View.call(t, element, calendar, viewName); - OverlayManager.call(t); - SelectionManager.call(t); - BasicEventRenderer.call(t); - var opt = t.opt; - var trigger = t.trigger; - var clearEvents = t.clearEvents; - var renderOverlay = t.renderOverlay; - var clearOverlays = t.clearOverlays; - var daySelectionMousedown = t.daySelectionMousedown; - var formatDate = calendar.formatDate; - - // locals - var head; - var headCells; - var body; - var bodyRows; - var bodyCells; - var bodyFirstCells; - var bodyCellTopInners; - var daySegmentContainer; - - var viewWidth; - var viewHeight; - var colWidth; - - var rowCnt, colCnt; - var coordinateGrid; - var hoverListener; - var colContentPositions; - - var rtl, dis, dit; - var firstDay; - var nwe; - var tm; - var colFormat; - - /* Rendering - ------------------------------------------------------------*/ - - disableTextSelection(element.addClass('fc-grid')); - - function renderBasic(maxr, r, c, showNumbers) { - rowCnt = r; - colCnt = c; - updateOptions(); - var firstTime = !body; - if (firstTime) { - buildSkeleton(maxr, showNumbers); - }else{ - clearEvents(); - } - updateCells(true); - } - - function updateOptions() { - rtl = opt('isRTL'); - if (rtl) { - dis = -1; - dit = colCnt - 1; - }else{ - dis = 1; - dit = 0; - } - firstDay = opt('firstDay'); - nwe = opt('weekends') ? 0 : 1; - tm = opt('theme') ? 'ui' : 'fc'; - colFormat = opt('columnFormat'); - } - - function buildSkeleton(maxRowCnt, showNumbers) { - var s; - var headerClass = tm + "-widget-header"; - var contentClass = tm + "-widget-content"; - var i, j; - var table; - - s = - "" + - "" + - ""; - for (i=0; i"; // need fc- for setDayID - } - s += - "" + - "" + - ""; - for (i=0; i"; - for (j=0; j" + // need fc- for setDayID - "
" + - (showNumbers ? - "
" : - '' - ) + - "
" + - "
 
" + - "
" + - "
" + - ""; - } - s += - ""; - } - s += - "
" + - "
"; - table = $(s).appendTo(element); - - head = table.find('thead'); - headCells = head.find('th'); - body = table.find('tbody'); - bodyRows = body.find('tr'); - bodyCells = body.find('td'); - bodyFirstCells = bodyCells.filter(':first-child'); - bodyCellTopInners = bodyRows.eq(0).find('div.fc-day-content div'); - - markFirstLast(head.add(head.find('tr'))); // marks first+last tr/th's - markFirstLast(bodyRows); // marks first+last td's - bodyRows.eq(0).addClass('fc-first'); // fc-last is done in updateCells - - dayBind(bodyCells); - daySegmentContainer = - $("
") - .appendTo(element); - } - - function updateCells(firstTime) { - var dowDirty = firstTime || rowCnt == 1; // could the cells' day-of-weeks need updating? - var month = t.start.getMonth(); - var today = clearTime(new Date()); - var cell; - var date; - var row; - - if (dowDirty) { - headCells.each(function(i, _cell) { - cell = $(_cell); - date = indexDate(i); - cell.html(formatDate(date, colFormat)); - setDayID(cell, date, opt); - }); - } - - bodyCells.each(function(i, _cell) { - cell = $(_cell); - date = indexDate(i); - if (date.getMonth() == month) { - cell.removeClass('fc-other-month'); - }else{ - cell.addClass('fc-other-month'); - } - if(opt('showWeekNumbers') && (i % 7 == 0)) { - removeWeekNumber(cell, date); - addWeekNumber(cell, date); - } - if (+date == +today) { - cell.addClass(tm + '-state-highlight fc-today'); - removeTodayText(cell, opt('buttonText', 'today')); - addTodayText(cell, opt('buttonText', 'today')); - }else{ - cell.removeClass(tm + '-state-highlight fc-today'); - removeTodayText(cell, opt('buttonText', 'today')); - } - cell.find('div.fc-day-number').text(date.getDate()); - if (dowDirty) { - setDayID(cell, date, opt); - } - }); - - bodyRows.each(function(i, _row) { - row = $(_row); - if (i < rowCnt) { - row.show(); - if (i == rowCnt-1) { - row.addClass('fc-last'); - }else{ - row.removeClass('fc-last'); - } - }else{ - row.hide(); - } - }); - } - - function updateGrid() - { - updateToday(); - setAxisFormat(); - setStartOfBusiness(); - setEndOfBusiness(); - setWeekendDays(); - setBindingMode(); - setSelectable(); - } - - function updateToday() - { - var today = clearTime(new Date()); - var cell; - var date; - - bodyCells.each(function(i, _cell) { - cell = $(_cell); - date = indexDate(i); - - if (+date == +today) { - cell.addClass(tm + '-state-highlight fc-today'); - removeTodayText(cell, opt('buttonText', 'today')); - addTodayText(cell, opt('buttonText', 'today')); - }else{ - cell.removeClass(tm + '-state-highlight fc-today'); - removeTodayText(cell, opt('buttonText', 'today')); - } - }); - } - - function setAxisFormat() - { - // dummy - } - - function setStartOfBusiness() - { - // dummy - } - - function setEndOfBusiness() - { - // dummy - } - - function setWeekendDays() - { - headCells.each(function(i, _cell) { - setDayID($(_cell), indexDate(i), opt); - }); - - bodyCells.each(function(i, _cell) { - setDayID($(_cell), indexDate(i), opt); - }); - } - - function setBindingMode() - { - dayBind(bodyCells); - } - - function setSelectable() - { - dayBind(bodyCells); - } - - function setHeight(height) { - viewHeight = height; - var bodyHeight = viewHeight - head.height(); - var rowHeight; - var rowHeightLast; - var cell; - - if (opt('weekMode') == 'variable') { - rowHeight = rowHeightLast = Math.floor(bodyHeight / (rowCnt==1 ? 2 : 6)); - }else{ - rowHeight = Math.floor(bodyHeight / rowCnt); - rowHeightLast = bodyHeight - rowHeight * (rowCnt-1); - } - - bodyFirstCells.each(function(i, _cell) { - if (i < rowCnt) { - cell = $(_cell); - setMinHeight( - cell.find('> div'), - (i==rowCnt-1 ? rowHeightLast : rowHeight) - vsides(cell) - ); - } - }); - } - - function setWidth(width) { - viewWidth = width; - colContentPositions.clear(); - colWidth = Math.floor(viewWidth / colCnt); - setOuterWidth(headCells.slice(0, -1), colWidth); - } - - /* Day clicking and binding - -----------------------------------------------------------*/ - - function dayBind(days) { - days.unbind('click dblclick'); - if(opt('bindingMode') == 'double') - days.dblclick(dayClick).mousedown(daySelectionMousedown); - else - days.click(dayClick).mousedown(daySelectionMousedown); - } - - function dayClick(ev) { - //if (!opt('selectable')) { // if selectable, SelectionManager will worry about dayClick - var index = parseInt(this.className.match(/fc\-day(\d+)/)[1]); // TODO: maybe use .data - var date = indexDate(index); - trigger('dayClick', this, date, true, ev); - //} - } - - /* Semi-transparent Overlay Helpers - ------------------------------------------------------*/ - - function renderDayOverlay(overlayStart, overlayEnd, refreshCoordinateGrid) { // overlayEnd is exclusive - if (refreshCoordinateGrid) { - coordinateGrid.build(); - } - var rowStart = cloneDate(t.visStart); - var rowEnd = addDays(cloneDate(rowStart), colCnt); - for (var i=0; i" + - "
 
  
"; - dayTable = $(s).appendTo(element); - dayHead = dayTable.find('thead'); - dayHeadCells = dayHead.find('th').slice(1, -1); - dayBody = dayTable.find('tbody'); - dayBodyCells = dayBody.find('td').slice(0, -1); - dayBodyCellInners = dayBodyCells.find('div.fc-day-content div'); - dayBodyFirstCell = dayBodyCells.eq(0); - dayBodyFirstCellStretcher = dayBodyFirstCell.find('> div'); - - markFirstLast(dayHead.add(dayHead.find('tr'))); - markFirstLast(dayBody.add(dayBody.find('tr'))); - - axisFirstCells = dayHead.find('th:first'); - gutterCells = dayTable.find('.fc-agenda-gutter'); - - slotLayer = - $("
") - .appendTo(element); - - if(opt('allDaySlot')) { - dayScroller = $("
").appendTo(slotLayer); - dayContent = $("
").appendTo(dayScroller); - daySegmentContainer = $("
").appendTo(dayContent); - - s = - "" + - "" + - "" + - "" + - "" + - "
" + opt('allDayText') + "" + - "
" + - "
"; - - allDayTable = $(s).appendTo(dayScroller); - allDayRow = allDayTable.find('tr'); - dayBind(allDayRow.find('td')); - axisFirstCells = axisFirstCells.add(allDayTable.find('th:first')); - gutterCells = gutterCells.add(allDayTable.find('th.fc-agenda-gutter')); - - divider = $( - "
" + - "
" + - "
" - ).appendTo(slotLayer); - - }else{ - daySegmentContainer = $([]); // in jQuery 1.4, we can just do $() - } - - slotJumpersTopContainer = $("
").appendTo(slotLayer); - slotJumpersBottomContainer = $("
").appendTo(slotLayer); - slotScroller = $("
").appendTo(slotLayer); - slotContent = $("
").appendTo(slotScroller); - slotSegmentContainer = $("
").appendTo(slotContent); - - for (i=0; i')); - slotJumpersBottomContainer.append($('
')); - } - slotJumpersTop = slotJumpersTopContainer.children(); - slotJumpersBottom = slotJumpersBottomContainer.children(); - - s = - "" + - ""; - d = zeroDate(); - maxd = addMinutes(cloneDate(d), maxMinute); - addMinutes(d, minMinute); - slotCnt = 0; - - var startOfBusiness = opt("startOfBusiness") * (60/opt("slotMinutes")); - var endOfBusiness = (opt("endOfBusiness") - (opt("slotMinutes")/60)) * (60/opt("slotMinutes")); - for (i=0; d < maxd; i++) { - minutes = d.getMinutes(); - var nonBusinessHours = (i < startOfBusiness || i > endOfBusiness) ? " fc-non-business-hours" : ""; - s += - "" + - "" + - "" + - ""; - addMinutes(d, opt('slotMinutes')); - slotCnt++; - } - s += - "" + - "
" + - ((!slotNormal || !minutes) ? formatDate(d, opt('axisFormat')) : ' ') + - "" + - "
 
" + - "
"; - slotTable = $(s).appendTo(slotContent); - slotTableFirstInner = slotTable.find('div:first'); - slotBind(slotTable.find('td')); - axisFirstCells = axisFirstCells.add(slotTable.find('th:first')); - } - - function updateCells() { - var i; - var headCell; - var bodyCell; - var axisCell; - var date; - var today = clearTime(new Date()); - axisCell = axisFirstCells[0]; - - if(opt('showWeekNumbers')) { - removeWeekNumber($(axisCell), colDate(0)); - addWeekNumber($(axisCell), colDate(0)); - } - for (i=0; i endOfBusiness) - $(element).addClass('fc-non-business-hours'); - else - $(element).removeClass('fc-non-business-hours'); - }); - } - - function setWeekendDays() - { - dayHeadCells.each(function(i, _cell) { - setDayID($(_cell), colDate(i), opt); - }); - - dayBodyCells.each(function(i, _cell) { - setDayID($(_cell), colDate(i), opt); - }); - } - - function setBindingMode() - { - dayBind(allDayRow.find('td')); - slotBind(slotTable.find('td')); - } - - function setSelectable() - { - dayBind(allDayRow.find('td')); - slotBind(slotTable.find('td')); - } - - function setHeight(height, dateChanged) { - if (height === undefined) { - height = viewHeight; - } - viewHeight = height; - slotTopCache = {}; - - var headHeight = dayBody.position().top; - var allDayHeight = opt('allDaySlot') ? 4 : 0; //if divider is present - var bodyHeight = Math.min( // total body height, including borders - height - headHeight, // when scrollbars - slotTable.height() + allDayHeight + 1 // when no scrollbars. +1 for bottom border - ); - - var maxAllDayHeight = Math.floor((bodyHeight - allDayHeight - 1) / 3); - dayScroller.css('max-height', maxAllDayHeight + 3); - allDayRow.find('div:first').children().css('max-height', maxAllDayHeight); - - allDayHeight = allDayTable.height(); - if(opt('allDaySlot')) { - divider.css('position', 'relative'); - divider.css('top', allDayHeight); - slotScroller.css('top', allDayHeight + 4); - } - - //allDayHeight = slotScroller.position().top; // including divider - bodyHeight = Math.min( // total body height, including borders - height - headHeight, // when scrollbars - slotTable.height() + allDayHeight + 1 // when no scrollbars. +1 for bottom border - ); - - dayBodyFirstCellStretcher - .height(bodyHeight - vsides(dayBodyFirstCell)); - - var slotScrollerHeight = bodyHeight - allDayHeight - 1 - (opt('allDaySlot') ? 4 : 0); - slotLayer.css('top', headHeight); - slotScroller.height(slotScrollerHeight); - slotHeight = slotTableFirstInner.height() + 1; // +1 for border - - slotJumpersTopContainer.css('top', allDayHeight+1); - slotJumpersBottomContainer.css('top', slotScrollerHeight + allDayHeight + 1 - slotJumpersBottom.first().height()); - - if (dateChanged) { - resetScroll(); - } - - if(t.addedView) { - t.addedView.setHeight(height, dateChanged); - } - } - - function setWidth(width) { - if (width === undefined) { - width = viewWidth; - } - viewWidth = width; - if(t.addedView) { - var outerWidth = Math.floor(element.parent().width() / 2); - element.css({'width' : outerWidth}); - viewWidth = outerWidth; - } - colContentPositions.clear(); - - axisWidth = 0; - setOuterWidth( - axisFirstCells - .width('') - .each(function(i, _cell) { - axisWidth = Math.max(axisWidth, $(_cell).outerWidth()); - }), - axisWidth - ); - - var slotTableWidth = slotScroller[0].clientWidth; // needs to be done after axisWidth (for IE7) - //slotTable.width(slotTableWidth); - - //var oldGutterWidth = gutterWidth; - gutterWidth = slotScroller.width() - slotTableWidth || dayScroller.width() - dayContent.width(); - if (gutterWidth) { - /*if(!gutterAck) { - viewWidth -= gutterWidth; - gutterAck = true; - }*/ - setOuterWidth(gutterCells, gutterWidth); - gutterCells - .show() - .prev() - .removeClass('fc-last'); - }else{ - /*if(gutterAck) { - viewWidth += oldGutterWidth; - gutterAck = false; - }*/ - gutterCells - .hide() - .prev() - .addClass('fc-last'); - } - - colWidth = Math.floor((slotTableWidth - axisWidth) / colCnt); - setOuterWidth(dayHeadCells.slice(0, -1), colWidth); - - slotJumpersTop.each(function(i,e){ - var jumper=$(e); - jumper.css('left',axisWidth + (colWidth*(i+1)) - 1 - jumper.width()); - }); - slotJumpersBottom.each(function(i,e){ - var jumper=$(e); - jumper.css('left',axisWidth + (colWidth*(i+1)) - 1 - jumper.width()); - }); - - if(t.addedView) { - t.addedView.setWidth(outerWidth); - } - } - - function resetScroll() { - var d0 = zeroDate(); - var scrollDate = cloneDate(d0); - scrollDate.setHours(opt('firstHour')); - var top = timePosition(d0, scrollDate) + 1; // +1 for the border - function scroll() { - slotScroller.scrollTop(top); - } - scroll(); - setTimeout(scroll, 0); // overrides any previous scroll state made by the browser - } - - function beforeHide() { - savedScrollTop = slotScroller.scrollTop(); - } - - function afterShow() { - slotScroller.scrollTop(savedScrollTop); - } - - /* Slot/Day clicking and binding - -----------------------------------------------------------------------*/ - - function dayBind(cells) { - cells.unbind('click dblclick'); - if(opt('bindingMode') == 'double') - cells.dblclick(daySlotClick).mousedown(daySelectionMousedown); - else - cells.click(daySlotClick).mousedown(daySelectionMousedown); - } - - function slotBind(cells) { - cells.unbind('click dblclick'); - if(opt('bindingMode') == 'double') - cells.dblclick(slotClick).mousedown(slotSelectionMousedown); - else - cells.click(slotClick).mousedown(slotSelectionMousedown); - } - - function daySlotClick(ev) { - var col = Math.min(colCnt-1, Math.floor((ev.pageX - dayTable.offset().left - axisWidth) / colWidth)); - var date = colDate(col); - trigger('dayClick', dayBodyCells[col], date, true, ev); - } - - function slotClick(ev) { - //if (!opt('selectable')) { // if selectable, SelectionManager will worry about dayClick - var col = Math.min(colCnt-1, Math.floor((ev.pageX - dayTable.offset().left - axisWidth) / colWidth)); - var date = colDate(col); - var rowMatch = this.parentNode.className.match(/fc-slot(\d+)/); // TODO: maybe use data - if (rowMatch) { - var mins = parseInt(rowMatch[1]) * opt('slotMinutes'); - var hours = Math.floor(mins/60); - date.setHours(hours); - date.setMinutes(mins%60 + minMinute); - trigger('dayClick', dayBodyCells[col], date, false, ev); - }else{ - trigger('dayClick', dayBodyCells[col], date, true, ev); - } - //} - } - - /* Semi-transparent Overlay Helpers - -----------------------------------------------------*/ - - function renderDayOverlay(startDate, endDate, refreshCoordinateGrid) { // endDate is exclusive - if (refreshCoordinateGrid) { - coordinateGrid.build(); - } - var visStart = cloneDate(t.visStart); - var startCol, endCol; - if (rtl) { - startCol = dayDiff(endDate, visStart)*dis+dit+1; - endCol = dayDiff(startDate, visStart)*dis+dit+1; - }else{ - startCol = dayDiff(startDate, visStart); - endCol = dayDiff(endDate, visStart); - } - startCol = Math.max(0, startCol); - endCol = Math.min(colCnt, endCol); - if (startCol < endCol) { - dayBind( - renderCellOverlay(0, startCol, 0, endCol-1) - ); - } - } - - function renderCellOverlay(row0, col0, row1, col1) { // only for all-day? - var rect = coordinateGrid.rect(row0, col0, row1, col1, slotLayer); - return renderOverlay(rect, slotLayer); - } - - function renderSlotOverlay(overlayStart, overlayEnd) { - var dayStart = cloneDate(t.visStart); - var dayEnd = addDays(cloneDate(dayStart), 1); - for (var i=0; i= 0) { - addMinutes(d, minMinute + slotIndex * opt('slotMinutes')); - } - return d; - } - - function colDate(col) { // returns dates with 00:00:00 - return addDays(cloneDate(t.visStart), col*dis+dit); - } - - function cellIsAllDay(cell) { - return opt('allDaySlot') && !cell.row; - } - - function dayOfWeekCol(dayOfWeek) { - return ((dayOfWeek - Math.max(firstDay, nwe) + colCnt) % colCnt)*dis+dit; - } - - // get the Y coordinate of the given time on the given day (both Date objects) - function timePosition(day, time) { // both date objects. day holds 00:00 of current day - day = cloneDate(day, true); - if (time < addMinutes(cloneDate(day), minMinute)) { - return 0; - } - if (time >= addMinutes(cloneDate(day), maxMinute)) { - return slotTable.height(); - } - var slotMinutes = opt('slotMinutes'), - minutes = time.getHours()*60 + time.getMinutes() - minMinute, - slotI = Math.floor(minutes / slotMinutes), - slotTop = slotTopCache[slotI]; - if (slotTop === undefined) { - slotTop = slotTopCache[slotI] = slotTable.find('tr:eq(' + slotI + ') td div')[0].offsetTop; //.position().top; // need this optimization??? - } - return Math.max(0, Math.round( - slotTop - 1 + slotHeight * ((minutes % slotMinutes) / slotMinutes) - )); - } - - function allDayBounds() { - return { - left: axisWidth, - right: viewWidth - gutterWidth - } - } - - function getAllDayRow(index) { - return allDayRow; - } - - function defaultEventEnd(event) { - var start = cloneDate(event.start); - if (event.allDay) { - return start; - } - return addMinutes(start, opt('defaultEventMinutes')); - } - - /* Selection - ---------------------------------------------------------------------------------*/ - - function defaultSelectionEnd(startDate, allDay) { - if (allDay) { - return cloneDate(startDate); - } - return addMinutes(cloneDate(startDate), opt('slotMinutes')); - } - - function renderSelection(startDate, endDate, allDay) { // only for all-day - if (allDay) { - if (opt('allDaySlot')) { - renderDayOverlay(startDate, addDays(cloneDate(endDate), 1), true); - } - }else{ - renderSlotSelection(startDate, endDate); - } - } - - function renderSlotSelection(startDate, endDate) { - var helperOption = opt('selectHelper'); - coordinateGrid.build(); - if (helperOption) { - var col = dayDiff(startDate, t.visStart) * dis + dit; - if (col >= 0 && col < colCnt) { // only works when times are on same day - var rect = coordinateGrid.rect(0, col, 0, col, slotContent); // only for horizontal coords - var top = timePosition(startDate, startDate); - var bottom = timePosition(startDate, endDate); - if (bottom > top) { // protect against selections that are entirely before or after visible range - rect.top = top; - rect.height = bottom - top; - rect.left += 2; - rect.width -= 5; - if ($.isFunction(helperOption)) { - var helperRes = helperOption(startDate, endDate); - if (helperRes) { - rect.position = 'absolute'; - rect.zIndex = 8; - selectionHelper = $(helperRes) - .css(rect) - .appendTo(slotContent); - } - }else{ - rect.isStart = true; // conside rect a "seg" now - rect.isEnd = true; // - selectionHelper = $(slotSegHtml( - { - title: '', - start: startDate, - end: endDate, - className: ['fc-select-helper'], - editable: false - }, - rect - )); - selectionHelper.css('opacity', opt('dragOpacity')); - } - if (selectionHelper) { - slotBind(selectionHelper); - slotContent.append(selectionHelper); - setOuterWidth(selectionHelper, rect.width, true); // needs to be after appended - setOuterHeight(selectionHelper, rect.height, true); - } - } - } - }else{ - renderSlotOverlay(startDate, endDate); - } - } - - function clearSelection() { - clearOverlays(); - if (selectionHelper) { - selectionHelper.remove(); - selectionHelper = null; - } - } - - function slotSelectionMousedown(ev) { - if (ev.which == 1 && opt('selectable')) { // ev.which==1 means left mouse button - unselect(ev); - var dates; - hoverListener.start(function(cell, origCell) { - clearSelection(); - if (cell && (cell.col == origCell.col || !opt('selectHelper')) && !cellIsAllDay(cell)) { - var d1 = cellDate(origCell); - var d2 = cellDate(cell); - dates = [ - d1, - addMinutes(cloneDate(d1), opt('slotMinutes')), - d2, - addMinutes(cloneDate(d2), opt('slotMinutes')) - ].sort(cmp); - renderSlotSelection(dates[0], dates[3]); - }else{ - dates = null; - } - }, ev); - $(document).one('mouseup', function(ev) { - hoverListener.stop(); - if (dates) { - if (+dates[0] == +dates[1]) { - //reportDayClick(dates[0], false, ev); - } - reportSelection(dates[0], dates[3], false, ev); - } - }); - } - } - - function reportDayClick(date, allDay, ev) { - trigger('dayClick', dayBodyCells[dayOfWeekCol(date.getDay())], date, allDay, ev); - } - - /* External Dragging - --------------------------------------------------------------------------------*/ - - function dragStart(_dragElement, ev, ui) { - hoverListener.start(function(cell) { - clearOverlays(); - if (cell) { - if (cellIsAllDay(cell)) { - renderCellOverlay(cell.row, cell.col, cell.row, cell.col); - }else{ - var d1 = cellDate(cell); - var d2 = addMinutes(cloneDate(d1), opt('defaultEventMinutes')); - renderSlotOverlay(d1, d2); - } - } - }, ev); - } - - function dragStop(_dragElement, ev, ui) { - var cell = hoverListener.stop(); - clearOverlays(); - if (cell) { - trigger('drop', _dragElement, cellDate(cell), cellIsAllDay(cell), ev, ui); - } - } - -} - -function AgendaEventRenderer() { - var t = this; - - // exports - t.renderEvents = renderEvents; - t.compileDaySegs = compileDaySegs; // for DayEventRenderer - t.clearEvents = clearEvents; - t.slotSegHtml = slotSegHtml; - t.bindDaySeg = bindDaySeg; - t.setTimeIndicator = setTimeIndicator; - - // imports - DayEventRenderer.call(t); - var opt = t.opt; - var trigger = t.trigger; - //var setOverflowHidden = t.setOverflowHidden; - var isEventDraggable = t.isEventDraggable; - var isEventResizable = t.isEventResizable; - var eventEnd = t.eventEnd; - var reportEvents = t.reportEvents; - var reportEventClear = t.reportEventClear; - var eventElementHandlers = t.eventElementHandlers; - var setHeight = t.setHeight; - var setWidth = t.setWidth; - var getDaySegmentContainer = t.getDaySegmentContainer; - var getSlotJumpersTop = t.getSlotJumpersTop; - var getSlotJumpersBottom = t.getSlotJumpersBottom; - var getslotScroller = t.getslotScroller; - var getSlotContent = t.getSlotContent; - var getSlotSegmentContainer = t.getSlotSegmentContainer; - var getHoverListener = t.getHoverListener; - var getMaxMinute = t.getMaxMinute; - var getMinMinute = t.getMinMinute; - var timePosition = t.timePosition; - var colContentLeft = t.colContentLeft; - var colContentRight = t.colContentRight; - var renderDaySegs = t.renderDaySegs; - var resizableDayEvent = t.resizableDayEvent; // TODO: streamline binding architecture - var getColCnt = t.getColCnt; - var getColWidth = t.getColWidth; - var getSlotHeight = t.getSlotHeight; - var getBodyContent = t.getBodyContent; - var reportEventElement = t.reportEventElement; - var showEvents = t.showEvents; - var hideEvents = t.hideEvents; - var eventDrop = t.eventDrop; - var eventResize = t.eventResize; - var renderDayOverlay = t.renderDayOverlay; - var renderSlotSelection = t.renderSlotSelection; - var clearOverlays = t.clearOverlays; - var calendar = t.calendar; - var formatDate = calendar.formatDate; - var formatDates = calendar.formatDates; - var timeLineInterval; - - /* Rendering - ----------------------------------------------------------------------------*/ - - // draw a horizontal line indicating the current time (#143) - function setTimeIndicator() - { - var container = getBodyContent(); - var timeline = container.children('.fc-timeline'); - var arrow = container.children('.fc-timeline-arrow'); - if (timeline.length == 0 || arrow.length == 0) { // if timeline isn't there, add it - timeline = $('
').addClass('fc-timeline').appendTo(container); - arrow = $('
').addClass('fc-timeline-arrow').appendTo(container); - } - - var cur_time = new Date(); - var daycol = $('.fc-today', t.element); - if (daycol.length > 0) { - timeline.show(); - arrow.show(); - } - else { - timeline.hide(); - arrow.hide(); - return; - } - - var secs = (cur_time.getHours() * 60 * 60) + (cur_time.getMinutes() * 60) + cur_time.getSeconds(); - var percents = secs / 86400; // 24 * 60 * 60 = 86400, # of seconds in a day - - timeline.css('top', Math.floor(container.height() * percents - 1) + 'px'); - arrow.css('top', Math.floor(container.height() * percents - 1) - 5 + 'px'); - - var left = daycol.position().left; - var width = daycol.width(); - timeline.css({ left: left + 'px', width: width + 'px' }); - } - - function renderEvents(events, modifiedEventId) { - reportEvents(events); - var i, len=events.length, - dayEvents=[], - slotEvents=[]; - for (i=0; i=currentPosition+slotScroller.height()-jumperReserve) - $(slotJumpersBottom[i]).css('display',''); - else - $(slotJumpersBottom[i]).css('display','none'); - } - }).trigger('scroll'); - slotJumpersTop.each(function(i, jumper){ - $(jumper).unbind('click').click(function(){ - var targetTop=0; - var currentPosition = slotScroller.scrollTop(); - $.each(colBoundaries[i].positions,function(ei,ee){ - if(ee.bottom<=currentPosition+jumperReserve) - targetTop=ee.top; - return ee.top=currentPosition+slotScroller.height()-jumperReserve) - { - targetPosition = ee; - return false; - } - }); - slotScroller.scrollTop( - targetPosition.bottom-targetPosition.top+t.getSlotHeight()>slotScroller.height()? - targetPosition.top-t.getSlotHeight(): - targetPosition.bottom-slotScroller.height()+t.getSlotHeight()+1 // +1 is a magic independent constant, used just to make the default scroll position look better - ); - }); - }); - - for (i=0; i" + - "
" + - "
" + - "
" + - htmlEscape(formatDates(event.start, event.end, opt('timeFormat'))) + - "
" + - "
" + - "
" + - "
" + - htmlEscape(event.title) + - "
" + - "
" + - "
" + - "
"; // close inner - if (seg.isEnd && isEventResizable(event)) { - html += - "
=
"; - } - html += - ""; - return html; - } - - function bindDaySeg(event, eventElement, seg) { - if (isEventDraggable(event)) { - draggableDayEvent(event, eventElement, seg.isStart); - } - if (seg.isEnd && isEventResizable(event)) { - resizableDayEvent(event, eventElement, seg); - } - eventElementHandlers(event, eventElement); - // needs to be after, because resizableDayEvent might stopImmediatePropagation on click - } - - function bindSlotSeg(event, eventElement, seg) { - var timeElement = eventElement.find('div.fc-event-time'); - if (isEventDraggable(event)) { - draggableSlotEvent(event, eventElement, timeElement); - } - if (seg.isEnd && isEventResizable(event)) { - resizableSlotEvent(event, eventElement, timeElement); - } - eventElementHandlers(event, eventElement); - } - - /* Dragging - -----------------------------------------------------------------------------------*/ - - // when event starts out FULL-DAY - - function draggableDayEvent(event, eventElement, isStart) { - var origWidth; - var revert; - var allDay=true; - var dayDelta; - var dis = opt('isRTL') ? -1 : 1; - var hoverListener = getHoverListener(); - var colWidth = getColWidth(); - var slotHeight = getSlotHeight(); - var minMinute = getMinMinute(); - eventElement.draggable({ - zIndex: 9, - scroll: false, - opacity: opt('dragOpacity', 'month'), // use whatever the month view was using - revertDuration: opt('dragRevertDuration'), - start: function(ev, ui) { - trigger('eventDragStart', eventElement, event, ev, ui); - //hideEvents(event, eventElement); - origWidth = eventElement.width(); - hoverListener.start(function(cell, origCell, rowDelta, colDelta) { - clearOverlays(); - if (cell) { - //setOverflowHidden(true); - revert = false; - dayDelta = colDelta * dis; - if (!cell.row) { - // on full-days - renderDayOverlay( - addDays(cloneDate(event.start), dayDelta), - addDays(exclEndDay(event), dayDelta) - ); - resetElement(); - }else{ - // mouse is over bottom slots - if (isStart) { - if (allDay) { - // convert event to temporary slot-event - eventElement.width(colWidth - 10); // don't use entire width - setOuterHeight( - eventElement, - slotHeight * Math.round( - (event.end ? ((event.end - event.start) / MINUTE_MS) : opt('defaultEventMinutes')) - / opt('slotMinutes') - ) - ); - eventElement.draggable('option', 'grid', [colWidth, 1]); - allDay = false; - } - else{ - var cellDate = t.cellDate; - if (cell && (cell.col == origCell.col || !opt('selectHelper'))) { - var d1 = cellDate(cell); - var duration = event.end ? minDiff(event.end, event.start) : opt('defaultEventMinutes'); - var d2 = addMinutes(cloneDate(d1, false), duration); - dates = [d1, d2].sort(cmp); - renderSlotSelection(dates[0], dates[1]); - } - } - - }else{ - revert = true; - } - } - revert = revert || (allDay && !dayDelta); - }else{ - resetElement(); - //setOverflowHidden(false); - revert = true; - } - eventElement.draggable('option', 'revert', revert); - }, ev, 'drag'); - }, - stop: function(ev, ui) { - hoverListener.stop(); - clearOverlays(); - trigger('eventDragStop', eventElement, event, ev, ui); - if (revert) { - // hasn't moved or is out of bounds (draggable has already reverted) - resetElement(); - eventElement.css('filter', ''); // clear IE opacity side-effects - //showEvents(event, eventElement); - }else{ - // changed! - var minuteDelta = 0; - if (!allDay) { - minuteDelta = Math.round((eventElement.offset().top - getBodyContent().offset().top) / slotHeight) - * opt('slotMinutes') - + minMinute - - (event.start.getHours() * 60 + event.start.getMinutes()); - } - eventDrop(this, event, dayDelta, minuteDelta, allDay, ev, ui); - } - //setOverflowHidden(false); - } - }); - function resetElement() { - if (!allDay) { - eventElement - .width(origWidth) - .height('') - .draggable('option', 'grid', null); - allDay = true; - } - } - } - - // when event starts out IN TIMESLOTS - - function draggableSlotEvent(event, eventElement, timeElement) { - var origPosition; - var allDay=false; - var dayDelta; - var minuteDelta; - var prevMinuteDelta; - var dis = opt('isRTL') ? -1 : 1; - var hoverListener = getHoverListener(); - var colCnt = getColCnt(); - var colWidth = getColWidth(); - var slotHeight = getSlotHeight(); - eventElement.draggable({ - zIndex: 9, - scroll: false, - grid: [colWidth, slotHeight], - axis: colCnt==1 ? 'y' : false, - opacity: opt('dragOpacity'), - revertDuration: opt('dragRevertDuration'), - start: function(ev, ui) { - trigger('eventDragStart', eventElement, event, ev, ui); - //hideEvents(event, eventElement); - origPosition = eventElement.position(); - minuteDelta = prevMinuteDelta = 0; - hoverListener.start(function(cell, origCell, rowDelta, colDelta) { - eventElement.draggable('option', 'revert', !cell); - clearOverlays(); - if (cell) { - dayDelta = colDelta * dis; - if (opt('allDaySlot') && !cell.row) { - // over full days - if (!allDay) { - // convert to temporary all-day event - allDay = true; - timeElement.hide(); - eventElement.draggable('option', 'grid', null); - } - renderDayOverlay( - addDays(cloneDate(event.start), dayDelta), - addDays(exclEndDay(event), dayDelta) - ); - }else{ - // on slots - resetElement(); - } - } - }, ev, 'drag'); - }, - drag: function(ev, ui) { - ui.position.left = origPosition.left + (dayDelta * dis) * colWidth; - minuteDelta = Math.round((ui.position.top - origPosition.top) / slotHeight) * opt('slotMinutes'); - if (minuteDelta != prevMinuteDelta) { - if (!allDay) { - updateTimeText(minuteDelta); - } - prevMinuteDelta = minuteDelta; - } - }, - stop: function(ev, ui) { - var cell = hoverListener.stop(); - clearOverlays(); - trigger('eventDragStop', eventElement, event, ev, ui); - if (cell && (dayDelta || minuteDelta || allDay)) { - // changed! - eventDrop(this, event, dayDelta, allDay ? 0 : minuteDelta, allDay, ev, ui); - }else{ - // either no change or out-of-bounds (draggable has already reverted) - resetElement(); - eventElement.css('filter', ''); // clear IE opacity side-effects - eventElement.css(origPosition); // sometimes fast drags make event revert to wrong position - updateTimeText(0); - //showEvents(event, eventElement); - } - } - }); - function updateTimeText(minuteDelta) { - var newStart = addMinutes(cloneDate(event.start), minuteDelta); - var newEnd; - if (event.end) { - newEnd = addMinutes(cloneDate(event.end), minuteDelta); - } - timeElement.text(formatDates(newStart, newEnd, opt('timeFormat'))); - } - function resetElement() { - // convert back to original slot-event - if (allDay) { - timeElement.css('display', ''); // show() was causing display=inline - eventElement.draggable('option', 'grid', [colWidth, slotHeight]); - allDay = false; - } - } - } - - /* Resizing - --------------------------------------------------------------------------------------*/ - - function resizableSlotEvent(event, eventElement, timeElement) { - var slotDelta, prevSlotDelta; - var slotHeight = getSlotHeight(); - eventElement.resizable({ - handles: { - s: 'div.ui-resizable-s' - }, - grid: slotHeight, - start: function(ev, ui) { - slotDelta = prevSlotDelta = 0; - //hideEvents(event, eventElement); - eventElement.css('z-index', 9); - trigger('eventResizeStart', this, event, ev, ui); - }, - resize: function(ev, ui) { - // don't rely on ui.size.height, doesn't take grid into account - slotDelta = Math.round((Math.max(slotHeight, eventElement.height()) - ui.originalSize.height) / slotHeight); - if (slotDelta != prevSlotDelta) { - timeElement.text( - formatDates( - event.start, - (!slotDelta && !event.end) ? null : // no change, so don't display time range - addMinutes(eventEnd(event), opt('slotMinutes')*slotDelta), - opt('timeFormat') - ) - ); - prevSlotDelta = slotDelta; - } - }, - stop: function(ev, ui) { - trigger('eventResizeStop', this, event, ev, ui); - - var minutesDelta = opt('slotMinutes')*slotDelta; - if(event.end===null) { - minutesDelta+=opt('defaultEventMinutes'); - } - - if (slotDelta) { - eventResize(this, event, 0, minutesDelta, ev, ui); - }else{ - eventElement.css('z-index', 8); - //showEvents(event, eventElement); - // BUG: if event was really short, need to put title back in span - } - } - }); - } -} - -function countForwardSegs(levels) { - var i, j, k, level, segForward, segBack; - for (i=levels.length-1; i>0; i--) { - level = levels[i]; - for (j=0; jt.getDaySegmentContainer().parent().height()) - { - var top=t.getDaySegmentContainer().parent().scrollTop(); - t.getDaySegmentContainer().parent().scrollTop(top+offset-(t.getDaySegmentContainer().parent().height()*0.2)); - } - - // Force event click callback, although its not pretty - if(!noClick) { - eventElement.trigger('mouseover').trigger('click'); - } - } - - function showEvents(event, exceptElement) { - eachEventElement(event, exceptElement, 'show'); - } - - function hideEvents(event, exceptElement) { - eachEventElement(event, exceptElement, 'hide'); - } - - function eachEventElement(event, exceptElement, funcName) { - event[funcName](); -// var elements = eventElementsByID[event._id], -// i, len = elements.length; -// for (i=0; i"); - var elements; - var segmentContainer = getDaySegmentContainer(); - var i; - var segCnt = segs.length; - var element; - tempContainer[0].innerHTML = daySegHTML(segs); // faster than .html() - elements = tempContainer.children(); - segmentContainer.append(elements); - daySegElementResolve(segs, elements); - daySegCalcHSides(segs); - daySegSetWidths(segs); - daySegCalcHeights(segs); - daySegSetTops(segs, getRowTops(getRowDivs())); - elements = []; - for (i=0; i" + - ""; - if (opt('dayEventSizeStrict')) { - html += "
"; - } - if (!event.allDay && seg.isStart && opt('timeFormat')) { - html += - "" + - htmlEscape(formatDates(event.start, event.end, opt('timeFormat'))) + - ""; - } - html += "" + htmlEscape(event.title.replace(/(\r\n|\n|\r)+/gm," ")) + ""; - if (opt('dayEventSizeStrict')) { - html += "
"; - } - html += "
"; - if (seg.isEnd && isEventResizable(event)) { - html += - "
" + - "   " + // makes hit area a lot better for IE6/7 - "
"; - } - html += - "
" + - ""; - seg.left = left; - seg.outerWidth = right - left; - seg.startCol = leftCol; - seg.endCol = rightCol + 1; // needs to be exclusive - } - return html; - } - - function daySegElementResolve(segs, elements) { // sets seg.element - var i; - var segCnt = segs.length; - var seg; - var event; - var element; - var triggerRes; - for (i=0; i div'); // optimal selector? - } - return rowDivs; - } - - - function getRowTops(rowDivs) { - var i; - var rowCnt = rowDivs.length; - var tops = []; - for (i=0; i selection for IE - element - .mousedown(function(ev) { // prevent native selection for others - ev.preventDefault(); - }) - .click(function(ev) { - if (isResizing) { - ev.preventDefault(); // prevent link from being visited (only method that worked in IE6) - ev.stopImmediatePropagation(); // prevent fullcalendar eventClick handler from being called - // (eventElementHandlers needs to be bound after resizableDayEvent) - } - }); - - handle.mousedown(function(ev) { - if (ev.which != 1) { - return; // needs to be left mouse button - } - isResizing = true; - var hoverListener = t.getHoverListener(); - var rowCnt = getRowCnt(); - var colCnt = getColCnt(); - var dis = rtl ? -1 : 1; - var dit = rtl ? colCnt-1 : 0; - var elementTop = element.css('top'); - var dayDelta; - var helpers; - var eventCopy = $.extend({}, event); - var minCell = dateCell(event.start); - clearSelection(); - $('body') - .css('cursor', direction + '-resize') - .one('mouseup', mouseup); - trigger('eventResizeStart', this, event, ev); - hoverListener.start(function(cell, origCell) { - if (cell) { - var r = Math.max(minCell.row, cell.row); - var c = cell.col; - if (rowCnt == 1) { - r = 0; // hack for all-day area in agenda views - } - if (r == minCell.row) { - if (rtl) { - c = Math.min(minCell.col, c); - }else{ - c = Math.max(minCell.col, c); - } - } - dayDelta = (r*7 + c*dis+dit) - (origCell.row*7 + origCell.col*dis+dit); - var newEnd = addDays(eventEnd(event), dayDelta, true); - if (dayDelta) { - eventCopy.end = newEnd; - var oldHelpers = helpers; - helpers = renderTempDaySegs(compileDaySegs([eventCopy]), seg.row, elementTop); - helpers.find('*').css('cursor', direction + '-resize'); - trigger('eventResizeHelperCreated', this, event, ev, element, helpers); - if (oldHelpers) { - oldHelpers.remove(); - } - //hideEvents(event); - hideEvents(element); - }else{ - if (helpers) { - //showEvents(event); - showEvents(element); - helpers.remove(); - helpers = null; - } - } - clearOverlays(); - renderDayOverlay(event.start, addDays(cloneDate(newEnd), 1)); // coordinate grid already rebuild at hoverListener.start - } - }, ev); - - function mouseup(ev) { - trigger('eventResizeStop', this, event, ev); - $('body').css('cursor', ''); - hoverListener.stop(); - clearOverlays(); - if (dayDelta) { - eventResize(this, event, dayDelta, 0, ev); - // event redraw will clear helpers - } - // otherwise, the drag handler already restored the old events - - setTimeout(function() { // make this happen after the element's click event - isResizing = false; - },0); - } - - }); - } - - -} - -//BUG: unselect needs to be triggered when events are dragged+dropped - -function SelectionManager() { - var t = this; - - - // exports - t.select = select; - t.unselect = unselect; - t.reportSelection = reportSelection; - t.daySelectionMousedown = daySelectionMousedown; - - - // imports - var opt = t.opt; - var trigger = t.trigger; - var defaultSelectionEnd = t.defaultSelectionEnd; - var renderSelection = t.renderSelection; - var clearSelection = t.clearSelection; - - - // locals - var selected = false; - - - - // unselectAuto - if (opt('selectable') && opt('unselectAuto')) { - $(document).mousedown(function(ev) { - var ignore = opt('unselectCancel'); - if (ignore) { - if ($(ev.target).parents(ignore).length) { // could be optimized to stop after first match - return; - } - } - unselect(ev); - }); - } - - - function select(startDate, endDate, allDay) { - unselect(); - if (!endDate) { - endDate = defaultSelectionEnd(startDate, allDay); - } - renderSelection(startDate, endDate, allDay); - reportSelection(startDate, endDate, allDay); - } - - - function unselect(ev) { - if (selected) { - selected = false; - clearSelection(); - trigger('unselect', null, ev); - } - } - - - function reportSelection(startDate, endDate, allDay, ev) { - selected = true; - trigger('select', null, startDate, endDate, allDay, ev); - } - - - function daySelectionMousedown(ev) { // not really a generic manager method, oh well - var cellDate = t.cellDate; - var cellIsAllDay = t.cellIsAllDay; - var hoverListener = t.getHoverListener(); - var reportDayClick = t.reportDayClick; // this is hacky and sort of weird - if (ev.which == 1 && opt('selectable')) { // which==1 means left mouse button - unselect(ev); - var _mousedownElement = this; - var dates; - hoverListener.start(function(cell, origCell) { // TODO: maybe put cellDate/cellIsAllDay info in cell - clearSelection(); - if (cell && cellIsAllDay(cell)) { - dates = [ cellDate(origCell), cellDate(cell) ].sort(cmp); - renderSelection(dates[0], dates[1], true); - }else{ - dates = null; - } - }, ev); - $(document).one('mouseup', function(ev) { - hoverListener.stop(); - if (dates) { - if (+dates[0] == +dates[1]) { - //reportDayClick(dates[0], true, ev); - } - reportSelection(dates[0], dates[1], true, ev); - } - }); - } - } - - -} - -function OverlayManager() { - var t = this; - - - // exports - t.renderOverlay = renderOverlay; - t.clearOverlays = clearOverlays; - - - // locals - var usedOverlays = []; - var unusedOverlays = []; - - - function renderOverlay(rect, parent) { - var e = unusedOverlays.shift(); - if (!e) { - e = $("
"); - } - if (e[0].parentNode != parent[0]) { - e.appendTo(parent); - } - usedOverlays.push(e.css(rect).show()); - return e; - } - - - function clearOverlays() { - var e; - while (e = usedOverlays.shift()) { - unusedOverlays.push(e.hide().unbind()); - } - } - - -} - -function CoordinateGrid(buildFunc) { - var t = this; - var rows; - var cols; - - t.build = function() { - rows = []; - cols = []; - buildFunc(rows, cols); - }; - - t.cell = function(x, y) { - var rowCnt = rows.length; - var colCnt = cols.length; - var i, r=-1, c=-1; - for (i=0; i= rows[i][0] && y < rows[i][1]) { - r = i; - break; - } - } - for (i=0; i= cols[i][0] && x < cols[i][1]) { - c = i; - break; - } - } - return (r>=0 && c>=0) ? { row:r, col:c } : null; - }; - - t.rect = function(row0, col0, row1, col1, originElement) { // row1,col1 is inclusive - var origin = originElement.offset(); - return { - top: rows[row0][0] - origin.top, - left: cols[col0][0] - origin.left, - width: cols[col1][1] - cols[col0][0], - height: rows[row1][1] - rows[row0][0] - }; - }; -} - -function HoverListener(coordinateGrid) { - - var t = this; - var bindType; - var change; - var firstCell; - var cell; - var origEvent; - - t.start = function(_change, ev, _bindType) { - origEvent = ev; - change = _change; - firstCell = cell = null; - coordinateGrid.build(); - mouse(ev); - bindType = _bindType || 'mousemove'; - $(document).bind(bindType, mouse); - }; - - function mouse(ev) { - _fixUIEvent(ev); // see below - if(origEvent.pageX - ev.pageX == 0 && origEvent.pageY - ev.pageY == 0) { - return false; - } - var newCell = coordinateGrid.cell(ev.pageX, ev.pageY); - if (!newCell != !cell || newCell && (newCell.row != cell.row || newCell.col != cell.col)) { - if (newCell) { - if (!firstCell) { - firstCell = newCell; - } - change(newCell, firstCell, newCell.row-firstCell.row, newCell.col-firstCell.col); - }else{ - change(newCell, firstCell); - } - cell = newCell; - } - } - - t.stop = function() { - $(document).unbind(bindType, mouse); - return cell; - }; -} - -// this fix was only necessary for jQuery UI 1.8.16 (and jQuery 1.7 or 1.7.1) -// upgrading to jQuery UI 1.8.17 (and using either jQuery 1.7 or 1.7.1) fixed the problem -// but keep this in here for 1.8.16 users -// and maybe remove it down the line - -function _fixUIEvent(event) { // for issue 1168 - if (event.pageX === undefined) { - event.pageX = event.originalEvent.pageX; - event.pageY = event.originalEvent.pageY; - } -} -function HorizontalPositionCache(getElement) { - - var t = this, - elements = {}, - lefts = {}, - rights = {}; - - function e(i) { - return elements[i] = elements[i] || getElement(i); - } - - t.left = function(i) { - return lefts[i] = lefts[i] === undefined ? e(i).position().left : lefts[i]; - }; - - t.right = function(i) { - return rights[i] = rights[i] === undefined ? t.left(i) + e(i).width() : rights[i]; - }; - - t.clear = function() { - elements = {}; - lefts = {}; - rights = {}; - }; -} - -function addTodayText(cell, todayText) -{ - target = cell.find(".fc-day-text"); - target.html(todayText); -} - -function removeTodayText(cell, todayText) -{ - target = cell.find(".fc-day-text"); - target.html(''); -} - -function addWeekNumber(cell, date) -{ - target = cell.find(".fc-week-number"); - target.html(getWeekNumber(date)); -} - -function removeWeekNumber(cell, date) -{ - target = cell.find(".fc-week-number"); - target.html(''); -} - -function addTodayClass(cell) -{ - var classes = cell.attr('class').split(' '); - var filter = ['fc-state-highlight', 'fc-today', 'fc-widget-content', 'fc-source-bg']; - classes = $.grep(classes, function(el) { - if ($.inArray(el, filter) > -1) { - return false; - } - - return true; - }); - classes.push('fc-widget-header'); - var target = $('.' + classes.join('.')); - target.addClass('fc-today'); -} - -function removeTodayClass(cell) -{ - var classes = cell.attr('class').split(' '); - var filter = ['fc-state-highlight', 'fc-today', 'fc-widget-content', 'fc-source-bg']; - classes = $.grep(classes, function(el) { - if ($.inArray(el, filter) > -1) { - return false; - } - return true; - }); - classes.push('fc-widget-header'); - var target = $('.' + classes.join('.')); - target.removeClass('fc-today'); -} - -function getWeekNumber(date) { - //By tanguy.pruvot at gmail.com (2010) - - //first week of year always contains 4th Jan, or 28 Dec (ISO) - - var jan4 = new Date(date.getFullYear(),0,4 ,date.getHours()); - - //ISO weeks numbers begins on monday, so rotate monday:sunday to 0:6 - var jan4Day = (jan4.getDay() - 1 + 7) % 7; - - var days = Math.round((date - jan4) / 86400000); - var week = Math.floor((days + jan4Day ) / 7)+1; - - //special cases - var thisDay = (date.getDay() - 1 + 7) % 7; - if (date.getMonth()==11 && date.getDate() >= 28) { - - jan4 = new Date(date.getFullYear()+1,0,4 ,date.getHours()); - jan4Day = (jan4.getDay() - 1 + 7) % 7; - - if (thisDay < jan4Day) return 1; - - var prevWeek = new Date(date.valueOf()-(86400000*7)); - return getWeekNumber(prevWeek) + 1; - } - - if (week == 0 && thisDay > 3 && date.getMonth()==0) { - var prevWeek = new Date(date.valueOf()-(86400000*7)); - return getWeekNumber(prevWeek) + 1; - } - - return week; -} - -/* Additional view: list (by bruederli@kolabsys.com) ----------------------------------------------------------------------------------*/ - -function ListEventRenderer() { - var t = this; - - // exports - t.renderEvents = renderEvents; - t.renderEventTime = renderEventTime; - t.compileDaySegs = compileSegs; // for DayEventRenderer - t.clearEvents = clearEvents; - t.lazySegBind = lazySegBind; - t.sortCmp = sortCmp; - - // imports - DayEventRenderer.call(t); - var opt = t.opt; - var trigger = t.trigger; - var reportEvents = t.reportEvents; - var reportEventClear = t.reportEventClear; - var reportEventElement = t.reportEventElement; - var eventElementHandlers = t.eventElementHandlers; - var showEvents = t.showEvents; - var hideEvents = t.hideEvents; - var getListContainer = t.getDaySegmentContainer; - var calendar = t.calendar; - var formatDate = calendar.formatDate; - var formatDates = calendar.formatDates; - - - /* Rendering - --------------------------------------------------------------------*/ - - function clearEvents() { - reportEventClear(); - getListContainer().empty(); - } - - function renderEvents(events, modifiedEventId) { - events.sort(sortCmp); - reportEvents(events); - renderSegs(compileSegs(events), modifiedEventId); - } - - /*function compileSegs(events) { - var segs = []; - var colFormat = opt('titleFormat', 'day'); - var firstDay = opt('firstDay'); - var segmode = opt('listSections'); - var event, i, dd, wd, md, seg, segHash, curSegHash, segDate, curSeg = -1; - var today = clearTime(new Date()); - var weekstart = addDays(cloneDate(today), -((today.getDay() - firstDay + 7) % 7)); - - for (i=0; i < events.length; i++) { - event = events[i]; - var eventEnd = event.end ? cloneDate(event.end) : cloneDate(event.start); - - // skip events out of range - if (eventEnd < t.start || event.start > t.visEnd) - continue; - - // define sections of this event - // create smart sections such as today, tomorrow, this week, next week, next month, ect. - segDate = cloneDate(event.start < t.start && eventEnd > t.start ? t.start : event.start, true); - dd = dayDiff(segDate, today); - wd = Math.floor(dayDiff(segDate, weekstart) / 7); - md = segDate.getMonth() + ((segDate.getYear() - today.getYear()) * 12) - today.getMonth(); - - // build section title - if (segmode == 'smart') { - if (dd < 0) { - segHash = opt('listTexts', 'past'); - } else if (dd == 0) { - segHash = opt('listTexts', 'today'); - } else if (dd == 1) { - segHash = opt('listTexts', 'tomorrow'); - } else if (wd == 0) { - segHash = opt('listTexts', 'thisWeek'); - } else if (wd == 1) { - segHash = opt('listTexts', 'nextWeek'); - } else if (md == 0) { - segHash = opt('listTexts', 'thisMonth'); - } else if (md == 1) { - segHash = opt('listTexts', 'nextMonth'); - } else if (md > 1) { - segHash = opt('listTexts', 'future'); - } - } else if (segmode == 'month') { - segHash = formatDate(segDate, 'MMMM yyyy'); - } else if (segmode == 'week') { - segHash = opt('listTexts', 'week') + formatDate(segDate, ' W'); - } else if (segmode == 'day') { - segHash = formatDate(segDate, colFormat); - } else { - segHash = ''; - } - - // start new segment - if (segHash != curSegHash) { - segs[++curSeg] = { events: [], start: segDate, title: segHash, daydiff: dd, weekdiff: wd, monthdiff: md }; - curSegHash = segHash; - } - - segs[curSeg].events.push(event); - } - - return segs; - }*/ - -function compileSegs(events) { - var segs = {}; - var colFormat = opt('columnFormat', t.name); - var firstDay = opt('firstDay'); - var segmode = opt('listSections'); - var event, i, j, dd, wd, md, seg, segHash, segDate; - var today = clearTime(new Date()); - var weekstart = addDays(cloneDate(today), -((today.getDay() - firstDay + 7) % 7)); - - for (i=0; i < events.length; i++) { - event = events[i]; - var eventEnd = event.end ? cloneDate(event.end) : cloneDate(event.start); - - // skip events out of range - if (eventEnd < t.start || event.start > t.visEnd) - continue; - - var boundEventStart = cloneDate(event.start < t.start ? t.start : event.start, true); - var boundEventEnd = cloneDate(eventEnd > t.visEnd ? t.visEnd : eventEnd, true); - var dayDuration = dayDiff(boundEventEnd, boundEventStart); - - for(j = 0; j <= dayDuration; j++) { - segDate = cloneDate(boundEventStart); - segDate.setDate(segDate.getDate() + j); - - // define sections of this event - // create smart sections such as today, tomorrow, this week, next week, next month, ect. - //segDate = cloneDate(event.start < t.start && eventEnd > t.start ? t.start : event.start, true); - dd = dayDiff(segDate, today); - wd = Math.floor(dayDiff(segDate, weekstart) / 7); - md = segDate.getMonth() + ((segDate.getYear() - today.getYear()) * 12) - today.getMonth(); - - // build section title - if (segmode == 'smart') { - if (dd < 0) { - segHash = opt('listTexts', 'past'); - } else if (dd == 0) { - segHash = opt('listTexts', 'today'); - } else if (dd == 1) { - segHash = opt('listTexts', 'tomorrow'); - } else if (wd == 0) { - segHash = opt('listTexts', 'thisWeek'); - } else if (wd == 1) { - segHash = opt('listTexts', 'nextWeek'); - } else if (md == 0) { - segHash = opt('listTexts', 'thisMonth'); - } else if (md == 1) { - segHash = opt('listTexts', 'nextMonth'); - } else if (md > 1) { - segHash = opt('listTexts', 'future'); - } - } else if (segmode == 'month') { - segHash = formatDate(segDate, 'MMMM yyyy'); - } else if (segmode == 'week') { - segHash = opt('listTexts', 'week') + formatDate(segDate, ' W'); - } else if (segmode == 'day') { - segHash = formatDate(segDate, colFormat); - } else { - segHash = ''; - } - - // start new segment - if (!(segHash in segs)) { - segs[segHash] = { events: [], start: segDate, title: segHash, daydiff: dd, weekdiff: wd, monthdiff: md }; - } - - segs[segHash].events.push(event); - } - } - - return segs; - } - - function sortCmp(a, b) { - /*var datediff = 0; - if(a.start != null && b.start != null) { - datediff = a.start.getTime() - b.start.getTime(); - } - if(datediff == 0 && a.end != null && b.end != null) { - datediff = a.end.getTime() - b.end.getTime(); - } - return datediff;*/ - var retVal = a.start.getTime() - b.start.getTime(); - - if(retVal == 0) { - var aEnd = a.end ? a.end : a.start; - var bEnd = b.end ? b.end : b.start; - retVal = aEnd.getTime() - bEnd.getTime(); - } - - if(retVal == 0) { - if(a.compareString < b.compareString) { - retVal = -1; - } - else if(b.compareString < a.compareString) { - retVal = 1; - } - } - return retVal; - } - - function renderSegs(segs, modifiedEventId) { - var tm = opt('theme') ? 'ui' : 'fc'; - var headerClass = tm + "-widget-header"; - var contentClass = tm + "-widget-content"; - var i, j, seg, event, times, s, skinCss, skinCssAttr, classes, segContainer, eventElement, eventElements, triggerRes; - - for (j=0; j < segs.length; j++) { - seg = segs[j]; - - if (seg.title) { - $('
' + htmlEscape(seg.title) + '
').appendTo(getListContainer()); - } - segContainer = $('
').addClass('fc-list-section ' + contentClass).appendTo(getListContainer()); - s = ''; - - for (i=0; i < seg.events.length; i++) { - event = seg.events[i]; - times = renderEventTime(event, seg); - skinCss = getSkinCss(event, opt); - skinCssAttr = (skinCss ? " style='" + skinCss + "'" : ''); - classes = ['fc-event', 'fc-event-skin', 'fc-event-vert', 'fc-corner-top', 'fc-corner-bottom'].concat(event.className); - if (event.source && event.source.className) { - classes = classes.concat(event.source.className); - } - - s += - "
" + - "
" + - "
" + - "
" + - (times[0] ? '' + times[0] + ' ' : '') + - (times[1] ? '' + times[1] + '' : '') + - "
" + - "
" + - "
" + - "
" + - htmlEscape(event.title.replace(/(\r\n|\n|\r)+/gm," ")) + - "
" + - "
" + - "
" + - "
" + // close inner - "
"; // close outer - } - - segContainer[0].innerHTML = s; - eventElements = segContainer.children(); - - // retrieve elements, run through eventRender callback, bind event handlers - for (i=0; i < seg.events.length; i++) { - event = seg.events[i]; - eventElement = $(eventElements[i]); // faster than eq() - triggerRes = trigger('eventRender', event, event, eventElement); - if (triggerRes === false) { - eventElement.remove(); - } else { - if (triggerRes && triggerRes !== true) { - eventElement.remove(); - eventElement = $(triggerRes).appendTo(segContainer); - } - if (event._id === modifiedEventId) { - eventElementHandlers(event, eventElement, seg); - } else { - eventElement[0]._fci = i; // for lazySegBind - } - reportEventElement(event, eventElement); - } - } - - lazySegBind(segContainer, seg, eventElementHandlers); - } - - markFirstLast(getListContainer()); - } - - // event time/date range to display - function renderEventTime(event, seg) { - var timeFormat = opt('timeFormat', 'list'); - var timeFormatFull = opt('timeFormat', 'listFull'); - var timeFormatFullAllDay = opt('timeFormat', 'listFullAllDay'); - var dateFormat = opt('columnFormat'); - var segmode = opt('listSections'); - var eventEnd = event.end ? cloneDate(event.end) : cloneDate(event.start); - var duration = eventEnd.getTime() - event.start.getTime(); - var datestr = '', timestr = ''; - - if (segmode == 'smart') { - if (event.start < seg.start) { - datestr = opt('listTexts', 'until') + ' ' + formatDate(eventEnd, (event.allDay || eventEnd.getDate() != seg.start.getDate()) ? dateFormat : timeFormat); - } else if (duration > DAY_MS) { - datestr = formatDates(event.start, eventEnd, dateFormat + '{ – ' + dateFormat + '}'); - } else if (seg.daydiff == 0) { - datestr = opt('listTexts', 'today'); - } else if (seg.daydiff == 1) { - datestr = opt('listTexts', 'tomorrow'); - } else if (seg.weekdiff == 0 || seg.weekdiff == 1) { - datestr = formatDate(event.start, 'dddd'); - } else if (seg.daydiff > 1 || seg.daydiff < 0) { - datestr = formatDate(event.start, dateFormat); - } - } else if (segmode != 'day') { - datestr = formatDates(event.start, eventEnd, dateFormat + (duration > DAY_MS ? '{ – ' + dateFormat + '}' : '')); - } - - if (!datestr && event.allDay) { - if(dayDiff(eventEnd, event.start)) { //spans multiple days - timestr = formatDates(event.start, eventEnd, timeFormatFullAllDay); - } - else { - timestr = opt('allDayText'); - } - } else if ((!datestr || !dayDiff(eventEnd, event.start)) && !event.allDay) { - if(dayDiff(eventEnd, event.start)) //spans multiple days - timestr = formatDates(event.start, eventEnd, timeFormatFull); - else if(duration) - timestr = formatDates(event.start, eventEnd, timeFormat); - else - timestr = formatDates(event.start, null, timeFormat); - } - - return [datestr, timestr]; - } - - function lazySegBind(container, seg, bindHandlers) { - container.unbind('mouseover').mouseover(function(ev) { - var parent = ev.target, e = parent, i, event; - while (parent != this) { - e = parent; - parent = parent.parentNode; - } - if ((i = e._fci) !== undefined) { - e._fci = undefined; - event = seg.events[i]; - bindHandlers(event, container.children().eq(i), seg); - $(ev.target).trigger(ev); - } - ev.stopPropagation(); - }); - } -} - -fcViews.list = ListView; - -function ListView(element, calendar) { - var t = this; - - // exports - t.render = render; - t.select = dummy; - t.unselect = dummy; - t.getDaySegmentContainer = function(){ return body; }; - - // imports - View.call(t, element, calendar, 'list'); - ListEventRenderer.call(t); - var opt = t.opt; - var trigger = t.trigger; - var clearEvents = t.clearEvents; - var reportEventClear = t.reportEventClear; - var formatDates = calendar.formatDates; - var formatDate = calendar.formatDate; - - // overrides - t.setWidth = setWidth; - t.setHeight = setHeight; - - // locals - var body; - var firstDay; - var nwe; - var tm; - var colFormat; - - - function render(date, delta) { - if (delta) { - addDays(date, opt('listPage') * delta); - } - t.start = t.visStart = cloneDate(date, true); - t.end = addDays(cloneDate(t.start), opt('listPage')); - t.visEnd = addDays(cloneDate(t.start), opt('listRange')); - addMinutes(t.visEnd, -1); // set end to 23:59 - t.title = formatDates(date, t.visEnd, opt('titleFormat')); - - updateOptions(); - - if (!body) { - buildSkeleton(); - } else { - clearEvents(); - } - } - - - function updateOptions() { - firstDay = opt('firstDay'); - nwe = opt('weekends') ? 0 : 1; - tm = opt('theme') ? 'ui' : 'fc'; - colFormat = opt('columnFormat', 'day'); - } - - - function buildSkeleton() { - body = $('
').addClass('fc-list-content').appendTo(element); - } - - function setHeight(height, dateChanged) { - body.css('height', (height-1)+'px').css('overflow', 'auto'); - } - - function setWidth(width) { - // nothing to be done here - } - - function dummy() { - // Stub. - } - -} - -/* Additional view: table (by bruederli@kolabsys.com) ----------------------------------------------------------------------------------*/ - -function TableEventRenderer() { - var t = this; - - // imports - ListEventRenderer.call(t); - var opt = t.opt; - var sortCmp = t.sortCmp; - var trigger = t.trigger; - var getOrigDate = t.getOrigDate; - var compileSegs = t.compileDaySegs; - var reportEvents = t.reportEvents; - var reportEventClear = t.reportEventClear; - var reportEventElement = t.reportEventElement; - var eventElementHandlers = t.eventElementHandlers; - var renderEventTime = t.renderEventTime; - var showEvents = t.showEvents; - var hideEvents = t.hideEvents; - var getListContainer = t.getDaySegmentContainer; - var lazySegBind = t.lazySegBind; - var calendar = t.calendar; - var formatDate = calendar.formatDate; - var formatDates = calendar.formatDates; - var prevMonth; - var nextMonth; - - // exports - t.renderEvents = renderEvents; - t.scrollToDate = scrollToDate; - t.clearEvents = clearEvents; - t.prevMonthNav = prevMonth; - t.nextMonthNav = nextMonth; - - - /* Rendering - --------------------------------------------------------------------*/ - - function scrollToDate(date) { - var colFormat = opt('columnFormat', t.name); - var currentDate = cloneDate(date, false); - var nextDate; - var segHash; - var currSegHash; - var segFound = false; - - if(currentDate.getDate() == 1) { - getListContainer().parent().scrollTop(0); - } - else { - while(!segFound) { - segHash = formatDate(currentDate, colFormat); - getListContainer().find('td.fc-list-header.fc-widget-header').each(function(){ - currSegHash = $(this).html(); - if(currSegHash == segHash) { - segFound = true; - var offset = $(this).position().top; - var top = getListContainer().parent().scrollTop(); - getListContainer().parent().scrollTop(top + offset); - } - }); - - if(!segFound) { - nextDate = cloneDate(currentDate, false); - nextDate.setDate(nextDate.getDate()+1); - - if(nextDate.getDate() > currentDate.getDate()) { - currentDate = cloneDate(nextDate, false); - } - else { - segFound = true; - getListContainer().parent().scrollTop(getListContainer().height()); - } - } - } - } - } - - function clearEvents() { - reportEventClear(); - getListContainer().children('tbody').remove(); - } - - function renderEvents(events, modifiedEventId) { - events.sort(sortCmp); - reportEvents(events); - renderSegs(compileSegs(events), modifiedEventId); - getListContainer().removeClass('fc-list-smart fc-list-day fc-list-month fc-list-week').addClass('fc-list-' + opt('listSections')); - scrollToDate(getOrigDate()); - } - - function renderSegs(segs, modifiedEventId) { - var tm = opt('theme') ? 'ui' : 'fc'; - var table = getListContainer(); - var headerClass = tm + "-widget-header"; - var contentClass = tm + "-widget-content"; - var segHeader = null; - var tableCols = opt('tableCols'); - var timecol = $.inArray('time', tableCols) >= 0; - var i, j, seg, event, times, s, bg, skinCss, skinCssAttr, skinClasses, rowClasses, segContainer, eventElements, eventElement, triggerRes; - - prevMonth = $('' + opt('buttonText', 'prevMonth') + '').appendTo(table); - prevMonth.click(function(){ - var prevMonthDate = cloneDate(t.getOrigDate(), true); - prevMonthDate.setDate(0); - calendar.gotoDate(prevMonthDate); - trigger('prevClick'); - }); - - for (j in segs) { - seg = segs[j]; - bg = false; - - if (seg.title) { - var segHeader = $('' + htmlEscape(seg.title) + '').appendTo(table); - } - segContainer = $('').addClass('fc-list-section ' + contentClass).appendTo(table); - s = ''; - - for (i=0; i < seg.events.length; i++) { - event = seg.events[i]; - times = renderEventTime(event, seg); - skinCss = getSkinCss(event, opt); - skinCssAttr = (skinCss ? " style='" + skinCss + "'" : ''); - skinClasses = ['fc-event-skin', 'fc-corner-left', 'fc-corner-right', 'fc-corner-top', 'fc-corner-bottom'].concat(event.className); - if (event.source && event.source.className) { - skinClasses = skinClasses.concat(event.source.className); - } - if(event.source && event.source.background) { - bg = true; - } - rowClasses = ['fc-'+dayIDs[event.start.getDay()], 'fc-event', 'fc-event-row']; - if(opt('weekendDays').length>0 && opt('weekendDays').indexOf(segs[j].start.getDay())!=-1) - rowClasses.splice(1, 0, 'fc-weekend-day'); - - if (seg.daydiff == 0) { - if(segHeader) - segHeader.addClass('fc-today'); - rowClasses.push('fc-today'); - rowClasses.push('fc-state-highlight'); - } - - s += ""; - for (var col, c=0; c < tableCols.length; c++) { - col = tableCols[c]; - if (col == 'handle') { - s += ""; - } else if (col == 'title') { - s += "" + (event.title ? htmlEscape(event.title.replace(/(\r\n|\n|\r)+/gm," ")) : ' ') + ""; - } else if (col == 'date') { - s += "" + htmlEscape(times[0]) + ""; - } else if (col == 'time') { - if (times[1]) { - s += "" + htmlEscape(times[1]) + ""; - } - } else { - s += "" + (event[col] ? htmlEscape(event[col]) : ' ') + ""; - } - } - s += ""; - - // IE doesn't like innerHTML on tbody elements so we insert every row individually - if (document.all) { - $(s).appendTo(segContainer); - s = ''; - } - } - - if (!document.all) - segContainer[0].innerHTML = s; - - eventElements = segContainer.children(); - - // retrieve elements, run through eventRender callback, bind event handlers - for (i=0; i < seg.events.length; i++) { - event = seg.events[i]; - eventElement = $(eventElements[i]); // faster than eq() - if(bg) { - eventElement.addClass('fc-source-bg'); - } - triggerRes = trigger('eventRender', event, event, eventElement); - if (triggerRes === false) { - eventElement.remove(); - } else { - if (triggerRes && triggerRes !== true) { - eventElement.remove(); - eventElement = $(triggerRes).appendTo(segContainer); - } - if (event._id === modifiedEventId) { - eventElementHandlers(event, eventElement, seg); - } else { - eventElement[0]._fci = i; // for lazySegBind - } - reportEventElement(event, eventElement); - } - trigger('eventAfterRender', event, event, eventElement); - } - - lazySegBind(segContainer, seg, eventElementHandlers); - markFirstLast(segContainer); - segContainer.addClass('fc-day-'+seg.start.getDay()); - } - - nextMonth = $('' + opt('buttonText', 'nextMonth') + '').appendTo(table); - nextMonth.click(function(){ - var nextMonthDate = cloneDate(t.getOrigDate(), true); - nextMonthDate.setDate(1); - nextMonthDate.setMonth(nextMonthDate.getMonth() + 1); - calendar.gotoDate(nextMonthDate); - trigger('nextClick'); - }); - - //markFirstLast(table); - } - -} - - -fcViews.table = TableView; - - -function TableView(element, calendar) { - var t = this; - - // exports - t.render = render; - t.select = dummy; - t.unselect = dummy; - t.getDaySegmentContainer = function(){return table;}; - t.getOrigDate = function() {return origDate;}; - t.updateGrid = updateGrid; - t.updateToday = updateToday; - t.setAxisFormat = setAxisFormat; - t.setStartOfBusiness = setStartOfBusiness; - t.setEndOfBusiness = setEndOfBusiness; - t.setWeekendDays = setWeekendDays; - t.setBindingMode = setBindingMode; - t.setSelectable = setSelectable; - - // imports - View.call(t, element, calendar, 'table'); - TableEventRenderer.call(t); - var opt = t.opt; - var trigger = t.trigger; - var clearEvents = t.clearEvents; - var reportEventClear = t.reportEventClear; - var formatDates = calendar.formatDates; - var formatDate = calendar.formatDate; - - // overrides - t.setWidth = setWidth; - t.setHeight = setHeight; - - // locals - var div; - var table; - var firstDay; - var nwe; - var tm; - var colFormat; - var datepicker; - var dateInfo; - var dateInfoNumber; - var dateInfoNumberDiv; - var dateInfoText; - var origDate; - - function render(date, delta) { - /*if (delta) { - addDays(date, opt('listPage') * delta); - } - t.start = t.visStart = cloneDate(date, true); - t.end = addDays(cloneDate(t.start), opt('listPage')); - t.visEnd = addDays(cloneDate(t.start), opt('listRange'));*/ - - origDate = date; - if (delta) { - addMonths(date, delta); - date.setDate(1); - } - t.start = cloneDate(date, true); - t.start.setDate(1); - t.end = addMonths(cloneDate(t.start), 1); - t.visStart = cloneDate(t.start); - t.visEnd = cloneDate(t.end); - - addMinutes(t.visEnd, -1); // set end to 23:59 - t.title = formatDates( - t.visStart, - t.visEnd, - opt('titleFormat') - ); - //t.title = (t.visEnd.getTime() - t.visStart.getTime() < DAY_MS) ? formatDate(date, opt('titleFormat')) : formatDates(date, t.visEnd, opt('titleFormat')); - - updateOptions(); - if (!table) { - buildSkeleton(origDate); - } else { - clearEvents(); - if(opt('showDatepicker')) { - dateInfoNumberDiv.html(origDate.getDate()); - dateInfoText.html(formatDates(origDate, null, opt('titleFormat', 'table'))); - datepicker.datepicker('option','firstDay',firstDay); - datepicker.datepicker('setDate', origDate); - } - } - } - - - function updateOptions() { - firstDay = opt('firstDay'); - nwe = opt('weekends') ? 0 : 1; - tm = opt('theme') ? 'ui' : 'fc'; - colFormat = opt('columnFormat'); - } - - function buildSkeleton(date) { - var tableCols = opt('tableCols'); - var s = - "" + - ""; - for (var c=0; c < tableCols.length; c++) { - s += ""; - } - s += "" + - "
"; - if(opt('showDatepicker')) { - dateInfo = $('
').addClass('fc-table-dateinfo').appendTo(element); - dateInfoNumber = $('
').addClass('fc-table-dateinfo-number').appendTo(dateInfo); - dateInfoNumberDiv = $('
').appendTo(dateInfoNumber); - dateInfoNumberDiv.html(date.getDate()); - dateInfoText = $('
').addClass('fc-table-dateinfo-text').appendTo(dateInfo); - dateInfoText.html(formatDates(origDate, null, opt('titleFormat', 'table'))); - datepicker = $('
').addClass('fc-table-datepicker').appendTo(element); - datepicker.datepicker({ - firstDay: opt('firstDay'), - weekendDays: opt('weekendDays'), - defaultDate: date, - showWeek: true, - weekHeader: '', - - onSelect: function(dateText, inst) { - var date = new Date(dateText); - calendar.gotoDate(date); - trigger('datepickerClick', this, date); - }, - }); - } - div = $('
').addClass('fc-list-content').appendTo(element); - table = $(s).appendTo(div); - } - - function updateGrid() - { - updateToday(); - setAxisFormat(); - setStartOfBusiness(); - setEndOfBusiness(); - setWeekendDays(); - setBindingMode(); - setSelectable(); - } - - function updateToday() - { - var today = clearTime(new Date()); - var segHash = formatDate(today, colFormat); - - $(table).find('.fc-list-header').each(function() { - $(this).removeClass('fc-today'); - $(this).next().children().removeClass('fc-state-highlight'); - - if(segHash == $(this).find('td').html()) { - $(this).addClass('fc-today'); - $(this).next().children().addClass('fc-state-highlight'); - } - }); - - datepicker.datepicker('refresh'); - } - - function setAxisFormat() - { - // dummy - } - - function setStartOfBusiness() - { - // dummy - } - - function setEndOfBusiness() - { - // dummy - } - - function setWeekendDays() - { - var weekendDays = opt('weekendDays'); - - $(table).find('.fc-list-section').each(function() { - var day=parseInt(this.className.match(/fc-day-(\d)/)[1],10); - if(weekendDays.indexOf(day)==-1) - $(this).children().removeClass('fc-weekend-day'); - else - $(this).children().addClass('fc-weekend-day'); - }); - - if(opt('showDatepicker')) - datepicker.datepicker('option','weekendDays',weekendDays); - } - - function setBindingMode() - { - // dummy - } - - function setSelectable() - { - // dummy - } - - function setHeight(height, dateChanged) { - if(opt('showDatepicker')) { - var datepickerHeight = datepicker.height(); - dateInfoText.css('padding-bottom', datepickerHeight - datepicker.children().outerHeight() + 3); //+3 for paddings - var textHeight = dateInfoText.outerHeight(); - dateInfoNumber.css({'height': datepickerHeight - textHeight, - 'font-size': 145 - textHeight}); - dateInfoNumberDiv.height(145 - textHeight); - } - - div.css('height', (height-div.position().top-2)+'px').css('overflow', 'auto'); - } - - function setWidth(width) { - var outerWidth = Math.floor(element.parent().width() / 2) - 8; - element.css({'left' : width, 'width' : outerWidth}); - } - - function dummy() { - // Stub. - } - -} - -function TodoEventRenderer() { - var t = this; - - // exports - t.renderEvents = renderEvents; - t.clearEvents = clearEvents; - t.renderEventTime = renderEventTime; - t.compileDaySegs = compileSegs; // for DayEventRenderer - t.lazySegBind = lazySegBind; - t.sortCmp = sortCmp; - - // imports - DayEventRenderer.call(t); - var opt = t.opt; - var sortCmp = t.sortCmp; - var trigger = t.trigger; - var compileSegs = t.compileDaySegs; - var reportEvents = t.reportEvents; - var reportEventClear = t.reportEventClear; - var reportEventElement = t.reportEventElement; - var eventElementHandlers = t.eventElementHandlers; - var renderEventTime = t.renderEventTime; - var showEvents = t.showEvents; - var hideEvents = t.hideEvents; - var getListContainer = t.getDaySegmentContainer; - var lazySegBind = t.lazySegBind; - var calendar = t.calendar; - var formatDate = calendar.formatDate; - var formatDates = calendar.formatDates; - var prevMonth; - var nextMonth; - - function compileSegs(events) { - var segs = {}; - var event, i; - - //for (i=0; i < events.length; i++) { - for (i=events.length-1; i > -1; i--) { - event = events[i]; - var segHash = event.repeatHash; - var eventEnd = event.end ? cloneDate(event.end) : cloneDate(event.start); - - // skip events out of range - if ((event.completedOn && event.completedOn < t.start && (opt('showUnstartedEvents') || !event.start || event.completedOn > event.start)) || - (!opt('showUnstartedEvents') && event.start && event.start > t.visEnd)) { - continue; - } - - // start new segment - if (!(segHash in segs)) { - segs[segHash] = { events: [], id: segHash}; - } - - segs[segHash].events.push(event); - } - - return segs; - } - - function reverseSegs(oldSegs) { - var newSegs = {}; - var keys = $.map(oldSegs, function (value, key) { return key; }); - var values = $.map(oldSegs, function (value, key) { return value; }); - - for (i=keys.length-1; i > -1; i--) { - newSegs[keys[i]] = values[i]; - } - - return newSegs; - } - - function sortCmp(a, b) { - /*var sd = a.start.getTime() - b.start.getTime(); - var aEnd = a.end ? a.end : a.start; - var bEnd = b.end ? b.end : b.start; - return sd + (sd ? 0 : aEnd.getTime() - bEnd.getTime());*/ - var aEnd = a.end ? a.end.getTime() : Infinity; - var bEnd = b.end ? b.end.getTime() : Infinity; - var aStart = a.start ? a.start.getTime() : Infinity; - var bStart = b.start ? b.start.getTime() : Infinity; - var aPriority = parseInt(a.priority, 10) || 10; - var bPriority = parseInt(b.priority, 10) || 10; - - var statusSort = { - "NEEDS-ACTION": 1, - "IN-PROCESS": 2, - "COMPLETED": 3, - "CANCELLED": 4 - }; - - if(aEnd < bEnd) { - return -1; - } - else if(bEnd < aEnd) { - return 1; - } - else if(aStart < bStart){ - return -1; - } - else if(bStart < aStart) { - return 1; - } - else if(aPriority < bPriority) { - return -1; - } - else if(bPriority < aPriority) { - return 1; - } - else if(statusSort[a.status] < statusSort[b.status]) { - return -1; - } - else if(statusSort[b.status] < statusSort[a.status]) { - return 1; - } - else if(a.percent < b.percent) { - return -1; - } - else if(b.percent < a.percent) { - return 1; - } - else if(a.compareString < b.compareString) { - return -1; - } - else if(b.compareString < a.compareString) { - return 1; - } - else { - return 0; - } - } - - // event time/date range to display - function renderEventTime(event) { - var timeFormat = opt('timeFormat', 'list'); - return event.end? formatDate(event.end, timeFormat) : ''; - } - - function lazySegBind(container, seg, bindHandlers) { - container.unbind('mouseover').mouseover(function(ev) { - var parent = ev.target, e = parent, i, event; - while (parent != this) { - e = parent; - parent = parent.parentNode; - } - if ((i = e._fci) !== undefined) { - e._fci = undefined; - event = seg.events[i]; - bindHandlers(event, container.children().eq(0), seg); - $(ev.target).trigger(ev); - } - ev.stopPropagation(); - }); - } - - function clearEvents() { - reportEventClear(); - getListContainer().children('tbody').remove(); - } - - function renderEvents(events, modifiedEventId) { - events.sort(sortCmp); - reportEvents(events); - renderSegs(reverseSegs(compileSegs(events)), modifiedEventId); - getListContainer().removeClass('fc-list-smart fc-list-day fc-list-month fc-list-week').addClass('fc-list-' + opt('listSections')); - //t.selectEvent(); - t.applyFilters(); - } - - function renderSegs(segs, modifiedEventId) { - var tm = opt('theme') ? 'ui' : 'fc'; - var table = getListContainer(); - var headerClass = tm + "-widget-header"; - var contentClass = tm + "-widget-content"; - var segHeader = null; - var tableCols = opt('todoCols'); - var timecol = $.inArray('time', tableCols) >= 0; - var i, j, iter, seg, event, times, s, skinCss, skinCssAttr, skinClasses, rowClasses, segContainer, eventElements, eventElement, triggerRes; - - for (j in segs) { - seg = segs[j]; - - segContainer = $('').addClass('fc-list-section ' + contentClass).appendTo(table); - s = ''; - - event = seg.events[0]; - iter=0; - if(opt('showUnstartedEvents') && seg.events.length>1) { - for(;iter"; - for (var col, c=0; c < tableCols.length; c++) { - col = tableCols[c]; - if (col == 'handle') { - s += ""; - } else if (col == 'check') { - s += "" + '' + ""; - } else if (col == 'priority') { - s += "" + (event.renderPriority ? ' ' : '') + ""; - } else if (col == 'time') { - s += "" + htmlEscape(dueTime) + ""; - } else if (col == 'title') { - s += "" + htmlEscape(event.title.replace(/(\r\n|\n|\r)+/gm, " ")) + ""; - } else if (col == 'location') { - s += "" + htmlEscape(event.location.replace(/(\r\n|\n|\r)+/gm, " ")) + ""; - } else if (col == 'status') { - s += ""; - } else if (col == 'percent') { - s += "" + event.percent + '%' + ""; - } - else { - s += "" + (event[col] ? htmlEscape(event[col]) : ' ') + ""; - } - } - s += ""; - - // IE doesn't like innerHTML on tbody elements so we insert every row individually - if (document.all) { - $(s).appendTo(segContainer); - s = ''; - } - - if (!document.all) - segContainer[0].innerHTML = s; - - eventElements = segContainer.children(); - - // retrieve elements, run through eventRender callback, bind event handlers - eventElement = $(eventElements[0]); // faster than eq() - triggerRes = trigger('eventRender', event, event, eventElement); - if (triggerRes === false) { - eventElement.remove(); - } else { - if (triggerRes && triggerRes !== true) { - eventElement.remove(); - eventElement = $(triggerRes).appendTo(segContainer); - } - if (event._id === modifiedEventId) { - eventElementHandlers(event, eventElement, seg); - } else { - eventElement[0]._fci = iter; // for lazySegBind - } - reportEventElement(event, eventElement); - } - trigger('eventCheckDefault', event, event, eventElement.find('.fc-event-checkbox')); - trigger('eventAfterRender', event, event, eventElement); - - lazySegBind(segContainer, seg, eventElementHandlers); - markFirstLast(segContainer); - } - - //markFirstLast(table); - } - -} - -fcViews.todo = TodoView; - -function TodoView(element, calendar) { - var t = this; - - // exports - t.render = render; - t.select = dummy; - t.unselect = dummy; - t.getDaySegmentContainer = function(){ return table; }; - t.applyFilters = applyFilters; - t.allowSelectEvent = allowSelectEvent; - t.eventSelectLock = 0; - t.updateGrid = updateGrid; - t.updateToday = updateToday; - t.setAxisFormat = setAxisFormat; - t.setStartOfBusiness = setStartOfBusiness; - t.setEndOfBusiness = setEndOfBusiness; - t.setWeekendDays = setWeekendDays; - t.setBindingMode = setBindingMode; - t.setSelectable = setSelectable; - - // imports - View.call(t, element, calendar, 'todo'); - TodoEventRenderer.call(t); - var opt = t.opt; - var trigger = t.trigger; - var clearEvents = t.clearEvents; - var reportEventClear = t.reportEventClear; - var formatDates = calendar.formatDates; - var formatDate = calendar.formatDate; - - // overrides - t.setWidth = setWidth; - t.setHeight = setHeight; - - // locals - var div; - var table; - var filter; - var filterTable; - var firstDay; - var nwe; - var tm; - var colFormat; - var currentDate; - var datepickers; - var dateInfo; - var dateInfoNumber; - var dateInfoNumberDiv; - var dateInfoText; - - function render(date, delta) { - if (delta) { - addMonths(date, delta); - date.setDate(1); - } - currentDate = date; - var start = cloneDate(date, true); - var end = addDays(cloneDate(start), 1); - t.title = formatDate(date, opt('titleFormat')); - t.start = t.visStart = start; - t.end = t.visEnd = end; - - updateOptions(); - if (!table) { - buildSkeleton(date); - initFilters(); - } else { - clearEvents(); - filterTable.find('.fc-filter-table-footer').text(opt('buttonText', 'filtersFooter').replace('%date%', formatDates(date, null, opt('columnFormat', 'todo')))); - if(opt('showDatepicker')) { - dateInfoNumberDiv.html(date.getDate()); - dateInfoText.html(formatDates(date, null, opt('titleFormat', 'todo'))); - - var defaultDate = cloneDate(date, true); - defaultDate.setHours(12); - defaultDate.setDate(1); - defaultDate.setMonth(currentDate.getMonth() - datepickers.length + 1); - - datepickers.forEach(function(e, i){ - defaultDate.setMonth(defaultDate.getMonth() + 1); - e.datepicker('option','firstDay',firstDay); - if((i===0 && datepickers.length<3) || (i===datepickers.length-2 && datepickers.length>2)) - e.datepicker('setDate', date); - else - e.datepicker('setDate', defaultDate); - }); - } - } - } - - function updateOptions() { - firstDay = opt('firstDay'); - nwe = opt('weekends') ? 0 : 1; - tm = opt('theme') ? 'ui' : 'fc'; - colFormat = opt('columnFormat'); - } - - function buildSkeleton(date) { - var tableCols = opt('todoCols'); - var s = - "" + - ""; - for (var c=0; c < tableCols.length; c++) { - s += ""; - } - s += "" + - "
"; - if(opt('showDatepicker')) { - dateInfo = $('
').addClass('fc-table-dateinfo').appendTo(element); - dateInfoNumber = $('
').addClass('fc-table-dateinfo-number').appendTo(dateInfo); - dateInfoNumberDiv = $('
').appendTo(dateInfoNumber); - dateInfoNumberDiv.html(date.getDate()); - dateInfoText = $('
').addClass('fc-table-dateinfo-text').appendTo(dateInfo); - dateInfoText.html(formatDates(date, null, opt('titleFormat', 'todo'))); - - datepickers = [$('
').addClass('fc-table-datepicker fc-table-datepicker-current').appendTo(element)]; - datepickers[0].datepicker({ - firstDay: opt('firstDay'), - weekendDays: opt('weekendDays'), - defaultDate: date, - showWeek: true, - weekHeader: '', - - onSelect: function(dateText, inst) { - var date = new Date(dateText); - calendar.gotoDate(date); - trigger('datepickerClick', this, date); - } - }); - } - filter = $('
').addClass('fc-filter').appendTo(element); - var ft = '' + - '' + - '' + - ''; - - if(opt('simpleFilters')) { - ft += '' + - '' + - '' + - ''; - } - else { - ft += '' + - '' + - '' + - '' + - '' + - '' + - '' + - ''; - } - - ft += '' + - '' + - '' + - '
'+opt('buttonText', 'filtersHeader')+'
'+ opt('buttonText', 'filterAction') +''+ opt('buttonText', 'filterCompleted') +' *
'+ opt('buttonText', 'filterAction') +''+ opt('buttonText', 'filterProgress') +'
'+ opt('buttonText', 'filterCompleted') +' *'+ opt('buttonText', 'filterCanceled') +'
'; - filterTable = $(ft).appendTo(filter); - div = $('
').addClass('fc-list-content').appendTo(element); - table = $(s).appendTo(div); - } - - function updateGrid() - { - updateToday(); - setAxisFormat(); - setStartOfBusiness(); - setEndOfBusiness(); - setWeekendDays(); - setBindingMode(); - setSelectable(); - } - - function updateToday() - { - if(opt('showDatepicker')) - datepickers.forEach(function(e){ - e.datepicker('refresh'); - }); - } - - function setAxisFormat() - { - // dummy - } - - function setStartOfBusiness() - { - // dummy - } - - function setEndOfBusiness() - { - // dummy - } - - function setWeekendDays() - { - if(opt('showDatepicker')) - datepickers.forEach(function(e){ - e.datepicker('option','weekendDays',opt('weekendDays')); - }); - } - - function setBindingMode() - { - // dummy - } - - function setSelectable() - { - // dummy - } - - function initFilters() { - filterTable.find('.fc-filter-option').each(function() { - if(opt('defaultFilters').indexOf($(this).attr('data-type')) != -1) { - filterToggle($(this)); - } - $(this).click(function(){ - filterToggle($(this)); - }); - }); - } - - function filterToggle(button) { - if(button.hasClass('fc-filter-option-selected')) { - button.removeClass('fc-filter-option-selected'); - } - else { - button.addClass('fc-filter-option-selected'); - } - applyFilters(); - } - - function applyFilters() { - filterTable.find('.fc-filter-option').each(function(){ - if($(this).hasClass('fc-filter-option-selected')) { - t.getDaySegmentContainer().find('.fc-event-' + $(this).attr('data-type')).removeClass('fc-filter-hide'); - } - else { - t.getDaySegmentContainer().find('.fc-event-' + $(this).attr('data-type')).addClass('fc-filter-hide'); - } - }); - - opt('todoOptionalCols').forEach(function(item){ - var itemsFilled = $('.fc-event-'+item.col+':visible').filter(function(){ - return this.innerHTML!==''; - }); - - $('col.fc-event-'+item.col).toggleClass('fc-hidden-empty', !itemsFilled.length); - }); - - //if(!t.getDaySegmentContainer().find('.fc-event-selected:visible').length) { - t.selectEvent(); - //} - } - - function setHeight(height, dateChanged) { - if(opt('showDatepicker')) { - var datepickerHeight = datepickers[0].height(); - dateInfoText.css('padding-bottom', datepickerHeight - datepickers[0].children().outerHeight() + 3); //+3 for paddings - var textHeight = dateInfoText.outerHeight(); - dateInfoNumber.css({'height': datepickerHeight - textHeight, - 'font-size': 145 - textHeight}); - dateInfoNumberDiv.height(145 - textHeight); - } - - div.css({'height': height-div.position().top-2, 'overflow': 'auto'}); - } - - function setWidth(width) { - element.width(width); - var slots = Math.floor((width - dateInfo.outerWidth() - 1) / datepickers[0].outerWidth()); - - if(slots > datepickers.length) { - var defaultDate = cloneDate(currentDate, true); - defaultDate.setHours(12); - defaultDate.setDate(1); - defaultDate.setMonth(currentDate.getMonth() + 1); - - if(datepickers.length==1) { - datepickers.push($('
').addClass('fc-table-datepicker fc-table-datepicker-no-default').prependTo(element).datepicker({ - firstDay: opt('firstDay'), - weekendDays: opt('weekendDays'), - defaultDate: cloneDate(defaultDate), - showWeek: true, - weekHeader: '', - hideIfNoPrevNext: true, - - onSelect: function(dateText, inst) { - var date = new Date(dateText); - calendar.gotoDate(date); - trigger('datepickerClick', this, date); - } - })); - } - - defaultDate.setMonth(defaultDate.getMonth() - datepickers.length + 1); - for(var i=datepickers.length; i').addClass('fc-table-datepicker fc-table-datepicker-no-default').insertBefore(filter).datepicker({ - firstDay: opt('firstDay'), - weekendDays: opt('weekendDays'), - defaultDate: cloneDate(defaultDate), - showWeek: true, - weekHeader: '', - hideIfNoPrevNext: true, - - onSelect: function(dateText, inst) { - var date = new Date(dateText); - calendar.gotoDate(date); - trigger('datepickerClick', this, date); - } - })); - } - } - else { - while(datepickers.length>slots && datepickers.length>1) { - if(datepickers.length==2) - datepickers.pop().remove(); - else - datepickers.shift().remove(); - } - } - - var hiddenWidth = 0; - opt('todoOptionalCols').forEach(function(e){ - hiddenWidth += $('col.fc-event-'+e.col).hasClass('fc-hidden-empty') ? e.width : 0; - }); - opt('todoColThresholds').forEach(function(e){ - $('col.fc-event-'+e.col).toggleClass('fc-hidden-width', width> 16, (b10 >> 8) & 0xff, b10 & 0xff)); - } - - switch (pads) { - case 1: - b10 = (getbyte64(s,i) << 18) | (getbyte64(s,i+1) << 12) | (getbyte64(s,i+2) << 6); - x.push(String.fromCharCode(b10 >> 16, (b10 >> 8) & 0xff)); - break; - case 2: - b10 = (getbyte64(s,i) << 18) | (getbyte64(s,i+1) << 12); - x.push(String.fromCharCode(b10 >> 16)); - break; - } - return x.join(''); -} - -base64.getbyte = function(s,i) { - var x = s.charCodeAt(i); - if (x > 255) { - throw base64.makeDOMException(); - } - return x; -} - -base64.encode = function(s) { - if (arguments.length !== 1) { - throw new SyntaxError("Not enough arguments"); - } - var padchar = base64.PADCHAR; - var alpha = base64.ALPHA; - var getbyte = base64.getbyte; - - var i, b10; - var x = []; - - // convert to string - s = '' + s; - - var imax = s.length - s.length % 3; - - if (s.length === 0) { - return s; - } - for (i = 0; i < imax; i += 3) { - b10 = (getbyte(s,i) << 16) | (getbyte(s,i+1) << 8) | getbyte(s,i+2); - x.push(alpha.charAt(b10 >> 18)); - x.push(alpha.charAt((b10 >> 12) & 0x3F)); - x.push(alpha.charAt((b10 >> 6) & 0x3f)); - x.push(alpha.charAt(b10 & 0x3f)); - } - switch (s.length - imax) { - case 1: - b10 = getbyte(s,i) << 16; - x.push(alpha.charAt(b10 >> 18) + alpha.charAt((b10 >> 12) & 0x3F) + - padchar + padchar); - break; - case 2: - b10 = (getbyte(s,i) << 16) | (getbyte(s,i+1) << 8); - x.push(alpha.charAt(b10 >> 18) + alpha.charAt((b10 >> 12) & 0x3F) + - alpha.charAt((b10 >> 6) & 0x3f) + padchar); - break; - } - return x.join(''); -} diff --git a/radicale_web/web/infcloud/lib/jquery-2.1.4.min.js b/radicale_web/web/infcloud/lib/jquery-2.1.4.min.js deleted file mode 100644 index 49990d6..0000000 --- a/radicale_web/web/infcloud/lib/jquery-2.1.4.min.js +++ /dev/null @@ -1,4 +0,0 @@ -/*! jQuery v2.1.4 | (c) 2005, 2015 jQuery Foundation, Inc. | jquery.org/license */ -!function(a,b){"object"==typeof module&&"object"==typeof module.exports?module.exports=a.document?b(a,!0):function(a){if(!a.document)throw new Error("jQuery requires a window with a document");return b(a)}:b(a)}("undefined"!=typeof window?window:this,function(a,b){var c=[],d=c.slice,e=c.concat,f=c.push,g=c.indexOf,h={},i=h.toString,j=h.hasOwnProperty,k={},l=a.document,m="2.1.4",n=function(a,b){return new n.fn.init(a,b)},o=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,p=/^-ms-/,q=/-([\da-z])/gi,r=function(a,b){return b.toUpperCase()};n.fn=n.prototype={jquery:m,constructor:n,selector:"",length:0,toArray:function(){return d.call(this)},get:function(a){return null!=a?0>a?this[a+this.length]:this[a]:d.call(this)},pushStack:function(a){var b=n.merge(this.constructor(),a);return b.prevObject=this,b.context=this.context,b},each:function(a,b){return n.each(this,a,b)},map:function(a){return this.pushStack(n.map(this,function(b,c){return a.call(b,c,b)}))},slice:function(){return this.pushStack(d.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(a){var b=this.length,c=+a+(0>a?b:0);return this.pushStack(c>=0&&b>c?[this[c]]:[])},end:function(){return this.prevObject||this.constructor(null)},push:f,sort:c.sort,splice:c.splice},n.extend=n.fn.extend=function(){var a,b,c,d,e,f,g=arguments[0]||{},h=1,i=arguments.length,j=!1;for("boolean"==typeof g&&(j=g,g=arguments[h]||{},h++),"object"==typeof g||n.isFunction(g)||(g={}),h===i&&(g=this,h--);i>h;h++)if(null!=(a=arguments[h]))for(b in a)c=g[b],d=a[b],g!==d&&(j&&d&&(n.isPlainObject(d)||(e=n.isArray(d)))?(e?(e=!1,f=c&&n.isArray(c)?c:[]):f=c&&n.isPlainObject(c)?c:{},g[b]=n.extend(j,f,d)):void 0!==d&&(g[b]=d));return g},n.extend({expando:"jQuery"+(m+Math.random()).replace(/\D/g,""),isReady:!0,error:function(a){throw new Error(a)},noop:function(){},isFunction:function(a){return"function"===n.type(a)},isArray:Array.isArray,isWindow:function(a){return null!=a&&a===a.window},isNumeric:function(a){return!n.isArray(a)&&a-parseFloat(a)+1>=0},isPlainObject:function(a){return"object"!==n.type(a)||a.nodeType||n.isWindow(a)?!1:a.constructor&&!j.call(a.constructor.prototype,"isPrototypeOf")?!1:!0},isEmptyObject:function(a){var b;for(b in a)return!1;return!0},type:function(a){return null==a?a+"":"object"==typeof a||"function"==typeof a?h[i.call(a)]||"object":typeof a},globalEval:function(a){var b,c=eval;a=n.trim(a),a&&(1===a.indexOf("use strict")?(b=l.createElement("script"),b.text=a,l.head.appendChild(b).parentNode.removeChild(b)):c(a))},camelCase:function(a){return a.replace(p,"ms-").replace(q,r)},nodeName:function(a,b){return a.nodeName&&a.nodeName.toLowerCase()===b.toLowerCase()},each:function(a,b,c){var d,e=0,f=a.length,g=s(a);if(c){if(g){for(;f>e;e++)if(d=b.apply(a[e],c),d===!1)break}else for(e in a)if(d=b.apply(a[e],c),d===!1)break}else if(g){for(;f>e;e++)if(d=b.call(a[e],e,a[e]),d===!1)break}else for(e in a)if(d=b.call(a[e],e,a[e]),d===!1)break;return a},trim:function(a){return null==a?"":(a+"").replace(o,"")},makeArray:function(a,b){var c=b||[];return null!=a&&(s(Object(a))?n.merge(c,"string"==typeof a?[a]:a):f.call(c,a)),c},inArray:function(a,b,c){return null==b?-1:g.call(b,a,c)},merge:function(a,b){for(var c=+b.length,d=0,e=a.length;c>d;d++)a[e++]=b[d];return a.length=e,a},grep:function(a,b,c){for(var d,e=[],f=0,g=a.length,h=!c;g>f;f++)d=!b(a[f],f),d!==h&&e.push(a[f]);return e},map:function(a,b,c){var d,f=0,g=a.length,h=s(a),i=[];if(h)for(;g>f;f++)d=b(a[f],f,c),null!=d&&i.push(d);else for(f in a)d=b(a[f],f,c),null!=d&&i.push(d);return e.apply([],i)},guid:1,proxy:function(a,b){var c,e,f;return"string"==typeof b&&(c=a[b],b=a,a=c),n.isFunction(a)?(e=d.call(arguments,2),f=function(){return a.apply(b||this,e.concat(d.call(arguments)))},f.guid=a.guid=a.guid||n.guid++,f):void 0},now:Date.now,support:k}),n.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),function(a,b){h["[object "+b+"]"]=b.toLowerCase()});function s(a){var b="length"in a&&a.length,c=n.type(a);return"function"===c||n.isWindow(a)?!1:1===a.nodeType&&b?!0:"array"===c||0===b||"number"==typeof b&&b>0&&b-1 in a}var t=function(a){var b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u="sizzle"+1*new Date,v=a.document,w=0,x=0,y=ha(),z=ha(),A=ha(),B=function(a,b){return a===b&&(l=!0),0},C=1<<31,D={}.hasOwnProperty,E=[],F=E.pop,G=E.push,H=E.push,I=E.slice,J=function(a,b){for(var c=0,d=a.length;d>c;c++)if(a[c]===b)return c;return-1},K="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",L="[\\x20\\t\\r\\n\\f]",M="(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",N=M.replace("w","w#"),O="\\["+L+"*("+M+")(?:"+L+"*([*^$|!~]?=)"+L+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+N+"))|)"+L+"*\\]",P=":("+M+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+O+")*)|.*)\\)|)",Q=new RegExp(L+"+","g"),R=new RegExp("^"+L+"+|((?:^|[^\\\\])(?:\\\\.)*)"+L+"+$","g"),S=new RegExp("^"+L+"*,"+L+"*"),T=new RegExp("^"+L+"*([>+~]|"+L+")"+L+"*"),U=new RegExp("="+L+"*([^\\]'\"]*?)"+L+"*\\]","g"),V=new RegExp(P),W=new RegExp("^"+N+"$"),X={ID:new RegExp("^#("+M+")"),CLASS:new RegExp("^\\.("+M+")"),TAG:new RegExp("^("+M.replace("w","w*")+")"),ATTR:new RegExp("^"+O),PSEUDO:new RegExp("^"+P),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+L+"*(even|odd|(([+-]|)(\\d*)n|)"+L+"*(?:([+-]|)"+L+"*(\\d+)|))"+L+"*\\)|)","i"),bool:new RegExp("^(?:"+K+")$","i"),needsContext:new RegExp("^"+L+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+L+"*((?:-\\d)?\\d*)"+L+"*\\)|)(?=[^-]|$)","i")},Y=/^(?:input|select|textarea|button)$/i,Z=/^h\d$/i,$=/^[^{]+\{\s*\[native \w/,_=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,aa=/[+~]/,ba=/'|\\/g,ca=new RegExp("\\\\([\\da-f]{1,6}"+L+"?|("+L+")|.)","ig"),da=function(a,b,c){var d="0x"+b-65536;return d!==d||c?b:0>d?String.fromCharCode(d+65536):String.fromCharCode(d>>10|55296,1023&d|56320)},ea=function(){m()};try{H.apply(E=I.call(v.childNodes),v.childNodes),E[v.childNodes.length].nodeType}catch(fa){H={apply:E.length?function(a,b){G.apply(a,I.call(b))}:function(a,b){var c=a.length,d=0;while(a[c++]=b[d++]);a.length=c-1}}}function ga(a,b,d,e){var f,h,j,k,l,o,r,s,w,x;if((b?b.ownerDocument||b:v)!==n&&m(b),b=b||n,d=d||[],k=b.nodeType,"string"!=typeof a||!a||1!==k&&9!==k&&11!==k)return d;if(!e&&p){if(11!==k&&(f=_.exec(a)))if(j=f[1]){if(9===k){if(h=b.getElementById(j),!h||!h.parentNode)return d;if(h.id===j)return d.push(h),d}else if(b.ownerDocument&&(h=b.ownerDocument.getElementById(j))&&t(b,h)&&h.id===j)return d.push(h),d}else{if(f[2])return H.apply(d,b.getElementsByTagName(a)),d;if((j=f[3])&&c.getElementsByClassName)return H.apply(d,b.getElementsByClassName(j)),d}if(c.qsa&&(!q||!q.test(a))){if(s=r=u,w=b,x=1!==k&&a,1===k&&"object"!==b.nodeName.toLowerCase()){o=g(a),(r=b.getAttribute("id"))?s=r.replace(ba,"\\$&"):b.setAttribute("id",s),s="[id='"+s+"'] ",l=o.length;while(l--)o[l]=s+ra(o[l]);w=aa.test(a)&&pa(b.parentNode)||b,x=o.join(",")}if(x)try{return H.apply(d,w.querySelectorAll(x)),d}catch(y){}finally{r||b.removeAttribute("id")}}}return i(a.replace(R,"$1"),b,d,e)}function ha(){var a=[];function b(c,e){return a.push(c+" ")>d.cacheLength&&delete b[a.shift()],b[c+" "]=e}return b}function ia(a){return a[u]=!0,a}function ja(a){var b=n.createElement("div");try{return!!a(b)}catch(c){return!1}finally{b.parentNode&&b.parentNode.removeChild(b),b=null}}function ka(a,b){var c=a.split("|"),e=a.length;while(e--)d.attrHandle[c[e]]=b}function la(a,b){var c=b&&a,d=c&&1===a.nodeType&&1===b.nodeType&&(~b.sourceIndex||C)-(~a.sourceIndex||C);if(d)return d;if(c)while(c=c.nextSibling)if(c===b)return-1;return a?1:-1}function ma(a){return function(b){var c=b.nodeName.toLowerCase();return"input"===c&&b.type===a}}function na(a){return function(b){var c=b.nodeName.toLowerCase();return("input"===c||"button"===c)&&b.type===a}}function oa(a){return ia(function(b){return b=+b,ia(function(c,d){var e,f=a([],c.length,b),g=f.length;while(g--)c[e=f[g]]&&(c[e]=!(d[e]=c[e]))})})}function pa(a){return a&&"undefined"!=typeof a.getElementsByTagName&&a}c=ga.support={},f=ga.isXML=function(a){var b=a&&(a.ownerDocument||a).documentElement;return b?"HTML"!==b.nodeName:!1},m=ga.setDocument=function(a){var b,e,g=a?a.ownerDocument||a:v;return g!==n&&9===g.nodeType&&g.documentElement?(n=g,o=g.documentElement,e=g.defaultView,e&&e!==e.top&&(e.addEventListener?e.addEventListener("unload",ea,!1):e.attachEvent&&e.attachEvent("onunload",ea)),p=!f(g),c.attributes=ja(function(a){return a.className="i",!a.getAttribute("className")}),c.getElementsByTagName=ja(function(a){return a.appendChild(g.createComment("")),!a.getElementsByTagName("*").length}),c.getElementsByClassName=$.test(g.getElementsByClassName),c.getById=ja(function(a){return o.appendChild(a).id=u,!g.getElementsByName||!g.getElementsByName(u).length}),c.getById?(d.find.ID=function(a,b){if("undefined"!=typeof b.getElementById&&p){var c=b.getElementById(a);return c&&c.parentNode?[c]:[]}},d.filter.ID=function(a){var b=a.replace(ca,da);return function(a){return a.getAttribute("id")===b}}):(delete d.find.ID,d.filter.ID=function(a){var b=a.replace(ca,da);return function(a){var c="undefined"!=typeof a.getAttributeNode&&a.getAttributeNode("id");return c&&c.value===b}}),d.find.TAG=c.getElementsByTagName?function(a,b){return"undefined"!=typeof b.getElementsByTagName?b.getElementsByTagName(a):c.qsa?b.querySelectorAll(a):void 0}:function(a,b){var c,d=[],e=0,f=b.getElementsByTagName(a);if("*"===a){while(c=f[e++])1===c.nodeType&&d.push(c);return d}return f},d.find.CLASS=c.getElementsByClassName&&function(a,b){return p?b.getElementsByClassName(a):void 0},r=[],q=[],(c.qsa=$.test(g.querySelectorAll))&&(ja(function(a){o.appendChild(a).innerHTML="",a.querySelectorAll("[msallowcapture^='']").length&&q.push("[*^$]="+L+"*(?:''|\"\")"),a.querySelectorAll("[selected]").length||q.push("\\["+L+"*(?:value|"+K+")"),a.querySelectorAll("[id~="+u+"-]").length||q.push("~="),a.querySelectorAll(":checked").length||q.push(":checked"),a.querySelectorAll("a#"+u+"+*").length||q.push(".#.+[+~]")}),ja(function(a){var b=g.createElement("input");b.setAttribute("type","hidden"),a.appendChild(b).setAttribute("name","D"),a.querySelectorAll("[name=d]").length&&q.push("name"+L+"*[*^$|!~]?="),a.querySelectorAll(":enabled").length||q.push(":enabled",":disabled"),a.querySelectorAll("*,:x"),q.push(",.*:")})),(c.matchesSelector=$.test(s=o.matches||o.webkitMatchesSelector||o.mozMatchesSelector||o.oMatchesSelector||o.msMatchesSelector))&&ja(function(a){c.disconnectedMatch=s.call(a,"div"),s.call(a,"[s!='']:x"),r.push("!=",P)}),q=q.length&&new RegExp(q.join("|")),r=r.length&&new RegExp(r.join("|")),b=$.test(o.compareDocumentPosition),t=b||$.test(o.contains)?function(a,b){var c=9===a.nodeType?a.documentElement:a,d=b&&b.parentNode;return a===d||!(!d||1!==d.nodeType||!(c.contains?c.contains(d):a.compareDocumentPosition&&16&a.compareDocumentPosition(d)))}:function(a,b){if(b)while(b=b.parentNode)if(b===a)return!0;return!1},B=b?function(a,b){if(a===b)return l=!0,0;var d=!a.compareDocumentPosition-!b.compareDocumentPosition;return d?d:(d=(a.ownerDocument||a)===(b.ownerDocument||b)?a.compareDocumentPosition(b):1,1&d||!c.sortDetached&&b.compareDocumentPosition(a)===d?a===g||a.ownerDocument===v&&t(v,a)?-1:b===g||b.ownerDocument===v&&t(v,b)?1:k?J(k,a)-J(k,b):0:4&d?-1:1)}:function(a,b){if(a===b)return l=!0,0;var c,d=0,e=a.parentNode,f=b.parentNode,h=[a],i=[b];if(!e||!f)return a===g?-1:b===g?1:e?-1:f?1:k?J(k,a)-J(k,b):0;if(e===f)return la(a,b);c=a;while(c=c.parentNode)h.unshift(c);c=b;while(c=c.parentNode)i.unshift(c);while(h[d]===i[d])d++;return d?la(h[d],i[d]):h[d]===v?-1:i[d]===v?1:0},g):n},ga.matches=function(a,b){return ga(a,null,null,b)},ga.matchesSelector=function(a,b){if((a.ownerDocument||a)!==n&&m(a),b=b.replace(U,"='$1']"),!(!c.matchesSelector||!p||r&&r.test(b)||q&&q.test(b)))try{var d=s.call(a,b);if(d||c.disconnectedMatch||a.document&&11!==a.document.nodeType)return d}catch(e){}return ga(b,n,null,[a]).length>0},ga.contains=function(a,b){return(a.ownerDocument||a)!==n&&m(a),t(a,b)},ga.attr=function(a,b){(a.ownerDocument||a)!==n&&m(a);var e=d.attrHandle[b.toLowerCase()],f=e&&D.call(d.attrHandle,b.toLowerCase())?e(a,b,!p):void 0;return void 0!==f?f:c.attributes||!p?a.getAttribute(b):(f=a.getAttributeNode(b))&&f.specified?f.value:null},ga.error=function(a){throw new Error("Syntax error, unrecognized expression: "+a)},ga.uniqueSort=function(a){var b,d=[],e=0,f=0;if(l=!c.detectDuplicates,k=!c.sortStable&&a.slice(0),a.sort(B),l){while(b=a[f++])b===a[f]&&(e=d.push(f));while(e--)a.splice(d[e],1)}return k=null,a},e=ga.getText=function(a){var b,c="",d=0,f=a.nodeType;if(f){if(1===f||9===f||11===f){if("string"==typeof a.textContent)return a.textContent;for(a=a.firstChild;a;a=a.nextSibling)c+=e(a)}else if(3===f||4===f)return a.nodeValue}else while(b=a[d++])c+=e(b);return c},d=ga.selectors={cacheLength:50,createPseudo:ia,match:X,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(a){return a[1]=a[1].replace(ca,da),a[3]=(a[3]||a[4]||a[5]||"").replace(ca,da),"~="===a[2]&&(a[3]=" "+a[3]+" "),a.slice(0,4)},CHILD:function(a){return a[1]=a[1].toLowerCase(),"nth"===a[1].slice(0,3)?(a[3]||ga.error(a[0]),a[4]=+(a[4]?a[5]+(a[6]||1):2*("even"===a[3]||"odd"===a[3])),a[5]=+(a[7]+a[8]||"odd"===a[3])):a[3]&&ga.error(a[0]),a},PSEUDO:function(a){var b,c=!a[6]&&a[2];return X.CHILD.test(a[0])?null:(a[3]?a[2]=a[4]||a[5]||"":c&&V.test(c)&&(b=g(c,!0))&&(b=c.indexOf(")",c.length-b)-c.length)&&(a[0]=a[0].slice(0,b),a[2]=c.slice(0,b)),a.slice(0,3))}},filter:{TAG:function(a){var b=a.replace(ca,da).toLowerCase();return"*"===a?function(){return!0}:function(a){return a.nodeName&&a.nodeName.toLowerCase()===b}},CLASS:function(a){var b=y[a+" "];return b||(b=new RegExp("(^|"+L+")"+a+"("+L+"|$)"))&&y(a,function(a){return b.test("string"==typeof a.className&&a.className||"undefined"!=typeof a.getAttribute&&a.getAttribute("class")||"")})},ATTR:function(a,b,c){return function(d){var e=ga.attr(d,a);return null==e?"!="===b:b?(e+="","="===b?e===c:"!="===b?e!==c:"^="===b?c&&0===e.indexOf(c):"*="===b?c&&e.indexOf(c)>-1:"$="===b?c&&e.slice(-c.length)===c:"~="===b?(" "+e.replace(Q," ")+" ").indexOf(c)>-1:"|="===b?e===c||e.slice(0,c.length+1)===c+"-":!1):!0}},CHILD:function(a,b,c,d,e){var f="nth"!==a.slice(0,3),g="last"!==a.slice(-4),h="of-type"===b;return 1===d&&0===e?function(a){return!!a.parentNode}:function(b,c,i){var j,k,l,m,n,o,p=f!==g?"nextSibling":"previousSibling",q=b.parentNode,r=h&&b.nodeName.toLowerCase(),s=!i&&!h;if(q){if(f){while(p){l=b;while(l=l[p])if(h?l.nodeName.toLowerCase()===r:1===l.nodeType)return!1;o=p="only"===a&&!o&&"nextSibling"}return!0}if(o=[g?q.firstChild:q.lastChild],g&&s){k=q[u]||(q[u]={}),j=k[a]||[],n=j[0]===w&&j[1],m=j[0]===w&&j[2],l=n&&q.childNodes[n];while(l=++n&&l&&l[p]||(m=n=0)||o.pop())if(1===l.nodeType&&++m&&l===b){k[a]=[w,n,m];break}}else if(s&&(j=(b[u]||(b[u]={}))[a])&&j[0]===w)m=j[1];else while(l=++n&&l&&l[p]||(m=n=0)||o.pop())if((h?l.nodeName.toLowerCase()===r:1===l.nodeType)&&++m&&(s&&((l[u]||(l[u]={}))[a]=[w,m]),l===b))break;return m-=e,m===d||m%d===0&&m/d>=0}}},PSEUDO:function(a,b){var c,e=d.pseudos[a]||d.setFilters[a.toLowerCase()]||ga.error("unsupported pseudo: "+a);return e[u]?e(b):e.length>1?(c=[a,a,"",b],d.setFilters.hasOwnProperty(a.toLowerCase())?ia(function(a,c){var d,f=e(a,b),g=f.length;while(g--)d=J(a,f[g]),a[d]=!(c[d]=f[g])}):function(a){return e(a,0,c)}):e}},pseudos:{not:ia(function(a){var b=[],c=[],d=h(a.replace(R,"$1"));return d[u]?ia(function(a,b,c,e){var f,g=d(a,null,e,[]),h=a.length;while(h--)(f=g[h])&&(a[h]=!(b[h]=f))}):function(a,e,f){return b[0]=a,d(b,null,f,c),b[0]=null,!c.pop()}}),has:ia(function(a){return function(b){return ga(a,b).length>0}}),contains:ia(function(a){return a=a.replace(ca,da),function(b){return(b.textContent||b.innerText||e(b)).indexOf(a)>-1}}),lang:ia(function(a){return W.test(a||"")||ga.error("unsupported lang: "+a),a=a.replace(ca,da).toLowerCase(),function(b){var c;do if(c=p?b.lang:b.getAttribute("xml:lang")||b.getAttribute("lang"))return c=c.toLowerCase(),c===a||0===c.indexOf(a+"-");while((b=b.parentNode)&&1===b.nodeType);return!1}}),target:function(b){var c=a.location&&a.location.hash;return c&&c.slice(1)===b.id},root:function(a){return a===o},focus:function(a){return a===n.activeElement&&(!n.hasFocus||n.hasFocus())&&!!(a.type||a.href||~a.tabIndex)},enabled:function(a){return a.disabled===!1},disabled:function(a){return a.disabled===!0},checked:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&!!a.checked||"option"===b&&!!a.selected},selected:function(a){return a.parentNode&&a.parentNode.selectedIndex,a.selected===!0},empty:function(a){for(a=a.firstChild;a;a=a.nextSibling)if(a.nodeType<6)return!1;return!0},parent:function(a){return!d.pseudos.empty(a)},header:function(a){return Z.test(a.nodeName)},input:function(a){return Y.test(a.nodeName)},button:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&"button"===a.type||"button"===b},text:function(a){var b;return"input"===a.nodeName.toLowerCase()&&"text"===a.type&&(null==(b=a.getAttribute("type"))||"text"===b.toLowerCase())},first:oa(function(){return[0]}),last:oa(function(a,b){return[b-1]}),eq:oa(function(a,b,c){return[0>c?c+b:c]}),even:oa(function(a,b){for(var c=0;b>c;c+=2)a.push(c);return a}),odd:oa(function(a,b){for(var c=1;b>c;c+=2)a.push(c);return a}),lt:oa(function(a,b,c){for(var d=0>c?c+b:c;--d>=0;)a.push(d);return a}),gt:oa(function(a,b,c){for(var d=0>c?c+b:c;++db;b++)d+=a[b].value;return d}function sa(a,b,c){var d=b.dir,e=c&&"parentNode"===d,f=x++;return b.first?function(b,c,f){while(b=b[d])if(1===b.nodeType||e)return a(b,c,f)}:function(b,c,g){var h,i,j=[w,f];if(g){while(b=b[d])if((1===b.nodeType||e)&&a(b,c,g))return!0}else while(b=b[d])if(1===b.nodeType||e){if(i=b[u]||(b[u]={}),(h=i[d])&&h[0]===w&&h[1]===f)return j[2]=h[2];if(i[d]=j,j[2]=a(b,c,g))return!0}}}function ta(a){return a.length>1?function(b,c,d){var e=a.length;while(e--)if(!a[e](b,c,d))return!1;return!0}:a[0]}function ua(a,b,c){for(var d=0,e=b.length;e>d;d++)ga(a,b[d],c);return c}function va(a,b,c,d,e){for(var f,g=[],h=0,i=a.length,j=null!=b;i>h;h++)(f=a[h])&&(!c||c(f,d,e))&&(g.push(f),j&&b.push(h));return g}function wa(a,b,c,d,e,f){return d&&!d[u]&&(d=wa(d)),e&&!e[u]&&(e=wa(e,f)),ia(function(f,g,h,i){var j,k,l,m=[],n=[],o=g.length,p=f||ua(b||"*",h.nodeType?[h]:h,[]),q=!a||!f&&b?p:va(p,m,a,h,i),r=c?e||(f?a:o||d)?[]:g:q;if(c&&c(q,r,h,i),d){j=va(r,n),d(j,[],h,i),k=j.length;while(k--)(l=j[k])&&(r[n[k]]=!(q[n[k]]=l))}if(f){if(e||a){if(e){j=[],k=r.length;while(k--)(l=r[k])&&j.push(q[k]=l);e(null,r=[],j,i)}k=r.length;while(k--)(l=r[k])&&(j=e?J(f,l):m[k])>-1&&(f[j]=!(g[j]=l))}}else r=va(r===g?r.splice(o,r.length):r),e?e(null,g,r,i):H.apply(g,r)})}function xa(a){for(var b,c,e,f=a.length,g=d.relative[a[0].type],h=g||d.relative[" "],i=g?1:0,k=sa(function(a){return a===b},h,!0),l=sa(function(a){return J(b,a)>-1},h,!0),m=[function(a,c,d){var e=!g&&(d||c!==j)||((b=c).nodeType?k(a,c,d):l(a,c,d));return b=null,e}];f>i;i++)if(c=d.relative[a[i].type])m=[sa(ta(m),c)];else{if(c=d.filter[a[i].type].apply(null,a[i].matches),c[u]){for(e=++i;f>e;e++)if(d.relative[a[e].type])break;return wa(i>1&&ta(m),i>1&&ra(a.slice(0,i-1).concat({value:" "===a[i-2].type?"*":""})).replace(R,"$1"),c,e>i&&xa(a.slice(i,e)),f>e&&xa(a=a.slice(e)),f>e&&ra(a))}m.push(c)}return ta(m)}function ya(a,b){var c=b.length>0,e=a.length>0,f=function(f,g,h,i,k){var l,m,o,p=0,q="0",r=f&&[],s=[],t=j,u=f||e&&d.find.TAG("*",k),v=w+=null==t?1:Math.random()||.1,x=u.length;for(k&&(j=g!==n&&g);q!==x&&null!=(l=u[q]);q++){if(e&&l){m=0;while(o=a[m++])if(o(l,g,h)){i.push(l);break}k&&(w=v)}c&&((l=!o&&l)&&p--,f&&r.push(l))}if(p+=q,c&&q!==p){m=0;while(o=b[m++])o(r,s,g,h);if(f){if(p>0)while(q--)r[q]||s[q]||(s[q]=F.call(i));s=va(s)}H.apply(i,s),k&&!f&&s.length>0&&p+b.length>1&&ga.uniqueSort(i)}return k&&(w=v,j=t),r};return c?ia(f):f}return h=ga.compile=function(a,b){var c,d=[],e=[],f=A[a+" "];if(!f){b||(b=g(a)),c=b.length;while(c--)f=xa(b[c]),f[u]?d.push(f):e.push(f);f=A(a,ya(e,d)),f.selector=a}return f},i=ga.select=function(a,b,e,f){var i,j,k,l,m,n="function"==typeof a&&a,o=!f&&g(a=n.selector||a);if(e=e||[],1===o.length){if(j=o[0]=o[0].slice(0),j.length>2&&"ID"===(k=j[0]).type&&c.getById&&9===b.nodeType&&p&&d.relative[j[1].type]){if(b=(d.find.ID(k.matches[0].replace(ca,da),b)||[])[0],!b)return e;n&&(b=b.parentNode),a=a.slice(j.shift().value.length)}i=X.needsContext.test(a)?0:j.length;while(i--){if(k=j[i],d.relative[l=k.type])break;if((m=d.find[l])&&(f=m(k.matches[0].replace(ca,da),aa.test(j[0].type)&&pa(b.parentNode)||b))){if(j.splice(i,1),a=f.length&&ra(j),!a)return H.apply(e,f),e;break}}}return(n||h(a,o))(f,b,!p,e,aa.test(a)&&pa(b.parentNode)||b),e},c.sortStable=u.split("").sort(B).join("")===u,c.detectDuplicates=!!l,m(),c.sortDetached=ja(function(a){return 1&a.compareDocumentPosition(n.createElement("div"))}),ja(function(a){return a.innerHTML="","#"===a.firstChild.getAttribute("href")})||ka("type|href|height|width",function(a,b,c){return c?void 0:a.getAttribute(b,"type"===b.toLowerCase()?1:2)}),c.attributes&&ja(function(a){return a.innerHTML="",a.firstChild.setAttribute("value",""),""===a.firstChild.getAttribute("value")})||ka("value",function(a,b,c){return c||"input"!==a.nodeName.toLowerCase()?void 0:a.defaultValue}),ja(function(a){return null==a.getAttribute("disabled")})||ka(K,function(a,b,c){var d;return c?void 0:a[b]===!0?b.toLowerCase():(d=a.getAttributeNode(b))&&d.specified?d.value:null}),ga}(a);n.find=t,n.expr=t.selectors,n.expr[":"]=n.expr.pseudos,n.unique=t.uniqueSort,n.text=t.getText,n.isXMLDoc=t.isXML,n.contains=t.contains;var u=n.expr.match.needsContext,v=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,w=/^.[^:#\[\.,]*$/;function x(a,b,c){if(n.isFunction(b))return n.grep(a,function(a,d){return!!b.call(a,d,a)!==c});if(b.nodeType)return n.grep(a,function(a){return a===b!==c});if("string"==typeof b){if(w.test(b))return n.filter(b,a,c);b=n.filter(b,a)}return n.grep(a,function(a){return g.call(b,a)>=0!==c})}n.filter=function(a,b,c){var d=b[0];return c&&(a=":not("+a+")"),1===b.length&&1===d.nodeType?n.find.matchesSelector(d,a)?[d]:[]:n.find.matches(a,n.grep(b,function(a){return 1===a.nodeType}))},n.fn.extend({find:function(a){var b,c=this.length,d=[],e=this;if("string"!=typeof a)return this.pushStack(n(a).filter(function(){for(b=0;c>b;b++)if(n.contains(e[b],this))return!0}));for(b=0;c>b;b++)n.find(a,e[b],d);return d=this.pushStack(c>1?n.unique(d):d),d.selector=this.selector?this.selector+" "+a:a,d},filter:function(a){return this.pushStack(x(this,a||[],!1))},not:function(a){return this.pushStack(x(this,a||[],!0))},is:function(a){return!!x(this,"string"==typeof a&&u.test(a)?n(a):a||[],!1).length}});var y,z=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/,A=n.fn.init=function(a,b){var c,d;if(!a)return this;if("string"==typeof a){if(c="<"===a[0]&&">"===a[a.length-1]&&a.length>=3?[null,a,null]:z.exec(a),!c||!c[1]&&b)return!b||b.jquery?(b||y).find(a):this.constructor(b).find(a);if(c[1]){if(b=b instanceof n?b[0]:b,n.merge(this,n.parseHTML(c[1],b&&b.nodeType?b.ownerDocument||b:l,!0)),v.test(c[1])&&n.isPlainObject(b))for(c in b)n.isFunction(this[c])?this[c](b[c]):this.attr(c,b[c]);return this}return d=l.getElementById(c[2]),d&&d.parentNode&&(this.length=1,this[0]=d),this.context=l,this.selector=a,this}return a.nodeType?(this.context=this[0]=a,this.length=1,this):n.isFunction(a)?"undefined"!=typeof y.ready?y.ready(a):a(n):(void 0!==a.selector&&(this.selector=a.selector,this.context=a.context),n.makeArray(a,this))};A.prototype=n.fn,y=n(l);var B=/^(?:parents|prev(?:Until|All))/,C={children:!0,contents:!0,next:!0,prev:!0};n.extend({dir:function(a,b,c){var d=[],e=void 0!==c;while((a=a[b])&&9!==a.nodeType)if(1===a.nodeType){if(e&&n(a).is(c))break;d.push(a)}return d},sibling:function(a,b){for(var c=[];a;a=a.nextSibling)1===a.nodeType&&a!==b&&c.push(a);return c}}),n.fn.extend({has:function(a){var b=n(a,this),c=b.length;return this.filter(function(){for(var a=0;c>a;a++)if(n.contains(this,b[a]))return!0})},closest:function(a,b){for(var c,d=0,e=this.length,f=[],g=u.test(a)||"string"!=typeof a?n(a,b||this.context):0;e>d;d++)for(c=this[d];c&&c!==b;c=c.parentNode)if(c.nodeType<11&&(g?g.index(c)>-1:1===c.nodeType&&n.find.matchesSelector(c,a))){f.push(c);break}return this.pushStack(f.length>1?n.unique(f):f)},index:function(a){return a?"string"==typeof a?g.call(n(a),this[0]):g.call(this,a.jquery?a[0]:a):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(a,b){return this.pushStack(n.unique(n.merge(this.get(),n(a,b))))},addBack:function(a){return this.add(null==a?this.prevObject:this.prevObject.filter(a))}});function D(a,b){while((a=a[b])&&1!==a.nodeType);return a}n.each({parent:function(a){var b=a.parentNode;return b&&11!==b.nodeType?b:null},parents:function(a){return n.dir(a,"parentNode")},parentsUntil:function(a,b,c){return n.dir(a,"parentNode",c)},next:function(a){return D(a,"nextSibling")},prev:function(a){return D(a,"previousSibling")},nextAll:function(a){return n.dir(a,"nextSibling")},prevAll:function(a){return n.dir(a,"previousSibling")},nextUntil:function(a,b,c){return n.dir(a,"nextSibling",c)},prevUntil:function(a,b,c){return n.dir(a,"previousSibling",c)},siblings:function(a){return n.sibling((a.parentNode||{}).firstChild,a)},children:function(a){return n.sibling(a.firstChild)},contents:function(a){return a.contentDocument||n.merge([],a.childNodes)}},function(a,b){n.fn[a]=function(c,d){var e=n.map(this,b,c);return"Until"!==a.slice(-5)&&(d=c),d&&"string"==typeof d&&(e=n.filter(d,e)),this.length>1&&(C[a]||n.unique(e),B.test(a)&&e.reverse()),this.pushStack(e)}});var E=/\S+/g,F={};function G(a){var b=F[a]={};return n.each(a.match(E)||[],function(a,c){b[c]=!0}),b}n.Callbacks=function(a){a="string"==typeof a?F[a]||G(a):n.extend({},a);var b,c,d,e,f,g,h=[],i=!a.once&&[],j=function(l){for(b=a.memory&&l,c=!0,g=e||0,e=0,f=h.length,d=!0;h&&f>g;g++)if(h[g].apply(l[0],l[1])===!1&&a.stopOnFalse){b=!1;break}d=!1,h&&(i?i.length&&j(i.shift()):b?h=[]:k.disable())},k={add:function(){if(h){var c=h.length;!function g(b){n.each(b,function(b,c){var d=n.type(c);"function"===d?a.unique&&k.has(c)||h.push(c):c&&c.length&&"string"!==d&&g(c)})}(arguments),d?f=h.length:b&&(e=c,j(b))}return this},remove:function(){return h&&n.each(arguments,function(a,b){var c;while((c=n.inArray(b,h,c))>-1)h.splice(c,1),d&&(f>=c&&f--,g>=c&&g--)}),this},has:function(a){return a?n.inArray(a,h)>-1:!(!h||!h.length)},empty:function(){return h=[],f=0,this},disable:function(){return h=i=b=void 0,this},disabled:function(){return!h},lock:function(){return i=void 0,b||k.disable(),this},locked:function(){return!i},fireWith:function(a,b){return!h||c&&!i||(b=b||[],b=[a,b.slice?b.slice():b],d?i.push(b):j(b)),this},fire:function(){return k.fireWith(this,arguments),this},fired:function(){return!!c}};return k},n.extend({Deferred:function(a){var b=[["resolve","done",n.Callbacks("once memory"),"resolved"],["reject","fail",n.Callbacks("once memory"),"rejected"],["notify","progress",n.Callbacks("memory")]],c="pending",d={state:function(){return c},always:function(){return e.done(arguments).fail(arguments),this},then:function(){var a=arguments;return n.Deferred(function(c){n.each(b,function(b,f){var g=n.isFunction(a[b])&&a[b];e[f[1]](function(){var a=g&&g.apply(this,arguments);a&&n.isFunction(a.promise)?a.promise().done(c.resolve).fail(c.reject).progress(c.notify):c[f[0]+"With"](this===d?c.promise():this,g?[a]:arguments)})}),a=null}).promise()},promise:function(a){return null!=a?n.extend(a,d):d}},e={};return d.pipe=d.then,n.each(b,function(a,f){var g=f[2],h=f[3];d[f[1]]=g.add,h&&g.add(function(){c=h},b[1^a][2].disable,b[2][2].lock),e[f[0]]=function(){return e[f[0]+"With"](this===e?d:this,arguments),this},e[f[0]+"With"]=g.fireWith}),d.promise(e),a&&a.call(e,e),e},when:function(a){var b=0,c=d.call(arguments),e=c.length,f=1!==e||a&&n.isFunction(a.promise)?e:0,g=1===f?a:n.Deferred(),h=function(a,b,c){return function(e){b[a]=this,c[a]=arguments.length>1?d.call(arguments):e,c===i?g.notifyWith(b,c):--f||g.resolveWith(b,c)}},i,j,k;if(e>1)for(i=new Array(e),j=new Array(e),k=new Array(e);e>b;b++)c[b]&&n.isFunction(c[b].promise)?c[b].promise().done(h(b,k,c)).fail(g.reject).progress(h(b,j,i)):--f;return f||g.resolveWith(k,c),g.promise()}});var H;n.fn.ready=function(a){return n.ready.promise().done(a),this},n.extend({isReady:!1,readyWait:1,holdReady:function(a){a?n.readyWait++:n.ready(!0)},ready:function(a){(a===!0?--n.readyWait:n.isReady)||(n.isReady=!0,a!==!0&&--n.readyWait>0||(H.resolveWith(l,[n]),n.fn.triggerHandler&&(n(l).triggerHandler("ready"),n(l).off("ready"))))}});function I(){l.removeEventListener("DOMContentLoaded",I,!1),a.removeEventListener("load",I,!1),n.ready()}n.ready.promise=function(b){return H||(H=n.Deferred(),"complete"===l.readyState?setTimeout(n.ready):(l.addEventListener("DOMContentLoaded",I,!1),a.addEventListener("load",I,!1))),H.promise(b)},n.ready.promise();var J=n.access=function(a,b,c,d,e,f,g){var h=0,i=a.length,j=null==c;if("object"===n.type(c)){e=!0;for(h in c)n.access(a,b,h,c[h],!0,f,g)}else if(void 0!==d&&(e=!0,n.isFunction(d)||(g=!0),j&&(g?(b.call(a,d),b=null):(j=b,b=function(a,b,c){return j.call(n(a),c)})),b))for(;i>h;h++)b(a[h],c,g?d:d.call(a[h],h,b(a[h],c)));return e?a:j?b.call(a):i?b(a[0],c):f};n.acceptData=function(a){return 1===a.nodeType||9===a.nodeType||!+a.nodeType};function K(){Object.defineProperty(this.cache={},0,{get:function(){return{}}}),this.expando=n.expando+K.uid++}K.uid=1,K.accepts=n.acceptData,K.prototype={key:function(a){if(!K.accepts(a))return 0;var b={},c=a[this.expando];if(!c){c=K.uid++;try{b[this.expando]={value:c},Object.defineProperties(a,b)}catch(d){b[this.expando]=c,n.extend(a,b)}}return this.cache[c]||(this.cache[c]={}),c},set:function(a,b,c){var d,e=this.key(a),f=this.cache[e];if("string"==typeof b)f[b]=c;else if(n.isEmptyObject(f))n.extend(this.cache[e],b);else for(d in b)f[d]=b[d];return f},get:function(a,b){var c=this.cache[this.key(a)];return void 0===b?c:c[b]},access:function(a,b,c){var d;return void 0===b||b&&"string"==typeof b&&void 0===c?(d=this.get(a,b),void 0!==d?d:this.get(a,n.camelCase(b))):(this.set(a,b,c),void 0!==c?c:b)},remove:function(a,b){var c,d,e,f=this.key(a),g=this.cache[f];if(void 0===b)this.cache[f]={};else{n.isArray(b)?d=b.concat(b.map(n.camelCase)):(e=n.camelCase(b),b in g?d=[b,e]:(d=e,d=d in g?[d]:d.match(E)||[])),c=d.length;while(c--)delete g[d[c]]}},hasData:function(a){return!n.isEmptyObject(this.cache[a[this.expando]]||{})},discard:function(a){a[this.expando]&&delete this.cache[a[this.expando]]}};var L=new K,M=new K,N=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,O=/([A-Z])/g;function P(a,b,c){var d;if(void 0===c&&1===a.nodeType)if(d="data-"+b.replace(O,"-$1").toLowerCase(),c=a.getAttribute(d),"string"==typeof c){try{c="true"===c?!0:"false"===c?!1:"null"===c?null:+c+""===c?+c:N.test(c)?n.parseJSON(c):c}catch(e){}M.set(a,b,c)}else c=void 0;return c}n.extend({hasData:function(a){return M.hasData(a)||L.hasData(a)},data:function(a,b,c){ -return M.access(a,b,c)},removeData:function(a,b){M.remove(a,b)},_data:function(a,b,c){return L.access(a,b,c)},_removeData:function(a,b){L.remove(a,b)}}),n.fn.extend({data:function(a,b){var c,d,e,f=this[0],g=f&&f.attributes;if(void 0===a){if(this.length&&(e=M.get(f),1===f.nodeType&&!L.get(f,"hasDataAttrs"))){c=g.length;while(c--)g[c]&&(d=g[c].name,0===d.indexOf("data-")&&(d=n.camelCase(d.slice(5)),P(f,d,e[d])));L.set(f,"hasDataAttrs",!0)}return e}return"object"==typeof a?this.each(function(){M.set(this,a)}):J(this,function(b){var c,d=n.camelCase(a);if(f&&void 0===b){if(c=M.get(f,a),void 0!==c)return c;if(c=M.get(f,d),void 0!==c)return c;if(c=P(f,d,void 0),void 0!==c)return c}else this.each(function(){var c=M.get(this,d);M.set(this,d,b),-1!==a.indexOf("-")&&void 0!==c&&M.set(this,a,b)})},null,b,arguments.length>1,null,!0)},removeData:function(a){return this.each(function(){M.remove(this,a)})}}),n.extend({queue:function(a,b,c){var d;return a?(b=(b||"fx")+"queue",d=L.get(a,b),c&&(!d||n.isArray(c)?d=L.access(a,b,n.makeArray(c)):d.push(c)),d||[]):void 0},dequeue:function(a,b){b=b||"fx";var c=n.queue(a,b),d=c.length,e=c.shift(),f=n._queueHooks(a,b),g=function(){n.dequeue(a,b)};"inprogress"===e&&(e=c.shift(),d--),e&&("fx"===b&&c.unshift("inprogress"),delete f.stop,e.call(a,g,f)),!d&&f&&f.empty.fire()},_queueHooks:function(a,b){var c=b+"queueHooks";return L.get(a,c)||L.access(a,c,{empty:n.Callbacks("once memory").add(function(){L.remove(a,[b+"queue",c])})})}}),n.fn.extend({queue:function(a,b){var c=2;return"string"!=typeof a&&(b=a,a="fx",c--),arguments.lengthx",k.noCloneChecked=!!b.cloneNode(!0).lastChild.defaultValue}();var U="undefined";k.focusinBubbles="onfocusin"in a;var V=/^key/,W=/^(?:mouse|pointer|contextmenu)|click/,X=/^(?:focusinfocus|focusoutblur)$/,Y=/^([^.]*)(?:\.(.+)|)$/;function Z(){return!0}function $(){return!1}function _(){try{return l.activeElement}catch(a){}}n.event={global:{},add:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,o,p,q,r=L.get(a);if(r){c.handler&&(f=c,c=f.handler,e=f.selector),c.guid||(c.guid=n.guid++),(i=r.events)||(i=r.events={}),(g=r.handle)||(g=r.handle=function(b){return typeof n!==U&&n.event.triggered!==b.type?n.event.dispatch.apply(a,arguments):void 0}),b=(b||"").match(E)||[""],j=b.length;while(j--)h=Y.exec(b[j])||[],o=q=h[1],p=(h[2]||"").split(".").sort(),o&&(l=n.event.special[o]||{},o=(e?l.delegateType:l.bindType)||o,l=n.event.special[o]||{},k=n.extend({type:o,origType:q,data:d,handler:c,guid:c.guid,selector:e,needsContext:e&&n.expr.match.needsContext.test(e),namespace:p.join(".")},f),(m=i[o])||(m=i[o]=[],m.delegateCount=0,l.setup&&l.setup.call(a,d,p,g)!==!1||a.addEventListener&&a.addEventListener(o,g,!1)),l.add&&(l.add.call(a,k),k.handler.guid||(k.handler.guid=c.guid)),e?m.splice(m.delegateCount++,0,k):m.push(k),n.event.global[o]=!0)}},remove:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,o,p,q,r=L.hasData(a)&&L.get(a);if(r&&(i=r.events)){b=(b||"").match(E)||[""],j=b.length;while(j--)if(h=Y.exec(b[j])||[],o=q=h[1],p=(h[2]||"").split(".").sort(),o){l=n.event.special[o]||{},o=(d?l.delegateType:l.bindType)||o,m=i[o]||[],h=h[2]&&new RegExp("(^|\\.)"+p.join("\\.(?:.*\\.|)")+"(\\.|$)"),g=f=m.length;while(f--)k=m[f],!e&&q!==k.origType||c&&c.guid!==k.guid||h&&!h.test(k.namespace)||d&&d!==k.selector&&("**"!==d||!k.selector)||(m.splice(f,1),k.selector&&m.delegateCount--,l.remove&&l.remove.call(a,k));g&&!m.length&&(l.teardown&&l.teardown.call(a,p,r.handle)!==!1||n.removeEvent(a,o,r.handle),delete i[o])}else for(o in i)n.event.remove(a,o+b[j],c,d,!0);n.isEmptyObject(i)&&(delete r.handle,L.remove(a,"events"))}},trigger:function(b,c,d,e){var f,g,h,i,k,m,o,p=[d||l],q=j.call(b,"type")?b.type:b,r=j.call(b,"namespace")?b.namespace.split("."):[];if(g=h=d=d||l,3!==d.nodeType&&8!==d.nodeType&&!X.test(q+n.event.triggered)&&(q.indexOf(".")>=0&&(r=q.split("."),q=r.shift(),r.sort()),k=q.indexOf(":")<0&&"on"+q,b=b[n.expando]?b:new n.Event(q,"object"==typeof b&&b),b.isTrigger=e?2:3,b.namespace=r.join("."),b.namespace_re=b.namespace?new RegExp("(^|\\.)"+r.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,b.result=void 0,b.target||(b.target=d),c=null==c?[b]:n.makeArray(c,[b]),o=n.event.special[q]||{},e||!o.trigger||o.trigger.apply(d,c)!==!1)){if(!e&&!o.noBubble&&!n.isWindow(d)){for(i=o.delegateType||q,X.test(i+q)||(g=g.parentNode);g;g=g.parentNode)p.push(g),h=g;h===(d.ownerDocument||l)&&p.push(h.defaultView||h.parentWindow||a)}f=0;while((g=p[f++])&&!b.isPropagationStopped())b.type=f>1?i:o.bindType||q,m=(L.get(g,"events")||{})[b.type]&&L.get(g,"handle"),m&&m.apply(g,c),m=k&&g[k],m&&m.apply&&n.acceptData(g)&&(b.result=m.apply(g,c),b.result===!1&&b.preventDefault());return b.type=q,e||b.isDefaultPrevented()||o._default&&o._default.apply(p.pop(),c)!==!1||!n.acceptData(d)||k&&n.isFunction(d[q])&&!n.isWindow(d)&&(h=d[k],h&&(d[k]=null),n.event.triggered=q,d[q](),n.event.triggered=void 0,h&&(d[k]=h)),b.result}},dispatch:function(a){a=n.event.fix(a);var b,c,e,f,g,h=[],i=d.call(arguments),j=(L.get(this,"events")||{})[a.type]||[],k=n.event.special[a.type]||{};if(i[0]=a,a.delegateTarget=this,!k.preDispatch||k.preDispatch.call(this,a)!==!1){h=n.event.handlers.call(this,a,j),b=0;while((f=h[b++])&&!a.isPropagationStopped()){a.currentTarget=f.elem,c=0;while((g=f.handlers[c++])&&!a.isImmediatePropagationStopped())(!a.namespace_re||a.namespace_re.test(g.namespace))&&(a.handleObj=g,a.data=g.data,e=((n.event.special[g.origType]||{}).handle||g.handler).apply(f.elem,i),void 0!==e&&(a.result=e)===!1&&(a.preventDefault(),a.stopPropagation()))}return k.postDispatch&&k.postDispatch.call(this,a),a.result}},handlers:function(a,b){var c,d,e,f,g=[],h=b.delegateCount,i=a.target;if(h&&i.nodeType&&(!a.button||"click"!==a.type))for(;i!==this;i=i.parentNode||this)if(i.disabled!==!0||"click"!==a.type){for(d=[],c=0;h>c;c++)f=b[c],e=f.selector+" ",void 0===d[e]&&(d[e]=f.needsContext?n(e,this).index(i)>=0:n.find(e,this,null,[i]).length),d[e]&&d.push(f);d.length&&g.push({elem:i,handlers:d})}return h]*)\/>/gi,ba=/<([\w:]+)/,ca=/<|&#?\w+;/,da=/<(?:script|style|link)/i,ea=/checked\s*(?:[^=]|=\s*.checked.)/i,fa=/^$|\/(?:java|ecma)script/i,ga=/^true\/(.*)/,ha=/^\s*\s*$/g,ia={option:[1,""],thead:[1,"","
"],col:[2,"","
"],tr:[2,"","
"],td:[3,"","
"],_default:[0,"",""]};ia.optgroup=ia.option,ia.tbody=ia.tfoot=ia.colgroup=ia.caption=ia.thead,ia.th=ia.td;function ja(a,b){return n.nodeName(a,"table")&&n.nodeName(11!==b.nodeType?b:b.firstChild,"tr")?a.getElementsByTagName("tbody")[0]||a.appendChild(a.ownerDocument.createElement("tbody")):a}function ka(a){return a.type=(null!==a.getAttribute("type"))+"/"+a.type,a}function la(a){var b=ga.exec(a.type);return b?a.type=b[1]:a.removeAttribute("type"),a}function ma(a,b){for(var c=0,d=a.length;d>c;c++)L.set(a[c],"globalEval",!b||L.get(b[c],"globalEval"))}function na(a,b){var c,d,e,f,g,h,i,j;if(1===b.nodeType){if(L.hasData(a)&&(f=L.access(a),g=L.set(b,f),j=f.events)){delete g.handle,g.events={};for(e in j)for(c=0,d=j[e].length;d>c;c++)n.event.add(b,e,j[e][c])}M.hasData(a)&&(h=M.access(a),i=n.extend({},h),M.set(b,i))}}function oa(a,b){var c=a.getElementsByTagName?a.getElementsByTagName(b||"*"):a.querySelectorAll?a.querySelectorAll(b||"*"):[];return void 0===b||b&&n.nodeName(a,b)?n.merge([a],c):c}function pa(a,b){var c=b.nodeName.toLowerCase();"input"===c&&T.test(a.type)?b.checked=a.checked:("input"===c||"textarea"===c)&&(b.defaultValue=a.defaultValue)}n.extend({clone:function(a,b,c){var d,e,f,g,h=a.cloneNode(!0),i=n.contains(a.ownerDocument,a);if(!(k.noCloneChecked||1!==a.nodeType&&11!==a.nodeType||n.isXMLDoc(a)))for(g=oa(h),f=oa(a),d=0,e=f.length;e>d;d++)pa(f[d],g[d]);if(b)if(c)for(f=f||oa(a),g=g||oa(h),d=0,e=f.length;e>d;d++)na(f[d],g[d]);else na(a,h);return g=oa(h,"script"),g.length>0&&ma(g,!i&&oa(a,"script")),h},buildFragment:function(a,b,c,d){for(var e,f,g,h,i,j,k=b.createDocumentFragment(),l=[],m=0,o=a.length;o>m;m++)if(e=a[m],e||0===e)if("object"===n.type(e))n.merge(l,e.nodeType?[e]:e);else if(ca.test(e)){f=f||k.appendChild(b.createElement("div")),g=(ba.exec(e)||["",""])[1].toLowerCase(),h=ia[g]||ia._default,f.innerHTML=h[1]+e.replace(aa,"<$1>")+h[2],j=h[0];while(j--)f=f.lastChild;n.merge(l,f.childNodes),f=k.firstChild,f.textContent=""}else l.push(b.createTextNode(e));k.textContent="",m=0;while(e=l[m++])if((!d||-1===n.inArray(e,d))&&(i=n.contains(e.ownerDocument,e),f=oa(k.appendChild(e),"script"),i&&ma(f),c)){j=0;while(e=f[j++])fa.test(e.type||"")&&c.push(e)}return k},cleanData:function(a){for(var b,c,d,e,f=n.event.special,g=0;void 0!==(c=a[g]);g++){if(n.acceptData(c)&&(e=c[L.expando],e&&(b=L.cache[e]))){if(b.events)for(d in b.events)f[d]?n.event.remove(c,d):n.removeEvent(c,d,b.handle);L.cache[e]&&delete L.cache[e]}delete M.cache[c[M.expando]]}}}),n.fn.extend({text:function(a){return J(this,function(a){return void 0===a?n.text(this):this.empty().each(function(){(1===this.nodeType||11===this.nodeType||9===this.nodeType)&&(this.textContent=a)})},null,a,arguments.length)},append:function(){return this.domManip(arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=ja(this,a);b.appendChild(a)}})},prepend:function(){return this.domManip(arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=ja(this,a);b.insertBefore(a,b.firstChild)}})},before:function(){return this.domManip(arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this)})},after:function(){return this.domManip(arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this.nextSibling)})},remove:function(a,b){for(var c,d=a?n.filter(a,this):this,e=0;null!=(c=d[e]);e++)b||1!==c.nodeType||n.cleanData(oa(c)),c.parentNode&&(b&&n.contains(c.ownerDocument,c)&&ma(oa(c,"script")),c.parentNode.removeChild(c));return this},empty:function(){for(var a,b=0;null!=(a=this[b]);b++)1===a.nodeType&&(n.cleanData(oa(a,!1)),a.textContent="");return this},clone:function(a,b){return a=null==a?!1:a,b=null==b?a:b,this.map(function(){return n.clone(this,a,b)})},html:function(a){return J(this,function(a){var b=this[0]||{},c=0,d=this.length;if(void 0===a&&1===b.nodeType)return b.innerHTML;if("string"==typeof a&&!da.test(a)&&!ia[(ba.exec(a)||["",""])[1].toLowerCase()]){a=a.replace(aa,"<$1>");try{for(;d>c;c++)b=this[c]||{},1===b.nodeType&&(n.cleanData(oa(b,!1)),b.innerHTML=a);b=0}catch(e){}}b&&this.empty().append(a)},null,a,arguments.length)},replaceWith:function(){var a=arguments[0];return this.domManip(arguments,function(b){a=this.parentNode,n.cleanData(oa(this)),a&&a.replaceChild(b,this)}),a&&(a.length||a.nodeType)?this:this.remove()},detach:function(a){return this.remove(a,!0)},domManip:function(a,b){a=e.apply([],a);var c,d,f,g,h,i,j=0,l=this.length,m=this,o=l-1,p=a[0],q=n.isFunction(p);if(q||l>1&&"string"==typeof p&&!k.checkClone&&ea.test(p))return this.each(function(c){var d=m.eq(c);q&&(a[0]=p.call(this,c,d.html())),d.domManip(a,b)});if(l&&(c=n.buildFragment(a,this[0].ownerDocument,!1,this),d=c.firstChild,1===c.childNodes.length&&(c=d),d)){for(f=n.map(oa(c,"script"),ka),g=f.length;l>j;j++)h=c,j!==o&&(h=n.clone(h,!0,!0),g&&n.merge(f,oa(h,"script"))),b.call(this[j],h,j);if(g)for(i=f[f.length-1].ownerDocument,n.map(f,la),j=0;g>j;j++)h=f[j],fa.test(h.type||"")&&!L.access(h,"globalEval")&&n.contains(i,h)&&(h.src?n._evalUrl&&n._evalUrl(h.src):n.globalEval(h.textContent.replace(ha,"")))}return this}}),n.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){n.fn[a]=function(a){for(var c,d=[],e=n(a),g=e.length-1,h=0;g>=h;h++)c=h===g?this:this.clone(!0),n(e[h])[b](c),f.apply(d,c.get());return this.pushStack(d)}});var qa,ra={};function sa(b,c){var d,e=n(c.createElement(b)).appendTo(c.body),f=a.getDefaultComputedStyle&&(d=a.getDefaultComputedStyle(e[0]))?d.display:n.css(e[0],"display");return e.detach(),f}function ta(a){var b=l,c=ra[a];return c||(c=sa(a,b),"none"!==c&&c||(qa=(qa||n("